captureStillImageAsynchronouslyFromConnection返回nil错误

时间:2016-03-04 04:30:15

标签: ios swift avcapturesession

我的自定义相机不能一直工作。有时它需要拍照,有时则会无声地崩溃。我的应用程序由3个选项卡和一个标签栏控制器组成。当我从主页选项卡访问相机时,我可以拍照。当我从配置文件选项卡访问相机时,它不会拍照并且它会在didPressTakePhoto功能中随机崩溃。我不是在标签之间传递数据所以它不应该发生。

override func viewWillAppear(animated: Bool) {
    super.viewWillAppear(animated)

    //Set current bottom border to photo
    borderPhoto.backgroundColor = newColor.CGColor
    borderPhoto.frame = CGRect(x: 0, y: 0 + libraryView.frame.size.height, width: libraryView.frame.size.width, height: 4)
    photoView.layer.addSublayer(borderPhoto)

    //self.tabBarController!.tabBar.hidden = true

    chosenMode = "Photo"
    libraryView.removeFromSuperview()
    photoButton.setBackgroundImage(buttonImage, forState: .Normal)

    if self.isRunning == false{
        captureSession = AVCaptureSession()
        captureSession!.sessionPreset = AVCaptureSessionPresetPhoto

        let backCamera = AVCaptureDevice.defaultDeviceWithMediaType(AVMediaTypeVideo)

        var error: NSError?

        do {
            input = try AVCaptureDeviceInput(device: backCamera)
        } catch let error1 as NSError {
            error = error1
            input = nil
        }

        if error == nil && captureSession!.canAddInput(input) {
            captureSession!.addInput(input)

            stillImageOutput = AVCaptureStillImageOutput()
            stillImageOutput!.outputSettings = [AVVideoCodecKey: AVVideoCodecJPEG]
            if captureSession!.canAddOutput(stillImageOutput) {
                captureSession!.addOutput(stillImageOutput)

                previewLayer = AVCaptureVideoPreviewLayer(session: captureSession)
                previewLayer!.videoGravity = AVLayerVideoGravityResizeAspectFill
                previewLayer!.connection?.videoOrientation = AVCaptureVideoOrientation.Portrait
                previewView.layer.addSublayer(previewLayer!)

                captureSession!.startRunning()
                self.isRunning = true



            }
        }

    }
    print("Done ViewWillApear")

}

@IBAction func didPressTakePhoto(sender: UIButton) {
    print("Beginning Method")

    self.previewLayer?.connection.enabled = false
    if let videoConnection = stillImageOutput!.connectionWithMediaType(AVMediaTypeVideo) {
        videoConnection.videoOrientation = AVCaptureVideoOrientation.Portrait
        stillImageOutput?.captureStillImageAsynchronouslyFromConnection(videoConnection, completionHandler: {(sampleBuffer, error) in
            //print(error)
            if (sampleBuffer != nil) {
                let imageData = AVCaptureStillImageOutput.jpegStillImageNSDataRepresentation(sampleBuffer)
                let dataProvider = CGDataProviderCreateWithCFData(imageData)
                let cgImageRef = CGImageCreateWithJPEGDataProvider(dataProvider, nil, true, CGColorRenderingIntent.RenderingIntentDefault)
                var image = UIImage()

                if UIDevice.currentDevice().orientation == .Portrait{
                    image = UIImage(CGImage: cgImageRef!, scale: 1.0, orientation: UIImageOrientation.Right)
                }else if UIDevice.currentDevice().orientation == .LandscapeLeft{
                    image = UIImage(CGImage: cgImageRef!, scale: 1.0, orientation: UIImageOrientation.Up)
                }else if UIDevice.currentDevice().orientation == .LandscapeRight{
                    image = UIImage(CGImage: cgImageRef!, scale: 1.0, orientation: UIImageOrientation.Down)
                }

                //Crop the image to a square
                let imageSize: CGSize = image.size
                let width: CGFloat = imageSize.width
                let height: CGFloat = imageSize.height
                if width != height {
                    let newDimension: CGFloat = min(width, height)
                    let widthOffset: CGFloat = (width - newDimension) / 2
                    let heightOffset: CGFloat = (height - newDimension) / 2
                    UIGraphicsBeginImageContextWithOptions(CGSizeMake(newDimension, newDimension), false, 0.0)
                    image.drawAtPoint(CGPointMake(-widthOffset, -heightOffset), blendMode: .Copy, alpha: 1.0)
                    image = UIGraphicsGetImageFromCurrentImageContext()
                    let imageData: NSData = UIImageJPEGRepresentation(image, 0.25)!
                    UIGraphicsEndImageContext()
                    self.captImage = UIImage(data: imageData)!
                }

            }
            self.performSegueWithIdentifier("fromCustomCamera", sender: self)
        })

    }


}

1 个答案:

答案 0 :(得分:1)

修正了它。我不得不压缩我的图像,因为它们对于记忆来说太大了。感谢那些帮助过的人。