001/*
002 * SVG Salamander
003 * Copyright (c) 2004, Mark McKay
004 * All rights reserved.
005 *
006 * Redistribution and use in source and binary forms, with or 
007 * without modification, are permitted provided that the following
008 * conditions are met:
009 *
010 *   - Redistributions of source code must retain the above 
011 *     copyright notice, this list of conditions and the following
012 *     disclaimer.
013 *   - Redistributions in binary form must reproduce the above
014 *     copyright notice, this list of conditions and the following
015 *     disclaimer in the documentation and/or other materials 
016 *     provided with the distribution.
017 *
018 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
019 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
020 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
021 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
022 * COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
023 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
024 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
025 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
026 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
027 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
028 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
029 * OF THE POSSIBILITY OF SUCH DAMAGE. 
030 * 
031 * Mark McKay can be contacted at mark@kitfox.com.  Salamander and other
032 * projects can be found at http://www.kitfox.com
033 *
034 * Created on August 15, 2004, 2:51 AM
035 */
036
037package com.kitfox.svg.animation;
038
039import com.kitfox.svg.SVGElement;
040import com.kitfox.svg.SVGException;
041import com.kitfox.svg.SVGLoaderHelper;
042import com.kitfox.svg.animation.parser.AnimTimeParser;
043import com.kitfox.svg.xml.StyleAttribute;
044import org.xml.sax.Attributes;
045import org.xml.sax.SAXException;
046
047
048/**
049 * Set is used to set a textual value; most likely for a style element.
050 *
051 * @author Mark McKay
052 * @author <a href="mailto:mark@kitfox.com">Mark McKay</a>
053 */
054public class SetSmil extends AnimationElement
055{
056    public static final String TAG_NAME = "set";
057    
058    private String toValue;
059    
060    /** Creates a new instance of Set */
061    public SetSmil()
062    {
063    }
064
065    public String getTagName()
066    {
067        return TAG_NAME;
068    }
069
070    public void loaderStartElement(SVGLoaderHelper helper, Attributes attrs, SVGElement parent) throws SAXException
071    {
072                //Load style string
073        super.loaderStartElement(helper, attrs, parent);
074
075        toValue = attrs.getValue("to");
076    }
077
078    protected void rebuild(AnimTimeParser animTimeParser) throws SVGException
079    {
080        super.rebuild(animTimeParser);
081
082        StyleAttribute sty = new StyleAttribute();
083
084        if (getPres(sty.setName("to")))
085        {
086            String newVal = sty.getStringValue();
087            toValue = newVal;
088        }
089    }
090
091    /**
092     * @return the toValue
093     */
094    public String getToValue()
095    {
096        return toValue;
097    }
098
099    /**
100     * @param toValue the toValue to set
101     */
102    public void setToValue(String toValue)
103    {
104        this.toValue = toValue;
105    }
106}