zoukankan      html  css  js  c++  java
  • Matlab——m_map指南(3)——实例

    m_map 实例

    1、

    clear all
    m_proj('ortho','lat', 48,'long',-123');%投影方式,范围
    m_coast('patch','r');%红色填充
    m_grid('linest','-','xticklabels',[],'yticklabels',[]);%标注为空
    patch(.55*[-1 1 1 -1],.25*[-1 -1 1 1]-.55,'w');%四个点,白色填充
    text(0,-.55,'M\_Map','fontsize',25,'color','b',...
       'vertical','middle','horizontal','center');%填充内容,属性要求,垂直水平居中,斜杠转义符
    set(gcf,'units','inches','position',[2 2 3 3]);%设置图片大小
    set(gcf,'paperposition',[3 16 6 6]);%[left bottom width height].
    

     

    2.

    clear all
    m_proj('lambert','long',[-160 -40],'lat',[30 80]);
    m_coast('patch',[1 .85 .7]);%填充海岸线
    m_elev('contourf',[500:500:6000]);%海深等高线
    m_grid('box','fancy','tickdir','in');
    colormap(flipud(copper));%翻转三原色的顺序排列,重新画图
    

    3、

    m_proj('stereographic','lat',90,'long',30,'radius',25);
    m_elev('contour',[-3500:1000:-500],'edgecolor','b');
    m_grid('xtick',12,'tickdir','out','ytick',[70 80],'linest','-');
    m_coast('patch',[.7 .7 .7],'edgecolor','r');

    4、

    4.1默认的加载形式

    clear all
    Slongs=[-100 0;-75 25;-5 45; 25 145;45 100;145 295;100 290];
    Slats= [  8 80;-80  8; 8 80;-80   8; 8  80;-80   0;  0  80];
    for l=1:7,
     m_proj('sinusoidal','long',Slongs(l,:),'lat',Slats(l,:));%分区块的载入地图
     m_grid;
     m_coast;
    end;
    xlabel('Interrupted Sinusoidal Projection of World Oceans');
    % In order to see all the maps we must undo the axis limits set by m_grid calls:
    set(gca,'xlimmode','auto','ylimmode','auto');%自动加载所有数据
    

    4.2

    clear all
    subplot(211);
    Slongs=[-100 0;-75 25;-5 45; 25 145;45 100;145 295;100 290];
    Slats= [  8 80;-80  8; 8 80;-80   8; 8  80;-80   0;  0  80];
    for l=1:7,
     m_proj('sinusoidal','long',Slongs(l,:),'lat',Slats(l,:));
     m_grid('fontsize',6,'xticklabels',[],'xtick',[-180:30:360],...%字体尺寸,隐藏坐标,坐标等距离排列
            'ytick',[-80:20:80],'yticklabels',[],'linest','-','color',[.9 .9 .9]);%线条形式实线,颜色
     m_coast('patch','g');%填充绿色
    end;
    xlabel('Interrupted Sinusoidal Projection of World Oceans');
    % In order to see all the maps we must undo the axis limits set by m_grid calls:
    set(gca,'xlimmode','auto','ylimmode','auto');
    
    subplot(212);
    Slongs=[-100 43;-75 20; 20 145;43 100;145 295;100 295];
    Slats= [  0  90;-90  0;-90   0; 0  90;-90   0;  0  90];%比上面范围重叠更多
    for l=1:6,
     m_proj('mollweide','long',Slongs(l,:),'lat',Slats(l,:));
     m_grid('fontsize',6,'xticklabels',[],'xtick',[-180:30:360],...
            'ytick',[-80:20:80],'yticklabels',[],'linest','-','color','k');
     m_coast('patch',[.6 .6 .6]);
    end;
    xlabel('Interrupted Mollweide Projection of World Oceans');
    set(gca,'xlimmode','auto','ylimmode','auto');%自动加载所有数据范围
    

    5、

    clear all
    % Nice looking data
    [lon,lat]=meshgrid([-136:2:-114],[36:2:54]);
    u=sin(lat/6);%?
    v=sin(lon/6);
    
    m_proj('oblique','lat',[56 30],'lon',[-132 -120],'aspect',.8);%注意纬度顺序,高纬到低纬,'aspect'长宽比
    
    subplot(121);
    m_coast('patch',[.9 .9 .9],'edgecolor','none');
    m_grid('tickdir','out','yaxislocation','right',...%边缘经纬线在外,纬度在右,经度在顶
           'xaxislocation','top','xlabeldir','end','ticklen',.05);%边缘经纬度宽度
    hold on;%图层合并
    m_quiver(lon,lat,u,v);%经度,纬度,向东,向北的速度分量,转化为矢量箭头
    xlabel('Simulated surface winds');
    
    subplot(122);
    m_coast('patch',[.9 .9 .9],'edgecolor','none');
    m_grid('tickdir','in','yticklabels',[],...
           'xticklabels',[],'linestyle','none','ticklen',.02);%经纬线去除
    hold on;
    [cs,h]=m_contour(lon,lat,sqrt(u.*u+v.*v));%画出轮廓
    clabel(cs,h,'fontsize',10,'Color','red','FontWeight','bold');%标注轮廓,字体,字体大小,颜色
    xlabel('Simulated something else');

    6、

    clear all
    
    % Plot a circular orbit
    lon=[-180:180];
    lat=atan(tan(60*pi/180)*cos((lon-30)*pi/180))*180/pi;
    
    m_proj('miller','lat',80);%查询,纬度(-80 80),经度(-180 180)
    m_coast('color',[0 .6 0]);
    m_line(lon,lat,'linewi',2,'color','r');%线宽,2;颜色
    m_grid('linestyle','none','box','fancy','tickdir','in');%没有网格,边框相间,
    %m_line(lon,lat,'linewi',2,'color','r','linestyle',':');控制线条格式,点画线还是直线

    7、

    clear all
    m_proj('lambert','lon',[-10 20],'lat',[33 48]);%范围设置与投影有关系
    m_tbase('contourf');%画5-min数据库轮廓
    m_grid('linestyle','none','tickdir','out','linewidth',3);

    没有安装terrainbase,所以轮廓很简陋,这个坑用到的时候再填

     

    8、不同分辨率情况下画的图

    clear all
    % Example showing the default coastline and all of the different resolutions 
    % of GSHHS coastlines as we zoom in on a section of Prince Edward Island.
    
    clf
    axes('position',[0.35 0.6 .37 .37]);%[left  bottom  width  height]
    m_proj('albers equal-area','lat',[40 60],'long',[-90 -50],'rect','on');%方形,扇形
    m_coast('patch',[0 1 0]);%填充
    m_grid('linest','none','linewidth',2,'tickdir','out','xaxisloc','top','yaxisloc','right');
    m_text(-69,41,'Standard coastline','color','r','fontweight','bold');%经纬度,内容,格式
    
    axes('position',[.09 .5 .37 .37]);
    m_proj('albers equal-area','lat',[40 54],'long',[-80 -55],'rect','on');
    m_gshhs_c('patch',[.2 .8 .2]);
    m_grid('linest','none','linewidth',2,'tickdir','out','xaxisloc','top');
    m_text(-80,52.5,'GSHHS\_C (crude)','color','m','fontweight','bold','fontsize',14);
    
    axes('position',[.13 .2 .37 .37]);
    m_proj('albers equal-area','lat',[43 48],'long',[-67 -59],'rect','on');
    m_gshhs_l('patch',[.4 .6 .4]);
    m_grid('linest','none','linewidth',2,'tickdir','out');
    m_text(-66.5,43.5,'GSHHS\_L (low)','color','m','fontweight','bold','fontsize',14);
    
    axes('position',[.35 .05 .37 .37]);
    m_proj('albers equal-area','lat',[45.8 47.2],'long',[-64.5 -62],'rect','on');
    m_gshhs_i('patch',[.5 .6 .5]);
    m_grid('linest','none','linewidth',2,'tickdir','out','yaxisloc','right');
    m_text(-64.4,45.9,'GSHHS\_I (intermediate)','color','m','fontweight','bold','fontsize',14);
    
    axes('position',[.55 .23 .37 .37]);
    m_proj('albers equal-area','lat',[46.375 46.6],'long',[-64.2 -63.7],'rect','on');
    m_gshhs_h('patch',[.6 .6 .6]);
    m_grid('linest','none','linewidth',2,'tickdir','out','xaxisloc','top','yaxisloc','right');
    m_text(-64.18,46.58,'GSHHS\_H (high)','color','m','fontweight','bold','fontsize',14);

    运行出现这样问题

    网站https://www.ngdc.noaa.gov/mgg/shorelines/data/gshhs/oldversions/version1.10/下载

     

    下载version1.10中 gshhs_1.10.zip 文件,将zip文件解压,把gshhs_*.b 文件复制到 matlabR2009 oolboxmatlabm_map@private 文件夹内。打开m_gshhs_c.m,补全路径。

    FILNAME='D:MATLAB	oolboxm_mapprivate/gshhs_c.b'
    

    同理将所有的m_gshhs_*.m路径都补充完整。  

    9、

    clear all
    m_proj('UTM','long',[-72 -68],'lat',[40 44]);
    m_gshhs_i('color','k');
    m_grid('box','fancy','tickdir','in');
    
    % fake up a trackline
    lons=[-71:.1:-67];
    lats=60*cos((lons+115)*pi/180);%轨迹经纬度
    dates=datenum(1997,10,23,15,1:41,zeros(1,41));%轨迹时间,1分钟到41分钟
    
    m_track(lons,lats,dates,'ticks',0,'times',4,'dates',8,...%刻度间隔,时间间隔4分钟,日期标签间隔8分钟
            'clip','off','color','r','orient','upright');%颜色标签方向

    10、范围环

    clear all
    m_proj('hammer','clong',170);%缩放范围
    m_grid('xtick',[],'ytick',[],'linestyle','-');
    m_coast('patch','g');
    m_line(100.5,13.5,'marker','square','color','r');%增加了一个标记点
    m_range_ring(100.5,13.5,[1000:1000:15000],'color','b','linewi',2);%范围,颜色,线宽
    xlabel('1000km range rings from Bangkok');%曼谷中心1000km的范围环
    

    11、

    clear all
    bndry_lon=[-128.8 -128.8 -128.3 -128 -126.8 -126.6 -128.8];
    bndry_lat=[  49    50.33  50.33  50   49.5   49     49];
    
    clf;
    m_proj('lambert','long',[-130 -121.5],'lat',[47 51.5],'rectbox','on');
    
    m_gshhs_i('color','k');              % Coastline...
    m_gshhs_i('speckle','color','r');    % with speckle added,斑点添加
    
    m_line(bndry_lon,bndry_lat,'linewi',2,'color','k');     % Area outline ...
    m_hatch(bndry_lon,bndry_lat,'single',30,5,'color','k'); % ...with hatching added.斜线,30度,5个单位相距
    
    m_grid('linewi',2,'linest','none','tickdir','out');
    title('Speckled Boundaries for nice B&W presentation (best in postscript format)','fontsize',14);
    m_text(-128,48,5,{'Pacific','Ocean'},'fontsize',18);
    

     

    12

    clear all
    
    m_proj('miller','lat',[-75 75]);  
    m_coast('patch',[.7 1 .7],'edgecolor','none');
    m_grid('box','fancy','linestyle','none','backcolor',[.9 .9 0.9]);
    
    cities={'Cairo','Washington','Buenos Aires'};
    lons=[ 30+2/60  -77-2/60   -58-22/60];
    lats=[ 31+21/60  38+53/60  -34-45/60];
    
    for k=1:3,
      [range,ln,lt]=m_lldist([-123-6/60 lons(k)],[49+13/60  lats(k)],40);
       %是两个位置之间分40个点,range返回距离,ln经度矩阵,lt纬度矩阵
      m_line(ln,lt,'color','r','linewi',2);
      m_text(ln(end),lt(end),sprintf('%s - %d km',cities{k},round(range)));
    end;
    
    title('Great Circle Routes','fontsize',14,'fontweight','bold');
    

    13、 全球/地区温度图

    (1)读取数据

    clear all
    setup_nctoolbox %调用工具包
    tic %计时
    %% 
    nc=ncgeodataset('tmpsfc.gdas.199401.grb2');   %读文件
    tem_1=nc.variables   %浏览数据类型
    %% 
    a1=nc.geovariable(tem_1(1));%取得数据类型为Temperature_surface的数据
    b1=a1.data(1,:,:); %第一个时间点温度数据
    c1=squeeze(b1)-273.16;%删除单一维度,换为摄氏温度
    %% 
    a2=nc.geovariable(tem_1(2));%取得数据类型为lat的数据,纬度
    b2=a2.data(:,1)%提取数据
    %% 
    a3=nc.geovariable(tem_1(3));%经度
    b3=a3.data(:,1)%
    %% 
    a4=nc.geovariable(tem_1(4));%取得数据类型为time的数据
    b4=a4.data(:,1)%
    %% 
    save A b2 b3 c1
    toc
    

    读取的是NCEP/CFSR数据,1994年1月的温度数据。

    该数据一共四项。温度,纬度,经度,时间。

    时间数据

    经度数据

    纬度数据

    可以看出该数据集的数据组织形式,经度纬度构成世界地图,记录了744个时间点的温度数据。约等于1小时采集一次数据。

    温度数据

    保存为mat格式数据,为画图做准备。

    (2)画图

    clear all
    load A
    
    [Plg,Plt]=meshgrid(b3',b2');%形成网格
    
     m_proj('hammer-aitoff','clongitude',-150);%投影模式
    
    m_pcolor(Plg,Plt,c1);
    shading flat;
    colormap('jet');%颜色选择
    hold on;
    m_pcolor(Plg-360,Plt,c1);
    shading flat; %着色模式
    colormap('jet');
    
    m_coast();
    m_grid('xaxis','middle');
    
    % h=colorbar('h');
    % set(get(h,'title'),'string','1991年1月全球温度');
    
    c=colorbar('southoutside','fontsize',12)
    c.Label.String = '1994年1月全球温度';
    c.Label.FontSize = 15;
    

    (3)找出最大、最小温度的经纬度

    clear all
    load C
    Max_col=max(c1);%列最大值
    Max_row=max(c1,[],2)%行最大值
    Max=max(max(c1));
    [x1,y1]=find(c1==max(max(c1)));%x 行,y 列
    T_1=Plt(x1,y1)%纬度
    T_2=Plg(x1,y1)%经度
    
    Min_col=min(c1);%列最大值
    Min_row=min(c1,[],2)%行最大值
    Min=min(min(c1));
    [x,y]=find(c1==min(min(c1)));%x 行,y 列
    T_x=Plt(x,y)%纬度
    T_y=Plg(x,y)%经度
    

     

    可以看出最热52度,在澳大利亚那块(142.8123E,23.2610S);最冷-62度,在北极圈那块(89.9999E,66.3486N)。

    (4)中国(地区)温度图

    clear all
    load A
    
    LATLIMS=[3 54];
    LONLIMS=[72 134];%选定边界范围
    
    [Plg,Plt]=meshgrid(b3',b2');%形成网格
    
     m_proj('lambert','lon',LONLIMS,'lat',LATLIMS);%投影模式
    
    m_pcolor(Plg,Plt,c1);
    shading flat;
    colormap('jet');%颜色选择
    hold on;
    m_pcolor(Plg-360,Plt,c1);
    shading flat; %着色模式
    colormap('jet');
    
    m_coast();
    m_grid('box','fancy','tickdir','in');
    
    % h=colorbar('h');
    % set(get(h,'title'),'string','1991年1月全球温度');
    
    c=colorbar('southoutside','fontsize',12)
    c.Label.String = '1994年1月中国温度';
    c.Label.FontSize = 15;
    

    该方法是读取全球数据,只展示部分

    (5)

    改进的区域方法,读取该区域的数据数据,

    clear all
    setup_nctoolbox %调用工具包
    tic %计时
    %% 
    min_lat=115;
    max_lat=279;
    min_lon=231;
    max_lon=430;  %区域经纬度范围,在数据中的位置
    
    %% 
    nc=ncgeodataset('tmp2m.gdas.199401.grb2');   %读文件
    tem_1=nc.variables   %浏览数据类型
    %% 
    N1=nc.size(tem_1(1));%读取数据大小,可以看出数据的组织形式
    a1=nc.geovariable(tem_1(1));%取得数据类型为Temperature_surface的数据
    b1=a1.data(1,1,min_lat:max_lat,min_lon:max_lon); %第一个时间点温度数据
    c1=squeeze(b1)-273.16;%删除单一维度,换为摄氏温度
    %% 
    N2=nc.size(tem_1(2));
    a2=nc.geovariable(tem_1(2));%取得数据类型为lat的数据,纬度
    b2=a2.data(min_lat:max_lat,1);%提取数据
    %% 
    N3=nc.size(tem_1(3))
    a3=nc.geovariable(tem_1(3));%经度
    b3=a3.data(min_lon:max_lon,1);%
    %% 
    N4=nc.size(tem_1(4))
    a4=nc.geovariable(tem_1(4));%取得数据类型为time的数据
    b4=a4.data(:,1);%
    %% 
    N5=nc.size(tem_1(5));%读取数据大小
    a5=nc.geovariable(tem_1(5));%取得数据类型为time的数据
    b5=a5.data(:,1);%
    %% 
    save tem b2 b3 c1
    toc
    

    clear all
    load tem
    
    LATLIMS=[3 54];
    LONLIMS=[72 134];%选定边界范围
    
    [Plg,Plt]=meshgrid(b3',b2');%形成网格
    
     m_proj('lambert','lon',LONLIMS,'lat',LATLIMS);%投影模式
    
    m_pcolor(Plg,Plt,c1);
    shading flat;
    colormap('jet');%颜色选择
    hold on;
    m_pcolor(Plg-360,Plt,c1);
    shading flat; %着色模式
    colormap('jet');
    
    m_coast();
    m_grid('box','fancy','tickdir','in');
    
    % h=colorbar('h');
    % set(get(h,'title'),'string','1991年1月全球温度');
    
    c=colorbar('southoutside','fontsize',12)
    c.Label.String = '1994年1月中国温度';
    c.Label.FontSize = 15;
    

    八、圆形区域的画图

    1、

    clear all
    
    LATLIMS=[14 22];
    LONLIMS=[108 118];%南海边界范围
    m_proj('miller','lon',LONLIMS,'lat',LATLIMS);%投影模式
    m_coast('patch',[0.1 0.7 0.4]);%绿色填充
    m_grid('box','fancy','tickdir','in');%没有网格,边框相间,%m_line(lon,lat,'linewi',2,'color','r','linestyle',':');控制线条格式,点画线还是直线
    
    lon=112:1:116;
    lat=16:1:20;
    m_line(lon,lat,'linewi',2,'color','r');%线宽,2;颜色
    
    [X,Y]=m_ll2xy(117,21);
    line(X,Y,'marker','.','markersize',24','color','r')%画点
    

    2、距离

    clear all
    %distance用法
    arclen=distance([37,0],[35,0])%返回两点间的相对球心的角度,以度为单位
    d=distance([37,0],[35,0],6371)% [纬度,经度] [纬度,经度] [半径]
    D=(arclen/180)*pi*6371
    %m_map中函数
    dist=m_lldist([0 0],[35 37])%[经度 经度] [纬度 纬度]
    

    3、

    clear all
    
    LATLIMS=[14 22];
    LONLIMS=[108 118];%南海边界范围
    m_proj('miller','lon',LONLIMS,'lat',LATLIMS);%投影模式
    m_coast('patch',[0.1 0.7 0.4]);%绿色填充
    m_grid('box','fancy','tickdir','in');%没有网格,边框相间,%m_line(lon,lat,'linewi',2,'color','r','linestyle',':');控制线条格式,点画线还是直线
    
    load EDH_south_sea_2008
    load coordi_south_sea_2008 
    
    m_range_ring(114,18,[1e2:1e2:3e2],'linewi',2,'color','b');%红色300km范围圆圈
    
    % 矩形点阵
    range_lat=4:24;%21N和15N对应的位置下标
    range_lon=20:40;%111.5E和116.5E对应的下标
    for i=1:length(range_lon)
        for j=1:length(range_lat)
            [X,Y]=m_ll2xy(lon_south_sea(range_lon(i)),lat_south_sea(range_lat(j)));%化为x,y坐标
            line(X,Y,'marker','.','markersize',10,'color','k')%画点
            hold on
        end
    end
    
    %离散圆
    [X0,Y0]=m_ll2xy(114,18);%化为x,y坐标
    line(X0,Y0,'marker','.','markersize',15,'color','r');%画圆心
    DIST=m_lldist([114 114],[18 19]);%纬度加1度,增加的距离
    R=300;%300km
    [X1,Y1]=m_ll2xy(114,18+R/DIST);%找到300km的一个点
    
    r=sqrt((X0-X1)^2+(Y0-Y1)^2);%地图距离到图上距离转换
    theta=0:pi/180:2*pi;%360度,360个点。
    x=X0+r*cos(theta); %(X0,Y0)圆心
    y=Y0+r*sin(theta);
    plot(x,y,'.','color','r')
    

    4、pcolor

    clear all
    n =18;
    r = (0:n)'/n;
    theta = pi*(-n:n)/n;
    X = r*cos(theta);
    Y = r*sin(theta);
    C = r*cos(2*theta);
    pcolor(X,Y,C)
    axis equal tight
    colorbar
    
    figure
    load PCOLOR %南海坐标和波导高度数据
    colormap('jet');
    shading flat;%平滑方式
    gca=pcolor(Plg,Plt,EDH_south_sea)
    set(gca, 'LineStyle','none');%去除网格
    axis equal tight %按比例展示
    colorbar %颜色条
    

    clear all
    n =6;
    r = (0:n)'/n;%0到6,半径上均分的数
    theta = pi*(-n:n)/n;%将整个圆分成了13分。
    X = r*cos(theta);
    Y = r*sin(theta);
    C = r*cos(2*theta);
    pcolor(X,Y,C)
    axis equal tight
    colorbar
    

      

      

      

      

      

      

      

      

      

      

     

  • 相关阅读:
    Qt 为何toggled无法触发setvisible(转)
    C++中const用法总结(转)
    C++输入输出流格式控制(转)
    ios-->iTunes同步应用失败
    apk签名
    常见缩写
    转:web_custom_request应用示例
    转:web_custom_request 函数
    转:web_submit_data函数
    转:web_custom_request 和 web_submit_data的差别
  • 原文地址:https://www.cnblogs.com/ruo-li-suo-yi/p/7674878.html
Copyright © 2011-2022 走看看