 
                        
        
                        
        com.googlecode.blaisemath.svg.SVGPolyline Maven / Gradle / Ivy
/**
 * Polyline.java
 * Created Sep 26, 2014
 */
package com.googlecode.blaisemath.svg;
/*
 * #%L
 * BlaiseGraphics
 * --
 * Copyright (C) 2014 - 2017 Elisha Peterson
 * --
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 * #L%
 */
import com.google.common.base.Converter;
import static com.google.common.base.Preconditions.checkArgument;
import static com.google.common.base.Preconditions.checkNotNull;
import java.awt.geom.GeneralPath;
import java.awt.geom.PathIterator;
import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlRootElement;
/**
 * 
 *   SVG Polyline object.
 * 
 * @author elisha
 */
@XmlRootElement(name="polyline")
public final class SVGPolyline extends SVGElement {
    
    private static final PolylineConverter CONVERTER_INST = new PolylineConverter();
    
    private String ptStr;
    public SVGPolyline() {
        super("polyline");
    }
    public SVGPolyline(String pts) {
        super("polyline");
        this.ptStr = checkPointString(pts);
    }
    
    //
    //
    // PROPERTY PATTERNS
    //
    
    @XmlAttribute(name="points")
    public String getPointStr() {
        return ptStr;
    }
    public void setPointStr(String ptStr) {
        this.ptStr = checkPointString(ptStr);
    }
    
    // 
    
    public static Converter shapeConverter() {
        return CONVERTER_INST;
    }
    
    private static final class PolylineConverter extends Converter {
        @Override
        protected GeneralPath doForward(SVGPolyline a) {
            return toPath(a.ptStr);
        }
        @Override
        protected SVGPolyline doBackward(GeneralPath b) {
            return new SVGPolyline(toPathString(b));
        }
    }
    
    //
    
    /** Ensures validity of a string of points */
    static String checkPointString(String s) {
        checkNotNull(s);
        String ps = s.replaceAll("\\s*,\\s*", ",");
        String[] pp = ps.split("\\s+");
        for (String p : pp) {
            String[] p2 = p.split(",");
            checkArgument(p2.length == 2, "Invalid point string: "+s);
            try {
                Double.valueOf(p2[0]);
                Double.valueOf(p2[1]);
            } catch (NumberFormatException x) {
                throw new IllegalArgumentException("Invalid point string: "+s, x);
            }
        }
        return s;
    }
    
    /** Converts point string to path */
    static GeneralPath toPath(String pointStr) {
        checkPointString(pointStr);
        String ps = pointStr.replaceAll("\\s*,\\s*", ",");
        GeneralPath path = new GeneralPath();
        for (String p : ps.split("\\s+")) {
            String[] sp2 = p.split(",");
            if (path.getCurrentPoint() == null) {
                path.moveTo(Double.valueOf(sp2[0]), Double.valueOf(sp2[1]));
            } else {
                path.lineTo(Double.valueOf(sp2[0]), Double.valueOf(sp2[1]));
            }
        }
        return path;
    }
    
    /** Converts path to point string */
    static String toPathString(GeneralPath gp) {
        PathIterator pi = gp.getPathIterator(null);
        float[] cur = new float[6];
        int curSegmentType = -1;
        String s0 = null;
        StringBuilder pathString = new StringBuilder();
        while (!pi.isDone()) {
            curSegmentType = pi.currentSegment(cur);
            if (curSegmentType == PathIterator.SEG_LINETO || curSegmentType == PathIterator.SEG_MOVETO) {
                String s = " "+SVGPath.numStr(",", 6, cur[0], cur[1]);
                pathString.append(s);
                if (s0 == null) {
                    s0 = s;
                }
            } else if (curSegmentType == PathIterator.SEG_CLOSE) {
                // ignore - this is the difference between polyline and polygon
            } else {
                throw new IllegalArgumentException("Path cannot be converted to polyline.");
            }
            pi.next();
        }
        return pathString.toString().trim();
    }
    
    // 
}
  © 2015 - 2025 Weber Informatics LLC | Privacy Policy