3D渐变柱状图

代码说明

  1. 数据准备

    • 数据可以是任意形式的矩阵,例如 5x7 的矩阵。

    • 行标签 (rowLabels) 和列标签 (colLabels) 是可选的,如果不需要可以删除相关部分。

  2. 颜色定义

    • 使用自定义的蓝黄渐变色 (map)。

    • 如果需要其他颜色,可以替换 map,例如使用 MATLAB 内置的 jetparula 等 colormap。

  3. 绘制三维柱状图

    • 使用 bar3 函数绘制 3D 柱状图。

    • 每个柱子的颜色根据其高度渐变。

  4. 坐标轴调整

    • 设置了行和列的标签(如果提供了 rowLabelscolLabels)。

    • 调整了网格线、刻度和字体样式。

  5. 输出图片

    • 图片保存为 GradientBarPlot.png,分辨率为 300 dpi。

运行代码后,将生成一个 3D 渐变柱状图:

  • X 轴:列标签(Col1Col7)。

  • Y 轴:行标签(Row1Row5)。

  • Z 轴:矩阵中的值。

  • 每个柱子的颜色根据其高度渐变。

  • 代码如下:

Matlab 复制代码
%% 1. 数据准备
% 假设数据是一个任意形式的矩阵
% 例如:5行 x 7列的矩阵
data = [3 5 2 6 8 4 7;
        7 2 6 9 3 5 8;
        4 8 3 7 2 6 9;
        6 1 5 8 4 7 2;
        9 4 7 3 6 2 5];

% 定义行和列的标签(可选)
rowLabels = {'Row1', 'Row2', 'Row3', 'Row4', 'Row5'}; % 行标签
colLabels = {'Col1', 'Col2', 'Col3', 'Col4', 'Col5', 'Col6', 'Col7'}; % 列标签

%% 2. 颜色定义
% 自定义渐变色(蓝黄渐变)
map = [linspace(0,1,300)' linspace(0,0.5,300)' linspace(1,0,300)'];

%% 3. 绘制三维柱状图
figureHandle = figure('Color','w'); % 创建白色背景图形窗口
b = bar3(data, 0.5); % 绘制3D柱状图,0.5控制柱子宽度

% 添加标签
hTitle = title('3D Gradient Bar Plot');
hXLabel = xlabel('Columns');
hYLabel = ylabel('Rows');
hZLabel = zlabel('Values');

%% 4. 颜色渐变设置
for k = 1:length(b)
    zdata = b(k).ZData;        % 获取柱子高度数据
    b(k).CData = zdata;         % 将高度数据映射为颜色数据
    b(k).FaceColor = 'interp';  % 设置渐变填充
end
colormap(map)                   % 应用颜色映射
colorbar                        % 添加颜色标尺

%% 5. 坐标轴调整
set(gca, 'Box', 'off',...                          % 关闭边框
        'LineWidth', 1,...                         % 坐标轴线宽
        'GridLineStyle', '-',...                   % 网格线型
        'XGrid', 'off', 'YGrid', 'off','ZGrid', 'on',... % 显示Z轴网格
        'TickDir', 'out',...                       % 刻度朝外
        'TickLength', [.015 .015],...              % 刻度长度
        'XColor', [.1 .1 .1],...                  % 坐标轴颜色
        'YColor', [.1 .1 .1],...
        'ZColor', [.1 .1 .1],...
        'XTickLabel', colLabels,...                % 设置列标签
        'YTickLabel', rowLabels,...                % 设置行标签
        'FontSize', 10);                          % 坐标轴字号

% 调整视角
view(-45, 30) % 设置3D视图角度

%% 6. 字体设置
set([hXLabel, hYLabel, hZLabel],...
    'FontSize', 12, 'FontWeight', 'bold',...
    'FontName', 'Arial');
set(hTitle, 'FontSize', 14, 'FontWeight', 'bold');

%% 7. 图片输出
print(figureHandle, 'GradientBarPlot.png', '-r300', '-dpng');
disp('图片已保存为GradientBarPlot.png');
相关推荐
rit84324991 天前
MATLAB对组合巴克码抗干扰仿真的实现方案
开发语言·matlab
suoge2231 天前
六面体传热单元Matlab有限元编程:三大类边界条件(上篇)| 固定温度边界条件 | 表面热通量边界条件 | 热对流边界条件)
matlab·有限元编程·传热有限元·热传导有限元·六面体热单元·边界条件·对流换热
ECT-OS-JiuHuaShan1 天前
哲学第三次世界大战:《易经》递归生成论打破西方机械还原论
人工智能·程序人生·机器学习·数学建模·量子计算
Evand J1 天前
【MATLAB例程,附代码下载链接】基于累积概率的三维轨迹,概率计算与定位,由轨迹匹配和滤波带来高精度位置,带测试结果演示
开发语言·算法·matlab·csdn·轨迹匹配·候选轨迹·完整代码
suoge2231 天前
六面体传热单元(热通量边界条件)有限元MATLAB程序【理论文本+代码】|热传导有限元|纽曼边界条件|有限元传热分析
matlab·有限元·有限元编程·传热有限元·稳态传热·热传导有限元·热固耦合
suoge2231 天前
六面体传热单元(固定温度边界条件)有限元MATLAB程序【理论文本+代码】|热传导有限元|狄利克雷边界|有限元传热分析
matlab·有限元·热传导·传热有限元·迪利克雷边界条件·有限元法·稳态传热
foundbug9991 天前
基于MATLAB的TDMP-LDPC译码器模型构建、仿真验证及定点实现
开发语言·matlab
Evand J1 天前
【MATLAB代码介绍】基于累积概率的三维轨迹匹配与定位,由轨迹匹配和卡尔曼滤波形成算法,带测试结果演示
算法·matlab·滤波·定位·导航·轨迹匹配
wuk9981 天前
梁非线性动力学方程MATLAB编程实现
前端·javascript·matlab
一个与程序bug抗争的程序员1 天前
Matlab App Designer设计人机交互界面并打包成exe——加法计算器
matlab·人机交互