30#ifndef GDAL_PAM_H_INCLUDED
31#define GDAL_PAM_H_INCLUDED
44#define GCIF_GEOTRANSFORM 0x01
45#define GCIF_PROJECTION 0x02
46#define GCIF_METADATA 0x04
49#define GCIF_NODATA 0x001000
50#define GCIF_CATEGORYNAMES 0x002000
51#define GCIF_MINMAX 0x004000
52#define GCIF_SCALEOFFSET 0x008000
53#define GCIF_UNITTYPE 0x010000
54#define GCIF_COLORTABLE 0x020000
55#define GCIF_COLORINTERP 0x020000
56#define GCIF_BAND_METADATA 0x040000
57#define GCIF_RAT 0x080000
58#define GCIF_MASK 0x100000
59#define GCIF_BAND_DESCRIPTION 0x200000
61#define GCIF_ONLY_IF_MISSING 0x10000000
62#define GCIF_PROCESS_BANDS 0x20000000
64#define GCIF_PAM_DEFAULT (GCIF_GEOTRANSFORM | GCIF_PROJECTION | \
65 GCIF_METADATA | GCIF_GCPS | \
66 GCIF_NODATA | GCIF_CATEGORYNAMES | \
67 GCIF_MINMAX | GCIF_SCALEOFFSET | \
68 GCIF_UNITTYPE | GCIF_COLORTABLE | \
69 GCIF_COLORINTERP | GCIF_BAND_METADATA | \
70 GCIF_RAT | GCIF_MASK | \
71 GCIF_ONLY_IF_MISSING | GCIF_PROCESS_BANDS|\
72 GCIF_BAND_DESCRIPTION)
77#define GPF_TRIED_READ_FAILED 0x02
78#define GPF_DISABLED 0x04
79#define GPF_AUXMODE 0x08
80#define GPF_NOSAVE 0x10
90class GDALDatasetPamInfo
93 char *pszPamFilename =
nullptr;
95 std::vector<CPLXMLTreeCloser> m_apoOtherNodes{};
97 OGRSpatialReference* poSRS =
nullptr;
99 int bHaveGeoTransform =
false;
100 double adfGeoTransform[6]{0,0,0,0,0,0};
103 GDAL_GCP *pasGCPList =
nullptr;
104 OGRSpatialReference* poGCP_SRS =
nullptr;
106 CPLString osPhysicalFilename{};
107 CPLString osSubdatasetName{};
108 CPLString osAuxFilename{};
110 int bHasMetadata =
false;
121 friend class GDALPamRasterBand;
124 int IsPamFilenameAPotentialSiblingFile();
128 GDALPamDataset(
void);
131 GDALDatasetPamInfo *psPam =
nullptr;
133 virtual const char *_GetProjectionRef()
override;
134 virtual const char *_GetGCPProjection()
override;
135 virtual CPLErr _SetProjection(
const char * pszProjection )
override;
136 virtual CPLErr _SetGCPs(
int nGCPCount,
const GDAL_GCP *pasGCPList,
137 const char *pszGCPProjection )
override;
139 virtual CPLXMLNode *SerializeToXML(
const char *);
142 virtual CPLErr TryLoadXML(
char **papszSiblingFiles =
nullptr);
143 virtual CPLErr TrySaveXML();
145 CPLErr TryLoadAux(
char **papszSiblingFiles =
nullptr);
148 virtual const char *BuildPamFilename();
150 void PamInitialize();
153 void SetPhysicalFilename(
const char * );
154 const char *GetPhysicalFilename();
155 void SetSubdatasetName(
const char *);
156 const char *GetSubdatasetName();
160 ~GDALPamDataset()
override;
179 const char * pszDomain =
"" )
override;
181 const char * pszValue,
182 const char * pszDomain =
"" )
override;
183 char **
GetMetadata(
const char * pszDomain =
"" )
override;
185 const char * pszDomain =
"" )
override;
194 CPLErr IBuildOverviews(
const char *pszResampling,
195 int nOverviews,
int *panOverviewList,
196 int nListBands,
int *panBandList,
197 GDALProgressFunc pfnProgress,
198 void * pProgressData )
override;
201 void MarkPamDirty() { nPamFlags |= GPF_DIRTY; }
202 GDALDatasetPamInfo *GetPamInfo() {
return psPam; }
203 int GetPamFlags() {
return nPamFlags; }
204 void SetPamFlags(
int nValue ) { nPamFlags = nValue; }
224 double dfNoDataValue;
231 char **papszCategoryNames;
250} GDALRasterBandPamInfo;
259 friend class GDALPamDataset;
263 virtual CPLXMLNode *SerializeToXML(
const char *pszVRTPath );
266 void PamInitialize();
269 GDALRasterBandPamInfo *psPam =
nullptr;
275 explicit GDALPamRasterBand(
int bForceCachedIO);
277 ~GDALPamRasterBand()
override;
297 double GetOffset(
int *pbSuccess =
nullptr )
override;
299 double GetScale(
int *pbSuccess =
nullptr )
override;
303 int nBuckets,
GUIntBig * panHistogram,
304 int bIncludeOutOfRange,
int bApproxOK,
305 GDALProgressFunc,
void *pProgressData )
override;
308 int *pnBuckets,
GUIntBig ** ppanHistogram,
310 GDALProgressFunc,
void *pProgressData)
override;
313 int nBuckets,
GUIntBig *panHistogram )
override;
316 const char * pszDomain =
"" )
override;
318 const char * pszValue,
319 const char * pszDomain =
"" )
override;
329 GDALRasterBandPamInfo *GetPamInfo() {
return psPam; }
344class CPL_DLL GDALPamMultiDim
347 std::unique_ptr<Private> d;
353 explicit GDALPamMultiDim(
const std::string& osFilename);
354 virtual ~GDALPamMultiDim();
356 std::shared_ptr<OGRSpatialReference>
GetSpatialRef(
const std::string& osArrayFullName);
361 CPLErr GetStatistics(
const std::string& osArrayFullName,
363 double *pdfMin,
double *pdfMax,
364 double *pdfMean,
double *pdfStdDev,
367 void SetStatistics(
const std::string& osArrayFullName,
369 double dfMin,
double dfMax,
370 double dfMean,
double dfStdDev,
385 std::shared_ptr<GDALPamMultiDim> m_poPam;
388 GDALPamMDArray(
const std::string& osParentName,
389 const std::string& osName,
390 const std::shared_ptr<GDALPamMultiDim>& poPam);
392 bool SetStatistics(
bool bApproxStats,
393 double dfMin,
double dfMax,
394 double dfMean,
double dfStdDev,
395 GUInt64 nValidCount )
override;
398 const std::shared_ptr<GDALPamMultiDim>& GetPAM()
const {
return m_poPam; }
400 CPLErr GetStatistics(
bool bApproxOK,
bool bForce,
401 double *pdfMin,
double *pdfMax,
402 double *pdfMean,
double *padfStdDev,
404 GDALProgressFunc pfnProgress,
void *pProgressData )
override;
408 bool SetSpatialRef(
const OGRSpatialReference* poSRS)
override;
410 std::shared_ptr<OGRSpatialReference>
GetSpatialRef()
const override;
414int CPL_DLL PamParseHistogram(
CPLXMLNode *psHistItem,
415 double *pdfMin,
double *pdfMax,
416 int *pnBuckets,
GUIntBig **ppanHistogram,
417 int *pbIncludeOutOfRange,
int *pbApproxOK );
419PamFindMatchingHistogram(
CPLXMLNode *psSavedHistograms,
420 double dfMin,
double dfMax,
int nBuckets,
421 int bIncludeOutOfRange,
int bApproxOK );
423PamHistogramToXMLTree(
double dfMin,
double dfMax,
424 int nBuckets,
GUIntBig * panHistogram,
425 int bIncludeOutOfRange,
int bApprox );
428const char CPL_DLL * PamGetProxy(
const char * );
429const char CPL_DLL * PamAllocateProxy(
const char * );
430const char CPL_DLL * PamDeallocateProxy(
const char * );
431void CPL_DLL PamCleanProxyDB(
void );
A color table / palette.
Definition gdal_priv.h:1025
A set of associated raster bands, usually from one file.
Definition gdal_priv.h:340
CPLErr SetMetadataItem(const char *pszName, const char *pszValue, const char *pszDomain) override
Set single metadata item.
virtual void FlushCache(bool bAtClosing=false)
Flush all write cached data to disk.
Definition gdaldataset.cpp:435
virtual int GetGCPCount()
Get number of GCPs.
Definition gdaldataset.cpp:1549
virtual CPLErr GetGeoTransform(double *padfTransform)
Fetch the affine transformation coefficients.
Definition gdaldataset.cpp:1177
virtual const OGRSpatialReference * GetGCPSpatialRef() const
Get output spatial reference system for GCPs.
Definition gdaldataset.cpp:1646
virtual void ClearStatistics()
Clear statistics.
Definition gdaldataset.cpp:8413
virtual CPLErr SetSpatialRef(const OGRSpatialReference *poSRS)
Set the spatial reference system for this dataset.
Definition gdaldataset.cpp:1059
virtual CPLErr SetGeoTransform(double *padfTransform)
Set the affine transformation coefficients.
Definition gdaldataset.cpp:1232
virtual CPLErr SetGCPs(int nGCPCount, const GDAL_GCP *pasGCPList, const OGRSpatialReference *poGCP_SRS)
Assign GCPs.
Definition gdaldataset.cpp:1834
virtual const OGRSpatialReference * GetSpatialRef() const
Fetch the spatial reference for this dataset.
Definition gdaldataset.cpp:928
CPLErr SetMetadata(char **papszMetadata, const char *pszDomain) override
Set metadata.
void static void char ** GetMetadata(const char *pszDomain="") override
Fetch metadata.
Definition gdaldataset.cpp:4229
virtual const GDAL_GCP * GetGCPs()
Fetch GCPs.
Definition gdaldataset.cpp:1729
virtual char ** GetFileList(void)
Fetch files forming dataset.
Definition gdaldataset.cpp:3026
Class modeling a multi-dimensional array.
Definition gdal_priv.h:2378
virtual const char * GetMetadataItem(const char *pszName, const char *pszDomain="")
Fetch single metadata item.
Definition gdalmajorobject.cpp:344
virtual void SetDescription(const char *)
Set object description.
Definition gdalmajorobject.cpp:120
PAM dataset.
Definition gdal_pam.h:120
void DeleteGeoTransform()
Remove geotransform from PAM.
Definition gdalpamdataset.cpp:1331
PAM raster band.
Definition gdal_pam.h:258
GDALColorInterp GetColorInterpretation() override
How should this band be interpreted as color?
Definition gdalpamrasterband.cpp:999
const char * GetUnitType() override
Return raster unit type.
Definition gdalpamrasterband.cpp:858
CPLErr SetDefaultRAT(const GDALRasterAttributeTable *) override
Set default Raster Attribute Table.
Definition gdalpamrasterband.cpp:1367
CPLErr SetColorTable(GDALColorTable *) override
Set the raster color table.
Definition gdalpamrasterband.cpp:949
double GetNoDataValue(int *pbSuccess=nullptr) override
Fetch the no data value for this band.
Definition gdalpamrasterband.cpp:767
CPLErr SetScale(double) override
Set scaling ratio.
Definition gdalpamrasterband.cpp:837
CPLErr GetHistogram(double dfMin, double dfMax, int nBuckets, GUIntBig *panHistogram, int bIncludeOutOfRange, int bApproxOK, GDALProgressFunc, void *pProgressData) override
Compute raster histogram.
Definition gdalpamrasterband.cpp:1185
double GetOffset(int *pbSuccess=nullptr) override
Fetch the raster value offset.
Definition gdalpamrasterband.cpp:783
GDALColorTable * GetColorTable() override
Fetch the color table associated with band.
Definition gdalpamrasterband.cpp:936
CPLErr SetCategoryNames(char **) override
Set the category names for this band.
Definition gdalpamrasterband.cpp:918
CPLErr SetOffset(double) override
Set scaling offset.
Definition gdalpamrasterband.cpp:799
CPLErr SetNoDataValue(double) override
Set the no data value for this band.
Definition gdalpamrasterband.cpp:731
CPLErr SetColorInterpretation(GDALColorInterp) override
Set color interpretation of a band.
Definition gdalpamrasterband.cpp:978
CPLErr SetDefaultHistogram(double dfMin, double dfMax, int nBuckets, GUIntBig *panHistogram) override
Set default histogram.
Definition gdalpamrasterband.cpp:1260
GDALRasterAttributeTable * GetDefaultRAT() override
Fetch default Raster Attribute Table.
Definition gdalpamrasterband.cpp:1352
CPLErr SetUnitType(const char *) override
Set unit type.
Definition gdalpamrasterband.cpp:874
CPLErr GetDefaultHistogram(double *pdfMin, double *pdfMax, int *pnBuckets, GUIntBig **ppanHistogram, int bForce, GDALProgressFunc, void *pProgressData) override
Fetch default raster histogram.
Definition gdalpamrasterband.cpp:1313
CPLErr DeleteNoDataValue() override
Remove the no data value for this band.
Definition gdalpamrasterband.cpp:749
char ** GetCategoryNames() override
Fetch the list of category names for this raster.
Definition gdalpamrasterband.cpp:905
double GetScale(int *pbSuccess=nullptr) override
Fetch the raster value scale.
Definition gdalpamrasterband.cpp:821
The GDALRasterAttributeTable (or RAT) class is used to encapsulate a table used to provide attribute ...
Definition gdal_rat.h:48
GDALRasterBand()
Definition gdalrasterband.cpp:65
This class represents an OpenGIS Spatial Reference System, and contains methods for converting betwee...
Definition ogr_spatialref.h:158
CPLErr
Error category.
Definition cpl_error.h:53
Definitions for CPL mini XML Parser/Serializer.
unsigned long long GUIntBig
Large unsigned integer type (generally 64-bit unsigned integer type).
Definition cpl_port.h:247
#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:955
GUIntBig GUInt64
Unsigned 64 bit integer type.
Definition cpl_port.h:265
GDALColorInterp
Definition gdal.h:204
Document node structure.
Definition cpl_minixml.h:70
Ground Control Point.
Definition gdal.h:711