31 #ifndef GDAL_MDREADER_H_INCLUDED
32 #define GDAL_MDREADER_H_INCLUDED
37 #define MD_DOMAIN_IMD "IMD"
38 #define MD_DOMAIN_RPC "RPC"
39 #define MD_DOMAIN_IMAGERY "IMAGERY"
40 #define MD_DOMAIN_DEFAULT ""
42 #define MD_NAME_ACQDATETIME "ACQUISITIONDATETIME"
43 #define MD_NAME_SATELLITE "SATELLITEID"
44 #define MD_NAME_CLOUDCOVER "CLOUDCOVER"
45 #define MD_NAME_MDTYPE "METADATATYPE"
47 #define MD_DATETIMEFORMAT "%Y-%m-%d %H:%M:%S"
48 #define MD_CLOUDCOVER_NA "999"
54 #define RPC_ERR_BIAS "ERR_BIAS"
55 #define RPC_ERR_RAND "ERR_RAND"
56 #define RPC_LINE_OFF "LINE_OFF"
57 #define RPC_SAMP_OFF "SAMP_OFF"
58 #define RPC_LAT_OFF "LAT_OFF"
59 #define RPC_LONG_OFF "LONG_OFF"
60 #define RPC_HEIGHT_OFF "HEIGHT_OFF"
61 #define RPC_LINE_SCALE "LINE_SCALE"
62 #define RPC_SAMP_SCALE "SAMP_SCALE"
63 #define RPC_LAT_SCALE "LAT_SCALE"
64 #define RPC_LONG_SCALE "LONG_SCALE"
65 #define RPC_HEIGHT_SCALE "HEIGHT_SCALE"
66 #define RPC_LINE_NUM_COEFF "LINE_NUM_COEFF"
67 #define RPC_LINE_DEN_COEFF "LINE_DEN_COEFF"
68 #define RPC_SAMP_NUM_COEFF "SAMP_NUM_COEFF"
69 #define RPC_SAMP_DEN_COEFF "SAMP_DEN_COEFF"
72 #define RPC_MIN_LONG "MIN_LONG"
73 #define RPC_MIN_LAT "MIN_LAT"
74 #define RPC_MAX_LONG "MAX_LONG"
75 #define RPC_MAX_LAT "MAX_LAT"
78 #define RPC_LAT_NUM_COEFF "LAT_NUM_COEFF"
79 #define RPC_LAT_DEN_COEFF "LAT_DEN_COEFF"
80 #define RPC_LON_NUM_COEFF "LON_NUM_COEFF"
81 #define RPC_LON_DEN_COEFF "LON_DEN_COEFF"
88 MDR_None = 0x00000000,
92 MDR_PLEIADES = 0x00000008,
93 MDR_SPOT = 0x00000010,
94 MDR_RDK1 = 0x00000020,
97 MDR_KOMPSAT = 0x00000100,
98 MDR_EROS = 0x00000200,
99 MDR_ALOS = 0x00000400,
100 MDR_ANY = MDR_DG | MDR_GE | MDR_OV | MDR_PLEIADES | MDR_SPOT | MDR_RDK1 |
101 MDR_LS | MDR_RE | MDR_KOMPSAT | MDR_EROS | MDR_ALOS
120 virtual char ** GetMetadataDomain(
const char *pszDomain);
126 virtual bool FillMetadata(GDALMultiDomainMetadata* poMDMD);
144 virtual void LoadMetadata();
150 virtual GIntBig GetAcquisitionTimeFromString(
const char* pszDateTime);
160 virtual char** ReadXMLToList(
CPLXMLNode* psNode,
char** papszList,
161 const char* pszName =
"");
171 virtual char** AddXMLNameValueToList(
char** papszList,
const char *pszName,
172 const char *pszValue);
175 char **m_papszIMDMD =
nullptr;
176 char **m_papszRPCMD =
nullptr;
177 char **m_papszIMAGERYMD =
nullptr;
178 char **m_papszDEFAULTMD =
nullptr;
179 bool m_bIsMetadataLoad =
false;
207 char **papszSiblingFiles,
218 char** GDALLoadRPBFile(
const CPLString& osFilePath );
219 char** GDALLoadRPCFile(
const CPLString& osFilePath );
220 char** GDALLoadIMDFile(
const CPLString& osFilePath );
221 bool GDALCheckFileHeader(
const CPLString& soFilePath,
222 const char * pszTestString,
223 int nBufferSize = 256);
225 CPLErr GDALWriteRPBFile(
const char *pszFilename,
char **papszMD );
226 CPLErr GDALWriteRPCTXTFile(
const char *pszFilename,
char **papszMD );
227 CPLErr GDALWriteIMDFile(
const char *pszFilename,
char **papszMD );
Convenient string class based on std::string.
Definition: cpl_string.h:320
The base class for all metadata readers.
Definition: gdal_mdreader.h:107
virtual bool HasRequiredFiles() const =0
Determine whether the input parameter correspond to the particular provider of remote sensing data co...
virtual char ** GetMetadataFiles() const =0
Get metadata file names.
The metadata reader main class.
Definition: gdal_mdreader.h:188
GDALMDReaderManager()
GDALMDReaderManager()
CPLErr
Error category.
Definition: cpl_error.h:53
Core portability definitions for CPL.
unsigned int GUInt32
Unsigned int32 type.
Definition: cpl_port.h:195
#define CPL_DISALLOW_COPY_ASSIGN(ClassName)
Helper to remove the copy and assignment constructors so that the compiler will not generate the defa...
Definition: cpl_port.h:927
long long GIntBig
Large signed integer type (generally 64-bit integer type).
Definition: cpl_port.h:230
Document node structure.
Definition: cpl_minixml.h:70