我正在使用Epson Perfection V700扫描仪,并在使用其工具进行扫描时选择以下选项:
产生这张图片:
现在我的问题是 - 我实际上需要使用TWAIN .Net与此扫描仪进行交互,当我这样做时,我得到的图像就是:
除此之外:我取消选择前面提到的两个选项并再次使用Epson进行扫描,并获得了与TWAIN所获得的非常相似的图像。
所以我认为也许这些是我可以在图像上自己完成的后处理步骤(也许它们是以某种方式在硬件中完成的,我不知道)。
我正在使用EmguCV所以我首先创建了一个应用ICM的扩展方法(我很难找到任何文档,所以这是一个猜测,也许我马上就错了但是我从这里得到了信息:The bitmap transform class它似乎对图像产生了影响):
public static Image<Bgr, TDepth> ApplyIcm<TDepth>(
this Image<Bgr, TDepth> source,
string sourceIcm,
string targetIcm)
where TDepth : new()
{
var target = source.CopyBlank();
using (source)
{
using (var b = source.Bitmap)
{
using (var memory = new MemoryStream())
{
b.Save(memory, ImageFormat.Bmp);
memory.Position = 0;
var bitmapImage = new BitmapImage();
bitmapImage.BeginInit();
bitmapImage.StreamSource = memory;
bitmapImage.CacheOption = BitmapCacheOption.OnLoad;
bitmapImage.EndInit();
var ccb = new ColorConvertedBitmap();
ccb.BeginInit();
ccb.Source = bitmapImage;
ccb.SourceColorContext =
new ColorContext(new Uri(sourceIcm));
ccb.DestinationColorContext =
new ColorContext(new Uri(targetIcm));
ccb.EndInit();
var encoder = new BmpBitmapEncoder();
encoder.Frames.Add(BitmapFrame.Create(ccb));
using (var ms = new MemoryStream())
{
encoder.Save(ms);
target.Bitmap = new Bitmap(ms);
}
}
}
}
return target;
}
然后我看了那个不好看的东西,发现了这个问题:How to sharpen an image in OpenCV?说:
使用高斯平滑滤镜并从原始图像中减去平滑后的版本
(我还检查了这个问题以找出等效的emgucv调用是Why might EmguCV Gaussian blur not return identical results as OpenCV Gaussian blur?)并提出了这个额外的扩展方法:
public static Image<Bgr, TDepth> UnsharpMask<TDepth>(
this Image<Bgr, TDepth> source,
Size kernelSize,
int kernelHoritonalStandardDeviation,
int kernelVerticalStandardDeviation,
double alpha,
double beta,
double gamma)
where TDepth : new()
{
Image<Bgr, TDepth> ret = source.CopyBlank();
CvInvoke.cvSmooth(source,
ret,
SMOOTH_TYPE.CV_GAUSSIAN,
kernelSize.Width,
kernelSize.Height,
kernelHoritonalStandardDeviation,
kernelVerticalStandardDeviation);
CvInvoke.cvAddWeighted(source, alpha, ret, beta, gamma, ret);
return ret;
}
现在我这样称呼它:
string sourceIcm = @"C:\Windows\System32\spool\drivers\color\ewrgb18.icm";
string targetIcm = @"C:\Windows\System32\spool\drivers\color\ewsrgb.icm";
using(var im = new Image<Bgr, byte>("out.bmp"))
{
using (var icmmed = im.ApplyIcm(sourceIcm, targetIcm))
{
using (var ret = icmmed.UnsharpMask(new Size(0, 0), 5, 5, 2.4, -1.5, 0))
{
ret.Save("ret.bmp");
}
}
}
这就是结果:
不太好! : - (
我无休止地摆弄这些参数,但我无法弄清楚我是如何(或者甚至)能够获得与爱普生工具相同的结果。
所以,我的问题是:
有没有人知道是否有可能使用opencv / emgucv(甚至是TWAIN)来实现结果 - 我查看了文档,并尝试调整一些功能参数,但我只是让图像变得更糟)这与上面的原始图像的清晰度相似,还是我应该尝试另一种技术(可能是我需要了解硬件本身的一些细节才能实现正确的锐化)?
答案 0 :(得分:2)
我认为您应该知道如何在项目中使用WIA(Windows Image Acquisition),您可能不需要使用opencv访问硬件。 WIA用于与网络摄像头和扫描仪集成。或者,您可以使用TWAIN,如上所述 看看他们可以为您的项目提供帮助的这些示例:
和
关于锐化,您可以在软件级别使用opencv功能,作为解决问题的另一种选择