gdal of c++ day01

Gdal学习第一天

1.基础指令值

CPLErr GDALRasterBand::RasterIO (   GDALRWFlag eRWFlag, // 读入还是写入
int     nXOff, // 起始坐标(左上角x值)
int     nYOff, // 起始坐标(左上角y值)
int     nXSize, // (读入/写入)图像的宽
int     nYSize, // (读入/写入)图像的高
void * pData, // 指向(读入/写入)的指针
int     nBufXSize, // 缓冲区宽(真正显示的宽)
int     nBufYSize, // 缓冲区高(真正显示的高)
GDALDataType    eBufType, // (读入/写入)的数据的类型
int     nPixelSpace, // 像素间隔,默认0
int     nLineSpace  // 像素行间隔,默认0
)

2.具体实现
实例1

#include<iostream>
#include<algorithm>
#include<vector>
#include "gdal_priv.h"

BYTE * loadRasterData()
{		
		const char * fileName = "D:\\Programme\\Viual Studio\\C++\\learning\\point_to_line\\Project1_test\\images\\grid.tiff";
		GDALAllRegister(); // 注册驱动
		// 支持中文路径
		CPLSetConfigOption("GDAL_FILENAME_IS_UTF8", "NO");
		// 读取数据
		GDALDataset * pDataset = (GDALDataset *)GDALOpen(fileName, GA_ReadOnly);

		// 判断是否读取成功
		if (NULL == pDataset)
		{
			cout << "未能成功读取!" << endl;
			return 0;
		}

	// 图像波段信息
	GDALRasterBand * pRasterBand;
	pRasterBand = pDataset->GetRasterBand(1); // 第一个波段指针
	CPLString DataType = GDALGetDataTypeName(pRasterBand->GetRasterDataType()); // 获取数据类型名字
	int imgX = pRasterBand->GetXSize();
	int imgY = pRasterBand->GetYSize();
	cout << "x,y分别为:" << imgX << "  " << imgY << endl;
	cout << "数据类型:" << DataType << endl;
	cout << "-------------------------------------------------------" << endl;

	// 读取数据
	int size_m = sizeof(int)*imgX*imgY;
	cout << size_m << endl;
	BYTE * mat = (BYTE *)CPLMalloc(size_m); // 分配内存
	pRasterBand->RasterIO(GF_Read, 0, 0, imgX, imgY, mat, imgX, imgY, GDT_Byte, 0, 0);

	// 打印数组
	for (int i = 0; i < imgX; i++)
	{
		for (int j = 0; j < imgY; j++)
		{
			cout << (int) mat[i*imgX+j] << " ";
		}
	}

	return mat; // 返回数组的首地址
}


int main()
{
	// 加载数据
	BYTE *mat = loadRasterData();

}

实例2

#include<iostream>
#include "gdal_priv.h"

using namespace std;

// 读取栅格数据
void loadRasterData() {

	const char * fileName = "D:\\Programme\\Viual Studio\\C++\\learning\\point_to_line\\Project1_test\\images\\grid.tiff";

	GDALAllRegister(); // 注册驱动
	// 支持中文路径
	CPLSetConfigOption("GDAL_FILENAME_IS_UTF8", "NO");
	// 读取数据
	GDALDataset * pDataset = (GDALDataset *)GDALOpen(fileName, GA_ReadOnly);

	// 判断是否读取成功
	if (NULL == pDataset)
	{
		cout << "未能成功读取!" << endl;
		return;
	}


	// 输出图像格式信息
	CPLString strDrive = pDataset->GetDriver()->GetDescription();
	CPLString strInfo = pDataset->GetDriver()->GetMetadataItem(GDAL_DMD_LONGNAME);
	cout << "文件格式:" << strDrive << " " << strInfo << endl;

	// 获取波段,长宽和波段数
	int x = pDataset->GetRasterXSize();
	int y = pDataset->GetRasterYSize();
	int band = pDataset->GetRasterCount(); // 高
	cout << "影像x: " << x << endl;
	cout << "影像y: " << y << endl;
	cout << "波段数:" << band << endl;
	cout << "-------------------------------------------------------" << endl;

	// 输出投影方式
	CPLString  strProjection = pDataset->GetProjectionRef();
	if (strProjection != "") // 如果没有投影信息,返回一个空字符串,不是NULL;
	{
		cout << "投影方式:" << strProjection << endl;
		cout << "-------------------------------------------------------" << endl;

	}

	//输出几何信息
	double GeoTransform[6];
	if (pDataset->GetGeoTransform(GeoTransform) == CE_None) // CE_None 表示成功获取
	{
		cout << "几何信息为:" << endl;
		for (int i = 0; i < 6; i++)
		{
			cout << GeoTransform[i] << " ";
		}
		cout << endl;
		cout << "-------------------------------------------------------" << endl;

	}

	// 图像波段信息
	GDALRasterBand * pRasterBand;
	pRasterBand = pDataset->GetRasterBand(1); // 第一个波段指针
	int nxBlock, nyBlock;
	pRasterBand->GetBlockSize(&nxBlock, &nyBlock); // TODO
	CPLString DataType = GDALGetDataTypeName(pRasterBand->GetRasterDataType()); // 获取数据类型名字
	CPLString ColorType = GDALGetColorInterpretationName(pRasterBand->GetColorInterpretation()); // 获取颜色类型名称
	cout << "分块大小为:" << nxBlock << " / " << nyBlock << endl;
	cout << "数据类型:" << DataType << endl;
	cout << "颜色类型:" << ColorType << endl;
	cout << "-------------------------------------------------------" << endl;

	// 统计像素的最值
	int arrMaxMin[2];
	arrMaxMin[0] = pRasterBand->GetMaximum();
	arrMaxMin[1] = pRasterBand->GetMinimum();
	cout << "像素的最大值:" << arrMaxMin[0] << endl;
	cout << "像素的最小值" << arrMaxMin[1] << endl;

	// 图像金字塔信息
	if(pRasterBand->GetOverviewCount()!=0) // 获取当前波段的金字塔层数,如果没有金字塔返回0
	{ 
		cout << "金字塔数目:" << pRasterBand->GetOverviewCount() << endl;
		cout << "-------------------------------------------------------" << endl;

	}
	return;
}

int main() {

	// 读取数据
	loadRasterData();
	system("pause");
	return 0;
}

参考文章01
参考文章02

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值