- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个使用 Adobe PDF 引擎渲染的 PDF 文件以及另一个 PDF rip。我想尝试找出它们呈现不同的地方。问题是它们都使用略微不同的抗锯齿、颜色和非常小的位置差异进行渲染。我更关心更大的差异。我想比较附件 match1.png
和 match2.png
。这两个应该匹配。文件 diff1.png
和 diff2.png
不应匹配。他们应该失败,因为那个人少了一封信。我使用过 ImageMagick 的比较,但没有得到足够好的结果来忽略细微的渲染差异而只关注主要差异。我认为以下算法可行,但我不确定如何读取 PNG 文件并逐像素比较它们。
这只是一个示例算法。我不确定如何逐像素处理 PNG 文件。我愿意接受 PHP 解决方案或使用 imagemagick 等命令行工具的解决方案。
最佳答案
如果您闪烁两个匹配图像(交替显示一个然后另一个来回显示),您将看到两个橙色是不同的。这不仅仅是边缘抗锯齿造成的差异。
因此使用 Imagemagick 6,比较会显示出相当多的变化(如红色)。如果使用 Imagemagick 7,请使用 magick compare。参见 http://www.imagemagick.org/Usage/compare/#compare .
compare -metric rmse match1.png match2.png match_diff.png
2304.18 (0.0351595)
这里的差异是 3.5%,但是由于每个像素都有不同的值,差异图像显示出很多红色。
查看差异的另一种方法是使用 -compose 差异。结果越白,差异越大。
convert match1.png match2.png -compose difference -composite match_diff2.png
这并没有显示出太大的不同,所以所有的值都只是略有不同。但是通过拉伸(stretch)动态范围,您可以看到它最不同的地方。
检查相邻像素的一种方法是重复比较,将一个图像在每个方向上移动 1 个像素(使用 -roll +X+Y),并可能使用 -shave XxY 在每个图像周围修剪掉 1 个像素。您可以循环执行此操作并保存每个结果。然后使用 -evaluate-sequence min 找到相同像素位置处每个图像的最小值(最接近的像素值)。这相当于搜索比较的 3x3 邻域。问题是您不知道哪个图像给出了最大结果。
附言您还可以使用 compare -metric AE -fuzz 5% 。模糊值将允许比较忽略该百分比内的值。这似乎在 Imagemagick 6.9.9.10 中不起作用,但在 Imagemagick 7.0.6.10 中起作用。
im7 magick compare -metric AE -fuzz 5% match1.png match2.png match_diff3.png
219487
这表示有 219487 个任意数量的不匹配像素。这是它们的不同之处。
关于image - 比较图像的渲染差异(忽略抗锯齿),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45946111/
尝试使用 tkinter 为一系列 PIL 图像制作动画。我的帧持续时间 (ms) 的图表如下所示: 有人知道是什么导致了这种尖尖的锯齿图案吗? 这是一个重现的脚本: from PIL import
我正在尝试使用 Canvas 创建“星爆”效果,但线段出现令人难以置信的像素化。我做错了什么吗? var rays = 40; var canvas = $("header canvas")[0];
爪牙 我在 JAGS 中有一个仅拦截逻辑模型,定义如下: model{ for(i in 1:Ny){ y[i] ~ dbern(mu[s[i]]) } for(j in 1:Ns){
我是一名优秀的程序员,十分优秀!