Контроллер представления не соответствует протоколу AVCaptureFileOutputRecordingDelegate
Я пытаюсь сделать камеру, которая может записывать видео, и мне нужно AVCaptureFileOutputRecordingDelegate, чтобы заставить его работать, но по какой-то причине он говорит...
Тип 'ViewController' не соответствует протоколу 'AVCaptureFileOutputRecordingDelegate'.
Я имею это выше моего названия класса, но все еще не решаю проблему...
class VideoDelegate : NSObject, AVCaptureFileOutputRecordingDelegate {
func captureOutput(captureOutput: AVCaptureFileOutput!, didFinishRecordingToOutputFileAtURL outputFileURL: NSURL!, fromConnections connections: [AnyObject]!, error: NSError!) {
println("capture output : finish recording to \(outputFileURL)")
}
func captureOutput(captureOutput: AVCaptureFileOutput!, didStartRecordingToOutputFileAtURL fileURL: NSURL!, fromConnections connections: [AnyObject]!) {
println("capture output: started recording to \(fileURL)")
}
}
Вот весь мой код:
import UIKit
import MediaPlayer
import MobileCoreServices
import AVFoundation
class VideoDelegate : NSObject, AVCaptureFileOutputRecordingDelegate {
func captureOutput(captureOutput: AVCaptureFileOutput!, didFinishRecordingToOutputFileAtURL outputFileURL: NSURL!, fromConnections connections: [AnyObject]!, error: NSError!) {
println("capture output : finish recording to \(outputFileURL)")
}
func captureOutput(captureOutput: AVCaptureFileOutput!, didStartRecordingToOutputFileAtURL fileURL: NSURL!, fromConnections connections: [AnyObject]!) {
println("capture output: started recording to \(fileURL)")
}
}
class ViewController: UIViewController, AVCaptureVideoDataOutputSampleBufferDelegate, AVCaptureFileOutputRecordingDelegate {
var previewLayer : AVCaptureVideoPreviewLayer?
var captureDevice : AVCaptureDevice?
var videoCaptureOutput = AVCaptureVideoDataOutput()
let captureSession = AVCaptureSession() // var videoCaptureOutputF = AVCaptureFileOutput()
override func viewDidLoad() {
super.viewDidLoad()
captureSession.sessionPreset = AVCaptureSessionPreset640x480
let devices = AVCaptureDevice.devices()
for device in devices {
if (device.hasMediaType(AVMediaTypeVideo)) {
if device.position == AVCaptureDevicePosition.Back {
captureDevice = device as? AVCaptureDevice
if captureDevice != nil {
beginSession()
}
}
}
}
}
func beginSession() {
var err : NSError? = nil
captureSession.addInput(AVCaptureDeviceInput(device: captureDevice, error: &err))
if err != nil {
println("Error: \(err?.localizedDescription)")
}
videoCaptureOutput.videoSettings = [kCVPixelBufferPixelFormatTypeKey:kCVPixelFormatType_32BGRA]
//videoCaptureOutput.sampleBufferDelegate=self
videoCaptureOutput.alwaysDiscardsLateVideoFrames = true
captureSession.addOutput(videoCaptureOutput)
previewLayer = AVCaptureVideoPreviewLayer(session: captureSession)
self.view.layer.addSublayer(previewLayer)
previewLayer?.frame = CGRectMake(0, 20, self.view.bounds.width, self.view.bounds.height)
var startVideoBtn = UIButton(frame: CGRectMake(10,40, 40, 40))
startVideoBtn.backgroundColor=UIColor.greenColor()
startVideoBtn.addTarget(self, action: "startVideoRecording", forControlEvents:
UIControlEvents.TouchUpInside)
self.view.addSubview(startVideoBtn)
var stopVideoBtn = UIButton(frame: CGRectMake(200, 40, 40, 40))
stopVideoBtn.backgroundColor=UIColor.redColor()
stopVideoBtn.addTarget(self, action: "stopVideoRecording", forControlEvents: UIControlEvents.TouchUpInside)
self.view.addSubview(stopVideoBtn)
}
func startVideoRecording(){
captureSession.startRunning()
}
func stopVideoRecording(){
captureSession.stopRunning()
print(videoCaptureOutput)
// here i am getting problems that how to save recorded video
let videoDelegate = VideoDelegate()
let fileOutput = AVCaptureMovieFileOutput()
// captureSession.addOutput(videoCaptureOutput)
let documentsPath = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)[0] as! NSString
let outputPath = "\(documentsPath)/output.mp4"
let outputFileUrl = NSURL(fileURLWithPath: outputPath)
fileOutput.startRecordingToOutputFileURL(outputFileUrl, recordingDelegate: videoDelegate)
}
}
Я не уверен, почему я получаю это или как это исправить. Пожалуйста помоги. Спасибо!
3 ответа
ViewController
не соответствует протоколу, поэтому вы получаете предупреждение. Это выглядит как VideoDelegate
не ViewController
,
Чтобы решить, либо переместите этот материал в ViewController
или установите ваш делегат захвата на экземпляр VideoDelegate
вместо ViewController
,
Это потому, что вы не включили обязательную функцию, которую нужно включить при вызове этого протокола. Добавьте эти функции внизу вашего кода (Swift 3):
func capture(_ captureOutput: AVCaptureFileOutput!, didStartRecordingToOutputFileAt fileURL: URL!, fromConnections connections: [Any]!) {
//Show User recording has started
}
func capture(_ captureOutput: AVCaptureFileOutput!, didFinishRecordingToOutputFileAt outputFileURL: URL!, fromConnections connections: [Any]!, error: Error!) {
print("Finished \(error)")
//Save Video to Camera Roll
if error == nil{
UISaveVideoAtPathToSavedPhotosAlbum(outputFileURL.path, nil, nil, nil)
}
}
У меня точно такая же проблема, и если я найду способ, я поставлю ответ.. Я посмотрел в вашем коде, и вам нужно удалить "AVCaptureVideoDataOutputSampleBufferDelegate" и "AVCaptureFileOutputRecordingDelegate" из вас ViewController, это потому, что вы не реализует методы каждого делегата.
С вашим классом videoDelegate все в порядке. Там вы правильно реализуете методы AVCaptureFileOutputRecordingDelegate.
так
class ViewController: UIViewController
вместо
class ViewController: UIViewController, AVCaptureVideoDataOutputSampleBufferDelegate, AVCaptureFileOutputRecordingDelegate