Matlab进阶绘图第69期—同步坐标图

同步坐标是指将同一figure上的两个或两个以上的子图,用相同的X轴、Y轴或XY轴表示,以方便同步分析。

话不多说,先来看一下同步坐标图的成品效果:

特别提示:本期内容『数据+代码』已上传资源群中,加群的朋友请自行下载。有需要的朋友可以关注同名公号【阿昆的科研日常】,后台回复关键词【全家桶】查看加入方式


1. 数据准备

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

复制代码
% 读取数据load data.mat

2. 颜色定义

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

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

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

复制代码
%% 颜色定义map = TheColor('sci',2064,'map',10);map = flipud(map);C = map([1 2 3 6],1:3);

3. 同步坐标图绘制

调用'tiledlayout'命令,绘制多个子图

复制代码
%% 同步坐标图绘制t = tiledlayout(2,1);​%% 上图绘制ax1 = nexttile;p = plot(x,dataLine);hYLabel1 = ylabel(ax1,'E (m)');% 细节调整MarkerL = {'v','o','^','s'};for i = 1:4    set(p(i),'LineStyle','-','Marker',MarkerL{i},'LineWidth',2.5,'Color',C(i,1:3))endset(gca,'box','on', ...        'xtick',1:8, ...        'ytick',10:20:60)legend(p,{'S1','S2','S3','S4'}, ...       'Location','southeastoutside');​%% 下图绘制ax2 = nexttile;GO = bar(ax2,x,dataBar,0.6,'stacked','EdgeColor','k');% 细节调整for i = 1:4    GO(i).FaceColor = C(i,1:3);endhYLabel2 = ylabel(ax2,'RMSE (m)');set(gca,'box','on', ...        'xtick',1:8, ...        'ytick',0:0.4:1.2,...        'ylim',[0 1.5])legend(GO,{'S1','S2','S3','S4'}, ...       'Location','southeastoutside');

然后进行坐标同步:

复制代码
%% 同步坐标linkaxes([ax1,ax2],'x');t.TileSpacing = 'none';hTitle = title(t,'Axes Link chart');hXLabel = xlabel(t,'Samples');

4. 细节优化

为了插图的美观,对坐标轴细节等进行美化:

复制代码
% 字体和字号set([ax1,ax2], 'FontName', 'Arial', 'FontSize', 10)set([hXLabel, hYLabel1, hYLabel2], 'FontName', 'Arial', 'FontSize', 11)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');

以上。

相关推荐
夜夜敲码11 分钟前
C语言教程(十六): C 语言字符串详解
c语言·开发语言
宋康18 分钟前
C语言结构体和union内存对齐
c语言·开发语言
居然是阿宋28 分钟前
Kotlin高阶函数 vs Lambda表达式:关键区别与协作关系
android·开发语言·kotlin
Cao1234567893211 小时前
简易学生成绩管理系统(C语言)
c语言·开发语言
The Future is mine1 小时前
C# new Bitmap(32043, 32043, PixelFormat.Format32bppArgb)报错:参数无效,如何将图像分块化处理?
开发语言·c#
亿坊电商1 小时前
PHP框架在微服务迁移中能发挥什么作用?
开发语言·微服务·php
烁3471 小时前
每日一题(小白)模拟娱乐篇33
java·开发语言·算法
坐吃山猪1 小时前
Python-Agent调用多个Server-FastAPI版本
开发语言·python·fastapi
88号技师1 小时前
【1区SCI】Fusion entropy融合熵,多尺度,复合多尺度、时移多尺度、层次 + 故障识别、诊断-matlab代码
开发语言·机器学习·matlab·时序分析·故障诊断·信息熵·特征提取
北漂老男孩2 小时前
Java对象转换的多种实现方式
java·开发语言