网站大量收购闲置独家精品文档,联系QQ:2885784924

图片比较算法.docVIP

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
图片比较算法

图片比较算法 上一篇 / 下一篇 ?2008-12-31 11:11:32 / 个人分类:自动化测试框架 查看( 151 ) / 评论( 1 ) / 评分( 0 / 0 ) 前几天其他项目组接了个项目,客户那边要求顺便给做个图片比较的工具,因为他们要看看同样的网页在IE7和IE8上显示有什么不同,不同的地方用用户指定的某种颜色标示出来,生成第三张图片。因为他们组比较忙,就帮他们做了做,UI界面就不用说了。 起初的想法是这样,先比较两幅图片的hash散列,如果相同就不比较了,下面就是这个算法: ??????? /// summary ??????? /// compare the hash value of two image files. ??????? /// /summary ??????? /// param name=leftImage/param ??????? /// param name=rightImage/param ??????? /// returns/returns ??????? private static bool HashCompare(Bitmap leftImage, Bitmap rightImage) ??????? { ??????????? if (leftImage.Size != rightImage.Size) ??????????? { ??????????????? return false; ??????????? } ??????????? byte[] buffer = new byte[1]; ??????????? byte[] buffer2 = new byte[1]; ??????????? ImageConverter converter = new ImageConverter(); ??????????? buffer = (byte[])converter.ConvertTo(leftImage, buffer.GetType()); ??????????? buffer2 = (byte[])converter.ConvertTo(rightImage, buffer2.GetType()); ??????????? SHA256Managed managed = new SHA256Managed(); ??????????? byte[] buffer3 = managed.ComputeHash(buffer); ??????????? byte[] buffer4 = managed.ComputeHash(buffer2); ??????????? for (int i = 0; (i buffer3.Length) (i buffer4.Length); i++) ??????????? { ??????????????? if (buffer3[i] != buffer4[i]) ??????????????? { ??????????????????? return false; ??????????????? } ??????????? } ??????????? return true; ??????? } 如果hash散列不同,就挨个像素比较,可这样有个问题,就是两幅图片有时候其实我们看起来是一样的,但是实际上你取他们像素的时候他们是不同的,如果我们将用户都不能分辨出不同的地方都标示出来意义不大,于是最后决定只比较像素的R.G.B,只要他们相同就行(这里的相同也做了妥协,就是两个像素的R.G.B值也允许有一定的误差),最后算法如下: ?? /// summary ??????? /// compare two bitmaps. ??????? /// /summary ??????? /// param name=leftImagethe first bitmap/param ??????? /// param name=rightImagethe second bitmap/param ??????? /// param name=resultImageFullPaththe result bitmap/param ??????? /// returnsreturn the comparision result/returns ??????? public static bool Compare(Bitmap leftImage, Bitmap rightImage, string resultImageFullPath) ??????? { ??????????? bool matched = true; ???

文档评论(0)

panguoxiang + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档