Существует ли что-то вроде cvShowImage для iOS?

Я обрабатываю изображения (используя AVFoundation и OpenCV на iOS) и хочу просто отобразить содержимое CMSampleBufferRef (или IplImage) на экране.

Просто: я просто хочу отобразить (как с OpenCV cvShowImage()) неконвертированное изображение, чтобы увидеть, имею ли я дело с поврежденным или каким-либо образом деформированным изображением.

1 ответ

К сожалению нет. Отличное растровое представление.

Возможно, вы хотите категорию? Я использую что-то вроде этого:

 // NSImage+OpenCV.h
 @interface NSImage (OpenCV)
 + (NSImage*)imageWithCVMat:(const cv::Mat&)cvMat;
 - (id)initWithCVMat:(const cv::Mat&)cvMat;
 - (cv::Ptr<cv::Mat>)cvMat;
 @end

 // NSImage+OpenCV.m
 using namespace cv;
 @implementation NSImage (OpenCV)

 - (id)initWithCVMat:(const cv::Mat&)cvMat {
      NSData *data = [NSData dataWithBytes:cvMat.data
                                 length:cvMat.total()*cvMat.elemSize()];    
      CGDataProviderRef provider = CGDataProviderCreateWithCFData((__bridge CFDataRef)data);
      CGColorSpaceRef colourSpace =  CGColorSpaceCreateDeviceRGB();

      CGImageRef imageRef = CGImageCreate(cvMat.cols,
                                         cvMat.rows,
                                         8,
                                         8 * cvMat.elemSize(),
                                         cvMat.step[0],
                                         colourSpace,                                           
                                         kCGImageAlphaNone |
                                         kCGBitmapByteOrderDefault,
                                         provider,
                                         NULL,
                                         false,
                                         kCGRenderingIntentDefault);       

      NSImage *image = [[NSImage alloc] initWithCGImage:imageRef size:CGSizeMake(cvMat.cols,cvMat.rows)];

      CGColorSpaceRelease(colourSpace);
      CGDataProviderRelease(provider);
      CGImageRelease(imageRef);

      return image;
 }

 +(NSImage*)imageWithCVMat:(const cv::Mat&)cvMat {
    return [[NSImage alloc] initWithCVMat:cvMat];
 }

 - (cv::Ptr<cv::Mat>)cvMat {
      CGImageSourceRef source =  CGImageSourceCreateWithData((__bridge CFDataRef)[self TIFFRepresentation],  NULL);     
      CGImageRef imageRef =  CGImageSourceCreateImageAtIndex(source, 0, NULL);
      cv::Ptr<cv::Mat> cvMat = new cv::Mat(self.size.height, self.size.width, CV_8UC4);          

      CGContextRef contextRef = CGBitmapContextCreate(cvMat->data,
                                                   cvMat->cols,
                                                   cvMat->rows,
                                                   8,
                                                   cvMat->step[0],                                                    
                                                   CGImageGetColorSpace(imageRef),
                                                   kCGImageAlphaNoneSkipLast |
                                                   kCGBitmapByteOrderDefault);   

      CGContextDrawImage(contextRef,
                        CGRectMake(0, 0, cvMat->cols, cvMat->rows),
                        imageRef);

      CGContextRelease(contextRef);
      CGImageRelease(imageRef);

      return cvMat;   
 }

 @end
Другие вопросы по тегам