在之前的文章中,分享了一系列Matlab折线图的绘制模板:
这一次,再来分享一种特殊的折线图:双对数刻度折线图。
先来看一下成品效果:
特别提示:Matlab论文插图绘制模板系列,旨在降低大家使用Matlab进行科研绘图的门槛,只需按照模板格式添加相应内容,即可得到满足大部分期刊以及学位论文格式要求的数据插图。如果觉得有用可以分享给你的朋友。
模板中最关键的部分内容:
1. 数据准备
此部分主要是读取原始数据,定义自变量和因变量。
% 读取数据
load data.mat
% 因变量
X = x;
% 自变量
Y1 = y(1,:);
Y2 = y(4,:);
Y3 = y(5,:);
Y4 = y(6,:);
Y5 = y(7,:);
2. 颜色定义
作图不配色就好比做菜不放盐,总让人感觉少些味道。
但颜色搭配比较考验个人审美,需要多加尝试。
这里直接使用TheColor配色工具中的SCI权威配色库:
%% 颜色定义
C = TheColor('sci',1796);
C1 = C(1,:);
C2 = C(2,:);
C3 = C(3,:);
C4 = C(4,:);
C5 = C(6,:);
3. 双对数刻度折线图绘制
使用‘loglog’命令,绘制未经美化的双对数刻度折线图。
LL1 = loglog(X, Y1);
hold on
LL2 = loglog(X, Y2);
LL3 = loglog(X, Y3);
LL4 = loglog(X, Y4);
LL5 = loglog(X, Y5);
hTitle = title('Loglog Plot');
hXLabel = xlabel('Xlabel');
hYLabel = ylabel('Ylabel');
4. 细节优化
为了插图的美观,将双对数刻度折线图赋上之前选择的颜色并进一步调整线属性细节:
% 线属性调整
LW = 2;
set(LL1, 'LineStyle', '-','LineWidth', LW, 'Color', C1)
set(LL2, 'LineStyle', '-','LineWidth', LW, 'Color', C2)
set(LL3, 'LineStyle', '-','LineWidth', LW, 'Color', C3)
set(LL4, 'LineStyle', '-','LineWidth', LW, 'Color', C4)
set(LL5, 'LineStyle', '-','LineWidth', LW, 'Color', C5)
然后,对坐标轴细节等进行美化:
% 坐标区调整
set(gca, 'Box', 'off', ... % 边框
'LineWidth',1,... % 线宽
'XGrid', 'on', 'YGrid', 'on', ... % 网格
'TickDir', 'out', 'TickLength', [.01 .01], ... % 刻度
'XMinorTick', 'on', 'YMinorTick', 'on', ... % 小刻度
'XColor', [.1 .1 .1], 'YColor', [.1 .1 .1],... % 坐标轴颜色
'Xlim' ,[0.1 10],'Ylim' ,[0.01 100]) % 坐标轴范围
% 添加上、右框线
XL = get(gca,'xlim'); XR = XL(2);
YL = get(gca,'ylim'); YT = YL(2);
xc = get(gca,'XColor');
yc = get(gca,'YColor');
plot(XL,YT*ones(size(XL)),'color', xc,'linewidth',1)
plot(XR*ones(size(YL)),YL,'color', yc,'linewidth',1)
% 添加图例
hLegend = legend([LL1,LL2,LL3,LL4,LL5], ...
'Samp1','Samp2','Samp3','Samp4','Samp5', ...
'Location', 'northeast');
P = hLegend.Position;
hLegend.Position = P + [0.001 -0.02 0 0.03];
% 字体和字号
set(gca,'FontName','Arial','FontSize',11)
set([hXLabel,hYLabel,hLegend],'FontName','Arial','FontSize',11)
set(hTitle,'FontName','Arial','FontSize',12)
% 背景颜色
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');
以上。