Statistics
| Revision:

root / branches / v2_0_0_prep / libraries / libFMap_controls / src / org / gvsig / fmap / mapcontrol / dal / feature / swing / table / GeometryCellRenderer.java @ 40391

History | View | Annotate | Download (2.28 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
 * 2008 {DiSiD Technologies}  {Create a JTable TableModel for a FeatureCollection}
26
 */
27
package org.gvsig.fmap.mapcontrol.dal.feature.swing.table;
28

    
29
import javax.swing.table.DefaultTableCellRenderer;
30

    
31
import org.gvsig.fmap.geom.Geometry;
32
import org.gvsig.fmap.geom.operation.GeometryOperationException;
33
import org.gvsig.fmap.geom.operation.GeometryOperationNotSupportedException;
34

    
35
/**
36
 * Simple renderer for cells of type {@link Geometry} .
37
 * 
38
 * @author <a href="mailto:cordin@disid.com">C�sar Ordi�ana</a>
39
 */
40
public class GeometryCellRenderer extends DefaultTableCellRenderer {
41

    
42
    private static final long serialVersionUID = -2470239399517077869L;
43

    
44
    protected void setValue(Object value) {
45
        if (value == null) {
46
            setText("");
47
        } else {
48
            Geometry geometry = (Geometry) value;
49
            try {
50
                String geomTxt = geometry.convertToWKT();
51
                setText(geomTxt);
52
            } catch (GeometryOperationNotSupportedException e) {
53
                throw new RuntimeException(
54
                    "Error getting as WKT the geometry: " + geometry, e);
55
            } catch (GeometryOperationException e) {
56
                throw new RuntimeException(
57
                    "Error getting as WKT the geometry: " + geometry, e);
58
            }
59
            setToolTipText(geometry.getGeometryType().getName());
60
        }
61
    }
62
}