我将 ZXing 用于应用程序,这主要与 ZXing 原始代码相同,除了我允许连续扫描几次(即,一旦检测到某些内容,ZXingWidgetController 就不必立即解除)。
当我按下调用的关闭按钮时,我经历了长时间的卡住(有时它永远不会结束)
- (void)cancelled {
// if (!self.isStatusBarHidden) {
// [[UIApplication sharedApplication] setStatusBarHidden:NO];
// }
[self stopCapture];
wasCancelled = YES;
if (delegate != nil) {
[delegate zxingControllerDidCancel:self];
}
}
和
- (void)stopCapture {
decoding = NO;
#if HAS_AVFF
if([captureSession isRunning])[captureSession stopRunning];
AVCaptureInput* input = [captureSession.inputs objectAtIndex:0];
[captureSession removeInput:input];
AVCaptureVideoDataOutput* output = (AVCaptureVideoDataOutput*)[captureSession.outputs objectAtIndex:0];
[captureSession removeOutput:output];
[self.prevLayer removeFromSuperlayer];
/*
// heebee jeebees here ... is iOS still writing into the layer?
if (self.prevLayer) {
layer.session = nil;
AVCaptureVideoPreviewLayer* layer = prevLayer;
[self.prevLayer retain];
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, 12000000000), dispatch_get_main_queue(), ^{
[layer release];
});
}
*/
self.prevLayer = nil;
self.captureSession = nil;
#endif
}
(请注意移除 View 的dismissModalViewController 是在delegate 方法中)
我只有在连续扫描几次时才解散时遇到卡住,并且仅使用 iPhone 4(使用 4S 不会卡住)
任何想法 ?
干杯
只读存储器
最佳答案
根据 AV Cam View Controller Example 调用 startRunning 或 stopRunning 直到 session 完成请求的操作才返回。由于您将这些消息发送到主线程上的 session ,因此它会卡住所有 UI,直到请求的操作完成。我建议您将调用包装在异步调度中,以便 View 不会锁定。
- (void)cancelled
{
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
[self stopCapture];
});
//You might want to think about putting the following in another method
//and calling it when the stop capture method finishes
wasCancelled = YES;
if (delegate != nil) {
[delegate zxingControllerDidCancel:self];
}
}
关于iphone - AVCaptureSession - 停止运行 - 需要很长时间,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/11905505/