C++使用GDAL庫(kù)實(shí)現(xiàn)Tiff文件的讀取
庫(kù)編譯
首先需要編譯對(duì)應(yīng)版本的GDAL庫(kù),官方鏈接:https://gdal.org/ ;
我有GDAL源碼、編譯好的win32和win64,百度網(wǎng)盤(pán)鏈接:
鏈接:https://pan.baidu.com/s/1trMAX-Ar6HFPxiy3ghejhg
提取碼:prra
解壓密碼:LinXi
項(xiàng)目配置
依賴庫(kù)
將上面解壓好的文件放在一個(gè)固定的路徑,注意不要有中文。
我的存放路徑如下:
項(xiàng)目配置
1、在項(xiàng)目配置中的配置屬性-》常規(guī)-》輸出目錄:.\bin_D\
2、在項(xiàng)目配置中的配置屬性-》C/C++》常規(guī)-》附加包含目錄:這里填寫(xiě)你剛剛存放對(duì)應(yīng)平臺(tái)的include文件。例如:32位你就選擇gdal_vs(86);64位你就選擇gdal_vs。
3、在項(xiàng)目配置中的配置屬性-》連接器》常規(guī)-》附加庫(kù)目錄:這里填寫(xiě)你剛剛存放對(duì)應(yīng)平臺(tái)的lib文件。例如:32位你就選擇gdal_vs(86);64位你就選擇gdal_vs。
4、在項(xiàng)目配置中的配置屬性-》連接器》輸入》附加依賴項(xiàng):這里不與平臺(tái)有關(guān),直接寫(xiě)gdal_i_lib
即可。
5、然后將gdal*.dll動(dòng)態(tài)庫(kù)拷貝到工程的輸入路徑下,proj動(dòng)態(tài)庫(kù)是gdal庫(kù)依賴的
測(cè)試
測(cè)試圖片
采用清華大學(xué)宮鵬教授學(xué)科組10m土地覆蓋數(shù)據(jù),具體可以在官網(wǎng)下載。
項(xiàng)目結(jié)構(gòu)
測(cè)試代碼
#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) { //注冊(cè)文件格式 GDALAllRegister(); const char* pszFile = "./fromglc10v01_0_100.tif"; // 讀取tiff文件 //const char* pszFile = "./01C_20210101-20220101.tif";//"C:\\Test.img"; //1.jpg //使用只讀方式打開(kāi)圖像 GDALDataset* poDataset = (GDALDataset*)GDALOpen(pszFile, GA_ReadOnly); if (poDataset == NULL) { printf("File: %s不能打開(kāi)!\n", pszFile); return; } //輸出圖像的格式信息 std::cout << "Driver:" << poDataset->GetDriver()->GetDescription() << "/" << poDataset->GetDriver()->GetMetadataItem(GDAL_DMD_LONGNAME) << std::endl; //輸出圖像的大小和波段個(gè)數(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]; //讀取第一個(gè)波段 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; }
運(yùn)行結(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)
解析成功。下一篇將會(huì)介紹如何讀取指定像元值
到此這篇關(guān)于C++使用GDAL庫(kù)實(shí)現(xiàn)Tiff文件的讀取的文章就介紹到這了,更多相關(guān)C++ GDAL Tiff文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++中opencv4.1.0環(huán)境配置的詳細(xì)過(guò)程
這篇文章主要介紹了C++中opencv4.1.0環(huán)境配置的詳細(xì)過(guò)程,本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-10-10C++中set/multiset與map/multimap的使用詳解
這篇文章主要為大家詳細(xì)介紹了C++中set/multiset與map/multimap的使用,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,需要的可以參考一下2023-02-02C語(yǔ)言實(shí)現(xiàn)線索二叉樹(shù)的定義與遍歷示例
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)線索二叉樹(shù)的定義與遍歷,結(jié)合具體實(shí)例形式分析了基于C語(yǔ)言的線索二叉樹(shù)定義及遍歷操作相關(guān)實(shí)現(xiàn)技巧與注意事項(xiàng),需要的朋友可以參考下2017-06-06C++中函數(shù)的默認(rèn)參數(shù)詳細(xì)解析
在函數(shù)聲明或定義時(shí),直接對(duì)參數(shù)賦值,該參數(shù)就是默認(rèn)參數(shù)。在函數(shù)調(diào)用時(shí),省略部分或全部參數(shù),這時(shí)就會(huì)使用默認(rèn)參數(shù)進(jìn)行代替2013-10-10C語(yǔ)言fgetc和fputc函數(shù)用法詳解(以字符形式讀寫(xiě)文件)
這篇文章主要介紹了C語(yǔ)言fgetc和fputc函數(shù)用法詳解(以字符形式讀寫(xiě)文件),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01使用ShellClass獲取文件屬性詳細(xì)信息的實(shí)現(xiàn)方法
本篇文章是對(duì)ShellClass獲取文件屬性詳細(xì)信息的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05