奇苛 2022-03-14 21:19 采纳率: 50%
浏览 208
已结题

matlab显示三种颜色RGB的直方图

我想知道怎么用matlab显示三种颜色RGB的直方图,我显示的只有一种颜色

  • 写回答

1条回答 默认 最新

  • slandarer MATLAB领域优质创作者 2022-03-15 15:10
    关注

    img


    代码:
    使用的时候改变imread中的图片文件路径即可

    function HistogramPic
    pic=imread('test.jpg');
    %pic=rgb2gray(pic);
    
    FreqNum=zeros(size(pic,3),256);
    for i=1:size(pic,3)
        for j=0:255
            FreqNum(i,j+1)=sum(sum(pic(:,:,i)==j));
        end
    end
    
    ax=gca;
    hold(ax,'on')
    
    if size(FreqNum,1)==3
        rBar=bar(0:255,FreqNum(1,:));
        gBar=bar(0:255,FreqNum(2,:));
        bBar=bar(0:255,FreqNum(3,:));
        rBar.FaceColor=[0.6350 0.0780 0.1840];
        gBar.FaceColor=[0.2400 0.5300 0.0900];
        bBar.FaceColor=[0      0.4470 0.7410];
        rBar.FaceAlpha=0.5;
        gBar.FaceAlpha=0.5;
        bBar.FaceAlpha=0.5;
        ax.XLabel.String='RGB brightness';
        
        rrange=find(FreqNum(1,:)~=0);
        rrange=[num2str(rrange(1)-1),' , ',num2str(rrange(end)-1)];
        grange=find(FreqNum(2,:)~=0);
        grange=[num2str(grange(1)-1),' , ',num2str(grange(end)-1)];
        brange=find(FreqNum(3,:)~=0);
        brange=[num2str(brange(1)-1),' , ',num2str(brange(end)-1)];
        legend({['R: range[',rrange,']'],...
                ['G: range[',grange,']'],...
                ['B: range[',brange,']']},...
                 'Location','northwest','Color',[0.9412    0.9412    0.9412],...
                 'FontName','Cambria','LineWidth',0.8,'FontSize',11);
    else 
        kBar=bar(0:255,FreqNum(1,:));
        kBar.FaceColor=[0.50 0.50 0.50];
        kBar.FaceAlpha=0.5;
        ax.XLabel.String='Gray scale';
        krange=find(FreqNum(1,:)~=0);
        krange=[num2str(krange(1)-1),' , ',num2str(krange(end)-1)];
        legend(['Gray: range[',krange,']'],...
               'Location','northwest','Color',[0.9412    0.9412    0.9412],...
               'FontName','Cambria','LineWidth',0.8,'FontSize',11);
    end
    box on
    grid on
    ax.LineWidth = 1;
    ax.GridLineStyle='--';
    ax.XLim=[-5 255];
    ax.XTick=[0:45:255,255];
    
    
    ax.XLabel.FontSize=13;
    ax.XLabel.FontName='Cambria';
    
    ax.YLabel.String='Frequency number';
    ax.YLabel.FontSize=13;
    ax.YLabel.FontName='Cambria';
    end
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 4月17日
  • 已采纳回答 4月9日
  • 创建了问题 3月14日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵