Documentation for OpenFLUID 2.2.0
GDALHelpers.hpp
Go to the documentation of this file.
1 /*
2 
3  This file is part of OpenFLUID software
4  Copyright(c) 2007, INRA - Montpellier SupAgro
5 
6 
7  == GNU General Public License Usage ==
8 
9  OpenFLUID is free software: you can redistribute it and/or modify
10  it under the terms of the GNU General Public License as published by
11  the Free Software Foundation, either version 3 of the License, or
12  (at your option) any later version.
13 
14  OpenFLUID is distributed in the hope that it will be useful,
15  but WITHOUT ANY WARRANTY; without even the implied warranty of
16  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17  GNU General Public License for more details.
18 
19  You should have received a copy of the GNU General Public License
20  along with OpenFLUID. If not, see <http://www.gnu.org/licenses/>.
21 
22 
23  == Other Usage ==
24 
25  Other Usage means a use of OpenFLUID that is inconsistent with the GPL
26  license, and requires a written agreement between You and INRA.
27  Licensees for Other Usage of OpenFLUID may use this file in accordance
28  with the terms contained in the written agreement between You and INRA.
29 
30 */
31 
32 /**
33  @file GDALHelpers.hpp
34 
35  @author Jean-Christophe FABRE <jean-christophe.fabre@inra.fr>
36  */
37 
38 
39 #ifndef __OPENFLUID_UTILS_GDALHELPERS_HPP__
40 #define __OPENFLUID_UTILS_GDALHELPERS_HPP__
41 
42 
43 #include <vector>
44 #include <map>
45 #include <set>
46 
47 #include <ogr_api.h>
48 
49 #include <openfluid/dllexport.hpp>
51 
52 
53 namespace openfluid { namespace utils {
54 
55 /**
56  Structure associating a driver label with a list of corresponding files extensions
57 */
59  /** Label of the driver */
60  std::string Label;
61 
62  /** Vector of files extensions */
63  std::vector<std::string> FilesExts;
64 };
65 
66 
67 /**
68  Map of drivercode => openfluid::utils::GDALDriverInfos_t
69 */
70 typedef std::map<std::string,GDALDriverInfos_t> GDALDriversFilesExts_t;
71 
72 
73 // =====================================================================
74 // =====================================================================
75 
76 
77 /**
78  Returns a list of OGR drivers available in OpenFLUID for GIS vector files
79  @return an openfluid::utils::GDALDriversFilesExts_t
80 */
82 
83 
84 /**
85  Returns a list of GDAL drivers available in OpenFLUID for GIS vector files
86  @return an openfluid::utils::GDALDriversFilesExts_t
87 */
89 
90 
91 /**
92  Returns a set of GIS vector files extensions available in OpenFLUID
93  @return a set of files extensions
94 */
95 const std::set<std::string> OPENFLUID_API getOGRFilesExtensionsForOpenFLUID();
96 
97 
98 /**
99  Returns the available GDAL/OGR formats as a QFileDialog formats string.
100  The string is built according to GDAL/OGR available drivers.
101  The OGRRegisterAll() and/or GDALAllRegister() instruction must be called before using this function.
102  @param[in] Drivers The available extensions list
103  @param[in] AllFormatsLabel the label displayed for all formats
104  @return the format string
105  (e.g. "All vector files (*.shp *.mif *.tab);;ESRI Shapefiles (*.shp);;Mapinfo (*.mif *.tab)")
106 */
108  const std::string& AllFormatsLabel);
109 
110 
111 /**
112  Returns true if the given field type is an OGR integer or an OGR 64bits integer,
113  taking into account the compatibility with both GDAL 1.xx and 2.xx
114  @param[in] FieldType the OGR field type
115  @return true if the field type is integer
116 */
117 inline bool OPENFLUID_API isOGRInteger(OGRFieldType FieldType)
118 {
119  return (FieldType == OFTInteger) || (FieldType == GDALOFTInteger64_COMPAT);
120 }
121 
122 
123 /**
124  Returns true if the given geometry type is a punctual type (e.g. wkbPoint),
125  @param[in] Type the OGR geometry type
126  @return true if the geometry type is punctual
127 */
128 inline bool OPENFLUID_API isOGRPunctualType(OGRwkbGeometryType Type)
129 {
130  OGRwkbGeometryType FlatType = wkbFlatten(Type);
131 
132  return (FlatType == wkbPoint || FlatType == wkbMultiPoint);
133 }
134 
135 
136 /**
137  Returns true if the given geometry type is a linear type (e.g. wkbLineString,
138  @param[in] Type the OGR geometry type
139  @return true if the geometry type is linear
140 */
141 inline bool OPENFLUID_API isOGRLinearType(OGRwkbGeometryType Type)
142 {
143  OGRwkbGeometryType FlatType = wkbFlatten(Type);
144 
145  return (OGR_GT_IsSubClassOf(FlatType,wkbCurve) || OGR_GT_IsSubClassOf(FlatType,wkbMultiCurve));
146 }
147 
148 
149 /**
150  Returns true if the given geometry type is a surfacic type (e.g. wkbPolygon),
151  @param[in] Type the OGR geometry type
152  @return true if the geometry type is surfacic
153 */
154 inline bool OPENFLUID_API isOGRSurfacicType(OGRwkbGeometryType Type)
155 {
156  OGRwkbGeometryType FlatType = wkbFlatten(Type);
157 
158  return (OGR_GT_IsSubClassOf(FlatType,wkbSurface) || OGR_GT_IsSubClassOf(FlatType,wkbMultiSurface));
159 }
160 
161 
162 } } // namespaces
163 
164 
165 #endif /* __OPENFLUID_UTILS_GDALHELPERS_HPP__ */
#define GDALOFTInteger64_COMPAT
Definition: GDALCompatibility.hpp:158
#define OPENFLUID_API
Definition: dllexport.hpp:86
std::map< std::string, GDALDriverInfos_t > GDALDriversFilesExts_t
Definition: GDALHelpers.hpp:70
bool OPENFLUID_API isOGRLinearType(OGRwkbGeometryType Type)
Definition: GDALHelpers.hpp:141
const std::set< std::string > OPENFLUID_API getOGRFilesExtensionsForOpenFLUID()
bool OPENFLUID_API isOGRPunctualType(OGRwkbGeometryType Type)
Definition: GDALHelpers.hpp:128
const GDALDriversFilesExts_t OPENFLUID_API getGDALFilesDriversForOpenFLUID()
const GDALDriversFilesExts_t OPENFLUID_API getOGRFilesDriversForOpenFLUID()
bool OPENFLUID_API isOGRSurfacicType(OGRwkbGeometryType Type)
Definition: GDALHelpers.hpp:154
bool OPENFLUID_API isOGRInteger(OGRFieldType FieldType)
Definition: GDALHelpers.hpp:117
std::string OPENFLUID_API getOGRGDALFormatsForQFileDialogs(const GDALDriversFilesExts_t &Drivers, const std::string &AllFormatsLabel)
Definition: ApplicationException.hpp:47
Definition: GDALHelpers.hpp:58
std::string Label
Definition: GDALHelpers.hpp:60
std::vector< std::string > FilesExts
Definition: GDALHelpers.hpp:63