我正在使用以下代码将UIImage
转换为cv::Mat
:
-(cv::Mat)openCVMat{
// Turn a UIImage into a cv::Mat
// Draw the image into a bitmap context: the Mat's matrix
CGColorSpaceRef colorSpace = CGImageGetColorSpace(self.CGImage);
CGFloat columns = self.size.width;
CGFloat rows = self.size.height;
cv::Mat m(rows, columns, CV_8UC4, cv::Scalar(0,0,0,0)); // (bits, 4 channels (RGBA)
CGContextRef context = CGBitmapContextCreate(m.data,
columns,
rows,
8,
m.step[0],
colorSpace,
kCGImageAlphaNoneSkipLast|kCGBitmapByteOrderDefault);
// Draw
CGContextDrawImage(context, CGRectMake(0, 0, columns, rows), self.CGImage);
// Cleanup
CGColorSpaceRelease(colorSpace);
CGContextRelease(context);
// Return
return m;
}
它似乎运行正常,但在某些图片上,如果我只是使用cv::Mat
从文件中读取结果imread
,则NSURL *url = [[NSBundle mainBundle] URLForResource:@"blue"
withExtension:@"png"];
cv::Mat fromFile = cv::imread([url.path cStringUsingEncoding:NSUTF8StringEncoding], CV_LOAD_IMAGE_UNCHANGED | CV_LOAD_IMAGE_COLOR);
cv::Mat withAlpha;
cv::cvtColor(fromFile, withAlpha, CV_BGRA2RGBA);
会有所不同:
cv::Mat
在这种情况下,结果UIImage
(withAlpha)略有不同,特别是在图像的角落。
例如,当您将图像作为cv::Mat
读取然后转换为{{1}}时,最终像素为:
[0,0,110,255]这是RGBA
而直接用imread读取后的最后一个像素是: [0,0,255,110]也是RGBA
为了让事情变得更好,所有图片都不会发生这种情况。
为什么会发生这种情况?
这是测试图像:blue.png
答案 0 :(得分:0)
正在读取的格式与创建cv :: Mat的格式之间存在一些不匹配。
我看到在从资源包中加载图像时,您正在使用:
CV_LOAD_IMAGE_UNCHANGED | CV_LOAD_IMAGE_COLOR.
保持CV_LOAD_IMAGE_UNCHANGED并检查。这应该保证从PNG加载alpha通道。 看看是否有帮助。