From 091a1e0179cb264cc2cab6e3b11ea31045c8536d Mon Sep 17 00:00:00 2001 From: kitfox Date: Tue, 29 May 2007 23:33:23 +0000 Subject: Restoring SVG Salamander to it's original code base, and updating build scripts. git-svn-id: https://svn.java.net/svn/svgsalamander~svn/trunk/svg-core@36 7dc7fa77-23fb-e6ad-8e2e-c86bd48ed22b --- .../java/com/kitfox/svg/animation/TrackBase.java | 104 +++++++++++++++++++++ 1 file changed, 104 insertions(+) create mode 100644 src/main/java/com/kitfox/svg/animation/TrackBase.java (limited to 'src/main/java/com/kitfox/svg/animation/TrackBase.java') diff --git a/src/main/java/com/kitfox/svg/animation/TrackBase.java b/src/main/java/com/kitfox/svg/animation/TrackBase.java new file mode 100644 index 0000000..a38866f --- /dev/null +++ b/src/main/java/com/kitfox/svg/animation/TrackBase.java @@ -0,0 +1,104 @@ +/* + * TrackManager.java + * + * The Salamander Project - 2D and 3D graphics libraries in Java + * Copyright (C) 2004 Mark McKay + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * + * Mark McKay can be contacted at mark@kitfox.com. Salamander and other + * projects can be found at http://www.kitfox.com + * + * Created on August 15, 2004, 11:34 PM + */ + +package com.kitfox.svg.animation; + +import com.kitfox.svg.xml.StyleAttribute; +import java.util.*; + +import com.kitfox.svg.xml.*; +import com.kitfox.svg.*; + +/** + * A track holds the animation events for a single parameter of a single SVG + * element. It also contains the default value for the element, should the + * user want to see the 'unanimated' value. + * + * @author Mark McKay + * @author Mark McKay + */ +abstract public class TrackBase +{ + protected final String attribName; + protected final int attribType; //AnimationElement.AT_* + + /** Element we're animating */ + protected final SVGElement parent; + + //It doesn't make sense to sort this, since some events will depend on + // other events - in many cases, there will be no meaningful sorted order. + final Vector animEvents = new Vector(); + + /** Creates a new instance of TrackManager */ +// public TrackBase(SVGElement parent) +// { +// this(parent, "", AnimationElement.AT_AUTO); +// } + + /** + * Creates a track that would be valid for the name and type of element + * passed in. Does not actually add this elemnt to the track. + */ + public TrackBase(SVGElement parent, AnimationElement ele) throws SVGElementException + { + this(parent, ele.getAttribName(), ele.getAttribType()); + } + + public TrackBase(SVGElement parent, String attribName, int attribType) throws SVGElementException + { + this.parent = parent; + this.attribName = attribName; + this.attribType = attribType; + + //Make sure parent has an attribute we will write to + if (attribType == AnimationElement.AT_AUTO + && !parent.hasAttribute(attribName, AnimationElement.AT_CSS) + && !parent.hasAttribute(attribName, AnimationElement.AT_XML)) + { + parent.addAttribute(attribName, AnimationElement.AT_CSS, ""); + } + else if (!parent.hasAttribute(attribName, attribType)) + { + parent.addAttribute(attribName, attribType, ""); + } + } + + public String getAttribName() { return attribName; } + public int getAttribType() { return attribType; } + + public void addElement(AnimationElement ele) + { + animEvents.add(ele); + } + + /** + * Returns a StyleAttribute representing the value of this track at the + * passed time. If this track does not apply, returns null. + * @return - True if successful, false if a value could not be obtained + */ + abstract public boolean getValue(StyleAttribute attrib, double curTime) throws SVGException; + +} -- cgit v1.2.3-55-g7522