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  ;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值