Statistics
| Revision:

svn-gvsig-desktop / branches / v2_0_0_prep / libraries / libFMap_mapcontext / src / org / gvsig / fmap / mapcontext / layers / vectorial / ReprojectDefaultGeometry.java @ 28076

History | View | Annotate | Download (5.36 KB)

1
/* gvSIG. Geographic Information System of the Valencian Government
2
*
3
* Copyright (C) 2007-2008 Infrastructures and Transports Department
4
* of the Valencian Government (CIT)
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
*/
22

    
23
/*
24
* AUTHORS (In addition to CIT):
25
* 2009 IVER T.I   {{Task}}
26
*/
27

    
28
/**
29
 *
30
 */
31
package org.gvsig.fmap.mapcontext.layers.vectorial;
32

    
33
import java.util.ArrayList;
34
import java.util.Iterator;
35
import java.util.List;
36

    
37
import org.cresques.cts.ICoordTrans;
38
import org.cresques.cts.IProjection;
39
import org.gvsig.fmap.dal.exception.DataException;
40
import org.gvsig.fmap.dal.feature.AbstractFeatureStoreTransform;
41
import org.gvsig.fmap.dal.feature.EditableFeature;
42
import org.gvsig.fmap.dal.feature.EditableFeatureAttributeDescriptor;
43
import org.gvsig.fmap.dal.feature.EditableFeatureType;
44
import org.gvsig.fmap.dal.feature.Feature;
45
import org.gvsig.fmap.dal.feature.FeatureAttributeDescriptor;
46
import org.gvsig.fmap.dal.feature.FeatureStore;
47
import org.gvsig.fmap.dal.feature.FeatureType;
48
import org.gvsig.fmap.geom.Geometry;
49
import org.gvsig.tools.persistence.PersistenceException;
50
import org.gvsig.tools.persistence.PersistentState;
51

    
52
/**
53
 * @author jmvivo
54
 *
55
 */
56
public class ReprojectDefaultGeometry extends AbstractFeatureStoreTransform {
57

    
58
        private IProjection targetSRS;
59
        private ICoordTrans ct;
60
        private IProjection sourceSRS;
61
        private FeatureType orgDefFeatureType;
62
        private List orgFeatureTypes;
63

    
64
        public IProjection getTargetSRS() {
65
                return targetSRS;
66
        }
67

    
68
        public void setTargetSRS(IProjection targetSRS) {
69
                this.targetSRS = targetSRS;
70
        }
71

    
72
        /* (non-Javadoc)
73
         * @see org.gvsig.fmap.dal.feature.FeatureStoreTransform#applyTransform(org.gvsig.fmap.dal.feature.Feature, org.gvsig.fmap.dal.feature.EditableFeature)
74
         */
75
        public void applyTransform(Feature source, EditableFeature target)
76
                        throws DataException {
77
                FeatureAttributeDescriptor attr;
78
                Iterator iter = target.getType().iterator();
79
                int defGeomIndex = target.getType().getDefaultGeometryAttributeIndex();
80
                while (iter.hasNext()) {
81
                        attr = (FeatureAttributeDescriptor)iter.next();
82
                        if (attr.getIndex() == defGeomIndex) {
83
                                Geometry geom =source.getDefaultGeometry();
84
                                geom.reProject(ct);
85
                                target.setDefaultGeometry(geom);
86
                        } else {
87
                                target.set(attr.getIndex(), source.get(attr.getName()));
88
                        }
89

    
90
                }
91

    
92
        }
93

    
94
        public void setFeatureStore(FeatureStore store) {
95
                try {
96
                        orgDefFeatureType = store.getDefaultFeatureType();
97
                        orgFeatureTypes = store.getFeatureTypes();
98
                        EditableFeatureType defFType = orgDefFeatureType
99
                                        .getEditable();
100
                        EditableFeatureAttributeDescriptor attr = (EditableFeatureAttributeDescriptor) defFType
101
                                        .getAttributeDescriptor(defFType
102
                                                        .getDefaultGeometryAttributeName());
103
                        sourceSRS = attr.getSRS();
104
                        ct = sourceSRS.getCT(targetSRS);
105
                        attr.setSRS(this.targetSRS);
106
                        FeatureType defaultType = defFType.getNotEditableCopy();
107
                        List types = new ArrayList();
108
                        Iterator iter = orgFeatureTypes.iterator();
109
                        FeatureType tmp;
110
                        while (iter.hasNext()) {
111
                                tmp = (FeatureType) iter.next();
112
                                if (tmp.getId().equals(defaultType.getId())) {
113
                                        types.add(defaultType);
114
                                } else {
115
                                        types.add(tmp);
116
                                }
117
                        }
118

    
119
                        this.setFeatureTypes(types, defaultType);
120
                } catch (DataException e) {
121
                        // FIXME
122
                        throw new RuntimeException(e);
123
                }
124

    
125
                super.setFeatureStore(store);
126
        }
127

    
128
        /* (non-Javadoc)
129
         * @see org.gvsig.fmap.dal.feature.FeatureStoreTransform#getSourceFeatureTypeFrom(org.gvsig.fmap.dal.feature.FeatureType)
130
         */
131
        public FeatureType getSourceFeatureTypeFrom(FeatureType targetFeatureType) {
132
                EditableFeatureType result = null;
133
                FeatureType tmp;
134
                EditableFeatureAttributeDescriptor attr;
135
                Iterator iter = orgFeatureTypes.iterator();
136
                Iterator iterAttr;
137
                while (iter.hasNext()) {
138
                        tmp = (FeatureType) iter.next();
139
                        if (tmp.getId().equals(targetFeatureType.getId())) {
140
                                result = tmp.getEditable();
141
                                iterAttr = result.iterator();
142
                                while (iterAttr.hasNext()) {
143
                                        attr = (EditableFeatureAttributeDescriptor) iterAttr.next();
144
                                        if (targetFeatureType.getIndex(attr.getName()) < 0) {
145
                                                iterAttr.remove();
146
                                        }
147
                                }
148
                                break;
149
                        }
150
                }
151
                return result.getNotEditableCopy();
152
        }
153

    
154
        /* (non-Javadoc)
155
         * @see org.gvsig.fmap.dal.feature.FeatureStoreTransform#isTransformsOriginalValues()
156
         */
157
        public boolean isTransformsOriginalValues() {
158
                return true;
159
        }
160

    
161
        /* (non-Javadoc)
162
         * @see org.gvsig.tools.persistence.Persistent#loadState(org.gvsig.tools.persistence.PersistentState)
163
         */
164
        public void saveToState(PersistentState state) throws PersistenceException {
165
                // TODO Auto-generated method stub
166

    
167
        }
168

    
169
        /* (non-Javadoc)
170
         * @see org.gvsig.tools.persistence.Persistent#setState(org.gvsig.tools.persistence.PersistentState)
171
         */
172
        public void setState(PersistentState state) throws PersistenceException {
173
                // TODO Auto-generated method stub
174

    
175
        }
176

    
177
}