青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 298  文章 - 377  trackbacks - 0
<2016年9月>
28293031123
45678910
11121314151617
18192021222324
2526272829301
2345678

常用鏈接

留言簿(34)

隨筆分類

隨筆檔案

文章檔案

相冊

收藏夾

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

<?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;    
    
   /**圖片類型對應(yīng)的開啟函數(shù)   
    * @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 當(dāng)成功開啟圖片則傳遞圖片 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));    
    
       /*計(jì)算圖片灰階值*/    
       $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);    
    
       /*計(jì)算所有像素的灰階平均值*/    
       $average = array_sum($grayArray)/count($grayArray);    
    
       /*計(jì)算 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;    
   }    
    
    
   /**比較兩個(gè) hash 值,是不是相似   
    * @param string $aHash A圖片的 hash 值   
    * @param string $bHash B圖片的 hash 值   
    * @return bool 當(dāng)圖片相似則傳遞 true,否則是 false   
    * 
*/    
   public static function isHashSimilar($aHash$bHash){    
       $aL = strlen($aHash); $bL = strlen($bHash);    
       if ($aL !== $bL){ return false; }    
    
       /*計(jì)算容許落差的數(shù)量*/    
       $allowGap = $aL*(100-self::$similarity)/100;    
    
       /*計(jì)算兩個(gè) hash 值的漢明距離*/    
       $distance = 0;    
       for($i=0; $i<$aL$i++){    
           if ($aHash{$i} !== $bHash{$i}){ $distance++; }    
       }    
    
       return ($distance<=$allowGap) ? true : false;    
   }    
    
    
   /**比較兩個(gè)圖片文件,是不是相似   
    * @param string $aHash A圖片的路徑   
    * @param string $bHash B圖片的路徑   
    * @return bool 當(dāng)圖片相似則傳遞 true,否則是 false   
    * 
*/    
   public static function isImageFileSimilar($aPath$bPath){    
       $aHash = ImageHash::hashImageFile($aPath);    
       $bHash = ImageHash::hashImageFile($bPath);    
       return ImageHash::isHashSimilar($aHash$bHash);    
   }    
    
}  
posted on 2016-09-22 11:20 聶文龍 閱讀(1346) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜精品剧场| 欧美3dxxxxhd| 亚洲精品资源| 欧美99久久| 亚洲国产毛片完整版| 久久阴道视频| 麻豆精品在线视频| 91久久久在线| 亚洲日韩欧美视频一区| 久久久噜久噜久久综合| 尤物精品在线| 欧美激情在线免费观看| 欧美人牲a欧美精品| 亚洲一区二区黄色| 宅男精品视频| 国产一区二区三区免费不卡 | 蜜桃av一区二区三区| 亚洲国产精品成人一区二区 | 一本色道久久综合亚洲精品不 | 久久综合九色综合网站| 久久久欧美精品| 日韩天堂在线视频| 一区电影在线观看| 国产日韩一区欧美| 欧美国产日韩一区二区在线观看 | 亚洲男人第一av网站| 红桃视频一区| 亚洲欧洲日韩在线| 国产精品豆花视频| 久久免费少妇高潮久久精品99| 久久免费少妇高潮久久精品99| 日韩一二三区视频| 亚洲一区精彩视频| 亚洲国产欧美日韩| 亚洲在线观看免费| 亚洲欧洲一区| 欧美一区91| 亚洲无吗在线| 久久久久久久尹人综合网亚洲 | 国产精品色在线| 欧美成人精品影院| 国产精品日韩久久久久| 亚洲大片精品永久免费| 国产农村妇女精品| 亚洲精品国产精品国自产在线 | 欧美成人中文字幕在线| 性亚洲最疯狂xxxx高清| 免费一级欧美在线大片| 久久国产精品毛片| 欧美欧美全黄| 免费成人毛片| 国产情侣一区| 一区二区三区日韩精品| 亚洲精品综合| 久久中文精品| 久久成人综合视频| 国产精品高潮呻吟久久av无限 | 亚洲影院免费观看| 女女同性女同一区二区三区91| 久久aⅴ国产欧美74aaa| 欧美日韩一区成人| 亚洲国产精品美女| 亚洲激情第一区| 久久国产黑丝| 久久精品视频在线观看| 国产精品久久久久久久午夜 | 欧美一级精品大片| 欧美日韩极品在线观看一区| 亚洲国产精品一区在线观看不卡| 一区二区亚洲精品国产| 欧美一区二区三区在线观看 | 国产一区二区三区精品久久久| 一区二区三区国产精华| 亚洲色图在线视频| 欧美日韩亚洲高清| 夜夜爽av福利精品导航| 一区二区三区www| 欧美日韩国产成人精品| 亚洲免费播放| 亚洲一区在线看| 国产精品高清在线| 中文国产成人精品| 亚洲欧美激情一区二区| 国产精品丝袜xxxxxxx| 亚洲深夜福利视频| 欧美一区二区三区啪啪| 国产偷国产偷精品高清尤物| 欧美一区二区精品| 麻豆精品一区二区综合av| 亚洲国产精品成人精品| 欧美日韩视频在线第一区| 一区二区三区国产| 久久久久一区二区| 亚洲激情电影在线| 欧美日韩综合一区| 欧美一区二区三区在线| 欧美国产精品中文字幕| 亚洲色图综合久久| 国产日韩欧美日韩| 久久综合狠狠| 一区二区日韩精品| 久久婷婷国产综合国色天香| 亚洲国产aⅴ天堂久久| 欧美视频手机在线| 久久久久久**毛片大全| 亚洲精品免费一二三区| 久久成人资源| 亚洲毛片在线| 国产色综合天天综合网| 欧美国产日韩一区二区在线观看 | 欧美一级片在线播放| 悠悠资源网久久精品| 欧美日韩国产影院| 久久精品人人做人人爽| 亚洲精品久久久久中文字幕欢迎你| 亚洲欧美日本国产专区一区| 在线欧美三区| 国产精品视频精品| 欧美国产日韩一区二区| 香蕉久久夜色| 99国产精品私拍| 久久久精品国产99久久精品芒果| 一二三区精品福利视频| 国产专区精品视频| 国产精品国产自产拍高清av| 久热精品视频在线免费观看| 亚洲男女自偷自拍| 一区二区日韩精品| 最新日韩在线视频| 美国成人毛片| 亚洲欧美另类久久久精品2019| 一区在线影院| 国产日韩欧美在线视频观看| 欧美美女视频| 欧美精品情趣视频| 久久久精品国产一区二区三区| 亚洲一级特黄| 一区二区91| 亚洲精品在线二区| 亚洲福利小视频| 欧美14一18处毛片| 久久久久免费观看| 久久成人精品一区二区三区| 欧美伊人久久| 欧美一级日韩一级| 午夜精品一区二区三区四区| 亚洲午夜精品久久久久久app| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲日本乱码在线观看| 欧美高清视频www夜色资源网| 久久一区国产| 久久久久久久精| 久久久久久国产精品mv| 欧美伊久线香蕉线新在线| 欧美一区二区日韩一区二区| 午夜国产不卡在线观看视频| 亚洲在线免费观看| 亚洲一区二区三区在线看| 亚洲一区二区三区777| 亚洲视频导航| 亚洲午夜精品福利| 欧美亚洲在线视频| 欧美在线国产| 久久久综合网| 免费在线一区二区| 亚洲福利国产精品| 亚洲美女性视频| 国产精品99久久久久久人| 亚洲一区二区三区在线看 | 欧美在线亚洲综合一区| 久久久久久久成人| 欧美成人首页| 日韩网站免费观看| 亚洲男人影院| 久久天天躁狠狠躁夜夜av| 猛男gaygay欧美视频| 欧美日韩美女在线观看| 国产精品中文字幕欧美| 激情欧美一区二区三区| 亚洲人午夜精品免费| 亚洲午夜视频| 久久久青草婷婷精品综合日韩| 欧美.www| 中文精品视频| 久久蜜桃资源一区二区老牛| 欧美激情国产日韩| 国产精品免费区二区三区观看| 狠狠狠色丁香婷婷综合激情| 亚洲精品中文字幕在线| 欧美一区二区啪啪| 亚洲欧洲偷拍精品| 午夜在线播放视频欧美| 欧美激情亚洲国产| 国产视频欧美| 一区二区三区 在线观看视| 久久九九99视频| 日韩天堂在线观看| 乱中年女人伦av一区二区| 欧美午夜欧美| 亚洲片在线资源|