代码美学:MATLAB制作渐变色

输入颜色个数n,颜色类型:

Matlab 复制代码
n = 2; % 输入颜色个数
colors = {[1, 0, 0], [0, 0, 1]}; 
createGradientHeatmap(n, colors);

调用函数:

Matlab 复制代码
function createGradientHeatmap(n, colors)
    % 输入检查
    if length(colors) ~= n
        error('输入的颜色数量与n不一致!');
    end
    
    % 创建渐变色
    gradientColors = zeros(200, 3); % 200行RGB颜色
    for i = 1:n-1
        startColor = colors{i};
        endColor = colors{i+1};
        % 插值计算当前段颜色
        range = linspace(0, 1, ceil(200/(n-1)));
        for j = 1:3
            gradientColors((i-1)*ceil(200/(n-1)) + (1:length(range)), j) = ...
                interp1([0 1], [startColor(j) endColor(j)], range);
        end
    end
    gradientColors = gradientColors(1:200, :); % 确保200个渐变
    
    % 创建20x10热力图矩阵
    heatmapMatrix = reshape(1:200, [20, 10]);
    
    % 绘制热力图
    figure('Position', [100, 100, 800, 400]); % 设置画布大小
    imagesc(heatmapMatrix);
    colormap(gradientColors);
    colorbar;
    title('Gradient Heatmap');
    axis equal tight;
    
    % 添加黑色分割线
    hold on;
    [rows, cols] = size(heatmapMatrix);
    for i = 1:rows+1
        plot([0.5, cols+0.5], [i-0.5, i-0.5], 'k', 'LineWidth', 1); % 横向分割线
    end
    for j = 1:cols+1
        plot([j-0.5, j-0.5], [0.5, rows+0.5], 'k', 'LineWidth', 1); % 纵向分割线
    end
    hold off;
    
    % 保存高清图片
    saveas(gcf, 'gradient_heatmap_with_lines.png');
    disp('热力图已保存为gradient_heatmap_with_lines.png');
end

%示例调用
%n = 3; % 输入颜色个数
%colors = {[1, 0, 0], [0, 1, 0], [0, 0, 1]}; % 红-绿-蓝渐变
%createGradientHeatmap(n, colors);

结果:

相关推荐
洛克希德马丁27 分钟前
Qt饼状图在图例上追踪鼠标落点
开发语言·qt·计算机外设
王哈哈嘻嘻噜噜27 分钟前
c++中的auto关键字
开发语言·c++
江沉晚呤时28 分钟前
C# 状态模式深度解析:构建灵活的状态驱动系统
开发语言·javascript·数据库·ui·ajax·c#·ecmascript
邪恶的贝利亚29 分钟前
如何深刻理解Reactor和Proactor
开发语言·php
邪恶的贝利亚30 分钟前
c++造轮子之REACTOR实战
开发语言·c++·php
暴龙胡乱写博客31 分钟前
python三大库之---pandas(二)
开发语言·人工智能·python·pandas
lsx20240644 分钟前
R Excel 文件:高效数据处理与可视化工具的完美结合
开发语言
独好紫罗兰1 小时前
洛谷题单3-P1307 [NOIP 2011 普及组] 数字反转-python-流程图重构
开发语言·python·算法
蹦蹦跳跳真可爱5891 小时前
Python----计算机视觉处理(Opencv:道路检测完整版:透视变换,提取车道线,车道线拟合,车道线显示,)
开发语言·人工智能·python·opencv·计算机视觉
lly2024061 小时前
C# 事件(Event)
开发语言