本文整理汇总了C++中VSIMalloc2函数的典型用法代码示例。如果您正苦于以下问题:C++ VSIMalloc2函数的具体用法?C++ VSIMalloc2怎么用?C++ VSIMalloc2使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了VSIMalloc2函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: VSIMalloc2
OGRErr OGRCurveCollection::importPreambuleFromWkb( OGRGeometry* poGeom,
unsigned char * pabyData,
int& nSize,
int& nDataOffset,
OGRwkbByteOrder& eByteOrder,
int nMinSubGeomSize,
OGRwkbVariant eWkbVariant )
{
OGRErr eErr = poGeom->importPreambuleOfCollectionFromWkb(
pabyData,
nSize,
nDataOffset,
eByteOrder,
nMinSubGeomSize,
nCurveCount,
eWkbVariant );
if( eErr >= 0 )
return eErr;
papoCurves = (OGRCurve **) VSIMalloc2(sizeof(void*), nCurveCount);
if (nCurveCount != 0 && papoCurves == NULL)
{
nCurveCount = 0;
return OGRERR_NOT_ENOUGH_MEMORY;
}
return -1;
}
示例2: CPLAssert
CPLErr GXFRasterBand::IReadBlock( CPL_UNUSED int nBlockXOff,
int nBlockYOff,
void * pImage )
{
GXFDataset *poGXF_DS = (GXFDataset *) poDS;
double *padfBuffer;
float *pafBuffer = (float *) pImage;
int i;
CPLErr eErr;
CPLAssert( nBlockXOff == 0 );
if (eDataType == GDT_Float32)
{
padfBuffer = (double *) VSIMalloc2(sizeof(double), nBlockXSize);
if( padfBuffer == NULL )
return CE_Failure;
eErr = GXFGetScanline( poGXF_DS->hGXF, nBlockYOff, padfBuffer );
for( i = 0; i < nBlockXSize; i++ )
pafBuffer[i] = (float) padfBuffer[i];
CPLFree( padfBuffer );
}
else if (eDataType == GDT_Float64)
eErr = GXFGetScanline( poGXF_DS->hGXF, nBlockYOff, (double*)pImage );
else
eErr = CE_Failure;
return eErr;
}
示例3: CPLDebug
OGRErr OGRSelafinLayer::ReorderFields(int *panMap) {
CPLDebug("Selafin","ReorderFields()");
if (VSIFSeekL(poHeader->fp,poHeader->getPosition(0),SEEK_SET)!=0) return OGRERR_FAILURE;
// Change the header according to the map
char **papszNew=(char**)VSIMalloc2(sizeof(char*),poHeader->nVar);
for (long i=0;i<poHeader->nVar;++i) papszNew[i]=poHeader->papszVariables[panMap[i]];
CPLFree(poHeader->papszVariables);
poHeader->papszVariables=papszNew;
poFeatureDefn->ReorderFieldDefns(panMap);
// Now comes the real change.
VSILFILE *fpNew;
const char *pszTempfile=CPLGenerateTempFilename(0);
fpNew=VSIFOpenL(pszTempfile,"wb+");
if( fpNew == NULL ) {
CPLError( CE_Failure, CPLE_OpenFailed, "Failed to open temporary file %s with write access, %s.",pszTempfile, VSIStrerror( errno ) );
return OGRERR_FAILURE;
}
if (Selafin::write_header(fpNew,poHeader)==0) {
VSIFCloseL(fpNew);
VSIUnlink(pszTempfile);
return OGRERR_FAILURE;
}
long nLen;
double dfDate;
double *padfValues=0;
for (long i=0;i<poHeader->nSteps;++i) {
if (Selafin::read_integer(poHeader->fp,nLen,true)==0 ||
Selafin::read_float(poHeader->fp,dfDate)==0 ||
Selafin::read_integer(poHeader->fp,nLen,true)==0 ||
Selafin::write_integer(fpNew,4)==0 ||
Selafin::write_float(fpNew,dfDate)==0 ||
Selafin::write_integer(fpNew,4)==0) {
VSIFCloseL(fpNew);
VSIUnlink(pszTempfile);
return OGRERR_FAILURE;
}
for (long j=0;j<poHeader->nVar;++j) {
if (VSIFSeekL(poHeader->fp,poHeader->getPosition(i,-1,panMap[j]),SEEK_SET)!=0 || Selafin::read_floatarray(poHeader->fp,&padfValues)==-1) {
VSIFCloseL(fpNew);
VSIUnlink(pszTempfile);
return OGRERR_FAILURE;
}
if (Selafin::write_floatarray(fpNew,padfValues,poHeader->nPoints)==0) {
CPLFree(padfValues);
VSIFCloseL(fpNew);
VSIUnlink(pszTempfile);
return OGRERR_FAILURE;
}
CPLFree(padfValues);
}
}
MoveOverwrite(poHeader->fp,fpNew);
VSIUnlink(pszTempfile);
return OGRERR_NONE;
}
示例4: VSIMalloc2
CPLErr GDALRescaledAlphaBand::IRasterIO( GDALRWFlag eRWFlag,
int nXOff, int nYOff, int nXSize, int nYSize,
void * pData, int nBufXSize, int nBufYSize,
GDALDataType eBufType,
GSpacing nPixelSpace,
GSpacing nLineSpace,
GDALRasterIOExtraArg* psExtraArg )
{
/* Optimization in common use case */
/* This avoids triggering the block cache on this band, which helps */
/* reducing the global block cache consumption */
if (eRWFlag == GF_Read && eBufType == GDT_Byte &&
nXSize == nBufXSize && nYSize == nBufYSize &&
nPixelSpace == 1)
{
if( pTemp == NULL )
{
pTemp = VSIMalloc2( sizeof(GUInt16), nRasterXSize );
if (pTemp == NULL)
{
CPLError( CE_Failure, CPLE_OutOfMemory,
"GDALRescaledAlphaBand::IReadBlock: Out of memory for buffer." );
return CE_Failure;
}
}
for(int j = 0; j < nBufYSize; j++ )
{
CPLErr eErr = poParent->RasterIO( GF_Read, nXOff, nYOff + j, nXSize, 1,
pTemp, nBufXSize, 1,
GDT_UInt16,
0, 0, NULL );
if (eErr != CE_None)
return eErr;
GByte* pabyImage = ((GByte*) pData) + j * nLineSpace;
GUInt16* pSrc = (GUInt16 *)pTemp;
for( int i = 0; i < nBufXSize; i++ )
{
/* In case the dynamics was actually 0-255 and not 0-65535 as */
/* expected, we want to make sure non-zero alpha will still be non-zero */
if( pSrc[i] > 0 && pSrc[i] < 257 )
pabyImage[i] = 1;
else
pabyImage[i] = (pSrc[i] * 255) / 65535;
}
}
return CE_None;
}
return GDALRasterBand::IRasterIO( eRWFlag, nXOff, nYOff, nXSize, nYSize,
pData, nBufXSize, nBufYSize,
eBufType,
nPixelSpace, nLineSpace, psExtraArg );
}
示例5: nCurveCount
OGRCurveCollection::OGRCurveCollection( const OGRCurveCollection& other ) :
nCurveCount( 0 ),
papoCurves( NULL )
{
if( other.nCurveCount > 0 )
{
nCurveCount = other.nCurveCount;
papoCurves = (OGRCurve **) VSIMalloc2(sizeof(void*), nCurveCount);
if( papoCurves )
{
for( int i = 0; i < nCurveCount; i++ )
{
papoCurves[i] = (OGRCurve*)other.papoCurves[i]->clone();
}
}
}
}
示例6: empty
OGRCurveCollection& OGRCurveCollection::operator=( const OGRCurveCollection& other )
{
if( this != &other)
{
empty(NULL);
if( other.nCurveCount > 0 )
{
nCurveCount = other.nCurveCount;
papoCurves = (OGRCurve **) VSIMalloc2(sizeof(void*), nCurveCount);
if( papoCurves )
{
for( int i = 0; i < nCurveCount; i++ )
{
papoCurves[i] = (OGRCurve*)other.papoCurves[i]->clone();
}
}
}
}
return *this;
}
示例7: ABS
void RawRasterBand::Initialize()
{
poCT = NULL;
eInterp = GCI_Undefined;
papszCategoryNames = NULL;
bDirty = FALSE;
/* -------------------------------------------------------------------- */
/* Allocate working scanline. */
/* -------------------------------------------------------------------- */
nLoadedScanline = -1;
if (nBlockXSize <= 0 || nPixelOffset > INT_MAX / nBlockXSize)
{
nLineSize = 0;
pLineBuffer = NULL;
}
else
{
nLineSize = ABS(nPixelOffset) * nBlockXSize;
pLineBuffer = VSIMalloc2( ABS(nPixelOffset), nBlockXSize );
}
if (pLineBuffer == NULL)
{
CPLError(CE_Failure, CPLE_AppDefined,
"Could not allocate line buffer : nPixelOffset=%d, nBlockXSize=%d",
nPixelOffset, nBlockXSize);
}
if( nPixelOffset >= 0 )
pLineStart = pLineBuffer;
else
pLineStart = ((char *) pLineBuffer) + ABS(nPixelOffset) * (nBlockXSize-1);
}
示例8: GDALSieveFilter
CPLErr CPL_STDCALL
GDALSieveFilter( GDALRasterBandH hSrcBand, GDALRasterBandH hMaskBand,
GDALRasterBandH hDstBand,
int nSizeThreshold, int nConnectedness,
char **papszOptions,
GDALProgressFunc pfnProgress,
void * pProgressArg )
{
VALIDATE_POINTER1( hSrcBand, "GDALSieveFilter", CE_Failure );
VALIDATE_POINTER1( hDstBand, "GDALSieveFilter", CE_Failure );
if( pfnProgress == NULL )
pfnProgress = GDALDummyProgress;
/* -------------------------------------------------------------------- */
/* Allocate working buffers. */
/* -------------------------------------------------------------------- */
CPLErr eErr = CE_None;
int nXSize = GDALGetRasterBandXSize( hSrcBand );
int nYSize = GDALGetRasterBandYSize( hSrcBand );
GInt32 *panLastLineVal = (GInt32 *) VSIMalloc2(sizeof(GInt32), nXSize);
GInt32 *panThisLineVal = (GInt32 *) VSIMalloc2(sizeof(GInt32), nXSize);
GInt32 *panLastLineId = (GInt32 *) VSIMalloc2(sizeof(GInt32), nXSize);
GInt32 *panThisLineId = (GInt32 *) VSIMalloc2(sizeof(GInt32), nXSize);
GInt32 *panThisLineWriteVal = (GInt32 *) VSIMalloc2(sizeof(GInt32), nXSize);
GByte *pabyMaskLine = (hMaskBand != NULL) ? (GByte *) VSIMalloc(nXSize) : NULL;
if (panLastLineVal == NULL || panThisLineVal == NULL ||
panLastLineId == NULL || panThisLineId == NULL ||
panThisLineWriteVal == NULL ||
(hMaskBand != NULL && pabyMaskLine == NULL))
{
CPLError(CE_Failure, CPLE_OutOfMemory,
"Could not allocate enough memory for temporary buffers");
CPLFree( panThisLineId );
CPLFree( panLastLineId );
CPLFree( panThisLineVal );
CPLFree( panLastLineVal );
CPLFree( panThisLineWriteVal );
CPLFree( pabyMaskLine );
return CE_Failure;
}
/* -------------------------------------------------------------------- */
/* The first pass over the raster is only used to build up the */
/* polygon id map so we will know in advance what polygons are */
/* what on the second pass. */
/* -------------------------------------------------------------------- */
int iY, iX, iPoly;
GDALRasterPolygonEnumerator oFirstEnum( nConnectedness );
std::vector<int> anPolySizes;
for( iY = 0; eErr == CE_None && iY < nYSize; iY++ )
{
eErr = GDALRasterIO(
hSrcBand,
GF_Read, 0, iY, nXSize, 1,
panThisLineVal, nXSize, 1, GDT_Int32, 0, 0 );
if( eErr == CE_None && hMaskBand != NULL )
eErr = GPMaskImageData( hMaskBand, pabyMaskLine, iY, nXSize, panThisLineVal );
if( iY == 0 )
oFirstEnum.ProcessLine(
NULL, panThisLineVal, NULL, panThisLineId, nXSize );
else
oFirstEnum.ProcessLine(
panLastLineVal, panThisLineVal,
panLastLineId, panThisLineId,
nXSize );
/* -------------------------------------------------------------------- */
/* Accumulate polygon sizes. */
/* -------------------------------------------------------------------- */
if( oFirstEnum.nNextPolygonId > (int) anPolySizes.size() )
anPolySizes.resize( oFirstEnum.nNextPolygonId );
for( iX = 0; iX < nXSize; iX++ )
{
iPoly = panThisLineId[iX];
CPLAssert( iPoly >= 0 );
anPolySizes[iPoly] += 1;
}
/* -------------------------------------------------------------------- */
/* swap this/last lines. */
/* -------------------------------------------------------------------- */
GInt32 *panTmp = panLastLineVal;
panLastLineVal = panThisLineVal;
panThisLineVal = panTmp;
panTmp = panThisLineId;
panThisLineId = panLastLineId;
panLastLineId = panTmp;
/* -------------------------------------------------------------------- */
/* Report progress, and support interrupts. */
/* -------------------------------------------------------------------- */
if( eErr == CE_None
//.........这里部分代码省略.........
示例9: CPLError
GDALDataset *RDataset::Open( GDALOpenInfo * poOpenInfo )
{
if( !Identify( poOpenInfo ) )
return NULL;
/* -------------------------------------------------------------------- */
/* Confirm the requested access is supported. */
/* -------------------------------------------------------------------- */
if( poOpenInfo->eAccess == GA_Update )
{
CPLError( CE_Failure, CPLE_NotSupported,
"The R driver does not support update access to existing"
" datasets.\n" );
return NULL;
}
/* -------------------------------------------------------------------- */
/* Do we need to route the file through the decompression */
/* machinery? */
/* -------------------------------------------------------------------- */
CPLString osAdjustedFilename;
if( memcmp(poOpenInfo->pabyHeader,"\037\213\b",3) == 0 )
osAdjustedFilename = "/vsigzip/";
osAdjustedFilename += poOpenInfo->pszFilename;
/* -------------------------------------------------------------------- */
/* Establish this as a dataset and open the file using VSI*L. */
/* -------------------------------------------------------------------- */
RDataset *poDS = new RDataset();
poDS->fp = VSIFOpenL( osAdjustedFilename, "r" );
if( poDS->fp == NULL )
{
delete poDS;
return NULL;
}
poDS->bASCII = EQUALN((const char *)poOpenInfo->pabyHeader,"RDA2\nA\n",7);
/* -------------------------------------------------------------------- */
/* Confirm this is a version 2 file. */
/* -------------------------------------------------------------------- */
VSIFSeekL( poDS->fp, 7, SEEK_SET );
if( poDS->ReadInteger() != R_LISTSXP )
{
delete poDS;
CPLError( CE_Failure, CPLE_OpenFailed,
"It appears %s is not a version 2 R object file after all!",
poOpenInfo->pszFilename );
return NULL;
}
/* -------------------------------------------------------------------- */
/* Skip the version values. */
/* -------------------------------------------------------------------- */
poDS->ReadInteger();
poDS->ReadInteger();
/* -------------------------------------------------------------------- */
/* Confirm we have a numeric vector object in a pairlist. */
/* -------------------------------------------------------------------- */
CPLString osObjName;
int nObjCode;
if( !poDS->ReadPair( osObjName, nObjCode ) )
{
delete poDS;
return NULL;
}
if( nObjCode % 256 != R_REALSXP )
{
delete poDS;
CPLError( CE_Failure, CPLE_OpenFailed,
"Failed to find expected numeric vector object." );
return NULL;
}
poDS->SetMetadataItem( "R_OBJECT_NAME", osObjName );
/* -------------------------------------------------------------------- */
/* Read the count. */
/* -------------------------------------------------------------------- */
int nValueCount = poDS->ReadInteger();
poDS->nStartOfData = VSIFTellL( poDS->fp );
/* -------------------------------------------------------------------- */
/* Read/Skip ahead to attributes. */
/* -------------------------------------------------------------------- */
if( poDS->bASCII )
{
poDS->padfMatrixValues = (double*) VSIMalloc2( nValueCount, sizeof(double) );
if (poDS->padfMatrixValues == NULL)
{
CPLError(CE_Failure, CPLE_AppDefined,
"Cannot allocate %d doubles", nValueCount);
delete poDS;
//.........这里部分代码省略.........
示例10: GDALMultiFilter
static CPLErr
GDALMultiFilter( GDALRasterBandH hTargetBand,
GDALRasterBandH hTargetMaskBand,
GDALRasterBandH hFiltMaskBand,
int nIterations,
GDALProgressFunc pfnProgress,
void * pProgressArg )
{
float *paf3PassLineBuf;
GByte *pabyTMaskBuf;
GByte *pabyFMaskBuf;
float *pafThisPass, *pafLastPass, *pafSLastPass;
int nBufLines = nIterations + 2;
int iPassCounter = 0;
int nNewLine; // the line being loaded this time (zero based scanline)
int nXSize = GDALGetRasterBandXSize( hTargetBand );
int nYSize = GDALGetRasterBandYSize( hTargetBand );
CPLErr eErr = CE_None;
/* -------------------------------------------------------------------- */
/* Report starting progress value. */
/* -------------------------------------------------------------------- */
if( !pfnProgress( 0.0, "Smoothing Filter...", pProgressArg ) )
{
CPLError( CE_Failure, CPLE_UserInterrupt, "User terminated" );
return CE_Failure;
}
/* -------------------------------------------------------------------- */
/* Allocate rotating buffers. */
/* -------------------------------------------------------------------- */
pabyTMaskBuf = (GByte *) VSIMalloc2(nXSize, nBufLines);
pabyFMaskBuf = (GByte *) VSIMalloc2(nXSize, nBufLines);
paf3PassLineBuf = (float *) VSIMalloc3(nXSize, nBufLines, 3 * sizeof(float));
if (pabyTMaskBuf == NULL || pabyFMaskBuf == NULL || paf3PassLineBuf == NULL)
{
CPLError(CE_Failure, CPLE_OutOfMemory,
"Could not allocate enough memory for temporary buffers");
eErr = CE_Failure;
goto end;
}
/* -------------------------------------------------------------------- */
/* Process rotating buffers. */
/* -------------------------------------------------------------------- */
for( nNewLine = 0;
eErr == CE_None && nNewLine < nYSize+nIterations;
nNewLine++ )
{
/* -------------------------------------------------------------------- */
/* Rotate pass buffers. */
/* -------------------------------------------------------------------- */
iPassCounter = (iPassCounter + 1) % 3;
pafSLastPass = paf3PassLineBuf
+ ((iPassCounter+0)%3) * nXSize*nBufLines;
pafLastPass = paf3PassLineBuf
+ ((iPassCounter+1)%3) * nXSize*nBufLines;
pafThisPass = paf3PassLineBuf
+ ((iPassCounter+2)%3) * nXSize*nBufLines;
/* -------------------------------------------------------------------- */
/* Where does the new line go in the rotating buffer? */
/* -------------------------------------------------------------------- */
int iBufOffset = nNewLine % nBufLines;
/* -------------------------------------------------------------------- */
/* Read the new data line if it is't off the bottom of the */
/* image. */
/* -------------------------------------------------------------------- */
if( nNewLine < nYSize )
{
eErr =
GDALRasterIO( hTargetMaskBand, GF_Read,
0, nNewLine, nXSize, 1,
pabyTMaskBuf + nXSize * iBufOffset, nXSize, 1,
GDT_Byte, 0, 0 );
if( eErr != CE_None )
break;
eErr =
GDALRasterIO( hFiltMaskBand, GF_Read,
0, nNewLine, nXSize, 1,
pabyFMaskBuf + nXSize * iBufOffset, nXSize, 1,
GDT_Byte, 0, 0 );
if( eErr != CE_None )
break;
eErr =
GDALRasterIO( hTargetBand, GF_Read,
0, nNewLine, nXSize, 1,
pafThisPass + nXSize * iBufOffset, nXSize, 1,
GDT_Float32, 0, 0 );
if( eErr != CE_None )
//.........这里部分代码省略.........
示例11: ParseXPM
//.........这里部分代码省略.........
for( i = 0; i < 256; i++ )
anCharLookup[i] = -1;
for( iColor = 0; iColor < nColorCount; iColor++ )
{
char **papszTokens = CSLTokenizeString( papszXPMList[iColor+1]+1 );
GDALColorEntry sColor;
int nRed, nGreen, nBlue;
if( CSLCount(papszTokens) != 2 || !EQUAL(papszTokens[0],"c") )
{
CPLError( CE_Failure, CPLE_AppDefined,
"Ill formed color definition (%s) in XPM header.",
papszXPMList[iColor+1] );
CSLDestroy( papszXPMList );
CSLDestroy( papszTokens );
return NULL;
}
anCharLookup[(int)papszXPMList[iColor+1][0]] = iColor;
if( EQUAL(papszTokens[1],"None") )
{
sColor.c1 = 0;
sColor.c2 = 0;
sColor.c3 = 0;
sColor.c4 = 0;
}
else if( sscanf( papszTokens[1], "#%02x%02x%02x",
&nRed, &nGreen, &nBlue ) != 3 )
{
CPLError( CE_Failure, CPLE_AppDefined,
"Ill formed color definition (%s) in XPM header.",
papszXPMList[iColor+1] );
CSLDestroy( papszXPMList );
CSLDestroy( papszTokens );
return NULL;
}
else
{
sColor.c1 = (short) nRed;
sColor.c2 = (short) nGreen;
sColor.c3 = (short) nBlue;
sColor.c4 = 255;
}
oCTable.SetColorEntry( iColor, &sColor );
CSLDestroy( papszTokens );
}
/* -------------------------------------------------------------------- */
/* Prepare image buffer. */
/* -------------------------------------------------------------------- */
GByte *pabyImage;
pabyImage = (GByte *) VSIMalloc2(*pnXSize, *pnYSize);
if( pabyImage == NULL )
{
CPLError( CE_Failure, CPLE_OutOfMemory,
"Insufficient memory for %dx%d XPM image buffer.",
*pnXSize, *pnYSize );
CSLDestroy( papszXPMList );
return NULL;
}
memset( pabyImage, 0, *pnXSize * *pnYSize );
/* -------------------------------------------------------------------- */
/* Parse image. */
/* -------------------------------------------------------------------- */
for( int iLine = 0; iLine < *pnYSize; iLine++ )
{
const char *pszInLine = papszXPMList[iLine + nColorCount + 1];
if( pszInLine == NULL )
{
CPLFree( pabyImage );
CSLDestroy( papszXPMList );
CPLError( CE_Failure, CPLE_AppDefined,
"Insufficient imagery lines in XPM image." );
return NULL;
}
for( int iPixel = 0;
pszInLine[iPixel] != '\0' && iPixel < *pnXSize;
iPixel++ )
{
int nPixelValue = anCharLookup[(int)pszInLine[iPixel]];
if( nPixelValue != -1 )
pabyImage[iLine * *pnXSize + iPixel] = (GByte) nPixelValue;
}
}
CSLDestroy( papszXPMList );
*ppoRetTable = oCTable.Clone();
return pabyImage;
}
示例12: GDALFPolygonize
CPLErr CPL_STDCALL
GDALFPolygonize( GDALRasterBandH hSrcBand,
GDALRasterBandH hMaskBand,
OGRLayerH hOutLayer, int iPixValField,
char **papszOptions,
GDALProgressFunc pfnProgress,
void * pProgressArg )
{
#ifndef OGR_ENABLED
CPLError(CE_Failure, CPLE_NotSupported, "GDALFPolygonize() unimplemented in a non OGR build");
return CE_Failure;
#else
VALIDATE_POINTER1( hSrcBand, "GDALFPolygonize", CE_Failure );
VALIDATE_POINTER1( hOutLayer, "GDALFPolygonize", CE_Failure );
if( pfnProgress == NULL )
pfnProgress = GDALDummyProgress;
int nConnectedness = CSLFetchNameValue( papszOptions, "8CONNECTED" ) ? 8 : 4;
/* -------------------------------------------------------------------- */
/* Confirm our output layer will support feature creation. */
/* -------------------------------------------------------------------- */
if( !OGR_L_TestCapability( hOutLayer, OLCSequentialWrite ) )
{
CPLError( CE_Failure, CPLE_AppDefined,
"Output feature layer does not appear to support creation\n"
"of features in GDALFPolygonize()." );
return CE_Failure;
}
/* -------------------------------------------------------------------- */
/* Allocate working buffers. */
/* -------------------------------------------------------------------- */
CPLErr eErr = CE_None;
int nXSize = GDALGetRasterBandXSize( hSrcBand );
int nYSize = GDALGetRasterBandYSize( hSrcBand );
float *pafLastLineVal = (float *) VSIMalloc2(sizeof(float),nXSize + 2);
float *pafThisLineVal = (float *) VSIMalloc2(sizeof(float),nXSize + 2);
GInt32 *panLastLineId = (GInt32 *) VSIMalloc2(sizeof(GInt32),nXSize + 2);
GInt32 *panThisLineId = (GInt32 *) VSIMalloc2(sizeof(GInt32),nXSize + 2);
GByte *pabyMaskLine = (hMaskBand != NULL) ? (GByte *) VSIMalloc(nXSize) : NULL;
if (pafLastLineVal == NULL || pafThisLineVal == NULL ||
panLastLineId == NULL || panThisLineId == NULL ||
(hMaskBand != NULL && pabyMaskLine == NULL))
{
CPLError(CE_Failure, CPLE_OutOfMemory,
"Could not allocate enough memory for temporary buffers");
CPLFree( panThisLineId );
CPLFree( panLastLineId );
CPLFree( pafThisLineVal );
CPLFree( pafLastLineVal );
CPLFree( pabyMaskLine );
return CE_Failure;
}
/* -------------------------------------------------------------------- */
/* Get the geotransform, if there is one, so we can convert the */
/* vectors into georeferenced coordinates. */
/* -------------------------------------------------------------------- */
GDALDatasetH hSrcDS = GDALGetBandDataset( hSrcBand );
double adfGeoTransform[6] = { 0.0, 1.0, 0.0, 0.0, 0.0, 1.0 };
if( hSrcDS )
GDALGetGeoTransform( hSrcDS, adfGeoTransform );
/* -------------------------------------------------------------------- */
/* The first pass over the raster is only used to build up the */
/* polygon id map so we will know in advance what polygons are */
/* what on the second pass. */
/* -------------------------------------------------------------------- */
int iY;
GDALRasterFPolygonEnumerator oFirstEnum(nConnectedness);
for( iY = 0; eErr == CE_None && iY < nYSize; iY++ )
{
eErr = GDALRasterIO(
hSrcBand,
GF_Read, 0, iY, nXSize, 1,
pafThisLineVal, nXSize, 1, GDT_Float32, 0, 0 );
if( eErr == CE_None && hMaskBand != NULL )
eErr = GPMaskImageData( hMaskBand, pabyMaskLine, iY, nXSize,
pafThisLineVal );
if( iY == 0 )
oFirstEnum.ProcessLine(
NULL, pafThisLineVal, NULL, panThisLineId, nXSize );
else
oFirstEnum.ProcessLine(
pafLastLineVal, pafThisLineVal,
panLastLineId, panThisLineId,
nXSize );
// swap lines
float * pafTmp = pafLastLineVal;
pafLastLineVal = pafThisLineVal;
pafThisLineVal = pafTmp;
//.........这里部分代码省略.........
示例13: CPLError
OGRErr OGRSelafinLayer::ICreateFeature(OGRFeature *poFeature) {
OGRGeometry *poGeom=poFeature->GetGeometryRef();
if (poGeom==0) return OGRERR_FAILURE;
if (VSIFSeekL(poHeader->fp,poHeader->getPosition(0),SEEK_SET)!=0) return OGRERR_FAILURE;
if (eType==POINTS) {
// If it's a point layer, it's the "easy" case: we add a new point feature and update the file
if (poGeom->getGeometryType()!=wkbPoint) {
CPLError( CE_Failure, CPLE_AppDefined, "The new feature should be of the same Point geometry as the existing ones in the layer.");
return OGRERR_FAILURE;
}
OGRPoint *poPoint=(OGRPoint*)poGeom;
poFeature->SetFID(poHeader->nPoints);
CPLDebug("Selafin","CreateFeature(%li,%f,%f)",poHeader->nPoints,poPoint->getX(),poPoint->getY());
// Change the header to add the new feature
poHeader->addPoint(poPoint->getX(),poPoint->getY());
} else {
// This is the most difficult case. The user wants to add a polygon element. First we check that it has the same number of vertices as the other polygon elements in the file. If there is no other element, then we define the number of vertices.
// Every vertex in the layer should have a corresponding point in the corresponding point layer. So if we add a polygon element, we also have to add points in the corresponding layer.
// The function tries to add as few new points as possible, reusing already existing points. This is generally what the user will expect.
// First we check that we have the required geometry
if (poGeom->getGeometryType()!=wkbPolygon) {
CPLError( CE_Failure, CPLE_AppDefined, "The new feature should be of the same Polygon geometry as the existing ones in the layer.");
return OGRERR_FAILURE;
}
// Now we check that we have the right number of vertices, or if this number was not defined yet (0), we define it at once
OGRLinearRing *poLinearRing=((OGRPolygon*)poGeom)->getExteriorRing();
poFeature->SetFID(poHeader->nElements);
CPLDebug("Selafin","CreateFeature(" CPL_FRMT_GIB ",%f,%f,%f,%f,%f,%f)",poFeature->GetFID(),poLinearRing->getX(0),poLinearRing->getY(0),poLinearRing->getX(1),poLinearRing->getY(1),poLinearRing->getX(2),poLinearRing->getY(2)); //!< This is not safe as we can't be sure there are at least three vertices in the linear ring, but we can assume that for a debug mode
int nNum=poLinearRing->getNumPoints();
if (poHeader->nPointsPerElement==0) {
if (nNum<4) {
CPLError( CE_Failure, CPLE_AppDefined, "The new feature should have at least 3 vertices.");
return OGRERR_FAILURE;
}
poHeader->nPointsPerElement=nNum-1;
if (poHeader->nElements>0) {
poHeader->panConnectivity=(long*)CPLRealloc(poHeader->panConnectivity,poHeader->nElements*poHeader->nPointsPerElement);
if (poHeader->panConnectivity==0) return OGRERR_FAILURE;
}
} else {
if (poLinearRing->getNumPoints()!=poHeader->nPointsPerElement+1) {
CPLError( CE_Failure, CPLE_AppDefined, "The new feature should have the same number of vertices %li as the existing ones in the layer.",poHeader->nPointsPerElement);
return OGRERR_FAILURE;
}
}
// Now we look for vertices that are already referenced as points in the file
int *anMap;
anMap=(int*)VSIMalloc2(sizeof(int),poHeader->nPointsPerElement);
if (anMap==0) {
CPLError(CE_Failure,CPLE_AppDefined,"%s","Not enough memory for operation");
return OGRERR_FAILURE;
}
for (long i=0;i<poHeader->nPointsPerElement;++i) anMap[i]=-1;
if (poHeader->nPoints>0) {
CPLRectObj *poBB=poHeader->getBoundingBox();
double dfMaxDist=(poBB->maxx-poBB->minx)/sqrt((double)(poHeader->nPoints))/1000.0; //!< Heuristic approach to estimate a maximum distance such that two points are considered equal if they are closer from each other
dfMaxDist*=dfMaxDist;
delete poBB;
for (long i=0;i<poHeader->nPointsPerElement;++i) anMap[i]=poHeader->getClosestPoint(poLinearRing->getX(i),poLinearRing->getY(i),dfMaxDist);
}
// We add new points if needed only
for (long i=0;i<poHeader->nPointsPerElement;++i) if (anMap[i]==-1) {
poHeader->addPoint(poLinearRing->getX(i),poLinearRing->getY(i));
anMap[i]=poHeader->nPoints-1;
}
// And we update the connectivity table to add the new element
poHeader->nElements++;
poHeader->panConnectivity=(long*)CPLRealloc(poHeader->panConnectivity,sizeof(long)*poHeader->nPointsPerElement*poHeader->nElements);
for (long i=0;i<poHeader->nPointsPerElement;++i) {
poHeader->panConnectivity[poHeader->nPointsPerElement*(poHeader->nElements-1)+i]=anMap[i]+1;
}
poHeader->setUpdated();
CPLFree(anMap);
}
// Now comes the real insertion. Since values have to be inserted nearly everywhere in the file and we don't want to store everything in memory to overwrite it, we create a new copy of it where we write the new values
VSILFILE *fpNew;
const char *pszTempfile=CPLGenerateTempFilename(0);
fpNew=VSIFOpenL(pszTempfile,"wb+");
if( fpNew == NULL ) {
CPLError( CE_Failure, CPLE_OpenFailed, "Failed to open temporary file %s with write access, %s.",pszTempfile, VSIStrerror( errno ) );
return OGRERR_FAILURE;
}
if (Selafin::write_header(fpNew,poHeader)==0) {
VSIFCloseL(fpNew);
VSIUnlink(pszTempfile);
return OGRERR_FAILURE;
}
long nLen;
double dfDate;
double *padfValues;
for (long i=0;i<poHeader->nSteps;++i) {
if (Selafin::read_integer(poHeader->fp,nLen,true)==0 ||
Selafin::read_float(poHeader->fp,dfDate)==0 ||
//.........这里部分代码省略.........
示例14: GeoLocLoadFullData
static int GeoLocLoadFullData( GDALGeoLocTransformInfo *psTransform )
{
int nXSize, nYSize;
int nXSize_XBand = GDALGetRasterXSize( psTransform->hDS_X );
int nYSize_XBand = GDALGetRasterYSize( psTransform->hDS_X );
int nXSize_YBand = GDALGetRasterXSize( psTransform->hDS_Y );
int nYSize_YBand = GDALGetRasterYSize( psTransform->hDS_Y );
if (nYSize_XBand == 1 && nYSize_YBand == 1)
{
nXSize = nXSize_XBand;
nYSize = nXSize_YBand;
}
else
{
nXSize = nXSize_XBand;
nYSize = nYSize_XBand;
}
psTransform->nGeoLocXSize = nXSize;
psTransform->nGeoLocYSize = nYSize;
psTransform->padfGeoLocY = (double *)
VSIMalloc3(sizeof(double), nXSize, nYSize);
psTransform->padfGeoLocX = (double *)
VSIMalloc3(sizeof(double), nXSize, nYSize);
if( psTransform->padfGeoLocX == NULL ||
psTransform->padfGeoLocY == NULL )
{
CPLError(CE_Failure, CPLE_OutOfMemory,
"GeoLocLoadFullData : Out of memory");
return FALSE;
}
if (nYSize_XBand == 1 && nYSize_YBand == 1)
{
/* Case of regular grid */
/* The XBAND contains the x coordinates for all lines */
/* The YBAND contains the y coordinates for all columns */
double* padfTempX = (double*)VSIMalloc2(nXSize, sizeof(double));
double* padfTempY = (double*)VSIMalloc2(nYSize, sizeof(double));
if (padfTempX == NULL || padfTempY == NULL)
{
CPLFree(padfTempX);
CPLFree(padfTempY);
CPLError(CE_Failure, CPLE_OutOfMemory,
"GeoLocLoadFullData : Out of memory");
return FALSE;
}
CPLErr eErr = CE_None;
eErr = GDALRasterIO( psTransform->hBand_X, GF_Read,
0, 0, nXSize, 1,
padfTempX, nXSize, 1,
GDT_Float64, 0, 0 );
int i,j;
for(j=0;j<nYSize;j++)
{
memcpy( psTransform->padfGeoLocX + j * nXSize,
padfTempX,
nXSize * sizeof(double) );
}
if (eErr == CE_None)
{
eErr = GDALRasterIO( psTransform->hBand_Y, GF_Read,
0, 0, nYSize, 1,
padfTempY, nYSize, 1,
GDT_Float64, 0, 0 );
for(j=0;j<nYSize;j++)
{
for(i=0;i<nXSize;i++)
{
psTransform->padfGeoLocY[j * nXSize + i] = padfTempY[j];
}
}
}
CPLFree(padfTempX);
CPLFree(padfTempY);
if (eErr != CE_None)
return FALSE;
}
else
{
if( GDALRasterIO( psTransform->hBand_X, GF_Read,
0, 0, nXSize, nYSize,
psTransform->padfGeoLocX, nXSize, nYSize,
GDT_Float64, 0, 0 ) != CE_None
|| GDALRasterIO( psTransform->hBand_Y, GF_Read,
0, 0, nXSize, nYSize,
psTransform->padfGeoLocY, nXSize, nYSize,
GDT_Float64, 0, 0 ) != CE_None )
//.........这里部分代码省略.........
示例15: GDALGetDataTypeSize
/*****************************************************
* \brief Write a natural block of raster band data
*****************************************************/
CPLErr PostGISRasterRasterBand::IWriteBlock(int nBlockXOff,
int nBlockYOff, void * pImage)
{
int nPixelSize = GDALGetDataTypeSize(eDataType) / 8;
int nNaturalBlockXSize = 0;
int nNaturalBlockYSize = 0;
int nDataSize = 0;
int nBandMetaDataSize = 0;
PostGISRasterDataset * poRDS = (PostGISRasterDataset *)poDS;
CPLDebug("PostGIS_Raster",
"PostGISRasterRasterBand::IWriteBlock(): Table %s.%s (%s), Srid : %d",
pszSchema, pszTable, pszColumn,poRDS->nSrid);
// How much data are we going to copy?
GetBlockSize(&nNaturalBlockXSize, &nNaturalBlockYSize);
nDataSize = nNaturalBlockXSize * nNaturalBlockYSize * nPixelSize;
// Allocating space for band metadata
nBandMetaDataSize = (nPixelSize + 1);
char * pszBandMetadata = (char*) VSIMalloc2(2 * nBandMetaDataSize, sizeof (char));
// Allocate memory for all bands data, if needed
if (!poRDS->pBufferToInsert) {
CPLDebug("PostGIS_Raster", "PostGISRasterRasterBand::IWriteBlock(); "
"Allocating memory for buffer to hold insert query data (%d characters)",
2 * (nDataSize + nBandMetaDataSize) * poRDS->nBandsToCopy);
poRDS->pBufferToInsert =
(char *)VSIMalloc3(poRDS->nBandsToCopy, 2 * (nDataSize + nBandMetaDataSize), sizeof(char));
poRDS->nPosToCopy = 0;
poRDS->nBandsCopied = 0;
}
CPLDebug("PostGIS_Raster",
"PostGISRasterRasterBand::IWriteBlock(): Block (%d x %d), Metadata %d. We are "
"copying %d bytes", nNaturalBlockXSize, nNaturalBlockYSize, nBandMetaDataSize, nDataSize+nBandMetaDataSize);
/**
* Copy the band data into the dataset buffer. We will raise the query
* after we have the data of all bands in the buffer.
*
* NOTE: At this point, datatype translation between src and dst has been
* performed by IRasterIO. So, we can use band datatype for both, origin
* and destination buffers.
**/
// GDALCopyWords(pImage, eDataType, 0,
// poRDS->pBufferToInsert + poRDS->nPosToCopy, eDataType, 0, nDataSize);
char cPostGISQueryWKT = TranslateDataTypeGDALtoPostGIS(&eDataType);
if(cPostGISQueryWKT == '\0'){
CPLDebug("PostGIS_Raster",
"PostGISRasterRasterBand::IWriteBlock(): PostGIS Datatype id : %c",
cPostGISQueryWKT);
return CE_Failure;
}
CPLDebug("PostGIS_Raster",
"PostGISRasterRasterBand::IWriteBlock(): HasNoDataValue = %s, NoDataValue = %f",
bNoDataValueSet? "True" : "False", dfNoDataValue);
/* Testing bNoDataValueSet :: Hack */
// bNoDataValueSet = 1;
// dfNoDataValue = 0;
if(bNoDataValueSet)
pszBandMetadata[0] = '4';
else
pszBandMetadata[0] = '0';
pszBandMetadata[1] = cPostGISQueryWKT;
strcpy(pszBandMetadata + 2, CPLBinaryToHex(nPixelSize,(GByte *)&dfNoDataValue));
memcpy(poRDS->pBufferToInsert + poRDS->nPosToCopy, pszBandMetadata, nBandMetaDataSize * 2);
poRDS->nPosToCopy += nBandMetaDataSize * 2;
memcpy(poRDS->pBufferToInsert + poRDS->nPosToCopy, CPLBinaryToHex(nDataSize,(GByte *)pImage), nDataSize * 2);
poRDS->nPosToCopy += nDataSize * 2;
poRDS->pBufferToInsert[poRDS->nPosToCopy] = '\0';
poRDS->nBandsCopied++;
// Check if we're done, to raise the insert query
if (poRDS->nBandsToCopy == poRDS->nBandsCopied) {
PGresult * poResult = NULL;
CPLString osCommand;
/*
// hack
pszSchema = "public";
pszTable = "newtable";
pszColumn = "rast";
*/
// Raise insert query
// TODO: The table may contain more fields
// FIXME: For some reason, pszSchema, pszTable and pszColumn are NULL.
// I think it's related with the fact we overwrote GDALDataset::IRasterIO,
// and we delegate in default implementation. Here, poDS is a simple
// GDALDataset *, not a PostGISRasterDataset *
// FIXME: anyway, even hardcoding schema/table/column names here, we
//.........这里部分代码省略.........