31 #ifndef GDALWARPER_H_INCLUDED 32 #define GDALWARPER_H_INCLUDED 44 #include "cpl_multiproc.h" 78 (*GDALMaskFunc)(
void *pMaskFuncArg,
81 int nXSize,
int nYSize,
82 GByte **papabyImageData,
83 int bMaskIsFloat,
void *pMask );
86 GDALWarpNoDataMasker(
void *pMaskFuncArg,
int nBandCount,
GDALDataType eType,
87 int nXOff,
int nYOff,
int nXSize,
int nYSize,
88 GByte **papabyImageData,
int bMaskIsFloat,
89 void *pValidityMask,
int* pbOutAllValid );
92 GDALWarpDstAlphaMasker(
void *pMaskFuncArg,
int nBandCount,
GDALDataType eType,
93 int nXOff,
int nYOff,
int nXSize,
int nYSize,
95 int bMaskIsFloat,
void *pValidityMask );
97 GDALWarpSrcAlphaMasker(
void *pMaskFuncArg,
int nBandCount,
GDALDataType eType,
98 int nXOff,
int nYOff,
int nXSize,
int nYSize,
100 int bMaskIsFloat,
void *pValidityMask,
int* pbOutAllOpaque );
103 GDALWarpSrcMaskMasker(
void *pMaskFuncArg,
int nBandCount,
GDALDataType eType,
104 int nXOff,
int nYOff,
int nXSize,
int nYSize,
106 int bMaskIsFloat,
void *pValidityMask );
109 GDALWarpCutlineMasker(
void *pMaskFuncArg,
int nBandCount,
GDALDataType eType,
110 int nXOff,
int nYOff,
int nXSize,
int nYSize,
112 int bMaskIsFloat,
void *pValidityMask );
208 CPLErr (*pfnPreWarpChunkProcessor)(
void *pKern,
void *pArg );
213 CPLErr (*pfnPostWarpChunkProcessor)(
void *pKern,
void *pArg);
230 void CPL_DLL CPL_STDCALL
233 void CPL_DLL CPL_STDCALL
236 void CPL_DLL CPL_STDCALL
239 void CPL_DLL CPL_STDCALL
242 void CPL_DLL CPL_STDCALL
245 void CPL_DLL CPL_STDCALL
248 void CPL_DLL CPL_STDCALL
262 CPLErr CPL_DLL CPL_STDCALL
267 GDALProgressFunc pfnProgress,
void *pProgressArg,
270 CPLErr CPL_DLL CPL_STDCALL
272 const char *pszDstFilename,
const char *pszDstWKT,
276 GDALProgressFunc pfnProgress,
void *pProgressArg,
285 const char *pszSrcWKT,
const char *pszDstWKT,
291 int nPixels,
int nLines,
double *padfGeoTransform,
294 CPLErr CPL_DLL CPL_STDCALL
300 #if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS) 311 #define WARP_EXTRA_ELTS 1 422 void* GWKThreadsCreate(
char** papszWarpOptions,
424 void* pTransformerArg);
425 void GWKThreadsEnd(
void* psThreadDataIn);
439 typedef struct _GDALWarpChunk GDALWarpChunk;
450 int ValidateOptions();
452 CPLErr ComputeSourceWindow(
int nDstXOff,
int nDstYOff,
453 int nDstXSize,
int nDstYSize,
454 int *pnSrcXOff,
int *pnSrcYOff,
455 int *pnSrcXSize,
int *pnSrcYSize,
456 double *pdfSrcXExtraSize,
double *pdfSrcYExtraSize,
457 double* pdfSrcFillRatio );
459 void ComputeSourceWindowStartingFromSource(
460 int nDstXOff,
int nDstYOff,
461 int nDstXSize,
int nDstYSize,
462 double* padfSrcMinX,
double* padfSrcMinY,
463 double* padfSrcMaxX,
double* padfSrcMaxY);
466 const char *pszType );
469 CPLMutex *hWarpMutex;
473 GDALWarpChunk *pasChunkList;
476 unsigned long nLastTimeReported;
480 void WipeChunkList();
481 CPLErr CollectChunkListInternal(
int nDstXOff,
int nDstYOff,
482 int nDstXSize,
int nDstYSize );
483 void CollectChunkList(
int nDstXOff,
int nDstYOff,
484 int nDstXSize,
int nDstYSize );
485 void ReportTiming(
const char * );
492 void* CreateDestinationBuffer(
int nDstXSize,
int nDstYSize,
493 int *pbWasInitialized =
nullptr );
494 static void DestroyDestinationBuffer(
void* pDstBuffer);
498 CPLErr ChunkAndWarpImage(
int nDstXOff,
int nDstYOff,
499 int nDstXSize,
int nDstYSize );
500 CPLErr ChunkAndWarpMulti(
int nDstXOff,
int nDstYOff,
501 int nDstXSize,
int nDstYSize );
502 CPLErr WarpRegion(
int nDstXOff,
int nDstYOff,
503 int nDstXSize,
int nDstYSize,
504 int nSrcXOff=0,
int nSrcYOff=0,
505 int nSrcXSize=0,
int nSrcYSize=0,
506 double dfProgressBase=0.0,
double dfProgressScale=1.0);
507 CPLErr WarpRegion(
int nDstXOff,
int nDstYOff,
508 int nDstXSize,
int nDstYSize,
509 int nSrcXOff,
int nSrcYOff,
510 int nSrcXSize,
int nSrcYSize,
511 double dfSrcXExtraSize,
double dfSrcYExtraSize,
512 double dfProgressBase,
double dfProgressScale);
513 CPLErr WarpRegionToBuffer(
int nDstXOff,
int nDstYOff,
514 int nDstXSize,
int nDstYSize,
517 int nSrcXOff=0,
int nSrcYOff=0,
518 int nSrcXSize=0,
int nSrcYSize=0,
519 double dfProgressBase=0.0,
double dfProgressScale=1.0);
520 CPLErr WarpRegionToBuffer(
int nDstXOff,
int nDstYOff,
521 int nDstXSize,
int nDstYSize,
524 int nSrcXOff,
int nSrcYOff,
525 int nSrcXSize,
int nSrcYSize,
526 double dfSrcXExtraSize,
double dfSrcYExtraSize,
527 double dfProgressBase,
double dfProgressScale);
542 int,
int,
int,
int,
int,
int,
int,
int );
545 int,
int,
int,
int );
554 typedef double (*FilterFuncType)(
double dfX);
558 typedef double (*FilterFunc4ValuesType)(
double* padfVals);
559 FilterFunc4ValuesType GWKGetFilterFunc4Values(
GDALResampleAlg eResampleAlg);
void * pDstValidityMaskFuncArg
Unused.
Definition: gdalwarper.h:205
int nSrcXOff
X offset of the source buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:382
Definition: gdalwarper.h:63
int nFiltInitX
X filtering offset.
Definition: gdalwarper.h:377
GDALDataType
Definition: gdal.h:60
double dfYScale
Y resampling scale, i.e.
Definition: gdalwarper.h:367
Document node structure.
Definition: cpl_minixml.h:66
This class represents the lowest level of abstraction of warping.
Definition: gdalwarper.h:320
Definitions for CPL mini XML Parser/Serializer.
Definition: gdalwarper.h:54
Definition: gdalwarper.h:61
void GDALWarpInitDstNoDataReal(GDALWarpOptions *, double dNoDataReal)
Initialize padfDstNoDataReal with specified value.
Definition: gdalwarper.cpp:1331
GByte ** papabySrcImage
Array of nBands source images of size nSrcXSize * nSrcYSize.
Definition: gdalwarper.h:344
#define CPL_C_START
Macro to start a block of C symbols.
Definition: cpl_port.h:337
double dfXScale
X resampling scale, i.e.
Definition: gdalwarper.h:365
Definition: gdalwarper.h:72
CPLErr GDALInitializeWarpedVRT(GDALDatasetH hDS, GDALWarpOptions *psWO)
Set warp info on virtual warped dataset.
Definition: vrtwarped.cpp:1159
GUInt32 * panUnifiedSrcValid
Unified validity mask of size (nSrcXSize * nSrcYSize + WARP_EXTRA_ELTS) / 8.
Definition: gdalwarper.h:349
int nDstXSize
Width of the destination image.
Definition: gdalwarper.h:354
int * panDstBands
Definition: gdalwarper.h:147
void * pProgressArg
Definition: gdalwarper.h:174
int nDstXOff
X offset of the destination buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:387
unsigned int GUInt32
Unsigned int32 type.
Definition: cpl_port.h:207
double dfWarpMemoryLimit
Definition: gdalwarper.h:125
int nSrcAlphaBand
Definition: gdalwarper.h:150
Definition: gdalwarper.h:62
void * GDALDatasetH
Opaque type used for the C bindings of the C++ GDALDataset class.
Definition: gdal.h:255
unsigned char GByte
Unsigned byte type.
Definition: cpl_port.h:215
GDALMaskFunc pfnSrcDensityMaskFunc
Unused.
Definition: gdalwarper.h:193
CPLErr GDALWarpRegionToBuffer(GDALWarpOperationH, int, int, int, int, void *, GDALDataType, int, int, int, int)
Definition: gdalwarpoperation.cpp:2273
char ** papszWarpOptions
Warp options.
Definition: gdalwarper.h:326
void ** papSrcPerBandValidityMaskFuncArg
Unused.
Definition: gdalwarper.h:185
void GDALWarpInitSrcNoDataReal(GDALWarpOptions *, double dNoDataReal)
Initialize padfSrcNoDataReal with specified value.
Definition: gdalwarper.cpp:1351
Definition: gdalwarper.h:55
void GDALWarpInitDefaultBandMapping(GDALWarpOptions *, int nBandCount)
Init src and dst band mappings such that Bands[i] = i+1 for nBandCount Does nothing if psOptionsIn->n...
Definition: gdalwarper.cpp:1519
void * pSrcDensityMaskFuncArg
Unused.
Definition: gdalwarper.h:195
Definition: gdalwarper.h:56
void * pPostWarpProcessorArg
Unused.
Definition: gdalwarper.h:215
GUInt32 * panDstValid
Validify mask of size (nDstXSize * nDstYSize) / 8.
Definition: gdalwarper.h:360
double * padfDstNoDataReal
Definition: gdalwarper.h:163
GWKAverageOrModeAlg
Definition: gdalwarper.h:67
GDALDataType eWorkingDataType
Working data type.
Definition: gdalwarper.h:331
float * pafUnifiedSrcDensity
Unified source density of size nSrcXSize * nSrcYSize + WARP_EXTRA_ELTS.
Definition: gdalwarper.h:351
double * padfSrcNoDataImag
Definition: gdalwarper.h:160
int nFiltInitY
Y filtering offset.
Definition: gdalwarper.h:379
GDALResampleAlg eResampleAlg
Definition: gdalwarper.h:128
CPLErr GDALChunkAndWarpMulti(GDALWarpOperationH, int, int, int, int)
Definition: gdalwarpoperation.cpp:1211
GDALMaskFunc pfnDstValidityMaskFunc
Unused.
Definition: gdalwarper.h:203
CPLErr GDALWarpRegion(GDALWarpOperationH, int, int, int, int, int, int, int, int)
Definition: gdalwarpoperation.cpp:1656
GDALDatasetH GDALCreateWarpedVRT(GDALDatasetH hSrcDS, int nPixels, int nLines, double *padfGeoTransform, GDALWarpOptions *psOptions)
Create virtual warped dataset.
Definition: vrtwarped.cpp:274
Definition: gdalwarper.h:68
GDALTransformerFunc pfnTransformer
Definition: gdalwarper.h:177
double dfProgressScale
Scale value for progress computation.
Definition: gdalwarper.h:404
void GDALDestroyWarpOperation(GDALWarpOperationH)
Definition: gdalwarpoperation.cpp:794
void GDALDestroyWarpOptions(GDALWarpOptions *)
Destroy a warp options structure.
Definition: gdalwarper.cpp:1231
void * pSrcValidityMaskFuncArg
Unused.
Definition: gdalwarper.h:190
CPLErr GDALReprojectImage(GDALDatasetH hSrcDS, const char *pszSrcWKT, GDALDatasetH hDstDS, const char *pszDstWKT, GDALResampleAlg eResampleAlg, double dfWarpMemoryLimit, double dfMaxError, GDALProgressFunc pfnProgress, void *pProgressArg, GDALWarpOptions *psOptions)
Reproject image.
Definition: gdalwarper.cpp:97
void GDALWarpInitDstNoDataImag(GDALWarpOptions *, double dNoDataImag)
Initialize padfDstNoDataImag with specified value.
Definition: gdalwarper.cpp:1389
double * padfDstNoDataImag
Definition: gdalwarper.h:167
GDALMaskFunc pfnSrcValidityMaskFunc
Unused.
Definition: gdalwarper.h:188
Definition: gdalwarper.h:69
Definition: gdalwarper.h:60
Definition: gdalwarper.h:71
GDALMaskFunc pfnDstDensityMaskFunc
Unused.
Definition: gdalwarper.h:198
int nDstYOff
Y offset of the destination buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:389
GDALResampleAlg eResample
Resample algorithm.
Definition: gdalwarper.h:329
void * pPreWarpProcessorArg
Unused.
Definition: gdalwarper.h:210
GDALResampleAlg
Definition: gdalwarper.h:50
double dfSrcYExtraSize
Extra pixels (included in nSrcYSize) reserved for filter window.
Definition: gdalwarper.h:342
void GDALWarpInitSrcNoDataImag(GDALWarpOptions *, double dNoDataImag)
Initialize padfSrcNoDataImag with specified value.
Definition: gdalwarper.cpp:1408
double dfProgressBase
Base/offset value for progress computation.
Definition: gdalwarper.h:402
Warp control options for use with GDALWarpOperation::Initialize()
Definition: gdalwarper.h:120
GDALProgressFunc pfnProgress
Definition: gdalwarper.h:171
void * pDstDensityMaskFuncArg
Unused.
Definition: gdalwarper.h:200
Definition: gdalwarper.h:53
High level image warping class.
Definition: gdalwarper.h:442
int nXRadius
X size of window to filter.
Definition: gdalwarper.h:373
GDALWarpOptions * GDALCloneWarpOptions(const GDALWarpOptions *)
Clone a warp options structure.
Definition: gdalwarper.cpp:1272
void * pTransformerArg
Definition: gdalwarper.h:180
int nSrcYSize
Height of the source image.
Definition: gdalwarper.h:338
GDALProgressFunc pfnProgress
Progress function.
Definition: gdalwarper.h:397
Definition: gdalwarper.h:59
Definition: gdalwarper.h:52
int * panSrcBands
Definition: gdalwarper.h:144
double * padfDstNoDataReal
Array of nBands value for destination nodata.
Definition: gdalwarper.h:407
int(* GDALTransformerFunc)(void *pTransformerArg, int bDstToSrc, int nPointCount, double *x, double *y, double *z, int *panSuccess)
Definition: gdal_alg.h:114
void * GDALDriverH
Opaque type used for the C bindings of the C++ GDALDriver class.
Definition: gdal.h:261
char ** papszWarpOptions
A string list of additional options controlling the warp operation in name=value format.
Definition: gdalwarper.h:122
int nDstYSize
Height of the destination image.
Definition: gdalwarper.h:356
GDALWarpOptions * GDALCreateWarpOptions(void)
Create a warp options structure.
Definition: gdalwarper.cpp:1212
Definition: gdalwarper.h:73
double dfXFilter
X size of filter kernel.
Definition: gdalwarper.h:369
int nBands
Number of input and output bands (excluding alpha bands)
Definition: gdalwarper.h:333
CPLErr GDALChunkAndWarpImage(GDALWarpOperationH, int, int, int, int)
Definition: gdalwarpoperation.cpp:976
Definition: gdalwarper.h:51
Public (C callable) GDAL algorithm entry points, and definitions.
void * pTransformerArg
User data provided to pfnTransformer.
Definition: gdalwarper.h:394
GDALMaskFunc * papfnSrcPerBandValidityMaskFunc
Unused.
Definition: gdalwarper.h:183
int nSrcXSize
Width of the source image.
Definition: gdalwarper.h:336
GDALDatasetH hSrcDS
Definition: gdalwarper.h:135
int nBandCount
Definition: gdalwarper.h:141
float * pafDstDensity
Destination density of size nDstXSize * nDstYSize.
Definition: gdalwarper.h:362
GDALDataType eWorkingDataType
Definition: gdalwarper.h:132
CPLErr GDALCreateAndReprojectImage(GDALDatasetH hSrcDS, const char *pszSrcWKT, const char *pszDstFilename, const char *pszDstWKT, GDALDriverH hDstDriver, char **papszCreateOptions, GDALResampleAlg eResampleAlg, double dfWarpMemoryLimit, double dfMaxError, GDALProgressFunc pfnProgress, void *pProgressArg, GDALWarpOptions *psOptions)
Reproject an image and create the target reprojected image.
Definition: gdalwarper.cpp:230
#define CPL_C_END
Macro to end a block of C symbols.
Definition: cpl_port.h:339
GDALTransformerFunc pfnTransformer
Pixel transformation function.
Definition: gdalwarper.h:392
void GDALWarpInitNoDataReal(GDALWarpOptions *, double dNoDataReal)
Initialize padfSrcNoDataReal and padfDstNoDataReal with specified value.
Definition: gdalwarper.cpp:1371
int nYRadius
Y size of window to filter.
Definition: gdalwarper.h:375
GDALDatasetH hDstDS
Definition: gdalwarper.h:138
Definition: gdalwarper.h:57
void * hCutline
Definition: gdalwarper.h:218
double dfYFilter
Y size of filter kernel.
Definition: gdalwarper.h:371
double dfCutlineBlendDist
Definition: gdalwarper.h:221
GDALDatasetH GDALAutoCreateWarpedVRT(GDALDatasetH hSrcDS, const char *pszSrcWKT, const char *pszDstWKT, GDALResampleAlg eResampleAlg, double dfMaxError, const GDALWarpOptions *psOptions)
Create virtual warped dataset automatically.
Definition: vrtwarped.cpp:104
double * padfSrcNoDataReal
Definition: gdalwarper.h:156
void * GDALWarpOperationH
Opaque type representing a GDALWarpOperation object.
Definition: gdalwarper.h:535
double dfSrcXExtraSize
Extra pixels (included in nSrcXSize) reserved for filter window.
Definition: gdalwarper.h:340
void * pProgress
User data provided to pfnProgress.
Definition: gdalwarper.h:399
int nSrcYOff
Y offset of the source buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:384
Definition: gdalwarper.h:70
CPLErr
Error category.
Definition: cpl_error.h:52
GDALWarpOperationH GDALCreateWarpOperation(const GDALWarpOptions *)
Definition: gdalwarpoperation.cpp:773
GByte ** papabyDstImage
Array of nBands destination images of size nDstXSize * nDstYSize.
Definition: gdalwarper.h:358
int nDstAlphaBand
Definition: gdalwarper.h:153
void GDALWarpResolveWorkingDataType(GDALWarpOptions *)
If the working data type is unknown, this method will determine a valid working data type to support ...
Definition: gdalwarper.cpp:1428
#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
GUInt32 ** papanBandSrcValid
Array of nBands validity mask of size (nSrcXSize * nSrcYSize + WARP_EXTRA_ELTS) / 8...
Definition: gdalwarper.h:347