Joj*_*dmo 3 iphone ios avcapture avcapturesession swift
我试图使用自定义视图拍摄照片(不使用UIImagePickerController),但每当我尝试拍照时,应用程序崩溃,并抛出此错误:
因未捕获的异常'NSInvalidArgumentException'而终止应用程序,原因:' - [AVCaptureStillImageOutput captureStillImageAsynchronouslyFromConnection:completionHandler:] - 传递了非活动/无效连接.
这是我的takePhoto()函数,导致错误:
func takePhoto(sender: UIButton!){
var still: AVCaptureStillImageOutput = AVCaptureStillImageOutput()
var connection: AVCaptureConnection = AVCaptureConnection(inputPorts: self.input.ports, output: still)
if(connection.enabled){
still.captureStillImageAsynchronouslyFromConnection(connection, completionHandler: {(buffer: CMSampleBuffer!, error: NSError!) -> Void in
println("picture taken")//this never gets executed
})
}
}
Run Code Online (Sandbox Code Playgroud)
我也尝试将函数中的connection变量设置takePhoto()为:
self.output.connections[0] as AVCaptureConnection
Run Code Online (Sandbox Code Playgroud)
以及
(self.session.outputs[0] as AVCaptureOutput).connections[0] as AVCaptureConnection
Run Code Online (Sandbox Code Playgroud)
我得到了相同的结果.
在拍摄照片按钮的同一视图上,还有相机的实时预览(可以正常工作):
func setupCamera(){
self.session = AVCaptureSession()
self.session.sessionPreset = AVCaptureSessionPreset640x480
self.session.beginConfiguration()
self.session.commitConfiguration()
var error: NSError?
var devices: [AVCaptureDevice] = AVCaptureDevice.devices() as [AVCaptureDevice]
for device in devices{
if(device.hasMediaType(AVMediaTypeVideo) && device.supportsAVCaptureSessionPreset(AVCaptureSessionPreset640x480)){
//the input variable is initialized here
self.input = AVCaptureDeviceInput.deviceInputWithDevice(device as AVCaptureDevice, error: &error) as AVCaptureDeviceInput
if(self.session.canAddInput(self.input)){
self.session.addInput(self.input)
break
}
}
}
var settings = [kCVPixelBufferPixelFormatTypeKey:kCVPixelFormatType_32BGRA]
//the output variable is initialized here
self.output = AVCaptureVideoDataOutput()
self.output.videoSettings = settings
self.output.alwaysDiscardsLateVideoFrames = true
if(self.session.canAddOutput(self.output)){
self.session.addOutput(self.output)
}
var captureLayer = AVCaptureVideoPreviewLayer(session: self.session)
captureLayer.frame = CGRectMake(0, 64, self.view.frame.width, (self.view.frame.width * 4) / 3)
self.view.layer.addSublayer(captureLayer)
self.session.startRunning()
}
Run Code Online (Sandbox Code Playgroud)
我正在我的iPhone 5s上进行测试,一切正常,包括预览,除了takePhoto()功能.
有没有办法做到这一点,还是我必须使用UIImagePickerController?
设置相机时,请向您的相机添加一个stillImageOutput AVCaptureSession.
self.stillImageOutput = AVCaptureStillImageOutput()
let stillSettings = [AVVideoCodecJPEG:AVVideoCodecKey]
self.stillImageOutput.outputSettings = stillSettings
if(self.session.canAddOutput(self.stillImageOutput)){
self.session.addOutput(self.stillImageOutput)
}
Run Code Online (Sandbox Code Playgroud)
然后在拍照时,AVCaptureSession从stillImageOutput获取.
func takePhoto(sender: UIButton!){
let connection = self.stillImageOutput.connectionWithMediaType(AVMediaTypeVideo)
if(connection.enabled){
self.stillImageOutput.captureStillImageAsynchronouslyFromConnection(connection, completionHandler: {(buffer: CMSampleBuffer!, error: NSError!) -> Void in
println("picture taken") // Now, this is executed
})
}
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2499 次 |
| 最近记录: |