com.kitfox.svg.LinearGradient Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of svg-salamander Show documentation
Show all versions of svg-salamander Show documentation
A tool for displaying and playing SVG content using the Java2D
The newest version!
/*
* SVG Salamander
* Copyright (c) 2004, Mark McKay
* 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.
*
* 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 HOLDER 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.
*
* Mark McKay can be contacted at [email protected]. Salamander and other
* projects can be found at http://www.kitfox.com
*
* Created on January 26, 2004, 1:54 AM
*/
package com.kitfox.svg;
import com.kitfox.svg.xml.StyleAttribute;
import java.awt.Color;
import java.awt.LinearGradientPaint;
import java.awt.MultipleGradientPaint;
import java.awt.Paint;
import java.awt.geom.AffineTransform;
import java.awt.geom.Point2D;
import java.awt.geom.Rectangle2D;
/**
* @author Mark McKay
* @author Mark McKay
*/
public class LinearGradient extends Gradient
{
public static final String TAG_NAME = "lineargradient";
float x1 = 0f;
float y1 = 0f;
float x2 = 1f;
float y2 = 0f;
/**
* Creates a new instance of LinearGradient
*/
public LinearGradient()
{
}
@Override
public String getTagName()
{
return TAG_NAME;
}
@Override
protected void build() throws SVGException
{
super.build();
StyleAttribute sty = new StyleAttribute();
if (getPres(sty.setName("x1")))
{
x1 = sty.getFloatValueWithUnits();
}
if (getPres(sty.setName("y1")))
{
y1 = sty.getFloatValueWithUnits();
}
if (getPres(sty.setName("x2")))
{
x2 = sty.getFloatValueWithUnits();
}
if (getPres(sty.setName("y2")))
{
y2 = sty.getFloatValueWithUnits();
}
}
@Override
public Paint getPaint(Rectangle2D bounds, AffineTransform xform)
{
MultipleGradientPaint.CycleMethod method;
switch (spreadMethod)
{
default:
case SM_PAD:
method = MultipleGradientPaint.CycleMethod.NO_CYCLE;
break;
case SM_REPEAT:
method = MultipleGradientPaint.CycleMethod.REPEAT;
break;
case SM_REFLECT:
method = MultipleGradientPaint.CycleMethod.REFLECT;
break;
}
Paint paint;
Point2D.Float pt1 = new Point2D.Float(x1, y1);
Point2D.Float pt2 = new Point2D.Float(x2, y2);
if (pt1.equals(pt2))
{
Color[] colors = getStopColors();
paint = colors.length > 0 ? colors[0] : Color.black;
} else if (gradientUnits == GU_USER_SPACE_ON_USE)
{
paint = new LinearGradientPaint(
pt1,
pt2,
getStopFractions(),
getStopColors(),
method,
MultipleGradientPaint.ColorSpaceType.SRGB,
gradientTransform == null
? new AffineTransform()
: gradientTransform);
} else
{
AffineTransform viewXform = new AffineTransform();
viewXform.translate(bounds.getX(), bounds.getY());
//This is a hack to get around shapes that have a width or height of 0. Should be close enough to the true answer.
double width = Math.max(1, bounds.getWidth());
double height = Math.max(1, bounds.getHeight());
viewXform.scale(width, height);
if (gradientTransform != null)
{
viewXform.concatenate(gradientTransform);
}
paint = new LinearGradientPaint(
pt1,
pt2,
getStopFractions(),
getStopColors(),
method,
MultipleGradientPaint.ColorSpaceType.SRGB,
viewXform);
}
return paint;
}
/**
* Updates all attributes in this diagram associated with a time event. Ie,
* all attributes with track information.
*
* @return - true if this node has changed state as a result of the time
* update
*/
@Override
public boolean updateTime(double curTime) throws SVGException
{
// if (trackManager.getNumTracks() == 0) return stopChange;
boolean changeState = super.updateTime(curTime);
//Get current values for parameters
StyleAttribute sty = new StyleAttribute();
boolean shapeChange = false;
if (getPres(sty.setName("x1")))
{
float newVal = sty.getFloatValueWithUnits();
if (newVal != x1)
{
x1 = newVal;
shapeChange = true;
}
}
if (getPres(sty.setName("y1")))
{
float newVal = sty.getFloatValueWithUnits();
if (newVal != y1)
{
y1 = newVal;
shapeChange = true;
}
}
if (getPres(sty.setName("x2")))
{
float newVal = sty.getFloatValueWithUnits();
if (newVal != x2)
{
x2 = newVal;
shapeChange = true;
}
}
if (getPres(sty.setName("y2")))
{
float newVal = sty.getFloatValueWithUnits();
if (newVal != y2)
{
y2 = newVal;
shapeChange = true;
}
}
return changeState || shapeChange;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy