Revision 298

View differences:

org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.app/pom.xml
1
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
2
  <modelVersion>4.0.0</modelVersion>
3
  <parent>
4
    <groupId>org.gvsig</groupId>
5
    <artifactId>org.gvsig.vectorediting.symmetry</artifactId>
6
    <version>1.0.0</version>
7
  </parent>
8
  <artifactId>org.gvsig.vectorediting.symmetry.app</artifactId>
9
  <packaging>pom</packaging>
10
  <name>org.gvsig.vectorediting.symmetry.app</name>
11
  <modules>
12
  	<module>org.gvsig.vectorediting.symmetry.app.mainplugin</module>
13
  </modules>
14
</project>
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.app/org.gvsig.vectorediting.symmetry.app.mainplugin/pom.xml
1
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
2
	<modelVersion>4.0.0</modelVersion>
3
	<parent>
4
		<groupId>org.gvsig</groupId>
5
		<artifactId>org.gvsig.vectorediting.symmetry.app</artifactId>
6
		<version>1.0.0</version>
7
	</parent>
8

  
9
	<artifactId>org.gvsig.vectorediting.symmetry.app.mainplugin</artifactId>
10
	<name>org.gvsig.vectorediting.symmetry.app.mainplugin</name>
11
	
12
	<properties>
13
        <!-- Package info property values -->
14
        <gvsig.package.info.state>devel</gvsig.package.info.state>
15
        <gvsig.package.info.dependencies>required: org.gvsig.app.mainplugin -ge 2.1.0-A, required: org.gvsig.vectorediting.mainplugin -ge 1.0.0</gvsig.package.info.dependencies>
16
        <gvsig.package.info.official>true</gvsig.package.info.official>
17
        <gvsig.package.info.name>Symmetry provider</gvsig.package.info.name>
18
        <gvsig.package.info.description>Symmetry provider: provides symmetrical geometries.</gvsig.package.info.description>
19
        <gvsig.package.info.categories>Vector</gvsig.package.info.categories>
20
        <gvsig.package.info.javaVM>j1_6</gvsig.package.info.javaVM>
21
        <gvsig.package.info.poolURL>https://devel.gvsig.org/download/projects/gvsig-vectorediting/pool</gvsig.package.info.poolURL>
22
    </properties>
23

  
24
	<dependencies>
25
		<dependency>
26
			<groupId>org.gvsig</groupId>
27
			<artifactId>org.gvsig.vectorediting.app.mainplugin</artifactId>
28
			<scope>compile</scope>
29
		</dependency>
30
		<dependency>
31
			<groupId>org.gvsig</groupId>
32
			<artifactId>org.gvsig.vectorediting.lib.api</artifactId>
33
		</dependency>
34
		<dependency>
35
			<groupId>org.gvsig</groupId>
36
			<artifactId>org.gvsig.vectorediting.lib.impl</artifactId>
37
		</dependency>
38
		<dependency>
39
			<groupId>org.gvsig</groupId>
40
			<artifactId>org.gvsig.vectorediting.lib.spi</artifactId>
41
		</dependency>
42
		<dependency>
43
			<groupId>org.gvsig</groupId>
44
			<artifactId>org.gvsig.vectorediting.symmetry.lib.prov.symmetry</artifactId>
45
		</dependency>
46
	</dependencies>
47
</project>
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.app/org.gvsig.vectorediting.symmetry.app.mainplugin/buildNumber.properties
1
#Tue Dec 16 09:53:04 CET 2014
2
buildNumber=2
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.app/org.gvsig.vectorediting.symmetry.app.mainplugin/src/main/assembly/gvsig-plugin-package.xml
1
<!--
2

  
3
    gvSIG. Desktop Geographic Information System.
4

  
5
    Copyright (C) 2007-2013 gvSIG Association.
6

  
7
    This program is free software; you can redistribute it and/or
8
    modify it under the terms of the GNU General Public License
9
    as published by the Free Software Foundation; either version 3
10
    of the License, or (at your option) any later version.
11

  
12
    This program is distributed in the hope that it will be useful,
13
    but WITHOUT ANY WARRANTY; without even the implied warranty of
14
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
    GNU General Public License for more details.
16

  
17
    You should have received a copy of the GNU General Public License
18
    along with this program; if not, write to the Free Software
19
    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
20
    MA  02110-1301, USA.
21

  
22
    For any additional information, do not hesitate to contact us
23
    at info AT gvsig.com, or visit our website www.gvsig.com.
24

  
25
-->
26
<assembly>
27
  <id>gvsig-plugin-package</id>
28
  <formats>
29
    <format>zip</format>
30
  </formats>
31
  <baseDirectory>${project.artifactId}</baseDirectory>
32
  <includeBaseDirectory>true</includeBaseDirectory>
33
  <files>
34
    <file>
35
      <source>target/${project.artifactId}-${project.version}.jar</source>
36
      <outputDirectory>lib</outputDirectory>
37
    </file>
38
    <file>
39
      <source>target/package.info</source>
40
    </file>
41
  </files>
42

  
43
  <fileSets>
44
    <fileSet>
45
      <directory>src/main/resources-plugin</directory>
46
      <outputDirectory>.</outputDirectory>
47
    </fileSet>
48
  </fileSets>
49

  
50

  
51
  <dependencySets>
52
    <dependencySet>
53
      <useProjectArtifact>false</useProjectArtifact>
54
      <useTransitiveDependencies>false</useTransitiveDependencies>
55
      <outputDirectory>lib</outputDirectory>
56
      <includes>
57
		<include>org.gvsig:org.gvsig.vectorediting.symmetry.lib.prov.symmetry</include>
58
      </includes>
59
    </dependencySet>
60
  </dependencySets>
61

  
62
</assembly>
63

  
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.app/org.gvsig.vectorediting.symmetry.app.mainplugin/src/main/resources-plugin/config.xml
1
<?xml version="1.0" encoding="ISO-8859-1"?>
2
<!-- gvSIG. Desktop Geographic Information System. Copyright (C) 2007-2013 
3
	gvSIG Association. This program is free software; you can redistribute it 
4
	and/or modify it under the terms of the GNU General Public License as published 
5
	by the Free Software Foundation; either version 3 of the License, or (at 
6
	your option) any later version. This program is distributed in the hope that 
7
	it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty 
8
	of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General 
9
	Public License for more details. You should have received a copy of the GNU 
10
	General Public License along with this program; if not, write to the Free 
11
	Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, 
12
	USA. For any additional information, do not hesitate to contact us at info 
13
	AT gvsig.com, or visit our website www.gvsig.com. -->
14
<plugin-config>
15
	<depends plugin-name="org.gvsig.vectorediting.app.mainplugin" />
16
	<resourceBundle name="text" />
17
	<libraries library-dir="lib" />
18
	<extensions>
19
		<extension class-name="org.gvsig.vectorediting.app.mainplugin.ServiceExtension"
20
			description="" active="true" priority="1">
21

  
22
			<action name="modify-symmetry" label="modify_symmetry"
23
                tooltip="modify_symmetry" position="601002400" action-command="modify-symmetry"
24
                icon="modify-symmetry" accelerator="" />
25

  
26
			<menu text="Layer/Modify/modify_symmetry" name="modify-symmetry" />
27

  
28
			<tool-bar name="vector_editing" position="600800000">
29
				<selectable-tool name="modify-symmetry" />
30
			</tool-bar>
31

  
32
		</extension>
33
	</extensions>
34
</plugin-config>
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/pom.xml
1
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
2
  <modelVersion>4.0.0</modelVersion>
3
  <parent>
4
    <groupId>org.gvsig</groupId>
5
    <artifactId>org.gvsig.vectorediting.symmetry</artifactId>
6
    <version>1.0.0</version>
7
  </parent>
8
  <artifactId>org.gvsig.vectorediting.symmetry.lib</artifactId>
9
  <packaging>pom</packaging>
10
  <name>org.gvsig.vectorediting.symmetry.lib</name>
11
  <modules>
12
  	<module>org.gvsig.vectorediting.symmetry.lib.prov</module>
13
  </modules>
14
</project>
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/pom.xml
1
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
2
  <modelVersion>4.0.0</modelVersion>
3
  <parent>
4
    <groupId>org.gvsig</groupId>
5
    <artifactId>org.gvsig.vectorediting.symmetry.lib</artifactId>
6
    <version>1.0.0</version>
7
  </parent>
8
  <artifactId>org.gvsig.vectorediting.symmetry.lib.prov</artifactId>
9
  <packaging>pom</packaging>
10
  <name>org.gvsig.vectorediting.symmetry.lib.prov</name>
11
  <modules>
12
  	<module>
13
  		org.gvsig.vectorediting.symmetry.lib.prov.symmetry
14
  	</module>
15
  </modules>
16
</project>
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/org.gvsig.vectorediting.symmetry.lib.prov.symmetry/src/main/resources/i18n/text.properties
1
modify_symmetry = Geometr\u00eda sim\u00e9trica
2
selection=Selecci\u00f3n
3
first_point_of_symmetry_axis=Primer punto del eje de simetr\u00eda
4
second_point_of_symmetry_axis=Segundo punto del eje de simetr\u00eda
5
delete_original_geometries_question=\u00bfDesea borrar las geometr\u00edas originales?
6
short_yes=S
7
short_no=N
8
delete_original_geometries = Eliminar geometr\u00edas originales
9
keep_original_geometries = Mantener geometr\u00edas originales
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/org.gvsig.vectorediting.symmetry.lib.prov.symmetry/src/main/resources/i18n/text_en.properties
1
modify_symmetry = Symmetrical geometry
2
selection = Selection
3
first_point_of_symmetry_axis=First point of the symmetry axis
4
second_point_of_symmetry_axis=Second point of the symmetry axis
5
delete_original_geometries_question=Delete original geometries?
6
short_yes=Y
7
short_no=N
8
delete_original_geometries = Delete original geometries
9
keep_original_geometries = Keep original geometries
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/org.gvsig.vectorediting.symmetry.lib.prov.symmetry/src/main/resources/META-INF/services/org.gvsig.tools.library.Library
1
org.gvsig.vectorediting.symmetry.lib.prov.symmetry.SymmetryEditingLibrary
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/org.gvsig.vectorediting.symmetry.lib.prov.symmetry/src/main/java/org/gvsig/vectorediting/symmetry/lib/prov/symmetry/SymmetryEditingLibrary.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright ? 2007-2014 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 2
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

  
25
package org.gvsig.vectorediting.symmetry.lib.prov.symmetry;
26

  
27
import org.gvsig.tools.ToolsLocator;
28
import org.gvsig.tools.i18n.I18nManager;
29
import org.gvsig.tools.library.AbstractLibrary;
30
import org.gvsig.tools.library.LibraryException;
31
import org.gvsig.vectorediting.lib.api.EditingLibrary;
32
import org.gvsig.vectorediting.lib.spi.EditingProviderLocator;
33
import org.gvsig.vectorediting.lib.spi.EditingProviderManager;
34

  
35
/**
36
 * Library for default implementation initialization and configuration.
37
 *
38
 * @author gvSIG team
39
 * @version $Id$
40
 */
41
public class SymmetryEditingLibrary extends AbstractLibrary {
42

  
43
    @Override
44
    public void doRegistration() {
45
        registerAsServiceOf(EditingLibrary.class);
46
    }
47

  
48
    @Override
49
    protected void doInitialize() throws LibraryException {
50
    }
51

  
52
    @Override
53
    protected void doPostInitialize() throws LibraryException {
54
        EditingProviderManager manager =
55
            EditingProviderLocator.getProviderManager();
56

  
57
        manager.addProviderFactory(new SymmetryEditingProviderFactory());
58

  
59
        manager.registerIcon("vectorediting-tools", "modify-symmetry", this
60
            .getClass().getClassLoader(), this.getClass().getName());
61

  
62
        registerTranslations();
63
    }
64

  
65
    private void registerTranslations() {
66
        I18nManager manager = ToolsLocator.getI18nManager();
67
        manager.addResourceFamily("i18n.text",
68
            this.getClass().getClassLoader(), "symmetry-editing");
69
    }
70

  
71
}
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/org.gvsig.vectorediting.symmetry.lib.prov.symmetry/src/main/java/org/gvsig/vectorediting/symmetry/lib/prov/symmetry/SymmetryEditingProvider.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright ? 2007-2014 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 2
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

  
25
package org.gvsig.vectorediting.symmetry.lib.prov.symmetry;
26

  
27
import java.awt.geom.AffineTransform;
28
import java.util.ArrayList;
29
import java.util.HashMap;
30
import java.util.LinkedHashMap;
31
import java.util.List;
32
import java.util.Map;
33

  
34
import org.gvsig.fmap.dal.exception.DataException;
35
import org.gvsig.fmap.dal.feature.EditableFeature;
36
import org.gvsig.fmap.dal.feature.Feature;
37
import org.gvsig.fmap.dal.feature.FeatureSelection;
38
import org.gvsig.fmap.dal.feature.FeatureStore;
39
import org.gvsig.fmap.geom.Geometry;
40
import org.gvsig.fmap.geom.GeometryLocator;
41
import org.gvsig.fmap.geom.operation.GeometryOperationException;
42
import org.gvsig.fmap.geom.operation.GeometryOperationNotSupportedException;
43
import org.gvsig.fmap.geom.primitive.Line;
44
import org.gvsig.fmap.geom.primitive.Point;
45
import org.gvsig.tools.ToolsLocator;
46
import org.gvsig.tools.dispose.DisposableIterator;
47
import org.gvsig.tools.dynobject.DynObject;
48
import org.gvsig.tools.i18n.I18nManager;
49
import org.gvsig.tools.service.spi.ProviderServices;
50
import org.gvsig.vectorediting.lib.api.DrawingStatus;
51
import org.gvsig.vectorediting.lib.api.EditingServiceParameter;
52
import org.gvsig.vectorediting.lib.api.EditingServiceParameter.TYPE;
53
import org.gvsig.vectorediting.lib.api.exceptions.DrawServiceException;
54
import org.gvsig.vectorediting.lib.api.exceptions.FinishServiceException;
55
import org.gvsig.vectorediting.lib.api.exceptions.InvalidEntryException;
56
import org.gvsig.vectorediting.lib.api.exceptions.StartServiceException;
57
import org.gvsig.vectorediting.lib.spi.AbstractEditingProvider;
58
import org.gvsig.vectorediting.lib.spi.DefaultDrawingStatus;
59
import org.gvsig.vectorediting.lib.spi.DefaultEditingServiceParameter;
60
import org.gvsig.vectorediting.lib.spi.EditingProvider;
61
import org.gvsig.vectorediting.lib.spi.EditingProviderFactory;
62
import org.gvsig.vectorediting.lib.spi.EditingProviderServices;
63

  
64
public class SymmetryEditingProvider extends AbstractEditingProvider implements
65
    EditingProvider {
66

  
67
    private I18nManager i18nManager = ToolsLocator.getI18nManager();
68

  
69
    private EditingServiceParameter selectionParameter;
70

  
71
    private EditingServiceParameter firstPointParameter;
72

  
73
    private EditingServiceParameter secondPointParameter;
74

  
75
    private EditingServiceParameter deleteOriginalGeometriesParameter;
76

  
77
    private boolean deleteOriginalGeometries = false;
78

  
79
    private Map<EditingServiceParameter, Object> values;
80

  
81
    private Map<String, String> options;
82

  
83
    private FeatureStore featureStore;
84

  
85
    public SymmetryEditingProvider(ProviderServices providerServices,
86
        DynObject parameters) {
87
        super(providerServices);
88
        this.featureStore =
89
            (FeatureStore) parameters
90
                .getDynValue(EditingProviderFactory.FEATURE_STORE_FIELD);
91

  
92
        this.selectionParameter =
93
            new DefaultEditingServiceParameter("selection",
94
                i18nManager.getTranslation("selection"), TYPE.SELECTION);
95

  
96
        this.firstPointParameter =
97
            new DefaultEditingServiceParameter("first_point_of_symmetry_axis",
98
                i18nManager.getTranslation("first_point_of_symmetry_axis"),
99
                TYPE.POSITION);
100

  
101
        this.secondPointParameter =
102
            new DefaultEditingServiceParameter("second_point_of_symmetry_axis",
103
                i18nManager.getTranslation("second_point_of_symmetry_axis"),
104
                TYPE.POSITION);
105

  
106
        this.options = new LinkedHashMap<String, String>();
107
        options.put(i18nManager.getTranslation("short_yes"),
108
            "delete_original_geometries");
109
        options.put(i18nManager.getTranslation("short_no"),
110
            "keep_original_geometries");
111

  
112
        EditingProviderServices editingProviderServices =
113
            (EditingProviderServices) getProviderServices();
114

  
115
        String consoleMsg =
116
            editingProviderServices.makeConsoleMessage(
117
                "delete_original_geometries_question", options);
118

  
119
        this.deleteOriginalGeometriesParameter =
120
            new DefaultEditingServiceParameter("Delete original geometries",
121
                consoleMsg, options, TYPE.OPTION);
122
    }
123

  
124
    public DrawingStatus getDrawingStatus(Point mousePosition)
125
        throws DrawServiceException {
126
        DefaultDrawingStatus geometries = new DefaultDrawingStatus();
127

  
128
        FeatureSelection selected =
129
            (FeatureSelection) values.get(selectionParameter);
130
        try {
131
            if ((selected != null) && !selected.isEmpty()) {
132
                Point p1 = (Point) values.get(firstPointParameter);
133
                if (p1 != null) {
134
                    Object p2Value = values.get(secondPointParameter);
135
                    Point p2 = null;
136
                    if ((p2Value != null) && (p2Value instanceof Point)) {
137
                        p2 = (Point) p2Value;
138
                    } else {
139
                        p2 = mousePosition;
140
                    }
141
                    Line line;
142
                    line =
143
                        GeometryLocator.getGeometryManager().createLine(
144
                            featureStore.getDefaultFeatureType()
145
                                .getDefaultGeometryAttribute().getGeomType()
146
                                .getSubType());
147
                    line.addVertex(p1);
148
                    line.addVertex(p2);
149

  
150
                    geometries.addGeometry(line);
151

  
152
                    DisposableIterator it;
153
                    it = selected.fastIterator();
154

  
155
                    AffineTransform at;
156
                    try {
157
                        at = getSymmetryAffineTransform(p1, p2);
158
                    } catch (Exception e) {
159
                        throw new DrawServiceException(e);
160
                    }
161

  
162
                    while (it.hasNext()) {
163
                        Feature feat = (Feature) it.next();
164
                        Geometry geom =
165
                            feat.getDefaultGeometry().cloneGeometry();
166
                        geom.transform(at);
167
                        geometries.addGeometry(geom);
168
                    }
169
                    it.dispose();
170
                }
171
                return geometries;
172
            }
173
        } catch (Exception e) {
174
            throw new DrawServiceException(e);
175
        }
176

  
177
        return null;
178

  
179
    }
180

  
181
    private AffineTransform getSymmetryAffineTransform(Point axisP1,
182
        Point axisP2) throws GeometryOperationNotSupportedException,
183
        GeometryOperationException {
184

  
185
        AffineTransform translate =
186
            AffineTransform
187
                .getTranslateInstance(-axisP1.getX(), -axisP1.getY());
188

  
189
        EditingProviderServices editingProviderServices =
190
            (EditingProviderServices) getProviderServices();
191
        Double angle = -editingProviderServices.getAngle(axisP1, axisP2);
192
        AffineTransform rotate = AffineTransform.getRotateInstance(angle);
193

  
194
        AffineTransform symmetry = new AffineTransform(1, 0, 0, -1, 0, 0);
195
        AffineTransform inverseRotate =
196
            AffineTransform.getRotateInstance(-angle);
197
        AffineTransform inverseTranslate =
198
            AffineTransform.getTranslateInstance(axisP1.getX(), axisP1.getY());
199
        AffineTransform at = new AffineTransform(translate);
200

  
201
        at.preConcatenate(rotate);
202
        at.preConcatenate(symmetry);
203
        at.preConcatenate(inverseRotate);
204
        at.preConcatenate(inverseTranslate);
205
        return at;
206
    }
207

  
208
    public EditingServiceParameter next() {
209
        if (values.get(selectionParameter) == null) {
210
            return this.selectionParameter;
211
        } else if (values.get(firstPointParameter) == null) {
212
            return this.firstPointParameter;
213
        } else if (values.get(secondPointParameter) == null) {
214
            return this.secondPointParameter;
215
        } else if (values.get(deleteOriginalGeometriesParameter) == null) {
216
            return this.deleteOriginalGeometriesParameter;
217
        }
218
        return null;
219
    }
220

  
221
    public void stop() {
222
        values.clear();
223
    }
224

  
225
    private void validateAndInsertValue(EditingServiceParameter param,
226
        Object value) throws InvalidEntryException {
227
        if (param == selectionParameter) {
228
            if (value instanceof FeatureSelection) {
229
                values.put(param, value);
230
                return;
231
            }
232
        } else if (param == firstPointParameter) {
233
            if (value instanceof Point) {
234
                values.put(param, value);
235
                return;
236
            }
237
        } else if (param == secondPointParameter) {
238
            if (value instanceof Point) {
239
                values.put(param, value);
240
                return;
241
            }
242
        } else if (param == deleteOriginalGeometriesParameter) {
243
            if (value instanceof String) {
244
                if (((String) value).trim().equalsIgnoreCase(
245
                    i18nManager.getTranslation("short_yes"))) {
246
                    deleteOriginalGeometries = true;
247
                } else if (((String) value).trim().equalsIgnoreCase(
248
                    i18nManager.getTranslation("short_no"))) {
249
                    deleteOriginalGeometries = false;
250
                } else {
251
                    throw new InvalidEntryException(null);
252
                }
253
                values.put(param, value);
254
            }
255
        }
256

  
257
    }
258

  
259
    public List<EditingServiceParameter> getParameters() {
260
        List<EditingServiceParameter> list =
261
            new ArrayList<EditingServiceParameter>();
262
        list.add(selectionParameter);
263
        list.add(firstPointParameter);
264
        list.add(secondPointParameter);
265
        return list;
266
    }
267

  
268
    public void setValue(Object value) throws InvalidEntryException {
269
        EditingServiceParameter param = next();
270
        validateAndInsertValue(param, value);
271
    }
272

  
273
    public void finishAndStore() throws FinishServiceException {
274

  
275
        FeatureSelection selected =
276
            (FeatureSelection) values.get(selectionParameter);
277
        try {
278
            if (!selected.isEmpty()) {
279
                Point p1 = (Point) values.get(firstPointParameter);
280
                Point p2 = (Point) values.get(secondPointParameter);
281
                if ((p1 != null) && (p2 != null)) {
282

  
283
                    AffineTransform at;
284
                    try {
285
                        at = getSymmetryAffineTransform(p1, p2);
286
                    } catch (GeometryOperationNotSupportedException e) {
287
                        throw new FinishServiceException(e);
288
                    } catch (GeometryOperationException e) {
289
                        throw new FinishServiceException(e);
290
                    }
291

  
292
                    DisposableIterator it;
293
                    it = selected.fastIterator();
294

  
295
                    while (it.hasNext()) {
296
                        Feature feature = (Feature) it.next();
297
                        Geometry geom =
298
                            feature.getDefaultGeometry().cloneGeometry();
299
                        geom.transform(at);
300
                        if (this.deleteOriginalGeometries) {
301
                            // Se sustituye la geometr?a original por la
302
                            // calculada
303
                            EditableFeature editableFeature =
304
                                feature.getEditable();
305
                            editableFeature.setDefaultGeometry(geom);
306
                            ((EditingProviderServices) getProviderServices())
307
                                .updateFeatureInFeatureStore(editableFeature,
308
                                    featureStore);
309
                        } else {
310
                            // Se crea una feature nueva copiando los valores de
311
                            // la feature original excepto aquellos que sean PK
312
                            EditingProviderServices editingProviderServices =
313
                                (EditingProviderServices) getProviderServices();
314
                            EditableFeature editableFeature =
315
                                editingProviderServices
316
                                    .getFeatureCopyWithoutPK(featureStore,
317
                                        feature);
318
                            editableFeature.setDefaultGeometry(geom);
319
                            editingProviderServices
320
                                .insertFeatureIntoFeatureStore(editableFeature,
321
                                    featureStore);
322
                        }
323
                    }
324
                    it.dispose();
325
                    featureStore.getFeatureSelection().deselectAll();
326
                }
327
            }
328
        } catch (DataException e) {
329
            throw new FinishServiceException(e);
330
        }
331
    }
332

  
333
    public Geometry finish() throws FinishServiceException {
334
        return null;
335
    }
336

  
337
    public void start() throws StartServiceException {
338
        this.values = new HashMap<EditingServiceParameter, Object>();
339
        FeatureSelection selected = null;
340
        if (featureStore != null) {
341
            try {
342
                selected =
343
                    (FeatureSelection) featureStore.getFeatureSelection()
344
                        .clone();
345
            } catch (DataException e) {
346
                throw new StartServiceException(e);
347
            } catch (CloneNotSupportedException e) {
348
                // Do nothing
349
            }
350
            if ((selected != null) && (selected.getSelectedCount() > 0)) {
351
                values.put(selectionParameter, selected);
352
            }
353
        }
354
    }
355

  
356
    public String getName() {
357
        return SymmetryEditingProviderFactory.PROVIDER_NAME;
358
    }
359

  
360
}
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/org.gvsig.vectorediting.symmetry.lib.prov.symmetry/src/main/java/org/gvsig/vectorediting/symmetry/lib/prov/symmetry/SymmetryEditingProviderFactory.java
1
/**
2
 * gvSIG. Desktop Geographic Information System.
3
 *
4
 * Copyright ? 2007-2014 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 2
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

  
25
package org.gvsig.vectorediting.symmetry.lib.prov.symmetry;
26

  
27
import org.gvsig.fmap.geom.Geometry;
28
import org.gvsig.tools.ToolsLocator;
29
import org.gvsig.tools.dynobject.DynClass;
30
import org.gvsig.tools.dynobject.DynObject;
31
import org.gvsig.tools.service.spi.AbstractProviderFactory;
32
import org.gvsig.tools.service.spi.Provider;
33
import org.gvsig.tools.service.spi.ProviderServices;
34
import org.gvsig.vectorediting.lib.api.EditingServiceInfo;
35
import org.gvsig.vectorediting.lib.spi.DefaultEditingServiceinfo;
36
import org.gvsig.vectorediting.lib.spi.EditingProviderFactory;
37

  
38
public class SymmetryEditingProviderFactory extends AbstractProviderFactory
39
implements EditingProviderFactory {
40

  
41
    public static final String PROVIDER_NAME = "modify-symmetry";
42

  
43
    private final static String PROVIDER_DESCRIPTION =
44
        "Creates symmetric geometries from selection";
45

  
46
    public void initialize() {
47

  
48
    }
49

  
50
    public EditingServiceInfo getServiceInfo() {
51
        EditingServiceInfo serviceInfo =
52
            new DefaultEditingServiceinfo(PROVIDER_NAME, "", false, null,
53
                new int[] { Geometry.TYPES.POINT, Geometry.TYPES.MULTIPOINT,
54
                Geometry.TYPES.SURFACE, Geometry.TYPES.MULTISURFACE,
55
                Geometry.TYPES.CURVE, Geometry.TYPES.MULTICURVE });
56

  
57
        return serviceInfo;
58
    }
59

  
60
    @Override
61
    protected Provider doCreate(DynObject parameters, ProviderServices services) {
62
        return new SymmetryEditingProvider(services, parameters);
63
    }
64

  
65
    @Override
66
    public DynObject createParameters() {
67
        DynObject dynobject = super.createParameters();
68
        dynobject.setDynValue(PROVIDER_NAME_FIELD, PROVIDER_NAME);
69
        return dynobject;
70
    }
71

  
72
    @Override
73
    protected DynClass createParametersDynClass() {
74
        DynClass dynclass =
75
            ToolsLocator.getDynObjectManager().createDynClass(PROVIDER_NAME,
76
                PROVIDER_DESCRIPTION);
77

  
78
        dynclass.addDynFieldString(PROVIDER_NAME_FIELD);
79
        dynclass.addDynFieldObject(FEATURE_STORE_FIELD);
80

  
81
        return dynclass;
82
    }
83

  
84
}
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/org.gvsig.vectorediting.symmetry.lib/org.gvsig.vectorediting.symmetry.lib.prov/org.gvsig.vectorediting.symmetry.lib.prov.symmetry/pom.xml
1
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
2
	<modelVersion>4.0.0</modelVersion>
3
	<parent>
4
		<groupId>org.gvsig</groupId>
5
		<artifactId>org.gvsig.vectorediting.symmetry.lib.prov</artifactId>
6
		<version>1.0.0</version>
7
	</parent>
8
	<artifactId>org.gvsig.vectorediting.symmetry.lib.prov.symmetry</artifactId>
9
	<name>org.gvsig.vectorediting.symmetry.lib.prov.symmetry</name>
10

  
11
	<dependencies>
12
		<dependency>
13
			<groupId>org.gvsig</groupId>
14
			<artifactId>org.gvsig.vectorediting.lib.api</artifactId>
15
		</dependency>
16
		<dependency>
17
			<groupId>org.gvsig</groupId>
18
			<artifactId>org.gvsig.vectorediting.lib.impl</artifactId>
19
		</dependency>
20
		<dependency>
21
			<groupId>org.gvsig</groupId>
22
			<artifactId>org.gvsig.vectorediting.lib.spi</artifactId>
23
		</dependency>
24
	</dependencies>
25
</project>
org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0/pom.xml
1
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
2
	<modelVersion>4.0.0</modelVersion>
3
	<parent>
4
		<groupId>org.gvsig</groupId>
5
		<artifactId>org.gvsig.desktop</artifactId>
6
		<version>2.0.72</version>
7
	</parent>
8
	<groupId>org.gvsig</groupId>
9
	<artifactId>org.gvsig.vectorediting.symmetry</artifactId>
10
	<version>1.0.0</version>
11
	<packaging>pom</packaging>
12
	<name>org.gvsig.vectorediting.symmetry</name>
13
	<description>Project that provides the symmetry vector editing tool</description>
14

  
15
	<repositories>
16
		<repository>
17
			<id>gvsig-public-http-repository</id>
18
			<name>gvSIG maven public HTTP repository</name>
19
			<url>http://devel.gvsig.org/m2repo/j2se</url>
20
			<releases>
21
				<enabled>true</enabled>
22
				<updatePolicy>daily</updatePolicy>
23
				<checksumPolicy>warn</checksumPolicy>
24
			</releases>
25
			<snapshots>
26
				<enabled>true</enabled>
27
				<updatePolicy>daily</updatePolicy>
28
				<checksumPolicy>warn</checksumPolicy>
29
			</snapshots>
30
		</repository>
31
	</repositories>
32

  
33
	<url>dav:https://devel.gvsig.org/sites/${project.artifactId}/${project.version}</url>
34
	<scm>
35
		<connection>scm:svn:https://devel.gvsig.org/svn/gvsig-vectorediting/org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0</connection>
36
		<developerConnection>scm:svn:https://devel.gvsig.org/svn/gvsig-vectorediting/org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0</developerConnection>
37
		<url>https://devel.gvsig.org/redmine/projects/gvsig-vector-editing/repository/show/org.gvsig.vectorediting.symmetry/tags/org.gvsig.vectorediting.symmetry-1.0.0</url>
38
	</scm>
39

  
40
	<distributionManagement>
41
		<site>
42
			<id>gvsig-repository</id>
43
			<url>dav:https://devel.gvsig.org/download/projects/gvsig-vectorediting/pool/${project.artifactId}/${project.version}</url>
44
		</site>
45
	</distributionManagement>
46

  
47
	<build>
48
		<plugins>
49
			<plugin>
50
				<groupId>org.apache.maven.plugins</groupId>
51
				<artifactId>maven-release-plugin</artifactId>
52
				<configuration>
53
					<tagBase>https://devel.gvsig.org/svn/gvsig-vectorediting/${project.artifactId}/tags</tagBase>
54
				</configuration>
55
			</plugin>
56
		</plugins>
57
	</build>
58

  
59

  
60
	<dependencyManagement>
61
		<dependencies>
62
			<dependency>
63
				<groupId>org.gvsig</groupId>
64
				<artifactId>
65
                org.gvsig.vectorediting.app.mainplugin
66
            </artifactId>
67
				<version>1.0.0</version>
68
			</dependency>
69
			<dependency>
70
				<groupId>org.gvsig</groupId>
71
				<artifactId>org.gvsig.vectorediting.lib.api</artifactId>
72
				<version>1.0.0</version>
73
			</dependency>
74
			<dependency>
75
				<groupId>org.gvsig</groupId>
76
				<artifactId>org.gvsig.vectorediting.lib.impl</artifactId>
77
				<version>1.0.0</version>
78
				<scope>runtime</scope>
79
			</dependency>
80
			<dependency>
81
				<groupId>org.gvsig</groupId>
82
				<artifactId>org.gvsig.vectorediting.lib.spi</artifactId>
83
				<version>1.0.0</version>
84
			</dependency>
85
			<dependency>
86
				<groupId>org.gvsig</groupId>
87
				<artifactId>org.gvsig.vectorediting.symmetry.lib.prov.symmetry</artifactId>
88
				<version>1.0.0</version>
89
			</dependency>
90
		</dependencies>
91
	</dependencyManagement>
92

  
93
	<modules>
94
		<module>org.gvsig.vectorediting.symmetry.lib</module>
95
		<module>org.gvsig.vectorediting.symmetry.app</module>
96
	</modules>
97
</project>
98

  

Also available in: Unified diff