30#ifndef GDAL_PAM_H_INCLUDED
31#define GDAL_PAM_H_INCLUDED
41#define GCIF_GEOTRANSFORM 0x01
42#define GCIF_PROJECTION 0x02
43#define GCIF_METADATA 0x04
46#define GCIF_NODATA 0x001000
47#define GCIF_CATEGORYNAMES 0x002000
48#define GCIF_MINMAX 0x004000
49#define GCIF_SCALEOFFSET 0x008000
50#define GCIF_UNITTYPE 0x010000
51#define GCIF_COLORTABLE 0x020000
52#define GCIF_COLORINTERP 0x020000
53#define GCIF_BAND_METADATA 0x040000
54#define GCIF_RAT 0x080000
55#define GCIF_MASK 0x100000
56#define GCIF_BAND_DESCRIPTION 0x200000
58#define GCIF_ONLY_IF_MISSING 0x10000000
59#define GCIF_PROCESS_BANDS 0x20000000
61#define GCIF_PAM_DEFAULT (GCIF_GEOTRANSFORM | GCIF_PROJECTION | \
62 GCIF_METADATA | GCIF_GCPS | \
63 GCIF_NODATA | GCIF_CATEGORYNAMES | \
64 GCIF_MINMAX | GCIF_SCALEOFFSET | \
65 GCIF_UNITTYPE | GCIF_COLORTABLE | \
66 GCIF_COLORINTERP | GCIF_BAND_METADATA | \
67 GCIF_RAT | GCIF_MASK | \
68 GCIF_ONLY_IF_MISSING | GCIF_PROCESS_BANDS|\
69 GCIF_BAND_DESCRIPTION)
74#define GPF_TRIED_READ_FAILED 0x02
75#define GPF_DISABLED 0x04
76#define GPF_AUXMODE 0x08
77#define GPF_NOSAVE 0x10
87class GDALDatasetPamInfo
90 char *pszPamFilename =
nullptr;
92 char *pszProjection =
nullptr;
94 int bHaveGeoTransform =
false;
95 double adfGeoTransform[6]{0,0,0,0,0,0};
99 char *pszGCPProjection =
nullptr;
105 int bHasMetadata =
false;
119 int IsPamFilenameAPotentialSiblingFile();
126 GDALDatasetPamInfo *psPam =
nullptr;
128 virtual CPLXMLNode *SerializeToXML(
const char *);
131 virtual CPLErr TryLoadXML(
char **papszSiblingFiles =
nullptr);
132 virtual CPLErr TrySaveXML();
134 CPLErr TryLoadAux(
char **papszSiblingFiles =
nullptr);
137 virtual const char *BuildPamFilename();
139 void PamInitialize();
142 void SetPhysicalFilename(
const char * );
143 const char *GetPhysicalFilename();
144 void SetSubdatasetName(
const char *);
145 const char *GetSubdatasetName();
163 const char *pszGCPProjection )
override;
166 const char * pszDomain =
"" )
override;
168 const char * pszValue,
169 const char * pszDomain =
"" )
override;
170 char **
GetMetadata(
const char * pszDomain =
"" )
override;
172 const char * pszDomain =
"" )
override;
179 CPLErr IBuildOverviews(
const char *pszResampling,
180 int nOverviews,
int *panOverviewList,
181 int nListBands,
int *panBandList,
182 GDALProgressFunc pfnProgress,
183 void * pProgressData )
override;
186 void MarkPamDirty() { nPamFlags |= GPF_DIRTY; }
187 GDALDatasetPamInfo *GetPamInfo() {
return psPam; }
188 int GetPamFlags() {
return nPamFlags; }
189 void SetPamFlags(
int nValue ) { nPamFlags = nValue; }
209 double dfNoDataValue;
216 char **papszCategoryNames;
233} GDALRasterBandPamInfo;
246 virtual CPLXMLNode *SerializeToXML(
const char *pszVRTPath );
249 void PamInitialize();
252 GDALRasterBandPamInfo *psPam =
nullptr;
264 CPLErr SetNoDataValue(
double )
override;
265 double GetNoDataValue(
int *pbSuccess =
nullptr )
override;
266 CPLErr DeleteNoDataValue()
override;
274 const char *GetUnitType()
override;
275 CPLErr SetUnitType(
const char * )
override;
277 char **GetCategoryNames()
override;
278 CPLErr SetCategoryNames(
char ** )
override;
280 double GetOffset(
int *pbSuccess =
nullptr )
override;
281 CPLErr SetOffset(
double )
override;
282 double GetScale(
int *pbSuccess =
nullptr )
override;
283 CPLErr SetScale(
double )
override;
285 CPLErr GetHistogram(
double dfMin,
double dfMax,
286 int nBuckets,
GUIntBig * panHistogram,
287 int bIncludeOutOfRange,
int bApproxOK,
288 GDALProgressFunc,
void *pProgressData )
override;
290 CPLErr GetDefaultHistogram(
double *pdfMin,
double *pdfMax,
291 int *pnBuckets,
GUIntBig ** ppanHistogram,
293 GDALProgressFunc,
void *pProgressData)
override;
295 CPLErr SetDefaultHistogram(
double dfMin,
double dfMax,
296 int nBuckets,
GUIntBig *panHistogram )
override;
299 const char * pszDomain =
"" )
override;
301 const char * pszValue,
302 const char * pszDomain =
"" )
override;
312 GDALRasterBandPamInfo *GetPamInfo() {
return psPam; }
320int CPL_DLL PamParseHistogram(
CPLXMLNode *psHistItem,
321 double *pdfMin,
double *pdfMax,
322 int *pnBuckets,
GUIntBig **ppanHistogram,
323 int *pbIncludeOutOfRange,
int *pbApproxOK );
325PamFindMatchingHistogram(
CPLXMLNode *psSavedHistograms,
326 double dfMin,
double dfMax,
int nBuckets,
327 int bIncludeOutOfRange,
int bApproxOK );
329PamHistogramToXMLTree(
double dfMin,
double dfMax,
330 int nBuckets,
GUIntBig * panHistogram,
331 int bIncludeOutOfRange,
int bApprox );
334const char CPL_DLL * PamGetProxy(
const char * );
335const char CPL_DLL * PamAllocateProxy(
const char * );
336const char CPL_DLL * PamDeallocateProxy(
const char * );
337void CPL_DLL PamCleanProxyDB(
void );
Convenient string class based on std::string.
Definition: cpl_string.h:330
A color table / palette.
Definition: gdal_priv.h:938
A set of associated raster bands, usually from one file.
Definition: gdal_priv.h:336
virtual const char * GetGCPProjection()
Get output projection for GCPs.
Definition: gdaldataset.cpp:1299
virtual CPLErr SetGCPs(int nGCPCount, const GDAL_GCP *pasGCPList, const char *pszGCPProjection)
Assign GCPs.
Definition: gdaldataset.cpp:1382
virtual int GetGCPCount()
Get number of GCPs.
Definition: gdaldataset.cpp:1264
virtual CPLErr GetGeoTransform(double *padfTransform)
Fetch the affine transformation coefficients.
Definition: gdaldataset.cpp:922
virtual CPLErr SetProjection(const char *pszProjection)
Set the projection reference string for this dataset.
Definition: gdaldataset.cpp:864
CPLErr SetMetadata(char **papszMetadata, const char *pszDomain) override
Set metadata.
virtual CPLErr SetGeoTransform(double *padfTransform)
Set the affine transformation coefficients.
Definition: gdaldataset.cpp:977
virtual const char * GetProjectionRef(void)
Fetch the projection definition string for this dataset.
Definition: gdaldataset.cpp:824
CPLErr SetMetadataItem(const char *pszName, const char *pszValue, const char *pszDomain) override
Set single metadata item.
virtual void FlushCache(void)
Flush all write cached data to disk.
Definition: gdaldataset.cpp:396
void char ** GetMetadata(const char *pszDomain="") override
Fetch metadata.
Definition: gdaldataset.cpp:3484
virtual const GDAL_GCP * GetGCPs()
Fetch GCPs.
Definition: gdaldataset.cpp:1332
virtual char ** GetFileList(void)
Fetch files forming dataset.
Definition: gdaldataset.cpp:2360
const char * GetMetadataItem(const char *pszName, const char *pszDomain) override
Fetch single metadata item.
virtual void SetDescription(const char *)
Set object description.
Definition: gdalmajorobject.cpp:120
PAM dataset.
Definition: gdal_pam.h:115
PAM raster band.
Definition: gdal_pam.h:241
The GDALRasterAttributeTable (or RAT) class is used to encapsulate a table used to provide attribute ...
Definition: gdal_rat.h:48
A single raster band (or channel).
Definition: gdal_priv.h:1033
CPLErr
Error category.
Definition: cpl_error.h:53
unsigned long long GUIntBig
Large unsigned integer type (generally 64-bit unsigned integer type).
Definition: cpl_port.h:251
#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:989
GDALColorInterp
Definition: gdal.h:191
Document node structure.
Definition: cpl_minixml.h:67
Ground Control Point.
Definition: gdal.h:561