Matlab进阶绘图第45期—蝴蝶气泡图

蝴蝶气泡图是一种特殊的柱泡图/气泡柱状图。

蝴蝶图一般由左右两个水平柱状图组合而成,其形如蝴蝶展翅,可以很直观地展示两种数据直接的差异

而蝴蝶气泡图则是在两个水平 柱状图每根柱子外侧额外添加大小不同的气泡,用于表示另外一个数据变量的大小

本文利用自己制作的BubbleButterfly 工具,进行蝴蝶气泡图的绘制,先来看一下成品效果:

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


1. 数据准备

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

复制代码
% 读取数据load data.mat% 初始化绘图参数butterflydata1 = x1;butterflydata2 = x2;bubbledata1 = y1;bubbledata2 = y2;offset1 = 800;textoffset1 = 100;offset2 = 800;textoffset2 = 100;bsz = [5 30];Label={'Sample1','Sample2','Sample3','Sample4','Sample5','Sample6','Sample7','Sample8'};

2. 颜色定义

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

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

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

复制代码
Colors = TheColor('sci',498);C1 = Colors(1,1:3);C2 = Colors(2,1:3);

3. 蝴蝶气泡图绘制

调用'BubbleButterfly'和命令,绘制初始蝴蝶气泡图

复制代码
[ax1,ax2,b1,b2,bubble1,bubble2]=BubbleButterfly(figureHandle,butterflydata1,butterflydata2, ...    bubbledata1,bubbledata2,offset1,offset2,bsz,Label,'normal');% 添加左翼气泡注释for i = 1:length(bubbledata1)    text(ax1, ...        offset1+textoffset1, i, num2str(bubbledata1(i)), ...        'HorizontalAlignment','right', ...        'VerticalAlignment','middle', ...        'FontSize',10, ...        'FontName','Arial', ...        'color','k')end  % 添加右翼气泡注释for i = 1:length(bubbledata2)    text(ax2, ...        offset2+textoffset2, i, num2str(bubbledata2(i)), ...        'HorizontalAlignment','left', ...        'VerticalAlignment','middle', ...        'FontSize',10, ...        'FontName','Arial', ...        'color','k')end 

4. 细节优化

为了插图的美观与信息完整性,对图形细节等进行美化

复制代码
% 左翼优化% 赋色b1.FaceColor = C1;bubble1.MarkerFaceColor = C1;bubble1.MarkerEdgeColor = C1;bubble1.MarkerFaceAlpha = 1;% 坐标区调整set(ax1, 'Box','off',...                % 边框         'LineWidth',1,...              % 坐标轴线宽         'TickLength',[0 0],...         % 刻度         'XGrid','on','YGrid','off',... % 网格         'XDir','reverse',...           % X坐标轴方向         'YDir','reverse',...           % Y坐标轴方向         'YAxisLocation','right',...    % Y坐标轴位置         'YTick',[])                    % Y刻度ax1.XRuler.Axle.LineStyle = 'none'; set(ax1, 'xtick',0:200:800,...         'xlim', [0 1000],...         'ylim', [0.5 8.5])% 标签及Legend1设置hLegend1 = legend(ax1, ...                 'Feature1', ...                 'Location', 'northoutside');hLegend1.ItemTokenSize = [10 10];hLegend1.Box = 'off';% 字体字号set([ax1,hLegend1], 'FontName', 'Arial', 'FontSize', 9)​% 右翼优化% 赋色b2.FaceColor = C2;bubble2.MarkerFaceColor = C2;bubble2.MarkerEdgeColor = C2;bubble2.MarkerFaceAlpha = 1;% 坐标区调整set(ax2, 'Box','off',...                % 边框         'LineWidth',1,...              % 坐标轴线宽         'TickLength',[0 0],...         % 刻度         'XGrid','on','YGrid','off',... % 网格         'XDir','normal',...            % X坐标轴方向         'YDir','reverse',...           % Y坐标轴方向         'YAxisLocation','left',...     % Y坐标轴位置         'YTick',[])                    % Y刻度ax2.XRuler.Axle.LineStyle = 'none'; set(ax2, 'xtick',0:200:800,...         'xlim', [0 1000],...         'ylim', [0.5 8.5]) % 标签及Legend2设置hLegend2 = legend(ax2, ...                 'Feature2', ...                 'Location', 'northoutside');hLegend2.ItemTokenSize = [10 10];hLegend2.Box = 'off';% 字体字号set([ax2,hLegend2], 'FontName', 'Arial', 'FontSize', 9)​% 背景颜色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');

以上。

相关推荐
2501_9216494929 分钟前
企业定制金融数据 API:从架构设计到 Python 接入实战
大数据·开发语言·python·websocket·金融·量化
直奔標竿32 分钟前
SpringAI + RAG + MCP + Agent 零基础全栈实战(完结篇)| 27课完整汇总,Java开发者AI转型必看
java·开发语言·人工智能·spring boot·后端·spring
reasonsummer1 小时前
【教学类-160-13】20260422 AI视频培训-练习013“豆包AI视频《师幼互动》+豆包图片风格:CG动画”
开发语言·python
曹牧1 小时前
Java:处理 HTTP 请求的 Content-Type
java·开发语言
itzixiao1 小时前
L1-066 猫是液体(5分)[java][python]
java·开发语言·python·算法
ytttr8731 小时前
MATLAB SIFT图像配准实现
算法·机器学习·matlab
Lightning-py1 小时前
Python 配置日志(Logging)
开发语言·python
隔窗听雨眠2 小时前
MySQL主从延迟根因诊断法
开发语言·php
Hui_AI7202 小时前
基于RAG的农产品GEO溯源智能问答系统实现
开发语言·网络·人工智能·python·算法·创业创新
CDwenhuohuo2 小时前
前端文件预览
开发语言·前端·javascript