zoukankan      html  css  js  c++  java
  • MATLAB地图工具箱学习总结(一)从地图投影说起

    MATLAB地图工具箱学习总结(一)从地图投影说起

    MATLAB地图工具箱学习总结系列:

    (一)从地图投影说起

    (二)大圆和恒向线

    (三)地图工具箱的基本知识

    (四)自定义投影

    前言

    本学期地图投影课上,李连营老师建议我们使用MATLAB完成每周的作业。从大二上学期开始接触MATLAB学习数学运算和地理数据处理的我,自然不会放过这次机会,每周找了点时间好好研究了一下,把作业比较轻松地就搞定了。不过由于网上相关的教程、资料比较少,在夹杂了多种专业词汇的同时,又没有中文翻译,也是让人感到头疼。在此想总结一下相关的函数,以帮助其他需要使用工具箱的人。作为一个学生,我所接触的仅仅是皮毛,也必然会有一些错误,希望看到的人能够指出,谢谢。

    PS:本文基于MATLAB  R2014a版本。

    1                    作业案例:地图投影作业5-7

    在作业5、6、7中,李老师分别要求我们在MATLAB中画出正轴、横轴、斜轴的方位、圆柱、圆锥投影(参数自定),查阅MATLAB帮助后,在其基础上完成了作业。以等角横轴圆柱投影为例,源代码及效果如下图所示:

    landareas = shaperead('landareas.shp','UseGeoCoords',true);
    axesm ('mercator', 'Frame', 'on', 'Grid', 'on','origin',[0 120 0]);
    geoshow(landareas,'FaceColor',[1 1 .5],'EdgeColor',[.6 .6 .6]);
    tissot;

      

    接下来我将详细解释一下各函数及其参数的意义和作用。

    2                    地图投影的分类:

    (1)          MATLAB中支持多种地图投影,查看具体支持哪些只需要在命令行中敲入maps,可以获得MATLAB中所有地图投影类型的分类属性(圆锥、圆柱、方位投影等),名称及MATLAB中使用时的简称。如下图:

    (2)          以下是我本人翻译的部分投影类型中英文翻译对照表。

    3                    shaperead的用法

    shaperead用于读取shapefile文件的数据,并将其进行存储。

    (1)          基本用法:shpaeread(filename,Name,Value)

    其中,filename指的是文件名,此项必设,后面可以跟多项设置。其生成一个结构体,包括Geometry几何对象,BoundingBox范围,X,Y坐标值等数据。

    (2)          常用设置

                                1)              BoundingBox:是一个2*2的数组,限定了读取文件要素的范围,只有该范围内的要素才能被选中。

                                2)              Attributes:读取属性设置,后面跟一个字符串数组,字符串即为所要读取的属性。当设置该属性后,shapefile文件中只有被选择的属性才可以被读取出来。

                                3)              UseGeoCoords:可以选择为true或者false(默认),即是否使用地理结构(GeoStruts)。如果数据已经被投影了就选择false,如果还未被投影,可以选择true以生成投影。

    4                    axesm的用法

    axesm是地图工具箱中最重要、最常用的函数之一,用来定义地图的坐标系,设置地图的属性。而地图投影的类型也可以在里面进行设置和调整。

    (1)          基本用法:axesm(projid,PropertyName,PropertyValue)

    其中,projid指的是投影类型的简称,此项必设,后面可以跟多项属性,包括属性名称和属性值。属性分为四大类:控制地图投影的属性,控制框架的属性,控制格网的属性,控制坐标轴标签的属性。下面就一一介绍一些常用的属性。此外,也可以直接在命令行中敲入axesm手动调整部分参数。

    (2)          常用属性:

                                1)              AngleUnits:包括degrees(默认)度和radians弧度两个属性,定义角度的单位。

                                2)              MapLatLimit[southern_limit northern_limit]和MapLonLimit[western_limit eastern_limit]:分别定义了经度和纬度的范围

                                3)              Origin[latitude longitude orientation]:定义了地图的中心区域。输入的经纬度将成为地图投影的中心。最后一个参数orientation则设置了地图旋转的角度。

                                4)              Frame:包括on和off(默认)两个属性。可以定义地图的边框是否显示。

                                5)              Grid:包括on和off(默认)两个属性。可以是否显示地图格网。

    5                    geoshow的用法

    geoshow是用来显示地图数据的函数,非常重要,大部分的地图都使用该函数进行显示。由于其使用的方法多种多样,在此仅仅介绍一小部分和本文开始案例相关的用法。

    (1)          基本用法:

                                1)              geoshow(lat,lon)直接输入经纬度,将以该经纬度为中心,生成一小片地图。

                                2)              geoshow(filename)直接输入地图文件名,生成该地图

                                3)              geoshow(_,Name,Value,)输入相关属性并设定参数,生成所需要的地图。

    (2)          常用属性:

                                1)              facecolor:定义了地图表面的颜色,需要输入三个参数且均在0至1之间。

                                2)              edgecolor:定义了海岸线边界的颜色,参数值同上。

    1 landareas=shaperead('landareas.shp','UseGeoCoords',true);
    2 axesm('mercator','Frame','on','Grid','on','origin',[0 120 0])
    3 geoshow(landareas,'FaceColor',[1 .2 .5],'EdgeColor',[.2 .6 .1]);
    4 tissot

    6                    tissot的用法

    tissot用来显示变形椭圆。

    (1)          基本用法:

                                1)              tissot可以自动显示变形椭圆,最小椭圆大小为显示范围的十分之一。

                                2)              tissot(radius)其中radius是最小椭圆的大小。

    1 landareas=shaperead('landareas.shp','UseGeoCoords',true);
    2 axesm('mercator','Frame','on','Grid','on','origin',[0 120 0]);
    3 geoshow(landareas,'FaceColor',[1 .2 .5],'EdgeColor',[.2 .6 .1]);
    4 tissot(0.05);

                                3)              tissot(linestyle)其中linestyle是椭圆线形。

                                4)              tissot(lineStyle,PropertyName,PropertyValue)可以设置关于线形的其他属性。

    7                    mdistort的用法

    mdistort用来显示等变形线。

    (1)          基本用法:

                                1)              mdistort可以自动显示等变形线。

                                2)              mdistort(parameter).可以对等变形线进行参数设置。

    (2)          常用属性:

                                1)              'area':后面跟数组,可以在相应的参数位置设置等变形线。

                                2)              'angle':根据角度设置等变形线的间隔。

                                3)              'parscale':和area类似,目前我本人也没有搞清楚两者之间具体的差异。

    1 landareas=shaperead('landareas.shp','UseGeoCoords',true);
    2 axesm('mercator','Frame','on','Grid','on','origin',[0 120 0]);
    3 geoshow(landareas,'FaceColor',[1 1 .5],'EdgeColor',[.6 .6 .6]);
    4 mdistort('parscale',[-500:100:500])

    今天关于MATLAB地图投影的相关知识就介绍这么多,看帮助才是最重要的,我这里仅仅挑出了相关的个别属性,但MATLAB功能实在强大,应该好好利用!下次准备讲一讲大圆和恒向线路径生成的问题。

    天靖居士

    2016.4.18

     

    4.24更新说明:添加mdistort等变形线说明。

    8.17更新说明:具体代码请参考:https://github.com/kkyyhh96/MapProjectionMatlab

    有关地图工具箱其他文章,请参看:

    MATLAB地图工具箱学习总结系列:

    (一)从地图投影说起

    (二)大圆和恒向线

    (三)地图工具箱的基本知识

    (四)自定义投影

    转载请注明作者和出处——天靖居士:http://www.cnblogs.com/kkyyhh96/ 海阔凭鱼跃,天高任鸟飞
  • 相关阅读:
    离线存储
    创业公司 加入
    console 代理
    HTTP 协议中 Vary 的一些研究
    reactNative 的一些学习
    srcset 图片自适应
    一些不错的文章分享
    前端网站大全
    c# 捕捉键盘按键
    SQL 中With as 的用法
  • 原文地址:https://www.cnblogs.com/kkyyhh96/p/5405968.html
Copyright © 2011-2022 走看看