使用Imagick实现图像直方图
2023-04-18 14:45:45 时间
玩过单反相机的人应该都知道图像直方图(Image Histogram),简单点说,它通过计算每个色阶在总像素中所占的比例来反映图像的曝光情况。我并不打算详细解释专业名词,有兴趣的读者可以查阅文章结尾处的参考链接,那里有通俗易懂的解释:
我们先找一个例子图像(用Canon 550D拍的):
例子图片:butterfly.jpg
下面看看如何使用Imagick实现图像直方图:
<?php
$file = 'butterfly.jpg';
$size = array(
'width' => 256,
'height' => 100,
);
$image = new Imagick($file);
$histogram = array_fill_keys(range(0, 255), 0);
foreach ($image->getImageHistogram() as $pixel) {
$rgb = $pixel->getColor();
$histogram[$rgb['r']] += $pixel->getColorCount();
$histogram[$rgb['g']] += $pixel->getColorCount();
$histogram[$rgb['b']] += $pixel->getColorCount();
}
$max = max($histogram);
$threshold = ($image->getImageWidth() * $image->getImageHeight()) / 256 * 12;
if ($max > $threshold) {
$max = $threshold;
}
$image = new Imagick();
$draw = new ImagickDraw();
$image->newImage($size['width'], $size['height'], 'white');
foreach ($histogram as $x => $count) {
if ($count == 0) {
continue;
}
$draw->setStrokeColor('black');
$height = min($count, $max) / $max * $size['height'];
$draw->line($x, $size['height'], $x, $size['height'] - $height);
$image->drawImage($draw);
$draw->clear();
}
$image->setImageFormat('png');
$image->writeImage('histogram.png');
?>
注:代码中之所以加入$threshold这个阀值,是因为有时候某些色阶的值可能会非常大,如果不做处理会干扰最终的生成效果。至于为什么要先除256,接着又乘12,没有什么道理可言,都是我一拍脑袋决定的,你也可以使用别的方法。
最终生成的直方图和Photoshop的效果基本一样,这里就贴一下Photoshop的:
Photoshop生成的直方图
注:使用Photoshop打开图片后,选择窗口,然后选择直方图即可。
本文说的实际上只是RGB通道的直方图绘制方法,原理上,RGB直方图是红绿蓝直方图累加的结果,至于红绿蓝三原色各自的直方图,上面代码稍加修改即可。
注:XARG.ORG上有一个HTML5实现的图像直方图开源项目,效果不错,值得学习。
最后顺便说一下,如果你对摄影知识感兴趣,可参考:如何解读数码相机的直方图。
相关文章
- 医疗AI的未来发展:值得关注的三大趋势
- 研究表明私有云依然活跃
- 企业为什么需要考虑采用混合云?
- 人工智能发展何时突破枷锁?
- 人工智能采用的七个最大障碍及其解决方案
- Docker容器:如何让应用程序优雅退出
- 腾讯安全TCSS容器安全服务发布,守护容器全生命周期安全
- 谷歌新AI火了!世界最长单词都能画
- 美国为何要让中国三大运营商退市
- 谈谈人工智能客服指标
- 主要网络IT投资包括5G、智能网卡、云计算
- 详解:实现广域确定性网络的三种技术路线
- 2020年我国云计算市场规模达1781亿元,增速为33.6%
- 在机器学习的工具箱里,藏着六种重要的算法
- 2021年中国基础云服务行业市场规模已经达到2256亿元
- 扬开源之帆,借官方认证考试之势,在NGINX领域脱颖而出
- 计算机视觉帮助解决业务挑战的五种方法
- 重磅!白山云全新发布 Baishan Canvas——极速、安全、敏捷的一体化边缘云平台
- Game Over?强AI与弱AI之争
- AI 成为增长新引擎,来听听亚马逊云科技的技术方法论