• <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>
            隨筆 - 298  文章 - 377  trackbacks - 0
            <2016年9月>
            28293031123
            45678910
            11121314151617
            18192021222324
            2526272829301
            2345678

            常用鏈接

            留言簿(34)

            隨筆分類

            隨筆檔案

            文章檔案

            相冊

            收藏夾

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            <?php
            /**
             * 
             * 相似圖片搜索hash的php實現
             * @author welefen
             *
             
            */
            class Imghash{
                
                private static $_instance = null;
                
                public $rate = 2;
                
                public static function getInstance(){
                    if (self::$_instance === null){
                        self::$_instance = new self();
                    }
                    return self::$_instance;
                }
                public function run($file){
                    if (!function_exists('imagecreatetruecolor')){
                        throw new Exception('must load gd lib', 1);
                    }
                    $isString = false;
                    if (is_string($file)){
                        $file = array($file);
                        $isString = true;
                    }
                    $result = array();
                    foreach ($file as $f){
                        $result[] = $this->hash($f);
                    }
                    return $isString ? $result[0] : $result;
                }
                public function checkIsSimilarImg($imgHash$otherImgHash){
                    if (file_exists($imgHash) && file_exists($otherImgHash)){
                        $imgHash = $this->run($imgHash);
                        $otherImgHash = $this->run($otherImgHash);
                    }
                    if (strlen($imgHash) !== strlen($otherImgHash)) return false;
                    $count = 0;
                    $len = strlen($imgHash);
                    for($i=0;$i<$len;$i++){
                        if ($imgHash{$i} !== $otherImgHash{$i}){
                            $count++;
                        }
                    }
                    return $count <= (5 * $this->rate * $this->rate) ? true : false;
                }
                public function hash($file){
                    if (!file_exists($file)){
                        return false;
                    }
                    $height = 8 * $this->rate;
                    $width = 8 * $this->rate;
                    $img = imagecreatetruecolor($width$height);
                    list($w$h) = getimagesize($file);
                    $source = $this->createImg($file);
                    imagecopyresampled($img$source, 0, 0, 0, 0, $width$height$w$h);
                    $value = $this->getHashValue($img);
                    imagedestroy($img);
                    return $value;
                }
                public function getHashValue($img){
                    $width = imagesx($img);
                    $height = imagesy($img);
                    $total = 0;
                    $array = array();
                    for ($y=0;$y<$height;$y++){
                        for ($x=0;$x<$width;$x++){
                            $gray = ( imagecolorat($img$x$y) >> 8 ) & 0xFF;
                            if (!@is_array($array[$y])){
                                $array[$y] = array();
                            }
                            $array[$y][$x] = $gray;
                            $total += $gray;
                        }
                    }
                    $average = intval($total / (64 * $this->rate * $this->rate));
                    $result = '';
                    for ($y=0;$y<$height;$y++){
                        for ($x=0;$x<$width;$x++){
                            if ($array[$y][$x] >= $average){
                                $result .= '1';
                            }else{
                                $result .= '0';
                            }
                        }
                    }
                    return $result;
                }
                public function createImg($file){
                    $ext = $this->getFileExt($file);
                    if ($ext === 'jpeg') $ext = 'jpg';
                    $img = null;
                    switch ($ext){
                        case 'png' : $img = imagecreatefrompng($file);break;
                        case 'jpg' : $img = imagecreatefromjpeg($file);break;
                        case 'gif' : $img = imagecreatefromgif($file);
                    }
                    return $img;
                }
                public function getFileExt($file){
                    $infos = explode('.', $file);
                    $ext = strtolower($infos[count($infos) - 1]);
                    return $ext;
                }
            }
            @import url(http://www.shnenglu.com/CuteSoft_Client/CuteEditor/Load.ashx?type=style&file=SyntaxHighlighter.css);@import url(/css/cuteeditor.css);
            posted on 2016-09-22 10:29 聶文龍 閱讀(426) 評論(1)  編輯 收藏 引用

            FeedBack:
            # re: 相似圖片搜索hash的php實現 2016-09-22 11:07 聶文龍
            require_once "Imghash.class.php";
            $instance = ImgHash::getInstance();
            $result = $instance->checkIsSimilarImg('chenyin/IMG_3214.png', 'chenyin/IMG_3212.JPG');
            如果$result值為true, 則表明2個圖片相似,否則不相似。  回復  更多評論
              
            久久精品国产亚洲AV大全| 久久综合日本熟妇| 成人综合伊人五月婷久久| 久久99热国产这有精品| 久久婷婷色综合一区二区| 亚洲国产精品无码久久一区二区| 精品久久久久久亚洲精品| 久久综合给合综合久久| 久久永久免费人妻精品下载| 国产亚洲成人久久| 国产成人无码久久久精品一| 日本精品一区二区久久久| 亚洲一区中文字幕久久| 色偷偷88888欧美精品久久久| 久久精品国产一区二区电影| 国产∨亚洲V天堂无码久久久 | 无码人妻久久一区二区三区免费 | 思思久久好好热精品国产| 7777精品久久久大香线蕉| 久久国产成人| 久久天天躁狠狠躁夜夜不卡 | 色婷婷噜噜久久国产精品12p| 97超级碰碰碰久久久久| 久久精品人人做人人爽电影| 久久综合久久性久99毛片| 91久久精品国产免费直播| 99精品国产在热久久无毒不卡 | 久久综合久久久| 丁香狠狠色婷婷久久综合| 久久久久久久久久久久中文字幕 | 日韩美女18网站久久精品| 国产午夜精品理论片久久| 精品99久久aaa一级毛片| 91精品国产高清久久久久久91| 狠狠狠色丁香婷婷综合久久俺| 久久久久高潮毛片免费全部播放| 亚洲国产精品高清久久久| 久久国产色av免费看| 人妻精品久久久久中文字幕69| 久久综合给合久久狠狠狠97色| 久久狠狠高潮亚洲精品|