您好,登錄后才能下訂單哦!
如何使用gdal操作影像,相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。
GDAL(Geospatial Data Abstraction Library)是一個(gè)在X/MIT許可協(xié)議下的開(kāi)源柵格空間數(shù)據(jù)轉(zhuǎn)換庫(kù)。它利用抽象數(shù)據(jù)模型來(lái)表達(dá)所支持的各種文件格式。它還有一系列命令行工具來(lái)進(jìn)行數(shù)據(jù)轉(zhuǎn)換和處理。
GDAL提供對(duì)多種柵格數(shù)據(jù)的支持,包括Arc/Info ASCII Grid(asc),GeoTiff (tiff),Erdas Imagine Images(img),ASCII DEM(dem) 等格式。
使用C#開(kāi)發(fā)gdal的程序,引用的C#類(lèi)庫(kù)不多,但是需要在執(zhí)行目錄中,添加不少C++的dll,要不然就會(huì)報(bào)錯(cuò),缺失dll文件,具體可以去網(wǎng)上下載。
C#的工程中,需要引用以下的dll:
Gdal.AllRegister();
//支持中文
//Gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8", "YES");
Dataset ds = Gdal.Open(strFilePath, Access.GA_ReadOnly);
Band Band = ds.GetRasterBand(1);
//獲取圖像的尺寸
int width = Band.XSize;
int height = Band.YSize;
//獲取坐標(biāo)變換系數(shù)
double[] adfGeoTransform = new double[6];
ds.GetGeoTransform(adfGeoTransform);
//獲取行列號(hào)
double dCol = 0.0, dRow = 0.0;
int dc = Convert.ToInt32(dCol);
int dr = Convert.ToInt32(dRow);
DataType DT = DataType.GDT_CFloat32;
//創(chuàng)建一個(gè)tiff文件的格式
OSGeo.GDAL.Driver driver = Gdal.GetDriverByName("GTiff");
Dataset dataset = driver.Create(testPath, fx, fy, 1, DT, null);
//影像轉(zhuǎn)換參數(shù)
dataset.SetGeoTransform(adfGeoTransform);
//投影轉(zhuǎn)換參數(shù)
dataset.SetProjection(ds.GetProjection());
//影像波段中寫(xiě)入數(shù)據(jù)
dataset.GetRasterBand(1).WriteRaster(0, 0, fx, fy, data, fx, fy, 0, 0);
dataset.GetRasterBand(1).FlushCache();
dataset.FlushCache();
以上是一個(gè)高程的數(shù)據(jù),tiff格式的讀取和寫(xiě)入,數(shù)據(jù)中存儲(chǔ)的就是每個(gè)點(diǎn),和每個(gè)點(diǎn)上的高程值,按順序?qū)懭氲接跋裆?,并且要把tiff圖上的像素對(duì)應(yīng)到空間坐標(biāo)的高程值。
看完上述內(nèi)容,你們掌握如何使用gdal操作影像的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。