首页
学习资料
三维资料
资源下载
绘画资料
站长博文
站长图片
微信关注
微信
移动客户端
您当前的位置 :
首页
>
学习资料
>
分享一个PHP简易的图片相似度比较类
投稿邮箱:a@w1.hk
投稿QQ:305766661
分享一个PHP简易的图片相似度比较类
2021-03-21 23:50:29
来源:
作者:
责任编辑:cncml
摘要:
本文讲的是分享一个PHP简易的图片相似度比较类, 由于相似图片搜索的php实现的 API 不怎么符合我的用途,所以我重新定义 API 的架构,改写成比较简单的函数方式,虽然还是用对象的方式包装。 代码如下 复制代码 <?php /** * 图
由于相似图片搜索的php实现的 API 不怎么符合我的用途,所以我重新定义 API 的架构,改写成比较简单的函数方式,虽然还是用对象的方式包装。
<?php
/**
* 图片相似度比较
*
* @version $Id: ImageHash.php 4429 2012-04-17 13:20:31Z jax [ DISCUZ_CODE_1 ]nbsp;
* @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);
}
}
复制代码
文章来源:
责任编辑:cncml
更多
学习资料
01-08
[php学习资料] visual studio code
01-08
[php学习资料] tp6 显示500错误问题
01-08
[php学习资料] centos下编译so文件
03-22
visual studio code
精彩推荐
新测试2011
视口照明和阴影『原创』
3ds max卡通(墨水)材质ink'n Pain(原创)
3ds max卡通(墨水)材质ink\'n Pain(原创)...
详细》
没事做着玩的『原创』
vray下怎样使用max的 批量渲染『原创』
19-三维老资料分享(二)
实现php间隔一段时间执行一次某段代码
19-三维老资料分享(五)
19-三维老资料分享(四)
19-三维老资料分享(三)
模拟蜡烛 并虚拟照度范围的测试
绘画资料
手绘原画动漫资源 Ⅰ 2012.10.17
手绘原画动漫资源 Ⅱ 2012.10.17
手绘原画动漫资源 Ⅲ 2012.10.17
手绘原画动漫资源 Ⅳ 2012.10.17
手绘游戏原画Ⅰ
手绘游戏原画Ⅱ
手绘游戏原画Ⅲ
手绘游戏原画Ⅳ
手绘游戏原画Ⅴ
德国素描精选
手绘的光照分析
《最后的晚餐》卡通原画 高清版
版权声明:
1、本主题所有言论和图片纯属会员个人意见,与本网站立场无关
2、本站所有主题由该文章作者发表,该文章作者与
享有文章相关版权
3、其他单位或个人使用、转载或引用本文时必须同时征得该文章作者和
的同意
4、文章作者须承担一切因本文发表而直接或间接导致的民事或刑事法律责任
5、本帖部分内容转载自其它媒体,但并不代表本站赞同其观点和对其真实性负责
6、如本帖侵犯到任何版权问题,请立即告知本站,本站将及时予与删除并致以最深的歉意
7、
管理员和版主有权不事先通知发贴者而删除本文
精彩置顶
新测试2011
视口照明和阴影『原创』
3Ds max _vray1.50打造真实3D动画手绘原画效果『原创』
3ds max卡通(墨水)材质ink'n Pain(原创)
没事做着玩的『原创』
vray下怎样使用max的 批量渲染『原创』
07年巴西渲染器
三维资源(一)
三维资源(二)
三维资源(三)
2013老三维资源
bc 三维资源
lt-三维老资料分享(一)
lt-三维老资料分享(二)
19-三维老资料分享(一)
绘画资料
手绘原画动漫资源 Ⅰ 2012.10.17
手绘原画动漫资源 Ⅱ 2012.10.17
手绘原画动漫资源 Ⅲ 2012.10.17
手绘原画动漫资源 Ⅳ 2012.10.17
手绘游戏原画Ⅰ
手绘游戏原画Ⅱ
手绘游戏原画Ⅲ
手绘游戏原画Ⅳ
手绘游戏原画Ⅴ
德国素描精选
手绘的光照分析
《最后的晚餐》卡通原画 高清版
独家推荐
新测试2011
视口照明和阴影『原创』
3Ds max _vray1.50打造真实3D动画手绘原画效果『原创』
3ds max卡通(墨水)材质ink'n Pain(原创)
没事做着玩的『原创』
vray下怎样使用max的 批量渲染『原创』
19-三维老资料分享(二)
模拟蜡烛 并虚拟照度范围的测试
手绘2013.3.09未完待续
视频
maya海景模拟
关于渲染和灯光的一些理论研究
简单分析日光散射【手稿-原创-未完】
Max中的文件管理教程【1o0o年殺.原创】
雪景模拟
软件推荐
Windows Media Player 11
千千静听 5.1.0 简体中文版
腾讯QQ2008 贺岁版
快车FlashGet 2.0 简体中文版
罗技G500s G700s G400s 驱动下载 x64位 x86 32位
不良信息举报信箱
新闻热线:18733599993 技术服务:18733599993
网上投稿
关于本站
|
广告服务
|
免责申明
|
招聘信息
|
联系我们
在线网
版权所有 Copyright(C)2005-2026