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支持算法功能的执行,下面对 ...
随机推荐
- Linux下的strerror是否线程安全?
下列是glibc-2.14中的源代码: 点击(此处)折叠或打开 char * strerror (errnum) int errnum; { char *ret = __strerror_r (err ...
- HttpClient connectionTimeout
转自:http://www.cnblogs.com/carlosk/archive/2013/03/12/2956502.html 前几天服务器端的产品经理跑来问我是否有做请求超时和响应超时的处理.我 ...
- Hibernate不能建表的问题
项目使用hibernate进行正向工程建立表,各项配置都正确,但就是不能生成对应的表,这就纳闷了!! 类: public class Market { private Long id; private ...
- poj1860 Currency Exchange(spfa判断正环)
Description Several currency exchange points are working in our city. Let us suppose that each point ...
- oracle 中 创建序列sequence
drop sequence SEQ_YCXWP_CGD; create sequence SEQ_YCXWP_CGD increment start nomaxvalue;
- if 判断
语法一: if 条件: #条件成立时执行的字代码块 代码1 代码2 代码3 示例: sex='female' age=18 is_beautiful=True if sex == 'female' a ...
- 比特币技术之迷-Transaction 交换
Transaction 交换每个客户端都会广播本地生成的Transaction,并转给来自其它节点的Transaction,本文主要描述Transaction之间的交换与流转过程. 大家也可以阅读以下 ...
- CRC-32 校验算法
crc32的头文件 ===========================分割线=========================== //crc32.h #ifndef _CRC32_H #de ...
- Vue 编程式导航,路由history模式
import Vue from 'vue' import App from './App.vue' import Home from './components/Home.vue' import Ne ...
- C#时常需要调用C++DLL
在合作开发时,C#时常需要调用C++DLL,当传递参数时时常遇到问题,尤其是传递和返回字符串是,现总结一下,分享给大家: VC++中主要字符串类型为:LPSTR,LPCSTR, LPCTSTR, st ...