找回密码
 立即注册

QQ登录

只需一步,快速开始

扫一扫,访问微社区

查看: 628|回复: 0

[每日一码] 不使用第三方库读取GEOTIFF卫星影像生成WORD FILE

[复制链接]

已领礼包: 40个

财富等级: 招财进宝

发表于 2021-1-13 21:08:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
本帖最后由 newer 于 2021-1-13 21:11 编辑

world file 是由地理信息系统(GIS)用于地理参考栅格地图图像的六行纯文本Sidecar文件。 文件规范由Esri [1] [2]引入,由仿射变换的六个系数组成,这些系数描述了地图上栅格的位置,比例和旋转.



  1. /// <summary>
  2.     /// Create tfw - world file.
  3.     /// </summary>
  4.     /// <param name="filename">tif image full filename</param>
  5.     private void CreateWorldFile(string filename)
  6.     {
  7.         using (var bitmapImage = new Bitmap(filename))
  8.         {
  9.             PropertyItem[] imageProps = bitmapImage.PropertyItems;

  10.             var modelscale = imageProps.First(a => a.Id == GEOTIFF_MODELPIXELSCALETAG);
  11.             var tiepoint = imageProps.First(a => a.Id == GEOTIFF_MODELTIEPOINTTAG);

  12.             double x = BitConverter.ToDouble(tiepoint.Value, 0 + 24);
  13.             double y = BitConverter.ToDouble(tiepoint.Value, 0 + 32);

  14.             double xscale = BitConverter.ToDouble(modelscale.Value, 0);
  15.             double yscale = BitConverter.ToDouble(modelscale.Value, 0 + 8);

  16.             string tfwFileName = Path.GetDirectoryName(filename) + "\\" + Path.GetFileNameWithoutExtension(filename) + ".tfw";

  17.             using (System.IO.StreamWriter file = new System.IO.StreamWriter(tfwFileName))
  18.             {
  19.                 file.WriteLine(xscale);
  20.                 file.WriteLine("0.0");
  21.                 file.WriteLine("0.0");
  22.                 file.WriteLine(yscale);
  23.                 file.WriteLine(x);
  24.                 file.WriteLine(y);
  25.             }
  26.         }
  27.     }

  28.     private readonly int GEOTIFF_MODELPIXELSCALETAG = 33550;
  29.     private readonly int GEOTIFF_MODELTIEPOINTTAG = 33922;


论坛插件加载方法
发帖求助前要善用【论坛搜索】功能,那里可能会有你要找的答案;
如果你在论坛求助问题,并且已经从坛友或者管理的回复中解决了问题,请把帖子标题加上【已解决】;
如何回报帮助你解决问题的坛友,一个好办法就是给对方加【D豆】,加分不会扣除自己的积分,做一个热心并受欢迎的人!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|申请友链|Archiver|手机版|小黑屋|辽公网安备|晓东CAD家园 ( 辽ICP备15016793号 )

GMT+8, 2024-9-28 06:23 , Processed in 0.156536 second(s), 28 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表