GDAL中通过GDALDriver类的Create函数实现图像的保存
GDAL中除了读取各种类型的图像外,也可以实现对各种图像的保存操作,具体实现测试代码如下:
int test_gadl_GDALDataset_write()
{
const char* image_name = "E:/GitCode/GDAL_Test/test_images/1.jpg";
{ // write bgr: CreateCopy
GDALAllRegister();
const char* pszFormat = "jpeg"; //"bmp";// "png";//"GTiff";
GDALDriver* poDriver = GetGDALDriverManager()->GetDriverByName(pszFormat);
if (!poDriver) {
fprintf(stderr, "get driver by name failed\n");
return -1;
}
char** papszMetadata = poDriver->GetMetadata();;
if (CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATE, FALSE))
fprintf(stderr, "Driver %s supports Create() method.\n", pszFormat);
if (CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATECOPY, FALSE))
fprintf(stderr, "Driver %s supports CreateCopy() method.\n", pszFormat);
if (!CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATECOPY, FALSE)) {
fprintf(stderr, "Driver %s don't supports CreateCopy() method.\n", pszFormat);
return -1;
}
GDALDataset* poDataset = (GDALDataset*)GDALOpen(image_name, GA_ReadOnly);
if (poDataset == nullptr) {
std::cout << "input image error" << std::endl;
return -1;
}
const char* pszDstFilename = "E:/GitCode/GDAL_Test/test_images/ret_1.jpg";
// All drivers that support creating new files support the CreateCopy() method, but only a few support the Create() method
GDALDataset* poDstDS = poDriver->CreateCopy(pszDstFilename, poDataset, FALSE, nullptr, nullptr, nullptr);
if (!poDstDS) {
std::cout << "create copy failed" << std::endl;
return -1;
}
GDALClose((GDALDatasetH)poDataset);
GDALClose((GDALDatasetH)poDstDS);
}
{ // write: bgr<->rgb
GDALAllRegister();
const char* pszFormat = "GTiff";
GDALDriver* poDriver = GetGDALDriverManager()->GetDriverByName(pszFormat);
if (!poDriver) {
fprintf(stderr, "get driver by name failed\n");
return -1;
}
char** papszMetadata = poDriver->GetMetadata();;
if (!CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATE, FALSE)) {
fprintf(stderr, "Driver %s don't supports Create() method.\n", pszFormat);
return -1;
}
GDALDataset* poDataset = (GDALDataset*)GDALOpen(image_name, GA_ReadOnly);
if (poDataset == nullptr) {
std::cout << "input image error" << std::endl;
return -1;
}
int width = poDataset->GetRasterXSize();
int height = poDataset->GetRasterYSize();
int band_count = poDataset->GetRasterCount();
GDALDataType gdal_data_type = poDataset->GetRasterBand(1)->GetRasterDataType();
int pBandMap[3] = { 1, 2, 3 };
unsigned char* pData = new unsigned char[width * height * band_count]; //RRRR...BBBB...GGGG...
poDataset->RasterIO(GF_Read, 0, 0, width, height, pData, width, height, gdal_data_type, band_count, pBandMap, 0, 0, 0);
char** papszOptions = nullptr;
papszOptions = CSLSetNameValue(papszOptions, "INTERLEAVE", "BAND");
const char* pszDstFilename = "E:/GitCode/GDAL_Test/test_images/ret_2.jpg";
GDALDataset* poDstDS = poDriver->Create(pszDstFilename, width, height, band_count, gdal_data_type, papszOptions);
if (!poDstDS) {
std::cout << "create copy failed" << std::endl;
return -1;
}
int pBandMap_[3] = { 3, 2, 1 };
poDstDS->RasterIO(GF_Write, 0, 0, width, height, pData, width, height, gdal_data_type, band_count, pBandMap_, 0, 0, 0);
GDALClose((GDALDatasetH)poDataset);
GDALClose((GDALDatasetH)poDstDS);
delete[] pData;
}
{ // write: bgr->b, single channel
GDALAllRegister();
const char* pszFormat = "GTiff";
GDALDriver* poDriver = GetGDALDriverManager()->GetDriverByName(pszFormat);
if (!poDriver) {
fprintf(stderr, "get driver by name failed\n");
return -1;
}
char** papszMetadata = poDriver->GetMetadata();;
if (!CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATE, FALSE)) {
fprintf(stderr, "Driver %s don't supports Create() method.\n", pszFormat);
return -1;
}
GDALDataset* poDataset = (GDALDataset*)GDALOpen(image_name, GA_ReadOnly);
if (poDataset == nullptr) {
std::cout << "input image error" << std::endl;
return -1;
}
int width = poDataset->GetRasterXSize();
int height = poDataset->GetRasterYSize();
int band_count = poDataset->GetRasterCount();
GDALDataType gdal_data_type = poDataset->GetRasterBand(1)->GetRasterDataType();
unsigned char* pData = new unsigned char[width * height];
GDALRasterBand* poBand = poDataset->GetRasterBand(2); // from 1 to GetRasterCount()
poBand->RasterIO(GF_Read, 0, 0, width, height, pData, width, height, gdal_data_type, 0, 0, 0);
char** papszOptions = nullptr;
papszOptions = CSLSetNameValue(papszOptions, "INTERLEAVE", "BAND");
const char* pszDstFilename = "E:/GitCode/GDAL_Test/test_images/ret_3.jpg";
GDALDataset* poDstDS = poDriver->Create(pszDstFilename, width, height, 1, gdal_data_type, papszOptions);
if (!poDstDS) {
std::cout << "create copy failed" << std::endl;
return -1;
}
int bandMap { 1 };
poDstDS->RasterIO(GF_Write, 0, 0, width, height, pData, width, height, gdal_data_type, 1, &bandMap, 0, 0, 0);
GDALClose((GDALDatasetH)poDataset);
GDALClose((GDALDatasetH)poDstDS);
delete[] pData;
}
{ // write: crop image
GDALAllRegister();
const char* pszFormat = "GTiff";
GDALDriver* poDriver = GetGDALDriverManager()->GetDriverByName(pszFormat);
if (!poDriver) {
fprintf(stderr, "get driver by name failed\n");
return -1;
}
char** papszMetadata = poDriver->GetMetadata();;
if (!CSLFetchBoolean(papszMetadata, GDAL_DCAP_CREATE, FALSE)) {
fprintf(stderr, "Driver %s don't supports Create() method.\n", pszFormat);
return -1;
}
GDALDataset* poDataset = (GDALDataset*)GDALOpen(image_name, GA_ReadOnly);
if (poDataset == nullptr) {
std::cout << "input image error" << std::endl;
return -1;
}
int width = poDataset->GetRasterXSize() / 2;
int height = poDataset->GetRasterYSize() / 2;
int band_count = poDataset->GetRasterCount();
GDALDataType gdal_data_type = poDataset->GetRasterBand(1)->GetRasterDataType();
unsigned char* pData = new unsigned char[width * height * band_count];
int pBandMap[3] = { 1, 2, 3 };
poDataset->RasterIO(GF_Read, 0, 0, width, height, pData, width, height, gdal_data_type, band_count, pBandMap, 0, 0, 0);
const char* pszDstFilename = "E:/GitCode/GDAL_Test/test_images/ret_4.jpg";
GDALDataset* poDstDS = poDriver->Create(pszDstFilename, width, height, band_count, gdal_data_type, nullptr);
if (!poDstDS) {
std::cout << "create copy failed" << std::endl;
return -1;
}
poDstDS->RasterIO(GF_Write, 0, 0, width, height, pData, width, height, gdal_data_type, band_count, pBandMap, 0, 0, 0);
GDALClose((GDALDatasetH)poDataset);
GDALClose((GDALDatasetH)poDstDS);
delete[] pData;
}
return 0;
}
GitHub:https://github.com/fengbingchun/GDAL_Test
GDAL中通过GDALDriver类的Create函数实现图像的保存的更多相关文章
- C++中怎么获取类的成员函数的函数指针?
用一个实际代码来说明. class A { public: staticvoid staticmember(){cout<<"static"<<endl;} ...
- VC/MFC中通过CWebPage类调用javascript函数(给js函数传参,并取得返回值)
转自:http://www.cnblogs.com/javaexam2/archive/2012/07/14/2632959.html ①需要一个别人写好的类CWebPage,将其对于的两个文件Web ...
- CImageList类Create函数参数解析
前面提到了CImageList类的Create(...)函数,虽然MSDN上已经有所解释,但仍有网友问到参数的具体含义,下面就我的理解,对参数进行一次轻量级的剖析 函数原型(其他重载函数请参看msdn ...
- Cocos2d-x Lua中Sprite精灵类
精灵类是Sprite,它的类图如下图所示. Sprite类图 Sprite类直接继承了Node类,具有Node基本特征.此外,我们还可以看到Sprite类的子类有:PhysicsSprite和Skin ...
- 【转载】C++中的基类与派生类
转自:http://www.cnblogs.com/sujz/articles/2044365.html 派生类的继承方式总结: 继承方式 说明 public 基类的public和protected的 ...
- C++中的基类与派生类
派生类的继承方式总结: 继承方式 说明 public 基类的public和protected的成员被派生类继承后,保持原来的状态 private 基类的public和protected的成员被派生类继 ...
- C++中的基类和派生类
转载自:http://www.cnblogs.com/sujz/archive/2011/05/12/2044365.html 派生类的继承方式总结: 继承方式 说明 public 基类的public ...
- Oracle数据库中调用Java类开发存储过程、函数的方法
Oracle数据库中调用Java类开发存储过程.函数的方法 时间:2014年12月24日 浏览:5538次 oracle数据库的开发非常灵活,不仅支持最基本的SQL,而且还提供了独有的PL/SQL, ...
- javascript中如何让类工厂和构造函数变成同一个函数
我们知道在js中可以用一个函数来定义对象的类,该函数称之为对象的构造函数,我们在需要create对象的时候直接调用这个构造函数即可: var Man = funciton(name){ this.na ...
随机推荐
- iOS 技能分类:
1.语言与系统: 2.架构与机制: 3.性能:cpu.gpu.io.缓存.内存:性能监测工具: 4.知名开源库:
- BZOJ3781:小B的询问(莫队)
Description 小B有一个序列,包含N个1~K之间的整数.他一共有M个询问,每个询问给定一个区间[L..R],求Sigma(c(i)^2)的值,其中i的值从1到K,其中c(i)表示数字i在[L ...
- Xiaocms验证码绕过分析
事实证明这套程序验证码没有办法存在绕过.具体分析在t00ls上.但是这套程序获取验证码的逻辑是存在问题的,思路是可以借鉴的. 第一次请求后台是,红线位置是请求验证码的url. 当我们第一次请求时,也就 ...
- DP入门——01背包 & 完全背包
01背包: 采药: https://www.luogu.org/problemnew/show/P1048 #include <iostream> #include <algorit ...
- Microsoft visual c++ 14.0 is required问题
错误信息: error: Microsoft Visual C++ 14.0 is required. Get it with "Microsoft Visual C++ Build Too ...
- php版本跟扩展模块版本不兼容问题
安装redis扩展后查看时候出现了这样报错: [root@localhost phpredis-develop]# php -m | grep redisPHP Warning: PHP Startu ...
- Reading Fast Packet Processing A Survey
COMST 2018 主要内容 这是一篇有关快速包转发的综述,先介绍了包转发的有关基础知识和背景,具体介绍了包转发的主流方法,对这些方法进行了细致详尽的比较,最后介绍了最新的方法和未来的研究方向. 包 ...
- 支付宝在ios应用上的开发[转]
前奏 现在随着移动开发的快速发展,越来越多的应用要求在线支付功能.最近做了一个关于支付宝支付功能的应用,在使用支付宝的过程中,遇到一些不必要的弯路,因此,写了这篇文章总结一下关于ios开发如何使用支付 ...
- mpvue微信小程序开发随笔
mpvue上手很快,学习成本低,目前是开源的,适合技术实力不是很强的公司采用. spring boot 做后台,开发效率杠杠的.建议会java的开发尽量使用spring boot 开发,省事. 最近用 ...
- TCL-事务
一.含义事务:一条或多条sql语句组成一个执行单位,一组sql语句要么都执行要么都不执行二.特点(ACID)A 原子性:一个事务是不可再分割的整体,要么都执行要么都不执行C 一致性:一个事务可以使数据 ...