Я схожу с ума, пытаясь заставить AVCaptureSession (в контроллере представления) быть представленным и отклоненным в моем проекте.Я в настоящее время на iOS5.1 и с включенным ARC.
Я могу заставить его работать нормально при первом представлении viewcontroller и начать сеанс, но когда я отклоняю и представляю второй раз, сеанс не будетНачните.Я подписался на уведомление «AVCaptureSessionRuntimeErrorNotification» и получаю следующую ошибку:
«Ошибка домена = код AVFoundationErrorDomain = -11819« Невозможно завершить действие »UserInfo = 0x1a4020 {NSLocalizedRecoverySuggestion = Попытаться позже, NSLocalizedDescription} "
Я предполагаю, что что-то не высвобождается должным образом в моем сеансе, но с ARC нет выпусков, и я вместо этого устанавливаю все для освобождения равным nil.
мои методы viewDidLoadв основном просто вызывает initCamera
метод initCamera:
AVCaptureSession *tmpSession = [[AVCaptureSession alloc] init];
session = tmpSession;
session.sessionPreset = AVCaptureSessionPresetMedium;
captureVideoPreviewLayer = [[AVCaptureVideoPreviewLayer alloc] initWithSession:session];
captureVideoPreviewLayer.frame = self.vImagePreview.bounds;
[self.vImagePreview.layer addSublayer:captureVideoPreviewLayer];
rearCamera = [AVCaptureDevice defaultDeviceWithMediaType:AVMediaTypeVideo];
NSError *error = nil;
input = [AVCaptureDeviceInput deviceInputWithDevice:rearCamera error:&error];
if (!input) {
// Handle the error appropriately.
NSLog(@"ERROR: trying to open camera: %@", error);
}
[session addInput:input];
videoDataOutput = [[AVCaptureVideoDataOutput alloc] init];
NSDictionary *outputSettings = [[NSDictionary alloc] initWithObjectsAndKeys: [NSNumber numberWithInt:kCVPixelFormatType_32BGRA], kCVPixelBufferPixelFormatTypeKey, nil];
[videoDataOutput setVideoSettings:outputSettings];
[videoDataOutput setAlwaysDiscardsLateVideoFrames:YES];
queue = dispatch_queue_create("cameraQueue", DISPATCH_QUEUE_SERIAL);
[videoDataOutput setSampleBufferDelegate:self queue:queue];
dispatch_release(queue);
[session addOutput:videoDataOutput];
NSNotificationCenter *notify =
[NSNotificationCenter defaultCenter];
[notify addObserver: self
selector: @selector(onVideoError:)
name: AVCaptureSessionRuntimeErrorNotification
object: session];
[session startRunning];
[rearCamera lockForConfiguration:nil];
rearCamera.whiteBalanceMode = AVCaptureWhiteBalanceModeContinuousAutoWhiteBalance;
rearCamera.exposureMode = AVCaptureExposureModeContinuousAutoExposure;
rearCamera.focusMode = AVCaptureFocusModeContinuousAutoFocus;
[rearCamera unlockForConfiguration];
Метод
captureOutput: (AVCaptureOutput *) captureOutput didOutputSampleBuffer: (CMSampleBufferRef) sampleBuffer AVConnection ()
вызывается без проблем при первом представлении модального viewcontroller, но со второй попытки этот метод перестает вызываться (поскольку сеанс не запускается)
Для очистки я звонюулицаopSession из моего родительского viewcontroller перед удалением, и это делает следующее:
if ([session isRunning]) {
[session removeInput:input];
[session stopRunning];
[vImagePreview removeFromSuperview];
vImagePreview = nil;
input = nil;
videoDataOutput = nil;
captureVideoPreviewLayer = nil;
session = nil;
queue = nil;
}
Мне кажется, что я пробовал все виды вещей, например, выполнял dispatch_sync (очередь, ^ {}) в очереди, чтобы ждатьчтобы его очистили, но это, похоже, не имеет значения (при вызове dispatch_sync я удалил вызов dispatch_release в моем методе камеры init).Я также пытался использовать метод dispatch_set_finalizer_f (queue, capture_cleanup), предложенный в другом вопросе, но я не знаю, что на самом деле нужно использовать в методе capture_cleanup, потому что все примеры, которые я нахожу, являются не-ARC-кодом, где они вызывают release дляуказатель на себя.Я также просмотрел весь пример кода, который можно найти в Apple (SquareCam и AVCam), но они также не являются ARC.Любая помощь будет принята с благодарностью.