appendPixelBuffer出错:withPresentationTime:

时间:2014-03-05 09:01:57

标签: ios iphone objective-c

我的AVAssetWriter和AVAssetWriterInputPixelBufferAdaptor存在问题。过了一会儿(这个时间可能从10秒到60秒不等),appendPixelBuffer:withPresentationTime:返回NO并出现以下错误:

错误Domain = AVFoundationErrorDomain Code = -11800“操作无法完成”UserInfo = 0x16520f50 {NSLocalizedDescription =操作无法完成,NSUnderlyingError = 0x16527f90“操作无法完成。(OSStatus错误-12780。 )“,NSLocalizedFailureReason =发生未知错误(-12780)}

请不要在stackoverflow上将我重定向到另一个问题。因为那里没有答案给我。不,我不是同时追加两个帧。记录了几次时间。

我正在使用实时数据,而writerInput需要它。

只有在我的AVAssetWriter上设置movieFragmentInterval且仅在我的iPhone 5s上才会出现此错误,并且我已经在具有不同iOS版本(7.1和7.0.5 / 6)的不同iPhone 5上进行了测试。但在早期的手机上运行良好。如果我注释掉那条线就行了。但我需要一个movieFragmentInterval用于我的应用程序中的一个重要目的。这就是我这样设置的,

    _writer = [AVAssetWriter assetWriterWithURL:recordingFileURL fileType:AVFileTypeMPEG4 error:error];
_writer.movieFragmentInterval = CMTimeMake(3, 1);

我的其他代码看起来像这样。

- (BOOL)writeVideoFrameAtTime:(CMTime)time image:(CGImageRef)image error:(NSError **)error {

if (!_started) {
_started = YES;
CRDebug(@"Start writing");
[_writer startWriting];
[_writer startSessionAtSourceTime:time];
[_video startSessionWithPresentationTime:time];
}

if (![_writerInput isReadyForMoreMediaData]) {
 CRDebug(@"Not ready for more data (video)");
return NO;
}

if (!_pixelBuffer) {
 CVReturn status = CVPixelBufferPoolCreatePixelBuffer(kCFAllocatorDefault, _bufferAdapter.pixelBufferPool, &_pixelBuffer);
if (status != kCVReturnSuccess) {
  if (_writer.error) {
    if (error) *error = _writer.error;
    CRWarn(@"Error creating pixel buffer: %@", _writer.error);
  } else {
    CRSetError(error, 0, @"Error creating pixel buffer");
  }
  return NO;
}
}

CVPixelBufferLockBaseAddress(_pixelBuffer, 0);
uint8_t *pixels = CVPixelBufferGetBaseAddress(_pixelBuffer);
CGDataProviderRef dataProvider = CGImageGetDataProvider(image);
CFDataRef imageData = CGDataProviderCopyData(dataProvider);
CFDataGetBytes(imageData, CFRangeMake(0, CFDataGetLength(imageData)), pixels);

if (_bufferAdapter && ![_bufferAdapter appendPixelBuffer:_pixelBuffer withPresentationTime:time]) {
if (_writer.error) {
  if (error) *error = _writer.error;
  CRWarn(@"Error appending pixel buffer: %@", _writer.error);
} else {
  CRSetError(error, 0, @"Error appending pixel buffer");
}
  CVPixelBufferUnlockBaseAddress(_pixelBuffer, 0);
  CFRelease(imageData);
  return NO;
}

CVPixelBufferUnlockBaseAddress(_pixelBuffer, 0);
CFRelease(imageData);
return YES;
}

提前致谢。任何帮助表示赞赏。

编辑: 有关此问题的联系苹果,他们希望我将其作为错误报告提交。我会尽快这样做,并在我了解更多时回到你们所有人那里。

1 个答案:

答案 0 :(得分:2)

我遇到了同样的问题。当我将AVFileTypeMPEG4movieFragmentInterval合并时,它会随机导致您看到的相同错误消息。我已经记录了资产编写的各个方面,我也绝对不会写重复的样本。

我最终通过将AVFileTypeMPEG4更改为AVFileTypeQuickTimeMovie来完成工作。我可以使用MPEG4可靠地重现它(虽然它需要的时间是随机的),但QuickTime似乎始终可以正常工作。我知道如果你真的想要mp4文件,这不一定是你的问题的解决方案,但我想我会分享我的发现。