在之前的文章中,分享了很多Matlab散点图的绘制模板:
进一步,再来分享一种特殊的散点图:带类别标签的散点图。
先来看一下成品效果:
特别提示:本期内容『数据+代码』已上传资源群中,加群的朋友请自行下载。有需要的朋友可以关注同名公号【阿昆的科研日常】,后台回复关键词【绘图桶】查看加入方式。
模板中最关键的部分内容:
1. 数据准备
此部分主要是读取原始数据并初始化绘图参数。
% 读取数据
A = load('data.txt');
% 初始化参数
X = A(:,1);
Y = A(:,2);
L = A(:,7);
lgs = {'Powerline','Low vegetation','Impervious surfaces','Car',...
'Fence/Hedge','Roof','Facade','Shrub','Tree'};
2. 颜色定义
作图不配色就好比做菜不放盐,总让人感觉少些味道。
但颜色搭配比较考验个人审美,需要多加尝试。
这里直接使用TheColor配色工具中的SCI权威配色库:
%% 颜色定义
C = TheColor('sci',503);%503 612 617 632
3. 带类别标签的散点图绘制
使用‘scatter’命令,绘制初始带类别标签的散点图。
Cluster = unique(L);
nCluster = length(Cluster);
for i = 1:nCluster
id = find(L==Cluster(i));
scatter(X(id,1),Y(id,1),8,...
'Marker','s', ...
'MarkerEdgeColor',C(i,1:3), ...
'MarkerFaceColor',C(i,1:3));
hold on
end
4. 细节优化
为了插图的美观,对坐标刻度、坐标区显示、图例等细节进行美化:
% 删除坐标刻度
set(gca,'xtick',[])
set(gca,'ytick',[])
% 坐标区显示调整
axis off tight equal
% Legend
[hL1,hL2]= legend(lgs,...
'FontWeight','bold',...
'Box','off',...
'Location', 'eastoutside',...
'Orientation','vertical');
set(hL1, 'FontName', 'Arial', 'FontSize', 10)
for n=1:length(hL2)
if sum(strcmp(properties(hL2(n)),'MarkerSize'))
hL2(n).MarkerSize=10;
elseif sum(strcmp(properties(hL2(n).Children),'MarkerSize'))
hL2(n).Children.MarkerSize=10;
end
end
% 删除白边
set(gca,'LooseInset',get(gca,'TightInset'))
% 背景颜色
set(gcf,'Color',[1 1 1])
设置完毕后,以期刊所需分辨率、格式输出图片。
%% 图片输出
figW = figureWidth;
figH = figureHeight;
set(figureHandle,'PaperUnits',figureUnits);
set(figureHandle,'PaperPosition',[0 0 figW figH]);
fileout = 'test';
print(figureHandle,[fileout,'.png'],'-r300','-dpng');
以上。