Matlab进阶绘图第73期-双组堆叠图

在之前的文章中,分享过Matlab多组堆叠图的绘制方法( Matlab论文插图绘制模板第24期---柱状图(多组堆叠)

此版内容仅用示范案例分享作图思路,灵活度不高,对部分人来说,可能不太理解该如何构造数据。

于是,本期内容直接将其制作成工具包,进行双组堆叠图的绘制,先来看一下成品效果:

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


1. 数据准备

此部分主要是读取原始数据并初始化绘图参数

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

2. 颜色定义

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

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

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

复制代码
map = TheColor('sci',2062,'map',10);C1 = map([2 3 4 5],:);C2 = map([10 9 8 7],:);

3. 双组堆叠图绘制

调用'multiStackedBar'命令,绘制初始双组堆叠图。​​​​​​​

复制代码
[GO1,GO2,xt] = multiStackedBar(Y1,Y2,0.8);hTitle = title('Multi-Stacked Bar Plot');hXLabel = xlabel('XAxis');hYLabel = ylabel('YAxis');

4. 细节优化

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

复制代码
% 赋色for i = 1:length(GO1)    % 第一组的赋色    GO1(i).FaceColor = C1(i,:);    % 第二组的赋色    GO2(i).FaceColor = C2(i,:);end% 坐标轴美化set(gca, 'Box', 'off', ...                                   % 边框         'LineWidth', 0.5,...                                % 线宽         'XGrid', 'off', 'YGrid', 'off', ...                 % 网格         'TickDir', 'out', 'TickLength', [.01 .01])          % 刻度set(gca,'XTick',xt,...        'Xticklabel',1:6)% Legend设置    hLegend = legend([GO1,GO2], ...                 'A1', 'A2', 'A3', 'A4','B1', 'B2', 'B3', 'B4', ...                 'Location', 'eastoutside','Orientation','vertical');hLegend.ItemTokenSize = [10 10];legend('boxoff');% 字体和字号set(gca, 'FontName', 'Arial', 'FontSize', 10)set([hLegend,hXLabel, hYLabel], 'FontSize', 10, 'FontName', 'Arial')set(hTitle, 'FontSize', 12, 'FontWeight' , 'bold')% 背景颜色set(gcf,'Color',[1 1 1])% 添加上、右框线xc = get(gca,'XColor');yc = get(gca,'YColor');unit = get(gca,'units');ax = axes( 'Units', unit,...           'Position',get(gca,'Position'),...           'XAxisLocation','top',...           'YAxisLocation','right',...           'Color','none',...           'XColor',xc,...           'YColor',yc);set(ax, 'linewidth',0.5,...        'XTick', [],...        'YTick', []);

设置完毕后,以期刊所需分辨率、格式输出图片。

复制代码
%% 图片输出figW = figureWidth;figH = figureHeight;set(figureHandle,'PaperUnits',figureUnits);set(figureHandle,'PaperPosition',[0 0 figW figH]);fileout = 'test';print(figureHandle,[fileout,'.png'],'-r300','-dpng');

以上。

相关推荐
leo__520几秒前
MATLAB实现牧羊人算法
开发语言·算法·matlab
格发许可优化管理系统13 分钟前
Mentor许可证使用规定全解析
java·大数据·c语言·开发语言·c++
FL162386312922 分钟前
C# OpenCvSharp 基于霍夫变换直线检测的文本图像倾斜校正文本图像倾斜校
开发语言·c#
leo__52025 分钟前
MATLAB实现UKF(无迹卡尔曼滤波)原理
人工智能·matlab
techdashen36 分钟前
在 Fly.io 上使用 Rust 构建远程开发环境:从 Tokio 到 eBPF
开发语言·后端·rust
fie888937 分钟前
LBP + HOG 特征检测与识别 MATLAB 实现
数据结构·算法·matlab
留白_40 分钟前
pandas文件读取与存储
开发语言·python·pandas
夕除1 小时前
AOP 实现 Redis 缓存切面解析
java·开发语言·python
feifeigo1231 小时前
马尔可夫决策过程(MDP)MATLAB 实现
开发语言·matlab
攻城狮Soar1 小时前
STL源码解析之list(1)
开发语言·c++