GDAL GeoTiff Corrupt при записи (C++)

Я получаю испорченный вывод при написании GeoTiff с использованием GDAL API (v1.10 - C++). Растровое геотрансформирование правильное, блок записан в правильной позиции, но пиксели записаны в случайных позициях и значениях внутри блока.

Пример: http://i.imgur.com/mntnAfK.png

Метод: Откройте GDAL Raster -> скопировать проекционную информацию и размер -> создать вывод GeoTiff -> записать блок из массива со смещением.

Код:

//Open the input DEM
const char* demFName = "/Users/mount.dem";
const char* outFName = "/Users/geodata/out_test.tif";
auto poDataset = ioUtils::openDem(demFName);
double adfGeoTransform[6];
poDataset->GetGeoTransform( adfGeoTransform );

//Setup driver
const char *pszFormat = "GTiff";
GDALDriver *poDriver;
poDriver = GetGDALDriverManager()->GetDriverByName(pszFormat);
char *pszSRS_WKT = NULL;
GDALRasterBand *poBand;
//Get size from input Raster
int xSize = poDataset->GetRasterXSize();
int ySize = poDataset->GetRasterYSize();

//Set output Dataset
GDALDataset *poDstDS;
char **papszOptions = NULL;

//Create output geotiff
poDstDS = poDriver->Create( outFName, xSize, ySize, 1, GDT_Byte, papszOptions );

//Get the geotrans from the input geotrans
poDataset->GetGeoTransform( adfGeoTransform );
poDstDS->SetGeoTransform( adfGeoTransform );
poDstDS->SetProjection( poDataset->GetProjectionRef() );

//Create some data to write
unsigned char rData[512*512];
//Assign some values other than 0
for (int col=0; col < 512; col++){
    for (int row=0; row < 512; row++){
        rData[col*row] = 50;
    }
}

//Write some data
poBand = poDstDS->GetRasterBand(1);
poBand->RasterIO( GF_Write, 200, 200, 512, 512,
                  rData, 512, 512, GDT_Byte, 0, 0 );

//Close
GDALClose( (GDALDatasetH) poDstDS );
std::cout << "Done" << std::endl;

Любые идеи / указатели, где я иду не так, высоко ценится.

1 ответ

Всегда что-то тривиальное...

rData[row*512+col] = 50 

Qudos в Even Rouault на Осгео.

Другие вопросы по тегам