31 #ifndef GDAL_MDREADER_H_INCLUDED
32 #define GDAL_MDREADER_H_INCLUDED
38 #define MD_DOMAIN_IMD "IMD"
39 #define MD_DOMAIN_RPC "RPC"
40 #define MD_DOMAIN_IMAGERY "IMAGERY"
41 #define MD_DOMAIN_DEFAULT ""
43 #define MD_NAME_ACQDATETIME "ACQUISITIONDATETIME"
44 #define MD_NAME_SATELLITE "SATELLITEID"
45 #define MD_NAME_CLOUDCOVER "CLOUDCOVER"
46 #define MD_NAME_MDTYPE "METADATATYPE"
48 #define MD_DATETIMEFORMAT "%Y-%m-%d %H:%M:%S"
49 #define MD_CLOUDCOVER_NA "999"
55 #define RPC_LINE_OFF "LINE_OFF"
56 #define RPC_SAMP_OFF "SAMP_OFF"
57 #define RPC_LAT_OFF "LAT_OFF"
58 #define RPC_LONG_OFF "LONG_OFF"
59 #define RPC_HEIGHT_OFF "HEIGHT_OFF"
60 #define RPC_LINE_SCALE "LINE_SCALE"
61 #define RPC_SAMP_SCALE "SAMP_SCALE"
62 #define RPC_LAT_SCALE "LAT_SCALE"
63 #define RPC_LONG_SCALE "LONG_SCALE"
64 #define RPC_HEIGHT_SCALE "HEIGHT_SCALE"
65 #define RPC_LINE_NUM_COEFF "LINE_NUM_COEFF"
66 #define RPC_LINE_DEN_COEFF "LINE_DEN_COEFF"
67 #define RPC_SAMP_NUM_COEFF "SAMP_NUM_COEFF"
68 #define RPC_SAMP_DEN_COEFF "SAMP_DEN_COEFF"
75 MDR_None = 0x00000000,
79 MDR_PLEIADES = 0x00000008,
80 MDR_SPOT = 0x00000010,
81 MDR_RDK1 = 0x00000020,
84 MDR_KOMPSAT = 0x00000100,
85 MDR_EROS = 0x00000200,
86 MDR_ALOS = 0x00000400,
87 MDR_ANY = MDR_DG | MDR_GE | MDR_OV | MDR_PLEIADES | MDR_SPOT | MDR_RDK1 |
88 MDR_LS | MDR_RE | MDR_KOMPSAT | MDR_EROS | MDR_ALOS
146 const char* pszName =
"");
157 const char *pszValue);
161 char **m_papszIMAGERYMD;
162 char **m_papszDEFAULTMD;
163 bool m_bIsMetadataLoad;
187 char **papszSiblingFiles,
188 GUInt32 nType = MDR_ANY);
196 char** GDALLoadRPBFile(
const CPLString& osFilePath );
197 char** GDALLoadRPCFile(
const CPLString& osFilePath );
198 char** GDALLoadIMDFile(
const CPLString& osFilePath );
199 bool GDALCheckFileHeader(
const CPLString& soFilePath,
200 const char * pszTestString,
201 int nBufferSize = 256);
203 CPLErr GDALWriteRPBFile(
const char *pszFilename,
char **papszMD );
204 CPLErr GDALWriteRPCTXTFile(
const char *pszFilename,
char **papszMD );
205 CPLErr GDALWriteIMDFile(
const char *pszFilename,
char **papszMD );
207 #endif //GDAL_MDREADER_H_INCLUDED
Document node structure.
Definition: cpl_minixml.h:65
Core portability definitions for CPL.
The base class for all metadata readers.
Definition: gdal_mdreader.h:95
Convenient string class based on std::string.
Definition: cpl_string.h:283
virtual char ** AddXMLNameValueToList(char **papszList, const char *pszName, const char *pszValue)
AddXMLNameValueToList Execute from ReadXMLToList to add name and value to list.
Definition: gdal_mdreader.cpp:288
virtual void LoadMetadata()
Load metadata to the correspondent IMD, RPB, IMAGERY and DEFAULT domains.
Definition: gdal_mdreader.cpp:219
GDALMDReaderBase(const char *pszPath, char **papszSiblingFiles)
GDALMDReaderBase()
Definition: gdal_mdreader.cpp:179
virtual ~GDALMDReaderBase()
~GDALMDReaderBase()
Definition: gdal_mdreader.cpp:191
virtual char ** ReadXMLToList(CPLXMLNode *psNode, char **papszList, const char *pszName="")
ReadXMLToList Transform xml to list of NULL terminated name=value strings.
Definition: gdal_mdreader.cpp:298
virtual time_t GetAcquisitionTimeFromString(const char *pszDateTime)
Convert string like 2012-02-25T00:25:59.9440000Z to time.
Definition: gdal_mdreader.cpp:229
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.
Definition: gdal_priv.h:83
The metadata reader main class.
Definition: gdal_mdreader.h:171
virtual char ** GetMetadataDomain(const char *pszDomain)
Get specified metadata domain.
Definition: gdal_mdreader.cpp:202
virtual bool FillMetadata(GDALMultiDomainMetadata *poMDMD)
Fill provided metadata store class.
Definition: gdal_mdreader.cpp:270