溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

發(fā)布時間:2023-03-27 15:42:26 來源:億速云 閱讀:164 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹了C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取的相關(guān)知識,內(nèi)容詳細(xì)易懂,操作簡單快捷,具有一定借鑒價值,相信大家閱讀完這篇C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取文章都會有所收獲,下面我們一起來看看吧。

庫編譯

首先需要編譯對應(yīng)版本的GDAL庫

項目配置

依賴庫

將上面解壓好的文件放在一個固定的路徑,注意不要有中文。

我的存放路徑如下:

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

項目配置

1、在項目配置中的配置屬性-》常規(guī)-》輸出目錄:.\bin_D\

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

2、在項目配置中的配置屬性-》C/C++》常規(guī)-》附加包含目錄:這里填寫你剛剛存放對應(yīng)平臺的include文件。例如:32位你就選擇gdal_vs(86);64位你就選擇gdal_vs。

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

3、在項目配置中的配置屬性-》連接器》常規(guī)-》附加庫目錄:這里填寫你剛剛存放對應(yīng)平臺的lib文件。例如:32位你就選擇gdal_vs(86);64位你就選擇gdal_vs。

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

4、在項目配置中的配置屬性-》連接器》輸入》附加依賴項:這里不與平臺有關(guān),直接寫gdal_i_lib即可。

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

5、然后將gdal*.dll動態(tài)庫拷貝到工程的輸入路徑下,proj動態(tài)庫是gdal庫依賴的

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

測試

測試圖片

采用清華大學(xué)宮鵬教授學(xué)科組10m土地覆蓋數(shù)據(jù),具體可以在官網(wǎng)下載。

項目結(jié)構(gòu)

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

測試代碼

#include "gdal_priv.h"

#include<iostream>
#include <iostream>
#include <list>

#include "gdal_priv.h"   
#include "cpl_conv.h" //for CPLMalloc()   

using namespace std;
void ReadTiffFile(double lon, double lat)
{
	//注冊文件格式   
	GDALAllRegister();

	const char* pszFile = "./fromglc10v01_0_100.tif"; // 讀取tiff文件
	//const char* pszFile = "./01C_20210101-20220101.tif";//"C:\\Test.img";  //1.jpg
	//使用只讀方式打開圖像 
	GDALDataset* poDataset = (GDALDataset*)GDALOpen(pszFile, GA_ReadOnly);
	if (poDataset == NULL)
	{
		printf("File: %s不能打開!\n", pszFile);
		return;
	}

	//輸出圖像的格式信息   
	std::cout << "Driver:" << poDataset->GetDriver()->GetDescription() << "/"
		<< poDataset->GetDriver()->GetMetadataItem(GDAL_DMD_LONGNAME) << std::endl;

	//輸出圖像的大小和波段個數(shù)   
	std::cout << "Size is" << poDataset->GetRasterXSize() << "*"
		<< poDataset->GetRasterYSize() << "*" << poDataset->GetRasterCount() << std::endl;

	//輸出圖像的投影信息   
	if (poDataset->GetProjectionRef() != NULL)
	{
		std::cout << "Projectionis" << poDataset->GetProjectionRef() << std::endl;
	}

	GDALRasterBand* poBand;
	int            nBlockXSize, nBlockYSize;
	int            bGotMin, bGotMax;
	double         adfMinMax[2];

	//讀取第一個波段   
	poBand = poDataset->GetRasterBand(1);

	int   nXSize = poBand->GetXSize();
	int nYSize = poBand->GetYSize();

	//輸出圖像的坐標(biāo)和分辨率信息   
	double adfGeoTransform[6];
	if (poDataset->GetGeoTransform(adfGeoTransform) == CE_None)
	{
		printf("Origin =(%.6f,%.6f)\n",
			adfGeoTransform[0], adfGeoTransform[3]);

		printf("PixelSize = (%.6f,%.6f)\n",
			adfGeoTransform[1], adfGeoTransform[5]);
	}


	CPLFree(poDataset);
	//關(guān)閉文件   
	GDALClose((GDALDatasetH)poDataset);
}

int main()
{
	double lon = 101.8615835729;
	double lat = 1.7389243989;
	ReadTiffFile(lon, lat);

	return 0;
}

運行結(jié)果

Driver:GTiff/GeoTIFF
Size is22265*22265*1
ProjectionisGEOGCS["WGS 84",DATUM["WGS_1984",SPHEROID["WGS 84",6378137,298.257223563,AUTHORITY["EPSG","7030"]],AUTHORITY["EPSG","6326"]],PRIMEM["Greenwich",0],UNIT["degree",0.0174532925199433,AUTHORITY["EPSG","9122"]],AXIS["Latitude",NORTH],AXIS["Longitude",EAST],AUTHORITY["EPSG","4326"]]
Origin =(99.999918,2.000009)
PixelSize = (0.000090,-0.000090)

C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取

關(guān)于“C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對“C++怎么使用GDAL庫實現(xiàn)Tiff文件的讀取”知識都有一定的了解,大家如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI