-
-
/** - * 画像の類似性比較
- *
- * @version $Id: ImageHash.php 4429 2012-04-17 13:20:31Z jax $
- * @authorjax.hu
- * www.osxue.com
- *//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'));
- *
- */
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 =>'imageCreateFromB MP ',
- IMAGETYPE_WBMP=>'imageCreateFromWBMP',
- IMAGETYPE_XBM =>'imageCreateFromXBM',
- );
/**ファイルから画像を作成する
- * @param string $filePath ファイルアドレス パス
- * @return 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);
- }
/**ハッシュ画像
- * @param resource $src image リソース ID
- * @return string 画像ハッシュ値、失敗した場合は false
- **/
- public static function hashImage($src){
- if(!$src){ return false; }
/*缩小图片尺寸*/
- $delta = 8 * self::$rate;
- $img = imageCreateTrueColor($delta,$delta);
- imageCopyResize($img,$src, 0,0,0,0, $デルタ,$デルタ,画像X($src),画像Y($src));
/*計算図片灰阶值*/
- $grayArray = array();
- for ($y=0; $y for ($x=0; $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);
/*计算ハッシュ值*/
- $hashStr = '';
- foreach ($grayArray as $gray){
- $hashStr .= ($gray>=$average) ? '1' : '0';
- }
- return $hashStr;
- }
/**ハッシュ画像ファイル
- * @param string $filePath ファイル アドレス パス
- * @return string 画像ハッシュ値、失敗した場合は false
- **/
- public static function hashImageFile($filePath){
- $src = self::createImage($filePath);
- $hashStr = self::hashImage($src);
- imagedestroy($src) ;
return $hashStr;
- }
/**2 つのハッシュ値を比較して似ているかどうかを確認します
- * @param string $aHash 写真 A のハッシュ値
- * @param string $bHash 写真 B のハッシュ値
- * @return bool 写真が似ている場合、true渡されます。それ以外の場合は false
- **/
- パブリック静的関数 isHashSimilar($aHash, $bHash){
- $aL = strlen($aHash); $bL = strlen($bHash);
- if ($aL !== $bL){ return false; }
/*計算許容落差の数*/
- $allowGap = $aL*(100-self::$similarity)/100;
/*2 つのハッシュ値を計算します*/
- $ distance = 0;
- for($i=0; $i if ($aHash{$i} !== $ bHash{$i}){ $ distance++; }
- }
return ($ distance<=$allowGap) ? true : false;
- }
/**2 つの画像ファイルを比較して、似ているかどうかを確認します
- * @param string $aHash 画像 A のパス
- * @param string $bHash 画像 B のパス
- * @return bool 画像が似ている場合は true が渡され、そうでない場合は嘘
- **/
- public static function isImageFileSimilar($aPath, $bPath){
- $aHash = ImageHash::hashImageFile($aPath);
- $bHash = ImageHash: :hashImageFile($bPath);
- return ImageHash::isHashSimilar($aHash, $bHash);
- }
- }>
|