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 );
206 CPLErr (*pfnPreWarpChunkProcessor)(
void *pKern,
void *pArg );
211 CPLErr (*pfnPostWarpChunkProcessor)(
void *pKern,
void *pArg);
228 void CPL_DLL CPL_STDCALL
231 void CPL_DLL CPL_STDCALL
234 void CPL_DLL CPL_STDCALL
237 void CPL_DLL CPL_STDCALL
240 void CPL_DLL CPL_STDCALL
243 void CPL_DLL CPL_STDCALL
246 void CPL_DLL CPL_STDCALL
260 CPLErr CPL_DLL CPL_STDCALL
265 GDALProgressFunc pfnProgress,
void *pProgressArg,
268 CPLErr CPL_DLL CPL_STDCALL
270 const char *pszDstFilename,
const char *pszDstWKT,
274 GDALProgressFunc pfnProgress,
void *pProgressArg,
283 const char *pszSrcWKT,
const char *pszDstWKT,
289 int nPixels,
int nLines,
double *padfGeoTransform,
292 CPLErr CPL_DLL CPL_STDCALL
298 #if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS) 309 #define WARP_EXTRA_ELTS 1 418 void* GWKThreadsCreate(
char** papszWarpOptions,
420 void* pTransformerArg);
421 void GWKThreadsEnd(
void* psThreadDataIn);
435 typedef struct _GDALWarpChunk GDALWarpChunk;
443 int ValidateOptions();
445 CPLErr ComputeSourceWindow(
int nDstXOff,
int nDstYOff,
446 int nDstXSize,
int nDstYSize,
447 int *pnSrcXOff,
int *pnSrcYOff,
448 int *pnSrcXSize,
int *pnSrcYSize,
449 double *pdfSrcXExtraSize,
double *pdfSrcYExtraSize,
450 double* pdfSrcFillRatio );
453 const char *pszType );
456 CPLMutex *hWarpMutex;
460 GDALWarpChunk *pasChunkList;
463 unsigned long nLastTimeReported;
467 void WipeChunkList();
468 CPLErr CollectChunkListInternal(
int nDstXOff,
int nDstYOff,
469 int nDstXSize,
int nDstYSize );
470 void CollectChunkList(
int nDstXOff,
int nDstYOff,
471 int nDstXSize,
int nDstYSize );
472 void ReportTiming(
const char * );
479 void* CreateDestinationBuffer(
int nDstXSize,
int nDstYSize,
480 int *pbWasInitialized =
nullptr );
481 static void DestroyDestinationBuffer(
void* pDstBuffer);
485 CPLErr ChunkAndWarpImage(
int nDstXOff,
int nDstYOff,
486 int nDstXSize,
int nDstYSize );
487 CPLErr ChunkAndWarpMulti(
int nDstXOff,
int nDstYOff,
488 int nDstXSize,
int nDstYSize );
489 CPLErr WarpRegion(
int nDstXOff,
int nDstYOff,
490 int nDstXSize,
int nDstYSize,
491 int nSrcXOff=0,
int nSrcYOff=0,
492 int nSrcXSize=0,
int nSrcYSize=0,
493 double dfProgressBase=0.0,
double dfProgressScale=1.0);
494 CPLErr WarpRegion(
int nDstXOff,
int nDstYOff,
495 int nDstXSize,
int nDstYSize,
496 int nSrcXOff,
int nSrcYOff,
497 int nSrcXSize,
int nSrcYSize,
498 double dfSrcXExtraSize,
double dfSrcYExtraSize,
499 double dfProgressBase,
double dfProgressScale);
500 CPLErr WarpRegionToBuffer(
int nDstXOff,
int nDstYOff,
501 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 WarpRegionToBuffer(
int nDstXOff,
int nDstYOff,
508 int nDstXSize,
int nDstYSize,
511 int nSrcXOff,
int nSrcYOff,
512 int nSrcXSize,
int nSrcYSize,
513 double dfSrcXExtraSize,
double dfSrcYExtraSize,
514 double dfProgressBase,
double dfProgressScale);
529 int,
int,
int,
int,
int,
int,
int,
int );
532 int,
int,
int,
int );
541 typedef double (*FilterFuncType)(
double dfX);
545 typedef double (*FilterFunc4ValuesType)(
double* padfVals);
546 FilterFunc4ValuesType GWKGetFilterFunc4Values(
GDALResampleAlg eResampleAlg);
void * pDstValidityMaskFuncArg
Unused.
Definition: gdalwarper.h:203
int nSrcXOff
X offset of the source buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:378
Definition: gdalwarper.h:63
int nFiltInitX
X filtering offset.
Definition: gdalwarper.h:373
GDALDataType
Definition: gdal.h:60
double dfYScale
Y resampling scale, i.e.
Definition: gdalwarper.h:363
Document node structure.
Definition: cpl_minixml.h:66
This class represents the lowest level of abstraction of warping.
Definition: gdalwarper.h:318
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:1335
GByte ** papabySrcImage
Array of nBands source images of size nSrcXSize * nSrcYSize.
Definition: gdalwarper.h:340
#define CPL_C_START
Macro to start a block of C symbols.
Definition: cpl_port.h:335
double dfXScale
X resampling scale, i.e.
Definition: gdalwarper.h:361
Definition: gdalwarper.h:72
CPLErr GDALInitializeWarpedVRT(GDALDatasetH hDS, GDALWarpOptions *psWO)
Set warp info on virtual warped dataset.
Definition: vrtwarped.cpp:1149
GUInt32 * panUnifiedSrcValid
Unified validity mask of size (nSrcXSize * nSrcYSize + WARP_EXTRA_ELTS) / 8.
Definition: gdalwarper.h:345
int nDstXSize
Width of the destination image.
Definition: gdalwarper.h:350
int * panDstBands
Definition: gdalwarper.h:147
void * pProgressArg
Definition: gdalwarper.h:172
int nDstXOff
X offset of the destination buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:383
unsigned int GUInt32
Unsigned int32 type.
Definition: cpl_port.h:205
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:213
GDALMaskFunc pfnSrcDensityMaskFunc
Unused.
Definition: gdalwarper.h:191
CPLErr GDALWarpRegionToBuffer(GDALWarpOperationH, int, int, int, int, void *, GDALDataType, int, int, int, int)
Definition: gdalwarpoperation.cpp:2217
char ** papszWarpOptions
Warp options.
Definition: gdalwarper.h:322
void ** papSrcPerBandValidityMaskFuncArg
Unused.
Definition: gdalwarper.h:183
void GDALWarpInitSrcNoDataReal(GDALWarpOptions *, double dNoDataReal)
Initialize padfSrcNoDataReal with specified value.
Definition: gdalwarper.cpp:1355
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:1523
void * pSrcDensityMaskFuncArg
Unused.
Definition: gdalwarper.h:193
Definition: gdalwarper.h:56
void * pPostWarpProcessorArg
Unused.
Definition: gdalwarper.h:213
GUInt32 * panDstValid
Validify mask of size (nDstXSize * nDstYSize) / 8.
Definition: gdalwarper.h:356
double * padfDstNoDataReal
Definition: gdalwarper.h:162
GWKAverageOrModeAlg
Definition: gdalwarper.h:67
GDALDataType eWorkingDataType
Working data type.
Definition: gdalwarper.h:327
float * pafUnifiedSrcDensity
Unified source density of size nSrcXSize * nSrcYSize + WARP_EXTRA_ELTS.
Definition: gdalwarper.h:347
double * padfSrcNoDataImag
Definition: gdalwarper.h:159
int nFiltInitY
Y filtering offset.
Definition: gdalwarper.h:375
GDALResampleAlg eResampleAlg
Definition: gdalwarper.h:128
CPLErr GDALChunkAndWarpMulti(GDALWarpOperationH, int, int, int, int)
Definition: gdalwarpoperation.cpp:1156
GDALMaskFunc pfnDstValidityMaskFunc
Unused.
Definition: gdalwarper.h:201
CPLErr GDALWarpRegion(GDALWarpOperationH, int, int, int, int, int, int, int, int)
Definition: gdalwarpoperation.cpp:1600
GDALDatasetH GDALCreateWarpedVRT(GDALDatasetH hSrcDS, int nPixels, int nLines, double *padfGeoTransform, GDALWarpOptions *psOptions)
Create virtual warped dataset.
Definition: vrtwarped.cpp:268
Definition: gdalwarper.h:68
GDALTransformerFunc pfnTransformer
Definition: gdalwarper.h:175
double dfProgressScale
Scale value for progress computation.
Definition: gdalwarper.h:400
void GDALDestroyWarpOperation(GDALWarpOperationH)
Definition: gdalwarpoperation.cpp:739
void GDALDestroyWarpOptions(GDALWarpOptions *)
Destroy a warp options structure.
Definition: gdalwarper.cpp:1235
void * pSrcValidityMaskFuncArg
Unused.
Definition: gdalwarper.h:188
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:1393
double * padfDstNoDataImag
Definition: gdalwarper.h:165
GDALMaskFunc pfnSrcValidityMaskFunc
Unused.
Definition: gdalwarper.h:186
Definition: gdalwarper.h:69
Definition: gdalwarper.h:60
Definition: gdalwarper.h:71
GDALMaskFunc pfnDstDensityMaskFunc
Unused.
Definition: gdalwarper.h:196
int nDstYOff
Y offset of the destination buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:385
GDALResampleAlg eResample
Resample algorithm.
Definition: gdalwarper.h:325
void * pPreWarpProcessorArg
Unused.
Definition: gdalwarper.h:208
GDALResampleAlg
Definition: gdalwarper.h:50
double dfSrcYExtraSize
Extra pixels (included in nSrcYSize) reserved for filter window.
Definition: gdalwarper.h:338
void GDALWarpInitSrcNoDataImag(GDALWarpOptions *, double dNoDataImag)
Initialize padfSrcNoDataImag with specified value.
Definition: gdalwarper.cpp:1412
double dfProgressBase
Base/offset value for progress computation.
Definition: gdalwarper.h:398
Warp control options for use with GDALWarpOperation::Initialize()
Definition: gdalwarper.h:120
GDALProgressFunc pfnProgress
Definition: gdalwarper.h:169
void * pDstDensityMaskFuncArg
Unused.
Definition: gdalwarper.h:198
Definition: gdalwarper.h:53
High level image warping class.
Definition: gdalwarper.h:438
int nXRadius
X size of window to filter.
Definition: gdalwarper.h:369
GDALWarpOptions * GDALCloneWarpOptions(const GDALWarpOptions *)
Clone a warp options structure.
Definition: gdalwarper.cpp:1276
void * pTransformerArg
Definition: gdalwarper.h:178
int nSrcYSize
Height of the source image.
Definition: gdalwarper.h:334
GDALProgressFunc pfnProgress
Progress function.
Definition: gdalwarper.h:393
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:403
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:352
GDALWarpOptions * GDALCreateWarpOptions(void)
Create a warp options structure.
Definition: gdalwarper.cpp:1216
Definition: gdalwarper.h:73
double dfXFilter
X size of filter kernel.
Definition: gdalwarper.h:365
int nBands
Number of input and output bands (excluding alpha bands)
Definition: gdalwarper.h:329
CPLErr GDALChunkAndWarpImage(GDALWarpOperationH, int, int, int, int)
Definition: gdalwarpoperation.cpp:921
Definition: gdalwarper.h:51
Public (C callable) GDAL algorithm entry points, and definitions.
void * pTransformerArg
User data provided to pfnTransformer.
Definition: gdalwarper.h:390
GDALMaskFunc * papfnSrcPerBandValidityMaskFunc
Unused.
Definition: gdalwarper.h:181
int nSrcXSize
Width of the source image.
Definition: gdalwarper.h:332
GDALDatasetH hSrcDS
Definition: gdalwarper.h:135
int nBandCount
Definition: gdalwarper.h:141
float * pafDstDensity
Destination density of size nDstXSize * nDstYSize.
Definition: gdalwarper.h:358
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:337
GDALTransformerFunc pfnTransformer
Pixel transformation function.
Definition: gdalwarper.h:388
void GDALWarpInitNoDataReal(GDALWarpOptions *, double dNoDataReal)
Initialize padfSrcNoDataReal and padfDstNoDataReal with specified value.
Definition: gdalwarper.cpp:1375
int nYRadius
Y size of window to filter.
Definition: gdalwarper.h:371
GDALDatasetH hDstDS
Definition: gdalwarper.h:138
Definition: gdalwarper.h:57
void * hCutline
Definition: gdalwarper.h:216
double dfYFilter
Y size of filter kernel.
Definition: gdalwarper.h:367
double dfCutlineBlendDist
Definition: gdalwarper.h:219
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:101
double * padfSrcNoDataReal
Definition: gdalwarper.h:156
void * GDALWarpOperationH
Opaque type representing a GDALWarpOperation object.
Definition: gdalwarper.h:522
double dfSrcXExtraSize
Extra pixels (included in nSrcXSize) reserved for filter window.
Definition: gdalwarper.h:336
void * pProgress
User data provided to pfnProgress.
Definition: gdalwarper.h:395
int nSrcYOff
Y offset of the source buffer regarding the top-left corner of the image.
Definition: gdalwarper.h:380
Definition: gdalwarper.h:70
CPLErr
Error category.
Definition: cpl_error.h:52
GDALWarpOperationH GDALCreateWarpOperation(const GDALWarpOptions *)
Definition: gdalwarpoperation.cpp:718
GByte ** papabyDstImage
Array of nBands destination images of size nDstXSize * nDstYSize.
Definition: gdalwarper.h:354
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:1432
GUInt32 ** papanBandSrcValid
Array of nBands validity mask of size (nSrcXSize * nSrcYSize + WARP_EXTRA_ELTS) / 8...
Definition: gdalwarper.h:343