在之前的文章中,分享了很多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:nClusterid = 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 onend

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;endend% 删除白边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');

以上。



















