投稿问答最小化  关闭

万维书刊APP下载

Matlab论文插图绘制模板第92期—折线图(Plot)

2023/5/23 14:08:29  阅读:84 发布者:

之前有分享过Matlab折线图的绘制模板:

但随着技术力的提升,发现很多地方还有待改进,于是便有了本期内容。

先来看一下成品效果:

模板中最关键的部分内容:

 

1. 数据准备

此部分主要是读取原始数据。

% 读取数据

load data.mat

2. 颜色定义

作图不配色就好比做菜不放盐,总让人感觉少些味道。

但颜色搭配比较考验个人审美,需要多加尝试。

这里直接使用TheColor配色工具中的SCI权威配色库:

%% 颜色定义

% C = TheColor('xkcd',[336 816 210 346]);

C = TheColor('sci',1796);

获取方式:公众号(阿昆的科研日常)后台回复 TC

 

3. 折线图绘制

使用plot’命令,绘制初始折线图。

p = plot(x,A);

hTitle = title('Line Plot');

hXLabel = xlabel('XAxis');

hYLabel = ylabel('YAxis');

 

4. 细节优化

为了插图的美观,将初始折线图赋上之前选择的颜色并对线属性进行批量调整:

% 线条属性调整

MarkerL = {'v','o','^','s'};

for i = 1:4

    set(p(i),'LineStyle','-','Marker',MarkerL{i},'LineWidth',2.5,'Color',C(i,1:3))

end

 

然后,对坐标轴细节等进行美化:

% 坐标区属性调整

set(gca, 'Box', 'off', ...                                % 边框

         'LineWidth', 1,...                               % 线宽

         'XGrid', 'off', 'YGrid', 'on', ...               % 网格

         'TickDir', 'out', 'TickLength', [.01 .01], ...   % 刻度

         'XMinorTick', 'off', 'YMinorTick', 'off', ...    % 小刻度

         'XColor', [.1 .1 .1],  'YColor', [.1 .1 .1])     % 坐标轴颜色

% 坐标轴刻度调整

set(gca, 'XTick', 0:1:8,  'YTick', 0:20:80,...            % 刻度位置、间隔

         'Xlim' ,[0 8],'Ylim' ,[0 60], ...                % 坐标轴范围

         'Xticklabel',{0:1:8},...                         % X坐标轴刻度标签

         'Yticklabel',{0:20:80})                          % Y坐标轴刻度标签

% Legend

hLegend = legend(p, ...

                 'Samp1', 'Samp2','Samp3','Samp4', ...

                 'Location', 'northeast');

% Legend位置微调

P = hLegend.Position;

hLegend.Position = P + [0.01 0.03 0 0];

% 字体和字号

set(gca, 'FontName', 'Arial', 'FontSize', 10)

set([hLegend, hXLabel, hYLabel], 'FontSize', 11, 'FontName', 'Arial')

set(hTitle, 'FontSize', 12, 'FontWeight' , 'bold')

% 背景颜色

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');

以上。

转自:“阿昆的科研日常”微信公众号

如有侵权,请联系本站删除!


  • 万维QQ投稿交流群    招募志愿者

    版权所有 Copyright@2009-2015豫ICP证合字09037080号

     纯自助论文投稿平台    E-mail:eshukan@163.com