Statistics
| Revision:

svn-gvsig-desktop / trunk / org.gvsig.desktop / org.gvsig.desktop.library / org.gvsig.symbology / org.gvsig.symbology.lib / org.gvsig.symbology.lib.impl / src / main / java / org / gvsig / symbology / fmap / mapcontext / rendering / symbol / marker / impl / ArrowMarkerSymbol.java @ 47790

History | View | Annotate | Download (6.15 KB)

1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright (C) 2007-2013 gvSIG Association.
5
 *
6
 * This program is free software; you can redistribute it and/or
7
 * modify it under the terms of the GNU General Public License
8
 * as published by the Free Software Foundation; either version 3
9
 * of the License, or (at your option) any later version.
10
 *
11
 * This program is distributed in the hope that it will be useful,
12
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
 * GNU General Public License for more details.
15
 *
16
 * You should have received a copy of the GNU General Public License
17
 * along with this program; if not, write to the Free Software
18
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
19
 * MA  02110-1301, USA.
20
 *
21
 * For any additional information, do not hesitate to contact us
22
 * at info AT gvsig.com, or visit our website www.gvsig.com.
23
 */
24
package org.gvsig.symbology.fmap.mapcontext.rendering.symbol.marker.impl;
25

    
26
import java.awt.BasicStroke;
27
import java.awt.Color;
28
import java.awt.Graphics2D;
29
import java.awt.Rectangle;
30
import java.awt.geom.AffineTransform;
31
import org.gvsig.fmap.dal.feature.Feature;
32
import org.gvsig.fmap.geom.Geometry;
33
import org.gvsig.fmap.geom.primitive.GeneralPathX;
34
import org.gvsig.fmap.geom.primitive.Point;
35
import org.gvsig.fmap.mapcontext.rendering.symbols.CartographicSupport;
36
import org.gvsig.fmap.mapcontext.rendering.symbols.ISymbol;
37
import org.gvsig.symbology.fmap.mapcontext.rendering.symbol.marker.IArrowMarkerSymbol;
38
import org.gvsig.tools.ToolsLocator;
39
import org.gvsig.tools.dynobject.DynStruct;
40
import org.gvsig.tools.persistence.PersistenceManager;
41
import org.gvsig.tools.persistence.PersistentState;
42
import org.gvsig.tools.persistence.exception.PersistenceException;
43
import org.gvsig.tools.task.Cancellable;
44
import org.gvsig.tools.util.Callable;
45

    
46
/**
47
 * @author 2005-2008 jaume dominguez faus - jaume.dominguez@iver.es
48
 * @author 2009-     <a href="cordinyana@gvsig.org">C?sar Ordi?ana</a> - gvSIG team
49
 */
50
public class ArrowMarkerSymbol extends AbstractMarkerSymbol implements CartographicSupport, IArrowMarkerSymbol {
51

    
52
        public static final String ARROW_MARKER_SYMBOL_DYNCLASS_NAME = "ArrowMarkerSymbol";
53

    
54
        private static final String FIELD_SHARPNESS = "sharpness";
55

    
56
        private ArrowMarkerSymbol symSel;
57
        private double sharpeness;
58

    
59
    @Override
60
    public ISymbol getSymbolForSelection(Color selectionColor) {
61
        if (symSel == null) {
62
            //symSel = new ArrowMarkerSymbol();
63
            symSel = (ArrowMarkerSymbol) this.cloneForSelection(selectionColor);
64
            symSel.setColor(selectionColor);
65
        } else {
66
            symSel.setColor(selectionColor);
67
        }
68
        if (symSel instanceof CartographicSupport) {
69
            ((CartographicSupport) symSel).setUnit(this.getUnit());
70
        }
71

    
72
        return symSel;
73
    }
74

    
75
        public String getClassName() {
76
                return getClass().getName();
77
        }
78

    
79
        /**
80
         * To get the sharpeness attribute.It will determine the final form of the arrow
81
         * @return
82
         */
83
        @Override
84
        public double getSharpness() {
85
                return sharpeness;
86
        }
87

    
88
        /**
89
         * To set the sharpeness.It will determine the final form of the arrow
90
         * @param sharpeness, the value of the arrow's edge angle IN RADIANS
91
         * @see #getSharpeness()
92
         */
93
        @Override
94
        public void setSharpness(double sharpeness) {
95
                this.sharpeness = sharpeness;
96
        }
97

    
98
    @Override
99
    public void draw(Graphics2D g, AffineTransform affineTransform, Geometry geom, Feature f, Cancellable cancel, Rectangle r) {
100
        double size_d = getEfectiveSize(f);
101
        size_d = this.getAdjustedSize(r, size_d);
102

    
103
        if(r != null){
104
            geom = getSampleGeometry(r);
105
        }
106

    
107
        if (geom == null) {
108
            return;
109
        }
110
        Point p;
111
        try {
112
            p = geom.centroid();
113
        } catch (Exception ex) {
114
            return;
115
        }
116
        double radian_half_sharpeness = Math.toRadians(getSharpness() * .5); //
117

    
118
        double halfHeight = size_d * Math.tan(radian_half_sharpeness);
119
        double theta = getRotation();
120

    
121
        g.setColor(getColor());
122

    
123
        g.setStroke(new BasicStroke());
124

    
125
        AffineTransform newAf = (AffineTransform) affineTransform.clone();
126

    
127
        newAf.translate(p.getX(), p.getY());
128
        newAf.rotate(theta);
129

    
130
        GeneralPathX gp = new GeneralPathX();
131
        gp.moveTo(0, 0);
132
        gp.lineTo(size_d, -halfHeight);
133
        gp.lineTo(size_d, halfHeight);
134
        gp.closePath();
135

    
136
        gp.transform(newAf);
137

    
138
        g.fill(gp);
139
    }
140

    
141
        @Override
142
        public Object clone() throws CloneNotSupportedException {
143
                ArrowMarkerSymbol copy  = (ArrowMarkerSymbol) super.clone();
144

    
145
                // Clone the selection symbol
146
                if (symSel != null) {
147
                        copy.symSel = (ArrowMarkerSymbol) symSel.clone();
148
                }
149
                return copy;
150
        }
151

    
152
        @Override
153
        public void loadFromState(PersistentState state)
154
                        throws PersistenceException {
155
                // Set parent fill symbol properties
156
                super.loadFromState(state);
157

    
158
                // Set own properties
159
                setSharpness(state.getDouble(FIELD_SHARPNESS));
160
        }
161

    
162
        @Override
163
        public void saveToState(PersistentState state) throws PersistenceException {
164
                // Save parent fill symbol properties
165
                super.saveToState(state);
166

    
167
                // Save own properties
168
                state.set(FIELD_SHARPNESS, getSharpness());
169
        }
170

    
171
        public static class RegisterPersistence implements Callable {
172

    
173
                @Override
174
                public Object call() throws Exception {
175
                        PersistenceManager manager = ToolsLocator.getPersistenceManager();
176
                        if( manager.getDefinition(ARROW_MARKER_SYMBOL_DYNCLASS_NAME)==null ) {
177
                                DynStruct definition = manager.addDefinition(
178
                                                ArrowMarkerSymbol.class,
179
                                                ARROW_MARKER_SYMBOL_DYNCLASS_NAME,
180
                                                ARROW_MARKER_SYMBOL_DYNCLASS_NAME+" Persistence definition",
181
                                                null,
182
                                                null
183
                                );
184
                                // Extend the FillSymbol base definition
185
                                definition.extend(manager.getDefinition(MARKER_SYMBOL_PERSISTENCE_DEFINITION_NAME));
186

    
187
                                // Sharpeness
188
                                definition.addDynFieldDouble(FIELD_SHARPNESS).setMandatory(true);
189
                        }
190
                        return Boolean.TRUE;
191
                }
192

    
193
        }
194

    
195
}