日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

C# GDAL 学习一

發(fā)布時(shí)間:2023/11/27 生活经验 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C# GDAL 学习一 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

最近一直琢磨如何用C#+GDAL讀取柵格數(shù)據(jù)(.tif.img),運(yùn)氣不錯(cuò)的在GDAL 的官網(wǎng)上找到一部分源碼。經(jīng)過本人測(cè)試,效果還不錯(cuò)。學(xué)習(xí)還將繼續(xù)深入下去。

參考網(wǎng)址:http://trac.osgeo.org/gdal/browser/trunk/gdal/swig/csharp/apps/GDALRead.cs

開發(fā)環(huán)境:VS2008+GDAL1.5

所需dll gdal15.dllgdal_csharp.dllgdal_wrap.dllgdalconst_csharp.dllgdalconst_warp.dll

一、將以上.dll添加到工程bin\debug目錄下。

二、建立控制臺(tái)程序,添加gdal_csharp引用。如圖

?

三、工程GDALRead處右鍵打開屬性對(duì)話框,調(diào)試一欄添加命令行參數(shù),如圖:

?

這里的命令行參數(shù)在程序中直接被數(shù)組args[]調(diào)用。

四、任務(wù)與目標(biāo)

(1)、讀取柵格數(shù)據(jù)的一般參數(shù),如坐標(biāo)投影(Projection)、波段數(shù)(Rsatercount)、數(shù)據(jù)驅(qū)動(dòng)、柵格大小(RasterSize)

(2)、每個(gè)波段的數(shù)據(jù)類型(DataType)、大小(Size)、PaletteInterp

五、完整代碼

?

View Code ?1?using?System;
?2?using?System.Collections.Generic;
?3?using?System.Linq;
?4?using?System.Text;
?5?using?OSGeo.GDAL;
?6?namespace?GDALRead
?7?{
?8?????class?Program
?9?????{
10?????????public?static?void?usage()
11?????????{
12?????????????Console.WriteLine("usage");
13?????????????System.Environment.Exit(-1);
14?????????}
15??????public??static?void?Main(string[]?args)
16?????????{
17?????????????//Console.WriteLine(args[0]);
18?????????????//Console.ReadLine();
19??????????try
20??????????{
21??????????????Gdal.AllRegister();
22??????????????Dataset?ds?=?Gdal.Open(args[0],Access.GA_ReadOnly);
23??????????????if?(ds==null)
24??????????????{
25?????????????????Console.WriteLine("Can't?open?"?+?args[0]);?
26??????????????????System.Environment.Exit(-1);?
27??????????????}
28??????????????Console.WriteLine("raster?dataset?parameters:");
29??????????????Console.WriteLine("??Projection:"?+?ds.GetProjectionRef());
30??????????????Console.WriteLine("??Rastercount:"?+?ds.RasterCount);//RasterCount是波段數(shù)
31??????????????Console.WriteLine("??RasterSize?("?+?ds.RasterXSize?+?","?+?ds.RasterYSize?+?")");
32?
33??????????????/************************************************************************/
34??????????????/*?Get?Driver?????????????????????????????????????????????????????????????????????*/
35??????????????/************************************************************************/
36??????????????Driver?drv?=?ds.GetDriver();
37??????????????if?(drv?==null)
38??????????????{
39??????????????????Console.WriteLine("Can't?get?driver");
40??????????????????System.Environment.Exit(-1);
41??????????????}
42??????????????Console.WriteLine("using?driver"?+?drv.LongName);
43??????????????/************************************************************************/
44??????????????/*?Get?raster?band????????????????????????????????????????????????????????????????????*/
45??????????????/************************************************************************/
46??????????????for?(int?iBand=1;iBand<=ds.RasterCount;iBand++)
47??????????????{
48??????????????????Band?band?=?ds.GetRasterBand(iBand);
49??????????????????Console.WriteLine("Band"?+?iBand?+?":");
50??????????????????Console.WriteLine("???DataType:"?+?band.DataType);
51??????????????????Console.WriteLine("???Size?("?+?band.XSize?+?","?+?band.YSize?+?")");
52?????????????????Console.WriteLine("???PaletteInterp:?"?+?band.GetRasterColorInterpretation().ToString());?//調(diào)色說明?
53?
54?????????????????for?(int?iOver?=?0;?iOver?<?band.GetOverviewCount();?iOver++)
55?????????????????{
56?????????????????????Band?over?=?band.GetOverview(iOver);
57?????????????????????Console.WriteLine("??????OverView?"?+?iOver?+?"?:");
58?????????????????????Console.WriteLine("?????????DataType:?"?+?over.DataType);
59?????????????????????Console.WriteLine("?????????Size?("?+?over.XSize?+?","?+?over.YSize?+?")");
60?????????????????????Console.WriteLine("?????????PaletteInterp:?"?+?over.GetRasterColorInterpretation().ToString());
61?????????????????}?
62?
63??????????????}
64??????????????/************************************************************************/
65??????????????/*?Processing?the?raster????
66???????????????*?To?be?continued
67??????????????/************************************************************************/
68?
69??????????}
70??????????????
71??????????catch?(System.Exception?ex)
72??????????{
73??????????????Console.WriteLine("Application?error:?"?+?ex.Message);
74??????????}
75??????????Console.ReadLine();
76?????????}
77?????}
78?}

六、運(yùn)行結(jié)果

我找了一幅.img的遙感影像,不含投影坐標(biāo),運(yùn)行結(jié)果如下:

?

轉(zhuǎn)載于:https://www.cnblogs.com/ming5536/archive/2011/05/30/ming5536.html

總結(jié)

以上是生活随笔為你收集整理的C# GDAL 学习一的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。