AVFoundation、SwiftUI:会话启动,但文件未写入以记录视频。
创始人
2024-11-13 01:00:45
0

我们可以使用以下代码示例解决此问题:

在SwiftUI中添加一个自定义视图,用于捕获视频并将其保存到设备的本地文件中。

import SwiftUI
import AVFoundation

struct CameraView: View {
    
    @StateObject var viewModel: CameraViewModel
    
    var body: some View {
        ZStack {
            CameraPreviewView(session: viewModel.session)
            VStack {
                Spacer()
                HStack {
                    RecordButtonView(viewModel: viewModel)
                        .padding()
                    Spacer()
                }
            }
        }
    }
}

class CameraViewModel: NSObject, ObservableObject, AVCaptureFileOutputRecordingDelegate {

    let session: AVCaptureSession
    var videoFileOutput: AVCaptureMovieFileOutput?
    var recording = false
    var videoURL: URL?
    
    init(session: AVCaptureSession) {
        self.session = session
        super.init()
        self.videoFileOutput = AVCaptureMovieFileOutput()
        if self.session.canAddOutput(self.videoFileOutput!) {
            self.session.addOutput(self.videoFileOutput!)
        }
    }
    
    func startRecording() {
        let fileURL = URL(fileURLWithPath: NSTemporaryDirectory() + "output.mov")
        self.videoFileOutput?.startRecording(to: fileURL, recordingDelegate: self)
        self.recording = true
        self.videoURL = fileURL
    }
    
    func stopRecording() {
        self.videoFileOutput?.stopRecording()
        self.recording = false
    }
    
    func fileOutput(_ output: AVCaptureFileOutput,
                    didFinishRecordingTo outputFileURL: URL,
                    from connections: [AVCaptureConnection],
                    error: Error?) {
        if let error = error {
            print(error.localizedDescription)
        } else {
            UISaveVideoAtPathToSavedPhotosAlbum(outputFileURL.path, nil, nil, nil)
        }
    }
}

struct CameraPreviewView: UIViewRepresentable {
    
    let session: AVCaptureSession
    
    func makeUIView(context: Context) -> UIView {
        let view = UIView(frame: .zero)
        
        if let previewLayer = AVCaptureVideoPreviewLayer(session: session) {
            previewLayer.videoGravity = .resizeAspectFill
            previewLayer.connection?.videoOrientation = .portrait
            view

相关内容

热门资讯

安卓换鸿蒙系统会卡吗,体验流畅... 最近手机圈可是热闹非凡呢!不少安卓用户都在议论纷纷,说鸿蒙系统要来啦!那么,安卓手机换上鸿蒙系统后,...
app安卓系统登录不了,解锁登... 最近是不是你也遇到了这样的烦恼:手机里那个心爱的APP,突然就登录不上了?别急,让我来帮你一步步排查...
安卓系统拦截短信在哪,安卓系统... 你是不是也遇到了这种情况:手机里突然冒出了很多垃圾短信,烦不胜烦?别急,今天就来教你怎么在安卓系统里...
安卓系统如何卸载app,轻松掌... 手机里的App越来越多,是不是感觉内存不够用了?别急,今天就来教你怎么轻松卸载安卓系统里的App,让...
windows官网系统多少钱 Windows官网系统价格一览:了解正版Windows的购买成本Windows 11官方价格解析微软...
安卓系统要维护多久,安卓系统维... 你有没有想过,你的安卓手机里那个陪伴你度过了无数日夜的安卓系统,它究竟要陪伴你多久呢?这个问题,估计...
怎么复制照片安卓系统,操作步骤... 亲爱的手机控们,是不是有时候想把自己的手机照片分享给朋友,或者备份到电脑上呢?别急,今天就来教你怎么...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
iphone系统与安卓系统更新... 最近是不是你也遇到了这样的烦恼?手机更新系统总是失败,急得你团团转。别急,今天就来给你揭秘为什么iP...
安卓系统应用怎么重装,安卓应用... 手机里的安卓应用突然罢工了,是不是让你头疼不已?别急,今天就来手把手教你如何重装安卓系统应用,让你的...