4

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

此外,当我这样做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)
4

1 回答 1

3

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

下面的情节

在此处输入图像描述

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)
于 2013-10-09T22:56:45.740 回答