在MATLAB中绘制地图上的点

时间:2013-10-09 21:52:16

标签: matlab map plot

我想在纽约州的地图上绘制不同的位置。我目前的代码绘制了整个北美地区,因为我找不到如何只绘制一个州。我正试图将经度和经度限制设置为纽约州,但它仍然给了我整个国家。

此外,当我hold all(或hold on)并尝试绘制点时,我会得到另一个弹出我指定标题的数字,但只是一个空白的白色方块。

另一个相关的问题是,一旦我得到了积分,我必须知道它们是什么点。如果我在一个单独的单元格数组中有名称,我怎样才能让MATLAB根据哪个坐标(存储在一个单独的列中)与哪个名称(如果名称存储在另一个列中)相对应来标记点?

%% Plot map
latlim = [39 47];
lonlim = [-81 -70];

ax = worldmap('USA');
load coast
geoshow(ax, lat, long,...
'DisplayType', 'polygon', 'FaceColor', [.45 .60 .30])
states = shaperead('usastatelo', 'UseGeoCoords', true, 'BoundingBox', [lonlim' latlim']);
axesm('lambert', 'MapLatLimit', latlim, 'MapLonLimit', lonlim);
faceColors = makesymbolspec('Polygon',...
    {'INDEX', [1 numel(states)], 'FaceColor', ...
    polcmap(numel(states))}); % NOTE - colors are random
geoshow(ax, states, 'DisplayType', 'polygon', ...
  'SymbolSpec', faceColors);
figure('Color', 'white')

title('PM2.5 Site in New York State in 2012');

hold all

% Plot points
axesm('lambert', 'MapLatLimit', latlim', 'MapLonLimit', lonlim');
datalat = str2double(datalat);
datalon = str2double(datalon);
scatterm(datalat, datalon)

1 个答案:

答案 0 :(得分:3)

您可以使用usamap('New York')获取美国州地图,并使用textm绘制叠加文字。在这里,25个随机点及其标签绘制在图上。

以下情节

enter image description here

生成
latlim = [39 47];
lonlim = [-81 -70];

figure('Color','w');
usamap('New York')
shi = shaperead('usastatehi', 'UseGeoCoords', true,...
            'Selector',{@(name) strcmpi(name,'New York'), 'Name'});
geoshow(shi, 'FaceColor', [0.3 1.0, 0.675])
textm(shi.LabelLat, shi.LabelLon, shi.Name, 'HorizontalAlignment', 'center')

nb_point = 25;
LAT = latlim(1) + (latlim(2)-latlim(1)).*rand(nb_point,1);
LON = lonlim(1) + (lonlim(2)-lonlim(1)).*rand(nb_point,1);
h = geoshow(LAT, LON, 'DisplayType', 'Point', 'Marker', '+', 'Color', 'red');
textm(LAT, LON+0.3, num2str((1:nb_point)'), 'FontSize',14)