这篇文章主要介绍了如何利用Matlab实现图像亮度分布统计图的绘制,文中的示例代码讲解详细,对我们学习Matlab有一定的帮助,感兴趣的可以了解一下
写了一个输入图片,便会生成美观的图像各通道亮度分布图的函数,大概效果如下:


老样子,工具函数放在最前面,之后会介绍咋用这个函数:
工具函数
function HistogramPic(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');box on;grid on
if size(FreqNum,1)==3
bar(0:255,FreqNum(1,:),'FaceColor',[0.6350 0.0780 0.1840],'FaceAlpha',0.5);
bar(0:255,FreqNum(2,:),'FaceColor',[0.2400 0.5300 0.0900],'FaceAlpha',0.5);
bar(0:255,FreqNum(3,:),'FaceColor',[0 0.4470 0.7410],'FaceAlpha',0.5);
ax.XLabel.String='RGB brightness';
rrange=[num2str(min(pic(:,:,1),[],[1,2])),' , ',num2str(max(pic(:,:,1),[],[1,2]))];
grange=[num2str(min(pic(:,:,2),[],[1,2])),' , ',num2str(max(pic(:,:,2),[],[1,2]))];
brange=[num2str(min(pic(:,:,3),[],[1,2])),' , ',num2str(max(pic(:,:,3),[],[1,2]))];
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
bar(0:255,FreqNum(1,:),'FaceColor',[0.50 0.50 0.50],'FaceAlpha',0.5);
ax.XLabel.String='Gray scale';
krange=[num2str(min(pic(:,:,1),[],[1,2])),' , ',num2str(max(pic(:,:,1),[],[1,2]))];
legend(['Gray: range[',krange,']'],...
'Location','northwest','Color',[0.9412 0.9412 0.9412],...
'FontName','Cambria','LineWidth',0.8,'FontSize',11);
end
ax.LineWidth=1;
ax.GridLineStyle='--';
ax.XLim=[-5 255];
ax.XTick=[0:45:255,255];
ax.YLabel.String='Frequency number';
ax.FontName='Cambria';
ax.FontSize=13;
end函数调用
非常简单的使用方法,就是读取图片后调用函数即可:
pic=imread('test.png');
HistogramPic(pic)若图像是彩图则效果如下:


若图像为灰度图则效果如下:


以上就是利用Matlab实现图像亮度分布统计图的详细内容,更多关于Matlab亮度分布统计图的资料请关注编程学习网其它相关文章!
沃梦达教程
本文标题为:利用Matlab实现图像亮度分布统计图
基础教程推荐
猜你喜欢
- Qt数据库应用之实现通用数据库请求 2023-03-18
- 纯C++代码详解二叉树相关操作 2023-05-15
- g++: const 丢弃限定符 2022-10-07
- VisualStudio2010安装教程 2023-01-05
- C语言数组长度的计算方法实例总结(sizeof与strlen) 2023-04-26
- C语言植物大战数据结构二叉树递归 2023-04-09
- C语言的三种条件判断语句你都了解吗 2023-03-05
- character-encoding – Linux中最常见的C语言编码(和Unix?) 2023-11-21
- 05-C语言进阶——动态内存管理 2023-11-20
- 利用QT设计秒表功能 2023-05-30
