PHP实现的简易版图片相似度比较

2015-01-24信息快讯网

这篇文章主要介绍了PHP实现的简易版图片相似度比较,本文直接给出实现代码,使用方法请看代码中的注释,需要的朋友可以参考下

由于相似图片搜索的php实现的 API 不怎么符合我的用途,所以我重新定义 API 的架构,改写成比较简单的函数方式,虽然还是用对象的方式包装。

<?php    
/**   
* 图片相似度比较   
*   
* @version     $Id: ImageHash.php 4429 2012-04-17 13:20:31Z jax $   
* @author      jax.hu   
*   
* <code>   
*  //Sample_1   
*  $aHash = ImageHash::hashImageFile('wsz.11.jpg');   
*  $bHash = ImageHash::hashImageFile('wsz.12.jpg');   
*  var_dump(ImageHash::isHashSimilar($aHash, $bHash));   
*   
*  //Sample_2   
*  var_dump(ImageHash::isImageFileSimilar('wsz.11.jpg', 'wsz.12.jpg'));   
* </code>   
*/    
    
class ImageHash {    
    
   /**取样倍率 1~10   
    * @access public   
    * @staticvar int   
    * */    
   public static $rate = 2;    
    
   /**相似度允许值 0~64   
    * @access public   
    * @staticvar int   
    * */    
   public static $similarity = 80;    
    
   /**图片类型对应的开启函数   
    * @access private   
    * @staticvar string   
    * */    
   private static $_createFunc = array(    
       IMAGETYPE_GIF   =>'imageCreateFromGIF',    
       IMAGETYPE_JPEG  =>'imageCreateFromJPEG',    
       IMAGETYPE_PNG   =>'imageCreateFromPNG',    
       IMAGETYPE_BMP   =>'imageCreateFromBMP',    
       IMAGETYPE_WBMP  =>'imageCreateFromWBMP',    
       IMAGETYPE_XBM   =>'imageCreateFromXBM',    
   );    
    
    
   /**从文件建立图片   
    * @param string $filePath 文件地址路径   
    * @return resource 当成功开启图片则传递图片 resource ID,失败则是 false   
    * */    
   public static function createImage($filePath){    
       if(!file_exists($filePath)){ return false; }    
    
       /*判断文件类型是否可以开启*/    
       $type = exif_imagetype($filePath);    
       if(!array_key_exists($type,self::$_createFunc)){ return false; }    
    
       $func = self::$_createFunc[$type];    
       if(!function_exists($func)){ return false; }    
    
       return $func($filePath);    
   }    
    
    
   /**hash 图片   
    * @param resource $src 图片 resource ID   
    * @return string 图片 hash 值,失败则是 false   
    * */    
   public static function hashImage($src){    
       if(!$src){ return false; }    
    
       /*缩小图片尺寸*/    
       $delta = 8 * self::$rate;    
       $img = imageCreateTrueColor($delta,$delta);    
       imageCopyResized($img,$src, 0,0,0,0, $delta,$delta,imagesX($src),imagesY($src));    
    
       /*计算图片灰阶值*/    
       $grayArray = array();    
       for ($y=0; $y<$delta; $y++){    
           for ($x=0; $x<$delta; $x++){    
               $rgb = imagecolorat($img,$x,$y);    
               $col = imagecolorsforindex($img, $rgb);    
               $gray = intval(($col['red']+$col['green']+$col['blue'])/3)& 0xFF;    
    
               $grayArray[] = $gray;    
           }    
       }    
       imagedestroy($img);    
    
       /*计算所有像素的灰阶平均值*/    
       $average = array_sum($grayArray)/count($grayArray);    
    
       /*计算 hash 值*/    
       $hashStr = '';    
       foreach ($grayArray as $gray){    
           $hashStr .= ($gray>=$average) ? '1' : '0';    
       }    
    
       return $hashStr;    
   }    
    
    
   /**hash 图片文件   
    * @param string $filePath 文件地址路径   
    * @return string 图片 hash 值,失败则是 false   
    * */    
   public static function hashImageFile($filePath){    
       $src = self::createImage($filePath);    
       $hashStr = self::hashImage($src);    
       imagedestroy($src);    
    
       return $hashStr;    
   }    
    
    
   /**比较两个 hash 值,是不是相似   
    * @param string $aHash A图片的 hash 值   
    * @param string $bHash B图片的 hash 值   
    * @return bool 当图片相似则传递 true,否则是 false   
    * */    
   public static function isHashSimilar($aHash, $bHash){    
       $aL = strlen($aHash); $bL = strlen($bHash);    
       if ($aL !== $bL){ return false; }    
    
       /*计算容许落差的数量*/    
       $allowGap = $aL*(100-self::$similarity)/100;    
    
       /*计算两个 hash 值的汉明距离*/    
       $distance = 0;    
       for($i=0; $i<$aL; $i++){    
           if ($aHash{$i} !== $bHash{$i}){ $distance++; }    
       }    
    
       return ($distance<=$allowGap) ? true : false;    
   }    
    
    
   /**比较两个图片文件,是不是相似   
    * @param string $aHash A图片的路径   
    * @param string $bHash B图片的路径   
    * @return bool 当图片相似则传递 true,否则是 false   
    * */    
   public static function isImageFileSimilar($aPath, $bPath){    
       $aHash = ImageHash::hashImageFile($aPath);    
       $bHash = ImageHash::hashImageFile($bPath);    
       return ImageHash::isHashSimilar($aHash, $bHash);    
   }    
    
}  

php使用正则表达式获取图片url的方法
php使用CURL伪造IP和来源实例详解
php+mysql实现无限分类实例详解
php截取html字符串及自动补全html标签的方法
php在linux下检测mysql同步状态的方法
将FCKeditor导入PHP+SMARTY的实现方法
php实现redis数据库指定库号迁移的方法
PHP中浮点数计算比较及取整不准确的解决方法
php模拟登陆的实现方法分析
php获取四位字母和数字的随机数的实现方法
PHP中使用php5-ffmpeg撷取视频图片实例
PHP和Shell实现检查SAMBA与NFS Server是否存在
PHP中使用SimpleXML检查XML文件结构实例
php中$_POST与php://input的区别实例分析
php静态文件返回304技巧分享
php判断当前用户已在别处登录的方法
php实现utf-8转unicode函数分享
phplot生成图片类用法详解
php中Socket创建与监听实现方法
php实现计数器方法小结
jQuery+PHP实现的掷色子抽奖游戏实例
php模仿asp Application对象在线人数统计实现方法
php采集内容中带有图片地址的远程图片并保存的方法
php将图片保存入mysql数据库失败的解决方法
解决phpcms更换javascript的幻灯片代码调用图片问题
PHP使用pcntl_fork实现多进程下载图片的方法
PHP实现的比较完善的购物车类
php常用字符串比较函数实例汇总
PHP字符串比较函数strcmp()和strcasecmp()使用总结
一个比较不错的PHP日历类分享
php字符比较函数similar_text、strnatcmp与strcasecmp用法分析
PHP改进计算字符串相似度的函数similar_text()、levenshtein()
©2014-2025 dbsqp.com