地图平移校正,当加载两幅空间参考一样的影像,其中一幅影像有点偏移,这时就以另一幅影像为基准将其进行平移校正,然后保存,再次加载就不会出现偏移了。

下面来介绍下实现的主要代码:

首先通过选中目录树中的要平移的图层,拖动图层进行平移校正,计算出图层平移的偏移量,然后修改栅格数据集的仿射变换参数的坐标即可,核心方法就是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地图平移校正的更多相关文章

  1. PIE SDK地图放大镜

    放大镜,在地图的浏览过程中在主地图和次地图中起到很好的辅助作用, 要实现放大镜功能主要就是通过两个mapControl控件,主地图控件是mapControlMain,放大镜控件是UserControl ...

  2. PIE SDK地图范围设置

    1.功能简介 地图范围设置主要就是对图层的地图浏览控制,例如地图的放大.缩小.漫游.全图显示.1:1视图.比例尺等功能,能更好的与地图有一个互动的地图浏览体验.PIE SDK对地图范围设置主要利用IC ...

  3. PIE SDK地图图层渲染方案管理

    1. 功能简介 在数据种类较多.渲染规则复杂的情况下,逐个设置其渲染方式是一件繁琐的工作.PIE SDK提供了一种省力省心的办法, PIE SDK提供栅格和矢量数据渲染方案的打开与保存.能够将配色方案 ...

  4. PIE SDK地图鹰眼图

    鹰眼图,是GIS的一个基本功能,在鹰眼图上可以像从空中俯视一样查看地图框中所显示的地图在整个图中的位置,是对全局地图的一种概述表达,能够起到很好的空间提示和导航的作用.网上有很多Arcengine 二 ...

  5. PIE SDK地图图层控制

    1. 功能简介 地图图层控制就是图层的相关操作,如地图图层数据的添加.删除.移动和拖拽等功能. 2. 功能实现说明 2.1. 实现思路及原理说明 第一步 图层添加是调用AddLayer方法将图层添加到 ...

  6. PIE SDK地图范围设置和图层事件监听

    1. 功能简介 地图范围设置的监听就是通过IMapControlEvents接口对地图的视图范围更新或者地图的分辨率发生变化进行监听,然后做出相应的操作. 图层事件的监听就是通过IActiveView ...

  7. PIE SDK地图显示范围截图

    1.1. 功能简介 地图显示范围截图是将当前地图显示的范围进行输出.输出的 格式是png.bmp,主要思路就是通过IActiveView接口下的Output()方法进行输出 1.2. 功能实现说明 2 ...

  8. PIE SDK地图鼠标事件监听

    1.功能简介 地图鼠标事件包含鼠标的按下MouseDown(),弹起MouseUp(),移动MouseMove()等事件,通过这些事件可以对地图进行动态的操作,接下来以地图状态栏的信息为例具体介绍如何 ...

  9. PIE SDK正射校正

    1. 算法功能简介 正射校正是对影像空间和几何畸变进行校正生成多中心投影平面正射图像的处理过程.它除了能纠正一般系统因素产生的几何畸变外,还可以消除地形引起的几何畸变 PIE支持算法功能的执行,下面对 ...

随机推荐

  1. 5.python之pip安装模块失败

    本文是篇水文,主要是在学习python过程中总是遇到使用pip安装一些模块失败,记录一下安装模块解决办法 第一种方法: 首先安装wheel模块: pip install wheel 如果wheel都安 ...

  2. Mysql CURD复习(数据库、表、数据)

    ###############################数据库的CURD:C: create database if not exists tp5_test default charset ut ...

  3. 第07章-Spring MVC 的高级技术

    Spring MVC 的高级技术 1. Spring MVC配置的替代方案 1.1 自定义DispatcherServlet配置 AbstractAnnotationConfigDispatcherS ...

  4. java 异常捕获与异常处理

    try{会产生异常的代码 }catch(出现异常的类型 e){ 异常出现后处理的方法 } 一旦异常出现又没有异常处理,程序就会中断. public static void main(String[] ...

  5. (转)MongoDB入门分享-笔记整理精选

    原文地址:http://www.cnblogs.com/Kummy/p/3372729.html 最近在学习MongoDB,怕以后忘记,自己做了一个整理,给不知道的小伙伴一起分享学习一下. 第一步&g ...

  6. Mathematical optimization数学上的最优化

    https://en.wikipedia.org/wiki/Mathematical_optimization In mathematics, computer science and operati ...

  7. bufferedReader与StringReader

    bufferedReader 这么说吧,这个类就是一个包装类,它可以包装字符流,将字符流放入缓存里,先把字符读到缓存里,到缓存满了或者你flush的时候,再读入内存,就是为了提供读的效率而设计的. S ...

  8. [原创]Java源代码学习

    一.一些关键字 方法声明中的native:调用本地方法,该方法一般是用C或者C++写的 变量声明中的transient:在序列化过程中会忽略该变量,即不进行序列化保存 变量声明中的volatile:编 ...

  9. Android 应用检查更新并下载

    1.在Android应用当中都有应用检查更新的要求,往往都是在打开应用的时候去更新下载. 实现的方法是:服务器端提供接口,接口中可以包含在最新APK下载的URL,最新APK的VersionCode,等 ...

  10. 干掉MessageBox,自定义弹出框JMessbox (WindowsPhone)

    先上效果图                                               QQ退出效果                                           ...