PIE SDK地图平移校正
地图平移校正,当加载两幅空间参考一样的影像,其中一幅影像有点偏移,这时就以另一幅影像为基准将其进行平移校正,然后保存,再次加载就不会出现偏移了。
下面来介绍下实现的主要代码:
首先通过选中目录树中的要平移的图层,拖动图层进行平移校正,计算出图层平移的偏移量,然后修改栅格数据集的仿射变换参数的坐标即可,核心方法就是PIE SDK的SetOffset 和GetOffset方法;
平移校正的过程主要涉及到鼠标的MouseDown、MouseUp和MouseMove事件。
当鼠标按下,记录鼠标的坐标,为开始坐标点m_StartPoint,鼠标移动就记录鼠标移动的坐标,为结束坐标点m_EndPoint,两个坐标去差值就是图层当前偏移的距离,然后设置图层的偏移量SetOffset()就可以移动图层。要注意的是当移动一次的时候再在上一次移动的基础上进行移动,需要设置开始坐标点的坐标为鼠标按下的点加上地图上一次偏移的距离的和,具体过程如代码所示。
/// <summary>
/// 图层平移校正按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void tbn_PanConrrection_Click(object sender, EventArgs e)
{
//选中图层 根据目录树选中的图层为平移图层
IHookHelper hookHelper = new HookHelper();
hookHelper.Hook = mapControlMain;
IPmdContents pmdContents = hookHelper.GetContent();
PIETOCNodeTag tag = pmdContents.CustomerProperty as PIETOCNodeTag;
if (tag == null) return;
if (tag.Layer == null) return;
m_SelectedLayer = tag.Layer;
m_IsPan = true;
}
/// <summary>
/// 保存平移校正结果按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void btn_SavePan_Click(object sender, EventArgs e)
{
if (m_IsPan != true) return;
double offsetX = ;
double offsetY = ;
m_SelectedLayer.GetOffset(ref offsetX, ref offsetY);//获取偏移量 string filePath = m_SelectedLayer.DataSourcePath;
IRasterDataset RasterDataset = DatasetFactory.OpenRasterDataset(filePath, OpenMode.Update);
double[] geoTrans = RasterDataset.GetGeoTransform(); geoTrans[] = geoTrans[] - offsetX;
geoTrans[] = geoTrans[] - offsetY;
RasterDataset.SetGeoTransform(geoTrans);
(RasterDataset as IDisposable).Dispose();//将平移校正后的结果进行保存
MessageBox.Show("保存成功");
m_IsPan = false;
}/// <summary>
/// 还原按钮
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void tbn_CancelPan_Click(object sender, EventArgs e)
{
if (m_SelectedLayer == null) return;
m_SelectedLayer.SetOffset(, );
mapControlMain.ActiveView.PartialRefresh(ViewDrawPhaseType.ViewAll);
}
一、鼠标按下事件,触发MouseDown事件,记录开始坐标
/// <summary>
/// 鼠标按下
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void mapControlMain_MouseDown(object sender, MouseEventArgs e)
{
if (m_IsPan == false || m_SelectedLayer == null) return;
mapControlMain.CurrentTool = null;//防止点击平移等其他按钮冲突问题
m_StartPoint = mapControlMain.ActiveView.DisplayTransformation.ToMapPoint(e.X, e.Y);
double offsetX = ;
double offsetY = ;
m_SelectedLayer.GetOffset(ref offsetX, ref offsetY);//获取偏移量
m_StartPoint.PutCoords(m_StartPoint.X + offsetX, m_StartPoint.Y + offsetY);//在上一次移动的基础上继续平移
}
二、当鼠标在地图上移动时会触发MouseMove事件,计算平移量,设置图层平移
/// <summary>
/// 鼠标移动
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void mapControlMain_MouseMove(object sender, MouseEventArgs e)
{
if (m_IsPan == false) return;
if (m_StartPoint == null || m_SelectedLayer == null) return;
m_EndPoint = mapControlMain.ActiveView.DisplayTransformation.ToMapPoint(e.X, e.Y); double offsetX = ;
double offsetY = ;
//计算偏移量
offsetX = m_StartPoint.X - m_EndPoint.X;
offsetY = m_StartPoint.Y - m_EndPoint.Y; m_SelectedLayer.SetOffset(offsetX, offsetY);//设置图层平移
mapControlMain.ActiveView.PartialRefresh(ViewDrawPhaseType.ViewAll);
}
三、最后鼠标弹起时,将开始点的坐标设置为空。
/// <summary>
/// 鼠标弹起事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void mapControlMain_MouseUp(object sender, MouseEventArgs e)
{
m_StartPoint = null;
}
代码路径:
|
项目名称 |
百度云盘地址下/PIE示例程序/13.小工具集锦/地图平移校正/ MapPanCorrectionDemo |
|
数据路径 |
百度云盘地址下/PIE示例数据/栅格数据/04.World/World.tif |
|
视频路径 |
百度云盘地址下/PIE视频教程/13.小工具集锦/地图平移校正.avi |
注意:
在地图初始化的时候,图层树控件需要手动绑定地图控件:
tocControlMain.SetBuddyControl(mapControlMain as PIE.Carto.IPmdContents);
效果图:
加载时,China.tif在World.tif之上,两幅图坐标系一致,但是却没有重合

平移保存之后,再次加载:

PIE SDK地图平移校正的更多相关文章
- PIE SDK地图放大镜
放大镜,在地图的浏览过程中在主地图和次地图中起到很好的辅助作用, 要实现放大镜功能主要就是通过两个mapControl控件,主地图控件是mapControlMain,放大镜控件是UserControl ...
- PIE SDK地图范围设置
1.功能简介 地图范围设置主要就是对图层的地图浏览控制,例如地图的放大.缩小.漫游.全图显示.1:1视图.比例尺等功能,能更好的与地图有一个互动的地图浏览体验.PIE SDK对地图范围设置主要利用IC ...
- PIE SDK地图图层渲染方案管理
1. 功能简介 在数据种类较多.渲染规则复杂的情况下,逐个设置其渲染方式是一件繁琐的工作.PIE SDK提供了一种省力省心的办法, PIE SDK提供栅格和矢量数据渲染方案的打开与保存.能够将配色方案 ...
- PIE SDK地图鹰眼图
鹰眼图,是GIS的一个基本功能,在鹰眼图上可以像从空中俯视一样查看地图框中所显示的地图在整个图中的位置,是对全局地图的一种概述表达,能够起到很好的空间提示和导航的作用.网上有很多Arcengine 二 ...
- PIE SDK地图图层控制
1. 功能简介 地图图层控制就是图层的相关操作,如地图图层数据的添加.删除.移动和拖拽等功能. 2. 功能实现说明 2.1. 实现思路及原理说明 第一步 图层添加是调用AddLayer方法将图层添加到 ...
- PIE SDK地图范围设置和图层事件监听
1. 功能简介 地图范围设置的监听就是通过IMapControlEvents接口对地图的视图范围更新或者地图的分辨率发生变化进行监听,然后做出相应的操作. 图层事件的监听就是通过IActiveView ...
- PIE SDK地图显示范围截图
1.1. 功能简介 地图显示范围截图是将当前地图显示的范围进行输出.输出的 格式是png.bmp,主要思路就是通过IActiveView接口下的Output()方法进行输出 1.2. 功能实现说明 2 ...
- PIE SDK地图鼠标事件监听
1.功能简介 地图鼠标事件包含鼠标的按下MouseDown(),弹起MouseUp(),移动MouseMove()等事件,通过这些事件可以对地图进行动态的操作,接下来以地图状态栏的信息为例具体介绍如何 ...
- PIE SDK正射校正
1. 算法功能简介 正射校正是对影像空间和几何畸变进行校正生成多中心投影平面正射图像的处理过程.它除了能纠正一般系统因素产生的几何畸变外,还可以消除地形引起的几何畸变 PIE支持算法功能的执行,下面对 ...
随机推荐
- Mybatis_映射文件_Select
一.Select元素来定义查询操作 Id:唯一标识符.用来引用这条SQL语句,需要和接口的方法名一致 parameterType:参数类型.可以不传,MyBatis会根据TypeHandler自动推断 ...
- html页面源代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- Media Queries 媒体类型
引用方法:1.<link rel="stylesheet" type="text/css" href="style.css" medi ...
- 编写高质量代码改善C#程序的157个建议——建议45:为泛型类型参数指定逆变
建议45:为泛型类型参数指定逆变 逆变是指方法的参数可以是委托或者泛型接口的参数类型的基类.FCL4.0中支持逆变的常用委托有: Func<int T,out TResult> Predi ...
- delphi窗体启动外部exe
uses Winapi.Windows; WinExec(PAnsiChar(Application.ExeName), sw_normal); // PAnsiChar : string to ...
- 使用"*"通配符来选择文件
Include 方法和IncludeDirectory 方法中的搜索模式中指定的虚拟路径可以接受一个"*"通配符字符作为前缀或后缀,以在最后一个路径段.搜索字符串是大小写不敏感的. ...
- 远程连接linux服务上的mysql
如果有童鞋linux上还未安装mysql数据库可以参考我上一篇博客 (1)首先确保 linux服务上的 mysql 的3306端口是对外开放的 编辑 vi /etc/sysconfig/iptable ...
- scrapy 调试功能
在使用 scrapy 来爬取网页的时候,我们难免会使用到调试功能,下面介绍两种调试方法: 1.终端使用 scrapy shell exampleurl exampleurl 为你要爬取网站的 url ...
- model中的Meta类
通过一个内嵌类 "class Meta" 给你的 model 定义元数据, 类似下面这样: class Foo(models.Model): bar = models.CharFi ...
- C# 根据列名获取列值
/// <summary> /// 根据列名获取列值 /// </summary> /// <param name="colName">< ...