最近刚好因为一些原因整理这方面的内容,所以还是把这篇鸽了一年多的博客顺手写出来了∠( ᐛ 」∠)_。因为是当时课程设计的一部分,程序上难免会有一些不足和bug,在这里将设计的思路分享给大家。

本篇博客的代码可以在我的github项目中查看:https://github.com/NewBearEar/Magnifying-azimuthal

关于matlab地图投影系列:

MATLAB地图工具箱学习心得(一)关于地图分带投影的拼接


一、定义坐标变换的方程

首先在matlab安装目录E:\MATLAB2016a\toolbox\map\mapproj\private\位置找到在方位投影中进行坐标变换的函数applyAzimuthalProjection.m,即在对应如图所示函数的应用之下,它将方位投影函数中的大地坐标转换为球面极坐标。

图1 球面极坐标转换函数

于是为了实现放大镜效果,可以利用如下公式对方位角进行判断,从而得到“放大镜”式的等距离方位投影效果。

图2 “放大镜”效果天顶距公式

为了实现该公式,并且不改变原有的mappingtoolbox工具箱结构,将applyAzimuthalProjection.m的内容复制作为applyMagnifyingAzimuthalProjection函数(applyMagnifyingAzimuthalProjection.m文件),并在其applyForward函数中添加如下代码,实现“放大镜”式的等距离方位投影的坐标变换公式:

%用msturct传递参数rng_val=zeros(size(rng));rngz1=mstruct.rngz1;%缩小系数ge=mstruct.zoom_factor;for j=1:size(rng,1)for k=1:size(rng,2)rng_val(j,k)=rng(j,k);if rng(j,k)>rngz1rng_val(j,k)=rngz1+(rng(j,k)-rngz1).*ge;endendendrng=rng_val;

图3 applyMagnifyingAzimuthalProjection.m文件applyForward函数中添加变换公式

​ 但值得注意的是,有时mappingtoolbox工具箱可能会对新添加的private函数(如applyMagnifyingAzimuthalProjection函数)产生找不到函数的问题,如果出现这种情况就只能直接修改工具箱的applyAzimuthalProjection.m的内容了。

二、通过mstruct传递自定义参数

​ (1)由于matlab的mappingtoolbox的任意一个投影都是通过mstruct定义包括投影中心,旋转情况,标准纬线等属性,在调用投影变换时也是直接传入 mstruct 并调用一些相应的方法(由于 msturct 只是一个结构体,而不是类,其方法与结构体本身是分离的,所有大多数方法都是传入一个 mstruct 作为参数)

E:\MATLAB2016a\toolbox\map\mapdisp\private中有 mstruct 的初始化文件 initmstruct.m,在这个文件中定义了 mstruct,如果需要传递参数,可以通过修改 mstruct的结构,他承载并传递一些其他自定义参数。为了实现“放大镜”式的等距离方位投影,需要rngz1作为内圆极距(公式中的z1),zoom_factor作为内外圆间的比例尺缩小系数(公式中的ge)。因此,在mstruct中定义如下参数并初始化。

图4 initmstruct.m中需要添加的mstruct成员变量

(2)由于mstruct属于私有域,所以需要在axesm.m文件中添加自定义的setter方法,并在其setprop方法中调用setter方法设置mstruct。

图5 axesm.m文件中添加自定义的setter方法

图6 axesm.m文件setprop方法中调用setter方法设置mstruct

三、定义并注册地图投影

程序采用的是等距离方位投影制作具有“放大镜”效果的地图投影程序,因此可以直接在ortho投影的基础上进行复制,然后修改,自定义投影variable_ortho.m。

自定义投影的方法是在 E:\MATLAB2016a\toolbox\map\mapproj 路径添加自定义的 m 文件(variable_ortho.m)

图7 variable_ortho.m文件调用之前定义的applyMagnifyingAzimuthalProjection函数

然后在E:\MATLAB2016a\toolbox\map\mapproj路径下maplist.m 文件中,将自定义的variable_ortho投影进行注册,如下图所示:

图8 maplist.m文件注册自定义投影

这里同样要注意的是,有时mappingtoolbox工具箱莫名其妙找不到新注册的自定义投影,所以,如果遇到这种情况,大概就只得在已有投影(例如ortho.m)上进行修改了。

四、定义并注册地图投影

GUIDE是指matlab用于设计GUI (图形用户界面) 的工具环境。GUIDE做GUI的学习成本很低,具有直观和低门槛的优点,虽然用GUIDE做出来的程序可维护性很糟糕,但用于设计这样一个简单的具有位置拾取功能的投影程序绰绰有余(主要是简单),所以这里利用matlab的GUIDE来设计GUI程序。关于GUIDE的使用方法和GUI界面设计不是重点,这里就不过多阐述了,GUI程序写在variable_program.m和variable_program.fig文件,有兴趣的朋友可以参考。

其中“开始选择点”按钮,用于调用坐标拾取函数,获取当前鼠标点位置函数,“确定”按钮用于重绘“放大镜”等距离方位投影地图。为界面中的控件设置好回调函数之后即可使用。并可以通过放大镜范围设置参数z1和缩放比例ge。

坐标拾取可以采用 ginput 函数或 inputm 函数,前者是通过鼠标点击的位置获取当前的屏幕坐标(设备坐标 DP),使用后只需将获得坐标轴的屏幕坐标反算到逻辑坐标 LP,再利用地图投影的反算公式反算回地球表面经纬度,即可完成点的选择。而后者是通过将上述操作封装,直接利用鼠标点击的位置获取地球表面的经纬度坐标,可以说,inputm 函数拾取坐标非常简便,但又缺乏灵活性。

由于放大镜的原理,改变了黄圈外围(黄圈即为 z1 所在等高圈)的正算公式,导致投影反解公式在放大镜外围失效,从而无法 inputm 选点。可以考虑使用ginput来进行坐标拾取。

程序的部分代码如下(详见variable_program.m):

% 重置坐标轴,防止图像重叠cla reset% 确定时调用投影landareas = shaperead('landareas.shp','UseGeoCoords',true);[n,k]=size(landareas);total = 1;lon=zeros(1,20000);lat=zeros(1,20000);for j=1:n[a,b]=size(landareas(j).Lon);for m=1:b​    lon(1,total) = [landareas(j).Lon(1,m)] ;​    lat(1,total) = [landareas(j).Lat(1,m)] ;​    total=total +1;endendglobal phi00 lambda00;%坐标轴采用自定义的variable_ortho投影类型axesm ('variable_ortho', 'Frame', 'on', 'Grid', 'on','origin',[phi00 lambda00 0],'rngz1',[str2double(get(handles.edit1,'string'))],'zoom_factor',[str2double(get(handles.edit2,'string'))]);geoshow(lat,lon);tissot;mdistort;......省略部分代码......%拾取经纬度坐标[lat,lon]=inputm(1);%判断经纬度坐标是否拾取成功if ~isempty(lat) && ~isempty(lon) phi00=lat;lambda00=lon;elseerror(message('坐标反算失败'))end

在该程序中,variable_program_OpeningFcn函数定义了程序启动时的初始化,pushbutton1_Callback函数定义了确定按钮单击事件的回调函数(改变投影图像),pushbutton3_Callback函数定义坐标拾取按钮单击事件的回调函数(用于拾取坐标),这三个函数是实现功能的主要函数。其中axesm函数是地图投影的核心,调用了自定义的variable_ortho投影

图9 axesm函数调用自定义投影

五、效果图

“放大镜”的效果取决于applyMagnifyingAzimuthalProjection.m中使用的公式,如果使用如下线性的等距离方位投影的公式,得到的效果如下图:


图10 采用线性公式的“放大镜”式等距离方位投影图

​ 同理,如果使用非线性的从内圆到外圆过渡的等距离方位投影,例如0.7为指数的幂函数,就能实现“放大镜”式渐变方位投影:

图11 采用非线性公式的“放大镜”式渐变方位投影

MATLAB地图工具箱学习心得(二)设计可变参数和位置拾取的“放大镜”式投影程序相关推荐

  1. 【Matlab 机器人工具箱 学习笔记】双旋转台5轴数控机床 运动学模型02

    参考: [1]何永红, 齐乐华, 赵宝林. 双转台五轴数控机床后置处理算法研究[J]. 制造技术与机床, 2006(1). [2]李永桥, 陈强, 谌永祥. 双转台五轴数控机床运动变换及求解方法的研究 ...

  2. STM32学习心得二十一:实时时钟RTC和备份寄存器BKP特征、原理及相关实验代码解读

    记录一下,方便以后翻阅~ 主要内容 1) RTC特征与原理: 2) BKP备份寄存器特征与原理: 3) RTC常用寄存器+库函数介绍: 4) 相关实验代码解读. 实验内容: 因为没有买LCD屏,所以计 ...

  3. BT源代码学习心得(二):程序运行参数的获取 -- 转贴自 wolfenstein (NeverSayNever)

    BT源代码学习心得(二):程序运行参数的获取 发信人: wolfenstein (NeverSayNever), 个人文集 标  题: BT源代码学习心得(二):程序运行参数的获取 发信站: 水木社区 ...

  4. STM32学习心得二十六:DAC数模转换实验

    记录一下,方便以后翻阅~ 主要内容: 1) DAC数模转换原理: 2) 寄存器和库函数介绍: 3) 相关实验代码解读. 实验功能:系统启动后,按WK_UP键,输出电压加200点,对应电压值200*3. ...

  5. matlab机器人工具箱学习笔记——ikine函数

    matlab机器人工具箱学习笔记--ikine函数 ikine函数用法 使用实例 链接: https://blog.csdn.net/weixin_42596724/article/details/8 ...

  6. MATLAB与深度学习(二)— 训练神经网络(图像分类识别)

    MATLAB与深度学习(二)- 训练神经网络(图像分类识别) 上一篇,我们介绍了与深度学习相关的MATLAB工具包.这一篇,我们将介绍如何训练神经网络和相关的基础知识.本文借鉴和引用了网上许多前辈的经 ...

  7. STM32学习心得二十四:内部温度传感器原理及实验

    记录一下,方便以后翻阅~ 主要内容: 1) STM32内部温度传感器概述: 2) 相关实验代码解读. 实验功能:系统启动后,实时将内部温度传感器的值传至串口助手上. 官方资料:<STM32中文参 ...

  8. 无人驾驶之MATLAB无人驾驶工具箱学习(3)

    接<无人驾驶之MATLAB无人驾驶工具箱学习(2)>中的内容. 4.驾驶情景生成及传感器模型 Generate Synthetic Detections from an Interacti ...

  9. matlab滤波器设计工具箱带阻滤波器,用matlab信号处理工具箱进行fir滤波器设计的三种方法...

    用matlab信号处理工具箱进行fir滤波器设计的三种方法 摘 要 介绍了利用 MATLAB 信号处理工具箱进行 FIR 滤波器设计的三种方法:程序设计法. FDATool 设计法和 SPTool 设 ...

最新文章

  1. Apache Flink vs Apache Spark——感觉二者是互相抄袭啊 看谁的好就抄过来 Flink支持在runtime中的有环数据流,这样表示机器学习算法更有效而且更有效率...
  2. 欧盟数据保护新规则 75%云应用没准备好
  3. HDU ACM 1728 逃离迷宫 (广搜BFS)
  4. 我的世界网易版显示dns服务器错误怎么弄,手机显示DNS异常怎么办
  5. Eclipse 汉化方法
  6. Leetcode之插入区间
  7. arm架构与体系结构
  8. 纪念概率学界最后一位集大成者——钟开莱
  9. 微信小程序--获取已发布微信小游戏和小程序源码
  10. vue日历排班组件_VUE实现日历组件功能
  11. MATLAB制作歌曲
  12. golang库文件收集
  13. python递归 及 面向对象初识及编程思想
  14. 3年半工作经验女程序员,聊聊程序员的薪水、工作内容和发展前景
  15. Java中print()\println()\printf()的区别及用法
  16. python房价预测_python预测房价
  17. 区块链相关安全名词及常见攻击手法
  18. 任务管理器无法结束进程
  19. Java实现FTP上传文件
  20. C#对SQLite的常用操作

热门文章

  1. 方向不对,努力白费(好文章)
  2. 苹果电脑安装Windows系统完整教程,新手快速解决装系统问题
  3. win10自带虚拟机好用吗_Win10自带的虚拟机功能,教你这样设置,免费让一台电脑变3台...
  4. 手机计算机数字显示在桌面上,手机桌面上的应用如何取消显示的数字角标
  5. 如何解决Camtasia下载安装时“2503”报错
  6. 双智机器人 珠海_格力智能工厂+智能家居亮相佛山,“双智战略”迈向6000亿目标...
  7. 重力铸造:冒口数据库(支持保温、发热冒口)
  8. 最全最新的java经典学习课件
  9. python整型数据源码分析_Python2 基本数据结构源码解析
  10. DHCP中继实验配置