Statistics
| Revision:

root / branches / Mobile_Compatible_Hito_1 / libFMap / src / es / prodevelop / gvsig / mobile / fmap / proj / Projection.java @ 21606

History | View | Annotate | Download (3.17 KB)

1
/* gvSIG. Sistema de Informaci?n Geogr?fica de la Generalitat Valenciana
2
 *
3
 * Copyright (C) 2006 Prodevelop and Generalitat Valenciana.
4
 *
5
 * This program is free software; you can redistribute it and/or
6
 * modify it under the terms of the GNU General Public License
7
 * as published by the Free Software Foundation; either version 2
8
 * of the License, or (at your option) any later version.
9
 *
10
 * This program is distributed in the hope that it will be useful,
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13
 * GNU General Public License for more details.
14
 *
15
 * You should have received a copy of the GNU General Public License
16
 * along with this program; if not, write to the Free Software
17
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307,USA.
18
 *
19
 * For more information, contact:
20
 *
21
 *   Generalitat Valenciana
22
 *   Conselleria d'Infraestructures i Transport
23
 *   Av. Blasco Ib??ez, 50
24
 *   46010 VALENCIA
25
 *   SPAIN
26
 *
27
 *   +34 963862235
28
 *   gvsig@gva.es
29
 *   http://www.gvsig.gva.es
30
 *
31
 *    or
32
 *
33
 *   Prodevelop Integraci?n de Tecnolog?as SL
34
 *   Conde Salvatierra de ?lava , 34-10
35
 *   46004 Valencia
36
 *   Spain
37
 *
38
 *   +34 963 510 612
39
 *   +34 963 510 968
40
 *   gis@prodevelop.es
41
 *   http://www.prodevelop.es
42
 *
43
 *    or
44
 *
45
 *   Instituto de Rob?tica
46
 *   Apartado de correos 2085
47
 *   46071 Valencia
48
 *   (Spain)
49
 *   
50
 *   +34 963 543 577
51
 *   jjordan@robotica.uv.es
52
 *   http://robotica.uv.es
53
 *   
54
 */
55

    
56
package es.prodevelop.gvsig.mobile.fmap.proj;
57

    
58
import es.prodevelop.geodetic.utils.conversion.GeoUtils;
59

    
60
/**
61
 * Basic projection class.
62
 * 
63
 * @see es.prodevelop.geodetic.utils.conversion.GeoUtils
64
 * 
65
 * @author jldominguez
66
 *
67
 */
68
public class Projection implements IProjection {
69

    
70
        private String abbreviation = null;
71
        private String unit = "?";
72
        private double metersPerUnit = 1;
73
        
74
        /**
75
         * Constructor
76
         * @param ab abbreviation
77
         */
78
        public Projection(String ab, String u, double meters_per_unit) {
79
                abbreviation = ab;
80
                unit = u;
81
                metersPerUnit = meters_per_unit;
82
                
83
        }
84

    
85
        /**
86
         * @see es.prodevelop.gvsig.mobile.fmap.proj.IProjection#getScale(double, double, double, double)
87
         */
88
        public double getScale(double minX, double maxX, double img_width, double dpi) {
89
                
90
                double inches = img_width / dpi;
91
                double meters = inches * 0.0254; 
92
                return GeoUtils.getScale(this, maxX-minX, meters);
93
        }
94

    
95
        /**
96
         * @see es.prodevelop.gvsig.mobile.fmap.proj.IProjection#getAbrev()
97
         */
98
        public String getAbrev() {
99
                return abbreviation;
100
        }
101

    
102
        /**
103
         * @see es.prodevelop.gvsig.mobile.fmap.proj.IProjection#getUnitsAbbrev()
104
         */
105
        public String getUnitsAbbrev() {
106

    
107
                return unit;
108
//                if (abbreviation.length() == 9) return "?";
109
//                if (abbreviation.indexOf("EPSG:230") != -1) return "m";
110
//                if (abbreviation.indexOf("EPSG:326") != -1) return "m";
111
//                if (abbreviation.indexOf("EPSG:327") != -1) return "m";
112
//                return "u";
113
        }
114

    
115
        /**
116
         * @see es.prodevelop.gvsig.mobile.fmap.proj.IProjection#getMetersPerProjUnit()
117
         */
118
        public double getMetersPerProjUnit() {
119
                return metersPerUnit;
120
                
121
//                if (abbreviation.compareToIgnoreCase(GeoUtils.CRS_CODE_WGS_84) == 0) {
122
//                        return 10000000.0 / 90.0;
123
//                } else {
124
//                        return 1.0;
125
//                }
126
        }
127

    
128
}