How to make part of picture same during comparison
Posted: 2018-08-11T22:43:08-07:00
I was trying to compare photo "newScreenshot" with "snapshotImage", with code like this:
data:image/s3,"s3://crabby-images/ecb63/ecb6365eb916c3c907daf6d9706cb5adf4c15a5d" alt="Image"
data:image/s3,"s3://crabby-images/7f4f2/7f4f2d3e8b349e23053c88df7eebc62274b658ce" alt="Image"
data:image/s3,"s3://crabby-images/e32d4/e32d4e49b5158b3e641245b221d130c0274be339" alt="Image"
My problem:
As we can see, at the bottom of diffImage:
Those text wordings get a lot of noise and recognized as different.
But from newScreenshot image and snapshotImage image, we can see that those wordings styles are just the same from a person's viewpoint:
data:image/s3,"s3://crabby-images/3e55f/3e55fecc72f0498f00ed331e90d37dd49a9f1d2f" alt="Image"
Wondering is there a way to pre-process 2 images or change a way of comparison, that can get a result of SAME?
Thank you very much !!!
Code: Select all
using (var newScreenshot = new MagickImage(newScreenshotPath))
{
var snapshotImage = TryGetBaselineImage(snapshotFilePath);
if (snapshotImage == null) return false;
using (snapshotImage)
{
var result = newScreenshot.Equals(snapshotImage);
if (result) return true;
using (var diffImage = new MagickImage())
{
newScreenshot.Compare(snapshotImage, ErrorMetric.Absolute, diffImage);
//I also tried fuzz(10) but with no luck
diffImage.Write(diffImagePath);
}
return false;
}
}
- newScreenshot file:
data:image/s3,"s3://crabby-images/ecb63/ecb6365eb916c3c907daf6d9706cb5adf4c15a5d" alt="Image"
- snapshotImage file:
data:image/s3,"s3://crabby-images/7f4f2/7f4f2d3e8b349e23053c88df7eebc62274b658ce" alt="Image"
- diffImage file:
data:image/s3,"s3://crabby-images/e32d4/e32d4e49b5158b3e641245b221d130c0274be339" alt="Image"
My problem:
As we can see, at the bottom of diffImage:
Those text wordings get a lot of noise and recognized as different.
But from newScreenshot image and snapshotImage image, we can see that those wordings styles are just the same from a person's viewpoint:
data:image/s3,"s3://crabby-images/3e55f/3e55fecc72f0498f00ed331e90d37dd49a9f1d2f" alt="Image"
Wondering is there a way to pre-process 2 images or change a way of comparison, that can get a result of SAME?
Thank you very much !!!