Qt + gdal读取geotiff头文件

Qt + gdal 读取geotiff头文件

.pro文件增加:

INCLUDEPATH += E:/opencv/build/include
CONFIG(debug, debug|release):{
LIBS += -LE:/opencv/build/x86/vc10/lib \
-lopencv_core2411d \
-lopencv_imgproc2411d \
-lopencv_highgui2411d \
-lopencv_ml2411d \
-lopencv_video2411d \
-lopencv_features2d2411d \
-lopencv_calib3d2411d \
-lopencv_objdetect2411d \
-lopencv_contrib2411d \
-lopencv_legacy2411d \
-lopencv_flann2411d
}
else:CONFIG(release, debug|release): {
LIBS += -LE:/opencv/build/x86/vc10/lib \
-lopencv_core2411 \
-lopencv_imgproc2411 \
-lopencv_highgui2411 \
-lopencv_ml2411 \
-lopencv_video2411 \
-lopencv_features2d2411 \
-lopencv_calib3d2411 \
-lopencv_objdetect2411 \
-lopencv_contrib2411 \
-lopencv_legacy2411 \
-lopencv_flann2411
}


win32: LIBS += -LE:/GDAL/lib/ -lgdal_i
INCLUDEPATH +=E:/GDAL/include
DEPENDPATH +=E:/GDAL/include

代码

#pragma execution_cha
racter_set("utf-8")
#include <vector>
#include <QDebug>
#include <QVector>
#include <QMetaType>
#include <cmath>
#include <algorithm>
#include <math.h>
#include "gdal_priv.h"
#include <ogr_spatialref.h>
#include < QTextCodec >
#include < QFile >

using namespace std;

void main(int argc, char *argv[])
{
    GDALAllRegister();
    CPLSetConfigOption("GDAL_FILENAME_IS_UTF8","NO");
    QTextCodec::setCodecForLocale(QTextCodec::codecForName("GBK"));
    GDALDataset *pData=NULL;
    QString filename = "H:/SAR_1_8.tif";
    QFile ff(filename);
    if(!ff.exists())
    {
        qDebug()<<"原始数据文件读取失败";
//        QMessageBox::information(NULL, "Information", "原始数据头文件读取失败", QMessageBox::Yes, QMessageBox::Yes);
        return  ;

    }
    else{
         qDebug()<<"原始数据文件读取ok";
    }

    filename.replace("/","\\");
    //QByteArray ba =filename.toLatin1(); // must
    QByteArray ba = filename.toLocal8Bit();
    char* ch=ba.data();
    pData=(GDALDataset*)GDALOpen(ch,GA_ReadOnly);
    if(pData==NULL)
    {
        qDebug()<<"原始数据头文件读取失败";
//        QMessageBox::information(NULL, "Information", "原始数据读取失败", QMessageBox::Yes, QMessageBox::Yes);
        return ;
    }
    else{
          qDebug()<<"原始数据头文件读取ok";
    }

    int nBand=pData->GetRasterCount();//波段数
    qDebug()<<"nBand"<<nBand;
    if(nBand!=1)
    {
        qDebug()<<"原始数据文件非单通道";
//        QMessageBox::information(NULL, "Information", "原始数据文件非单通道", QMessageBox::Yes, QMessageBox::Yes);
        return ;
    }
    qDebug()<<"列数"<<pData->GetRasterXSize();
    qDebug()<<"行数"<<pData->GetRasterYSize();
    double adfGeoTransform[6];
    pData->GetGeoTransform( adfGeoTransform);

    qDebug()<<"5"<< adfGeoTransform[5];
    qDebug()<<"1"<< adfGeoTransform[1];
    qDebug()<<"3"<< adfGeoTransform[3];
    
    return  ;
}
  • 0
    点赞
  • 0
    收藏
  • 打赏
    打赏
  • 0
    评论
<p class="MsoNormal"><span style="mso-spacerun: 'yes'; font-family: 宋体; mso-ascii-font-family: Calibri; mso-hansi-font-family: Calibri; mso-bidi-font-family: 'Times New Roman'; font-size: 10.5000pt; mso-font-kerning: 1.0000pt;"><span style="font-family: 宋体;">本课程主要结合</span><span style="font-family: Calibri;">Python</span><span style="font-family: 宋体;">语言,讲解</span><span style="font-family: Calibri;">GDAL</span><span style="font-family: 宋体;">的空间数据处理入门知识。通过学习理论知识并结合我在实际工作中中用到的一些案例程序进行讲解,例如遥感影像分块处理、计算植被指数、深度学习样本制作、栅格矢量化等,做到学以致用,提高学习和工作效率。</span></span></p> <p class="MsoNormal"><span style="mso-spacerun: 'yes'; font-family: 宋体; mso-ascii-font-family: Calibri; mso-hansi-font-family: Calibri; mso-bidi-font-family: 'Times New Roman'; font-size: 10.5000pt; mso-font-kerning: 1.0000pt;"><span style="font-family: 宋体;"><img src="https://img-bss.csdnimg.cn/202111080426391115.png" alt="" /></span></span></p> <p class="MsoNormal"><img src="https://img-bss.csdnimg.cn/202111080124033833.png" alt="深度学习样本制作" /></p> <p class="MsoNormal"><img src="https://img-bss.csdnimg.cn/202111080126198077.jpg" alt="栅格矢量化" /></p> <p class="MsoNormal"><img src="https://img-bss.csdnimg.cn/202111080126465224.png" alt="矢量化的不同效果对比" /></p>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:大白 设计师:CSDN官方博客 返回首页
评论

打赏作者

勾勾黄

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值