IceCubesApp/Packages/Status/Sources/Status/Media/VideoPlayerView.swift

83 lines
2 KiB
Swift
Raw Normal View History

2022-12-24 07:29:45 +00:00
import AVKit
import DesignSystem
import Env
2023-01-30 06:27:06 +00:00
import SwiftUI
2022-12-24 07:29:45 +00:00
class VideoPlayerViewModel: ObservableObject {
@Published var player: AVPlayer?
private let url: URL
2023-01-17 10:36:01 +00:00
2022-12-24 07:29:45 +00:00
init(url: URL) {
self.url = url
}
2023-01-17 10:36:01 +00:00
func preparePlayer(autoPlay: Bool) {
2022-12-24 07:29:45 +00:00
player = .init(url: url)
2022-12-30 23:07:42 +00:00
player?.isMuted = true
player?.audiovisualBackgroundPlaybackPolicy = .pauses
if autoPlay {
player?.play()
} else {
player?.pause()
}
2022-12-24 07:29:45 +00:00
guard let player else { return }
NotificationCenter.default.addObserver(forName: .AVPlayerItemDidPlayToEndTime,
object: player.currentItem, queue: .main) { [weak self] _ in
if autoPlay {
self?.player?.seek(to: CMTime.zero)
self?.player?.play()
}
2022-12-24 07:29:45 +00:00
}
}
2023-01-22 05:38:30 +00:00
func pause() {
player?.pause()
}
2023-01-22 05:38:30 +00:00
func play() {
player?.play()
}
2023-01-17 10:36:01 +00:00
2022-12-24 07:29:45 +00:00
deinit {
NotificationCenter.default.removeObserver(self, name: .AVPlayerItemDidPlayToEndTime, object: self.player)
}
}
struct VideoPlayerView: View {
@Environment(\.scenePhase) private var scenePhase
@EnvironmentObject private var preferences: UserPreferences
@EnvironmentObject private var theme: Theme
2023-01-30 06:27:06 +00:00
2022-12-24 07:29:45 +00:00
@StateObject var viewModel: VideoPlayerViewModel
2023-01-22 05:38:30 +00:00
2022-12-24 07:29:45 +00:00
var body: some View {
ZStack {
2022-12-24 07:29:45 +00:00
VideoPlayer(player: viewModel.player)
if !preferences.autoPlayVideo {
Image(systemName: "play.fill")
.font(.largeTitle)
.foregroundColor(theme.tintColor)
.padding()
.background(Circle().fill(.thinMaterial))
.padding(theme.statusDisplayStyle == .compact ? 0 : 10)
}
2022-12-24 07:29:45 +00:00
}.onAppear {
viewModel.preparePlayer(autoPlay: preferences.autoPlayVideo)
2022-12-24 07:29:45 +00:00
}
.cornerRadius(4)
.onChange(of: scenePhase, perform: { scenePhase in
switch scenePhase {
case .background, .inactive:
viewModel.pause()
case .active:
if preferences.autoPlayVideo {
viewModel.play()
}
default:
break
}
})
2022-12-24 07:29:45 +00:00
}
}