php中使用Imagick实现图像直方图的实现代码


Posted in PHP onAugust 30, 2011

我并不打算详细解释专业名词,有兴趣的读者可以查阅文章结尾处的参考链接,那里有通俗易懂的解释:

我们先找一个例子图像(用Canon 550D拍的):
php中使用Imagick实现图像直方图的实现代码
例子图片: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的:
php中使用Imagick实现图像直方图的实现代码
Photoshop生成的直方图
注:使用Photoshop打开图片后,选择窗口,然后选择直方图即可。
本文说的实际上只是RGB通道的直方图绘制方法,原理上,RGB直方图是红绿蓝直方图累加的结果,至于红绿蓝三原色各自的直方图,上面代码稍加修改即可。
注:XARG.ORG上有一个HTML5实现的图像直方图开源项目,效果不错,值得学习。
最后顺便说一下,如果你对摄影知识感兴趣,可参考:如何解读数码相机的直方图。

PHP 相关文章推荐
使用php重新实现PHP脚本引擎内置函数
Mar 06 PHP
在JavaScript中调用php程序
Mar 09 PHP
apache2.2.4+mysql5.0.77+php5.2.8安装精简
Apr 29 PHP
php设计模式  Command(命令模式)
Jun 17 PHP
php实现12306余票查询、价格查询示例
Apr 17 PHP
php实现简单的语法高亮函数实例分析
Apr 27 PHP
PHP封装的字符串加密解密函数
Dec 18 PHP
配置Nginx+PHP的正确思路与过程
May 10 PHP
Docker 如何布置PHP开发环境
Jun 21 PHP
PHP水印类,支持添加图片、文字、填充颜色区域的实现
Feb 04 PHP
PHP7匿名类的用法示例
Apr 05 PHP
PHP设计模式入门之迭代器模式原理与实现方法分析
Apr 26 PHP
PHP正确配置mysql(apache环境)
Aug 28 #PHP
PHP MySQL应用中使用XOR运算加密算法分享
Aug 28 #PHP
PHP 时间日期操作实战
Aug 26 #PHP
PHP url 加密解密函数代码
Aug 26 #PHP
php图片上传存储源码并且可以预览
Aug 26 #PHP
PHP 无限分类三种方式 非函数的递归调用!
Aug 26 #PHP
php中将图片gif,jpg或mysql longblob或blob字段值转换成16进制字符串
Aug 23 #PHP
You might like
深入PHP nl2br()格式化输出的详解
2013/06/05 PHP
php实现计数器方法小结
2015/01/05 PHP
PHP数组和explode函数示例总结
2015/05/08 PHP
PHP带节点操作的无限分类实现方法详解
2016/11/09 PHP
PHP大文件分割上传 PHP分片上传
2017/08/28 PHP
PHP一个简单的无需刷新爬虫
2019/01/05 PHP
Javascript学习笔记7 原型链的原理
2010/01/11 Javascript
给页面渲染时间加速 干掉Dom Level 0 Event
2012/12/19 Javascript
浅谈javascript的Touch事件
2015/09/27 Javascript
AngularJS入门教程之REST和定制服务详解
2016/08/19 Javascript
JavaScript数据结构之数组的表示方法示例
2017/04/12 Javascript
JavaScript之json_动力节点Java学院整理
2017/06/29 Javascript
彻底理解js面向对象之继承
2018/02/04 Javascript
Vue页面骨架屏注入方法
2018/05/13 Javascript
微信小程序项目总结之点赞 删除列表 分享功能
2018/06/25 Javascript
vue.js实现格式化时间并每秒更新显示功能示例
2018/07/07 Javascript
详解在React.js中使用PureComponent的重要性和使用方式
2018/07/10 Javascript
使用vuepress搭建静态博客的示例代码
2019/02/14 Javascript
JQuery实现折叠式菜单的详细代码
2020/06/03 jQuery
OpenLayers3加载常用控件使用方法详解
2020/09/25 Javascript
python中__slots__用法实例
2015/06/04 Python
Python简单读取json文件功能示例
2017/11/30 Python
Python多进程原理与用法分析
2018/08/21 Python
Python自定义函数计算给定日期是该年第几天的方法示例
2019/05/30 Python
django 中QuerySet特性功能详解
2019/07/25 Python
在python中创建指定大小的多维数组方式
2019/11/28 Python
python+opencv实现移动侦测(帧差法)
2020/03/20 Python
世界上第一个创建了罩杯系统的美国内衣品牌:Maidenform
2019/03/23 全球购物
建筑专业毕业生求职信
2014/09/30 职场文书
2014年六五普法工作总结
2014/11/25 职场文书
优秀党务工作者先进事迹材料
2014/12/25 职场文书
走进科学观后感
2015/06/18 职场文书
高中升旗仪式主持词
2015/07/03 职场文书
2015年小学教科研工作总结
2015/07/20 职场文书
Python快速优雅的批量修改Word文档样式
2021/05/20 Python
DBCA命令行搭建Oracle ADG的流程
2021/06/11 Oracle