⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 fsmorphgradient.java

📁 利用opensource的开源jar实现生成flash文件
💻 JAVA
字号:
/*
 * FSMorphGradient.java
 * Transform
 * 
 * Copyright (c) 2001-2006 Flagstone Software Ltd. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without modification, 
 * are permitted provided that the following conditions are met:
 *
 *  * Redistributions of source code must retain the above copyright notice, this
 *    list of conditions and the following disclaimer.
 *  * Redistributions in binary form must reproduce the above copyright notice, 
 *    this list of conditions and the following disclaimer in the documentation 
 *    and/or other materials provided with the distribution.
 *  * Neither the name of Flagstone Software Ltd. nor the names of its contributors 
 *    may be used to endorse or promote products derived from this software 
 *    without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND 
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED 
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
 * IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, 
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, 
 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF 
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 
 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED 
 * OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package com.flagstone.transform;

/**
FSMorphGradient defines the control points that is used to specify how a gradient fill is 
displayed at the start and end of the shape morphing process. 
 
<p>Two or more control points are used to define how the colour changes across the gradient square.</p>

<table class="datasheet">

<tr><th align="left" colspan="2">Attributes</th></tr>

<tr>
<td><a name="FSMorphGradient_0">startRatio</a></td>
<td>The location of the control point across the gradient square at the start of the morphing process.</td>
</tr>

<tr>
<td><a name="FSMorphGradient_1">endRatio</a></td>
<td>The location of the control point across the gradient square at the end of the morphing process.</td>
</tr>

<tr>
<td><a name="FSMorphGradient_2">startColor</a></td>
<td>The colour at the control point at the start of the morphing process.</td>
</tr>

<tr>
<td><a name="FSMorphGradient_3">startColor</a></td>
<td>The colour at the control point at the end of the morphing process.</td>
</tr>
</table>

<p>The location of the control point is defined by a ratio - a number between 0 and 255 that specifies the relative location in the square. For Linear Gradient Fills a ratio of zero is mapped to the left side of the gradient square and 255 is mapped to the right side of the square. For Radial Gradient Fills a ratio of zero is mapped to the centre of the gradient square and 255 is mapped to the edge of the largest circle that fits inside the gradient square.</p>

<p>FSMorphGradients are only used in FSDefineMorphShape objects which support transparent colours so values for all the colour channels must be specified in the FSColor objects.</p>

<p>When the Flash Player displays the gradient control points they are sorted by the ratio with the FSGradient object with the smallest ratio value displayed first.</p>

<h1 class="datasheet">History</h1>

<p>The FSMorphGradient class represents the MorphGradientRecord structure from the Macromedia Flash (SWF) File Format Specification. Shape morphing was introduced in Flash 3.</p>
 */  
public class FSMorphGradient extends FSTransformObject
{
    private int startRatio = 0;
    private int endRatio = 0;
    private FSColor startColor = null;
    private FSColor endColor = null;
    
    /**
     * Construct an FSMorphGradient object, initalizing it with values decoded 
     * from an encoded object.
     * 
     * @param coder an FSCoder containing the binary data.
     */
    public FSMorphGradient(FSCoder coder)
    {
        decode(coder);
    }
    /** Constructs an FSMorphGradient object specifying the starting and ending ratios and colours.

        @param aStartRatio the ratio along the gradient square at the start of the morphing process.
        @param anEndRatio the ratio along the gradient square at the end of the morphing process.
        @param aStartColor the colour at the starting control point.
        @param anEndColor the colour at the ending control point.
        */
    public FSMorphGradient(int aStartRatio, int anEndRatio, FSColor aStartColor, FSColor anEndColor)
    {
        setStartRatio(aStartRatio);
        setEndRatio(anEndRatio);
        setStartColor(aStartColor);
        setEndColor(anEndColor);
    }
    /**
     * Constructs an FSMorphGradient object by copying values from an existing 
     * object.
     *
     * @param obj an FSMorphGradient object.
     */
    public FSMorphGradient(FSMorphGradient obj)
    {
        startRatio = obj.startRatio;
        endRatio = obj.endRatio;
        startColor = new FSColor(obj.startColor);
        endColor = new FSColor(obj.endColor);
    }    

    /** Gets the ratio at the start of the morphing process.

        @return the start ratio.
        */
    public int getStartRatio() { return startRatio; }

    /** Gets the ratio at the end of the morphing process.

        @return the end ratio.
        */
    public int getEndRatio() { return endRatio; }

    /** Gets the colour at the start of the morphing process.

        @return the start colour.
        */
    public FSColor getStartColor() { return startColor; }

    /** Gets the colour at the end of the morphing process.

        @return the end colour.
        */
    public FSColor getEndColor() { return endColor; }

    /** Sets the ratio along the gradient square at the start of the morphing process.

        @param aNumber the starting ratio.
        */
    public void setStartRatio(int aNumber)
    {
        startRatio = aNumber;
    }

    /** Sets the ratio along the gradient square at the end of the morphing process.

        @param aNumber the ending ratio.
        */
    public void setEndRatio(int aNumber)
    {
        endRatio = aNumber;
    }

    /** Sets the colour at the start of the morphing process.

        @param aColor the start colour.
        */
    public void setStartColor(FSColor aColor)
    {
        startColor = aColor;
    }

    /** Sets the colour at the end of the morphing process.

        @param aColor the end colour.
        */
    public void setEndColor(FSColor aColor)
    {
        endColor = aColor;
    }

    public Object clone()
    {
        FSMorphGradient anObject = (FSMorphGradient)super.clone();
        
        anObject.startColor = (startColor != null) ? (FSColor)startColor.clone() : null;
        anObject.endColor = (endColor != null) ? (FSColor)endColor.clone() : null;

        return anObject;
    }

    /** 
     * Returns true if anObject is equal to this one. Objects are considered 
     * equal if they would generate identical binary data when they are encoded 
     * to a Flash file.
     *
     * @return true if this object would be identical to anObject when encoded.
     */
    public boolean equals(Object anObject)
    {
        boolean result = false;
        
        if (super.equals(anObject))
        {
            FSMorphGradient typedObject = (FSMorphGradient)anObject;
            
            result = startRatio == typedObject.startRatio;
            result = result && endRatio == typedObject.endRatio;

            if (startColor != null)
                result = result && startColor.equals(typedObject.startColor);
            else
                result = result && startColor == typedObject.startColor;

            if (endColor != null)
                result = result && endColor.equals(typedObject.endColor);
            else
                result = result && endColor == typedObject.endColor;
        }
        return result;
    }

    public void appendDescription(StringBuffer buffer, int depth)
    {
        buffer.append(name());
        
        if (depth > 0)
        {
            buffer.append(": { ");
            Transform.append(buffer, "startRatio", startRatio);
            Transform.append(buffer, "endRatio", endRatio);
            Transform.append(buffer, "startColor", startColor, depth);
            Transform.append(buffer, "endColor", endColor, depth);
            buffer.append("}");
        }
    }

    public int length(FSCoder coder)
    {
        int length = 2;
    
        length += startColor.length(coder);
        length += endColor.length(coder);
    
        return length;
    }
    
    public void encode(FSCoder coder)
    {
        coder.writeWord(startRatio, 1);
        startColor.encode(coder);
        coder.writeWord(endRatio, 1);
        endColor.encode(coder);
    }
    
    public void decode(FSCoder coder)
    {
        startRatio = coder.readWord(1, false);
        startColor = new FSColor(coder);
        endRatio = coder.readWord(1, false);
        endColor = new FSColor(coder);
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -