如果您具有与特定地理位置相关联的数据,请使用地理轴或图表在地图上可视化您的数据并提供可视化的上下文。例如,如果您有描述世界各地海啸发生的数据,请在地理轴上绘制数据,标记在该地理轴上每次发生海啸的位置。
以下示例说明了如何在地理坐标中创建折线图,散点图,气泡图和密度图。
创建地理线图
在西雅图和安克雷奇之间的地图上画一条线。指定每个城市的纬度和经度,然后使用geoplot
函数绘制数据。使用线规格'g-*'
自定义线的外观。使用geolimits
调整地图的纬度和经度限制。
latSeattle = 47.62;%纬度
lonSeattle = -122.33;%经度
latAnchorage = 61.20;%纬度
lonAnchorage = -149.9;%经度
geoplot([latSeattle latAnchorage],[lonSeattle lonAnchorage],'g-*')
geolimits([45 62],[-149 -123])
创建地理散点图
创建纬度和经度位置并定义每个点的值。使用geoscatter
函数在地图上绘制值。以下示例指定标记为三角形,大小和颜色表示值的变化。
lon = (-170:10:170);
lat = 50 * cosd(3*lon);
A = 101 + 100*(sind(2*lon));
C = cosd(4*lon);
geoscatter(lat,lon,A,C,'^')
创建地理气泡图
根据海啸数据创建表格。将一个值定义为分类值。使用geobubble
函数将数据绘制在地图上。以下示例使用气泡的大小指示海啸波的高度,并使用颜色指示海啸的原因。
tsunamis = readtable('tsunamis.xlsx');
tsunamis.Cause = categorical(tsunamis.Cause);
figure
gb = geobubble(tsunamis,'Latitude','Longitude', ...
'SizeVariable','MaxHeight','ColorVariable','Cause');
geolimits([10 65],[-180 -80])
title 'Tsunamis in North America';
gb.SizeLegendTitle = 'Maximum Height';
创建地理密度图(热力图)
根据海啸数据创建表格。使用geodensityplot
函数绘制数据。
tsunamis = readtable('tsunamis.xlsx');
lat = tsunamis.Latitude;
lon = tsunamis.Longitude;
weights = tsunamis.MaxHeight;
geodensityplot(lat,lon,weights)
geolimits([10 65],[-180 -80])
注:本文根据MATLAB官网内容修改而成。
我推荐给你以下的视频教程,特点是没有PPT,不掺水,直接编程环境下的实操课程: 用100分钟了解MATLAB编程
知乎 - 安全中心www.1data.pro《MATLAB编程360》视频课程:
MATLAB编程360 - 网易云课堂study.163.comstudy.163.com