2013-03-09 15 views
6

Próbuję przekonwertować pixelBuffer wyodrębniony z AVPlayerItemVideoOutput na CIImage, ale zawsze będzie zero.CVPixelBuffer do CIImage zawsze powracający zero

Kodeks

if([videoOutput_ hasNewPixelBufferForItemTime:player_.internalPlayer.currentItem.currentTime]) 
{ 
    CVPixelBufferRef pixelBuffer = [videoOutput_ copyPixelBufferForItemTime:player_.internalPlayer.currentItem.currentTime 
                 itemTimeForDisplay:nil]; 

    CIImage *image = [CIImage imageWithCVPixelBuffer:pixelBuffer]; // Always image === nil 
    CIFilter *filter = [FilterCollection filterSepiaForImage:image]; 
    image = filter.outputImage; 

    CIContext *context = [CIContext contextWithOptions:nil]; 
    CGImageRef cgimg = [context createCGImage:image fromRect:[image extent]]; 
    [pipLayer_ setContents:(id)CFBridgingRelease(cgimg)]; 

} 

Poniżej znajdują się szczegóły dotyczące pixelBuffer stosowanych w celu stworzenia CIImage (co zawsze powoduje nil):

$0 = 0x09b48720 <CVPixelBuffer 0x9b48720 width=624 height=352 bytesPerRow=2496 pixelFormat=BGRA iosurface=0x0 attributes=<CFBasicHash 0x98241d0 [0x1d244d8]>{type = immutable dict, count = 3, 
entries => 
    0 : <CFString 0x174cf4 [0x1d244d8]>{contents = "Height"} = <CFNumber 0x9a16e70 [0x1d244d8]>{value = +352, type = kCFNumberSInt32Type} 
    1 : <CFString 0x174ce4 [0x1d244d8]>{contents = "Width"} = <CFNumber 0x9a109d0 [0x1d244d8]>{value = +624, type = kCFNumberSInt32Type} 
    2 : <CFString 0x1750e4 [0x1d244d8]>{contents = "PixelFormatType"} = <CFArray 0x1090ddd0 [0x1d244d8]>{type = mutable-small, count = 1, values = (
    0 : <CFNumber 0x7a28050 [0x1d244d8]>{value = +1111970369, type = kCFNumberSInt32Type} 
)} 
} 
propagatedAttachments=<CFBasicHash 0x9b485c0 [0x1d244d8]>{type = mutable dict, count = 6, 
entries => 
    0 : <CFString 0x174ff4 [0x1d244d8]>{contents = "CVImageBufferTransferFunction"} = <CFString 0x174f84 [0x1d244d8]>{contents = "ITU_R_709_2"} 
    2 : <CFString 0x174f74 [0x1d244d8]>{contents = "CVImageBufferYCbCrMatrix"} = <CFString 0x174f94 [0x1d244d8]>{contents = "ITU_R_601_4"} 
    9 : <CFString 0x174f14 [0x1d244d8]>{contents = "CVPixelAspectRatio"} = <CFBasicHash 0x9b1bc30 [0x1d244d8]>{type = immutable dict, count = 2, 
entries => 
    0 : <CFString 0x174f34 [0x1d244d8]>{contents = "VerticalSpacing"} = <CFNumber 0x9b0f730 [0x1d244d8]>{value = +1, type = kCFNumberSInt32Type} 
    2 : <CFString 0x174f24 [0x1d244d8]>{contents = "HorizontalSpacing"} = <CFNumber 0x9b0f730 [0x1d244d8]>{value = +1, type = kCFNumberSInt32Type} 
} 

    10 : <CFString 0x174fb4 [0x1d244d8]>{contents = "CVImageBufferColorPrimaries"} = <CFString 0x174fd4 [0x1d244d8]>{contents = "SMPTE_C"} 
    11 : <CFString 0x174e24 [0x1d244d8]>{contents = "QTMovieTime"} = <CFBasicHash 0x7a47940 [0x1d244d8]>{type = immutable dict, count = 2, 
entries => 
    0 : <CFString 0x174e44 [0x1d244d8]>{contents = "TimeScale"} = <CFNumber 0x7a443d0 [0x1d244d8]>{value = +90000, type = kCFNumberSInt32Type} 
    2 : <CFString 0x174e34 [0x1d244d8]>{contents = "TimeValue"} = <CFNumber 0x7a476e0 [0x1d244d8]>{value = +1047297, type = kCFNumberSInt64Type} 
} 

    12 : <CFString 0x174eb4 [0x1d244d8]>{contents = "CVFieldCount"} = <CFNumber 0x9b0f730 [0x1d244d8]>{value = +1, type = kCFNumberSInt32Type} 
} 
nonPropagatedAttachments=<CFBasicHash 0x9b44b40 [0x1d244d8]>{type = mutable dict, count = 0, 
entries => 
} 
> 

Odpowiedz

10

rozwiązał ten problem - Byłem próby na symulatorze, a wydaje się, to jest obsługiwane tylko na urządzeniach.

+0

OMG ... czy to gdzieś udokumentowano? –

+0

Ten "rozwiązał" również mój problem. W Swift moje let inputImage = CIImage (CVPixelBuffer: pixelBuffer) zawsze zwraca zero na symulatorze i obiekcie na urządzeniu. :( –

+0

Dostaję zero nawet na urządzeniu.Czy ktokolwiek może podać powód? –

2

Wydaje się, że nie masz zdefiniowano klucz właściwości iosurface. Nie 100% to rozwiąże problem, ale spróbuj to:

CFDictionaryRef attrs = (CFDictionaryRef)@{ 
    (id)kCVPixelBufferWidthKey: @(WIDTH_OF_YOUR_VIDEO_GOES_HERE), 
    (id)kCVPixelBufferHeightKey: @(HEIGHT_OF_YOUR_VIDEO_GOES_HERE), 
    (id)kCVPixelBufferPixelFormatTypeKey: @(kCVPixelFormatType_420YpCbCr8BiPlanarFullRange;), // kCVPixelFormatType_32BGRA 
    (id)kCVPixelBufferIOSurfacePropertiesKey: @{}, 
} 

I przekazać tę słownika wraz z innymi klawiszami podczas tworzenia swojej pixelbuffer

+0

W macosie 10.10 trzeba ustawić kCVPixelBufferPixelFormatTypeKey = kCVPixelFormatType_32ARGB, a następnie "+ [CIImage imageWithCVPixelBuffer:]" może być sukcesem – fengxing

0

To nie jest sposób w jaki ustawiasz zawartość warstwy; jest to:

(identyfikator __bridge) uiImage.CGImage;

Nie ma sposobu, aby uzyskać pracę nad urządzeniem lub symulatorem.

Powiązane problemy