当前位置:Gxlcms > PHP教程 > php比较图片相似度代码示例

php比较图片相似度代码示例

时间:2021-07-01 10:21:17 帮助过:21人阅读

  1. /**

  2. * 图片相似度比较
  3. *
  4. * @version $Id: ImageHash.php 4429 2012-04-17 13:20:31Z jax $
  5. * @authorjax.hu
  6. * www.osxue.com
  7. *//Sample_1
  8. *$aHash = ImageHash::hashImageFile('wsz.11.jpg');
  9. *$bHash = ImageHash::hashImageFile('wsz.12.jpg');
  10. *var_dump(ImageHash::isHashSimilar($aHash, $bHash));
  11. *
  12. *//Sample_2
  13. *var_dump(ImageHash::isImageFileSimilar('wsz.11.jpg', 'wsz.12.jpg'));
  14. *
  15. */

  16. class ImageHash {

  17. /**取样倍率 1~10
  18. * @access public
  19. * @staticvar int
  20. * */
  21. public static $rate = 2;

  22. /**相似度允许值 0~64

  23. * @access public
  24. * @staticvar int
  25. * */
  26. public static $similarity = 80;

  27. /**图片类型对应的开启函数

  28. * @access private
  29. * @staticvar string
  30. * */
  31. private static $_createFunc = array(
  32. IMAGETYPE_GIF =>'imageCreateFromGIF',
  33. IMAGETYPE_JPEG=>'imageCreateFromJPEG',
  34. IMAGETYPE_PNG =>'imageCreateFromPNG',
  35. IMAGETYPE_BMP =>'imageCreateFromBMP',
  36. IMAGETYPE_WBMP=>'imageCreateFromWBMP',
  37. IMAGETYPE_XBM =>'imageCreateFromXBM',
  38. );

  39. /**从文件建立图片

  40. * @param string $filePath 文件地址路径
  41. * @return resource 当成功开启图片则传递图片 resource ID,失败则是 false
  42. * */
  43. public static function createImage($filePath){
  44. if(!file_exists($filePath)){ return false; }

  45. /*判断文件类型是否可以开启*/

  46. $type = exif_imagetype($filePath);
  47. if(!array_key_exists($type,self::$_createFunc)){ return false; }

  48. $func = self::$_createFunc[$type];

  49. if(!function_exists($func)){ return false; }

  50. return $func($filePath);

  51. }

  52. /**hash 图片

  53. * @param resource $src 图片 resource ID
  54. * @return string 图片 hash 值,失败则是 false
  55. * */
  56. public static function hashImage($src){
  57. if(!$src){ return false; }

  58. /*缩小图片尺寸*/

  59. $delta = 8 * self::$rate;
  60. $img = imageCreateTrueColor($delta,$delta);
  61. imageCopyResized($img,$src, 0,0,0,0, $delta,$delta,imagesX($src),imagesY($src));

  62. /*计算图片灰阶值*/

  63. $grayArray = array();
  64. for ($y=0; $y<$delta; $y++){
  65. for ($x=0; $x<$delta; $x++){
  66. $rgb = imagecolorat($img,$x,$y);
  67. $col = imagecolorsforindex($img, $rgb);
  68. $gray = intval(($col['red']+$col['green']+$col['blue'])/3)& 0xFF;

  69. $grayArray[] = $gray;

  70. }
  71. }
  72. imagedestroy($img);

  73. /*计算所有像素的灰阶平均值*/

  74. $average = array_sum($grayArray)/count($grayArray);

  75. /*计算 hash 值*/

  76. $hashStr = '';
  77. foreach ($grayArray as $gray){
  78. $hashStr .= ($gray>=$average) ? '1' : '0';
  79. }
  80. return $hashStr;
  81. }

  82. /**hash 图片文件

  83. * @param string $filePath 文件地址路径
  84. * @return string 图片 hash 值,失败则是 false
  85. * */
  86. public static function hashImageFile($filePath){
  87. $src = self::createImage($filePath);
  88. $hashStr = self::hashImage($src);
  89. imagedestroy($src);

  90. return $hashStr;

  91. }

  92. /**比较两个 hash 值,是不是相似

  93. * @param string $aHash A图片的 hash 值
  94. * @param string $bHash B图片的 hash 值
  95. * @return bool 当图片相似则传递 true,否则是 false
  96. * */
  97. public static function isHashSimilar($aHash, $bHash){
  98. $aL = strlen($aHash); $bL = strlen($bHash);
  99. if ($aL !== $bL){ return false; }

  100. /*计算容许落差的数量*/

  101. $allowGap = $aL*(100-self::$similarity)/100;

  102. /*计算两个 hash 值的汉明距离*/

  103. $distance = 0;
  104. for($i=0; $i<$aL; $i++){
  105. if ($aHash{$i} !== $bHash{$i}){ $distance++; }
  106. }

  107. return ($distance<=$allowGap) ? true : false;

  108. }

  109. /**比较两个图片文件,是不是相似

  110. * @param string $aHash A图片的路径
  111. * @param string $bHash B图片的路径
  112. * @return bool 当图片相似则传递 true,否则是 false
  113. * */
  114. public static function isImageFileSimilar($aPath, $bPath){
  115. $aHash = ImageHash::hashImageFile($aPath);
  116. $bHash = ImageHash::hashImageFile($bPath);
  117. return ImageHash::isHashSimilar($aHash, $bHash);
  118. }
  119. }

人气教程排行