C++使用GDAL庫實現(xiàn)Tiff文件的讀取
庫編譯
首先需要編譯對應(yīng)版本的GDAL庫,官方鏈接:https://gdal.org/ ;
我有GDAL源碼、編譯好的win32和win64,百度網(wǎng)盤鏈接:
鏈接:https://pan.baidu.com/s/1trMAX-Ar6HFPxiy3ghejhg
提取碼:prra
解壓密碼:LinXi
項目配置
依賴庫
將上面解壓好的文件放在一個固定的路徑,注意不要有中文。
我的存放路徑如下:

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

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

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

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

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

測試
測試圖片
采用清華大學(xué)宮鵬教授學(xué)科組10m土地覆蓋數(shù)據(jù),具體可以在官網(wǎng)下載。
項目結(jié)構(gòu)

測試代碼
#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)

解析成功。下一篇將會介紹如何讀取指定像元值
到此這篇關(guān)于C++使用GDAL庫實現(xiàn)Tiff文件的讀取的文章就介紹到這了,更多相關(guān)C++ GDAL Tiff文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++編程中的數(shù)據(jù)類型和常量學(xué)習(xí)教程
這篇文章主要介紹了C++編程中的數(shù)據(jù)類型和常量學(xué)習(xí)教程,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-09-09
C++實現(xiàn)LeetCode(157.用Read4來讀取N個字符)
這篇文章主要介紹了C++實現(xiàn)LeetCode(157.用Read4來讀取N個字符),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++ 數(shù)據(jù)結(jié)構(gòu)實現(xiàn)兩個棧實現(xiàn)一個隊列
這篇文章主要介紹了詳解C++ 數(shù)據(jù)結(jié)構(gòu)實現(xiàn)兩個棧實現(xiàn)一個隊列的相關(guān)資料,需要的朋友可以參考下2017-03-03

