From d5f8ad4eec3f70e32b8e62ecb4a69dbb5f5d3fc8 Mon Sep 17 00:00:00 2001 From: Arkadiusz Fal Date: Mon, 29 Aug 2022 00:29:29 +0200 Subject: [PATCH] Fix updating now playing info with mpv on tvOS Other minor tvOS fixes --- Model/Player/PlayerModel.swift | 74 ++++++++++++--------------- Shared/Player/PlayerBackendView.swift | 18 +++++++ 2 files changed, 51 insertions(+), 41 deletions(-) diff --git a/Model/Player/PlayerModel.swift b/Model/Player/PlayerModel.swift index ae5c17a3..9c7ba576 100644 --- a/Model/Player/PlayerModel.swift +++ b/Model/Player/PlayerModel.swift @@ -505,16 +505,7 @@ final class PlayerModel: ObservableObject { self.backend.setNeedsDrawing(self.presentingPlayer) } - #if os(tvOS) - if presentingPlayer { - controls.show() - Delay.by(1) { [weak self] in - self?.controls.hide() - } - } - #else - controls.hide() - #endif + controls.hide() #if !os(macOS) UIApplication.shared.isIdleTimerDisabled = presentingPlayer @@ -883,38 +874,39 @@ final class PlayerModel: ObservableObject { } func updateNowPlayingInfo() { - #if !os(tvOS) - guard let video = currentItem?.video else { - MPNowPlayingInfoCenter.default().nowPlayingInfo = .none - return - } - - let currentTime = (backend.currentTime?.seconds.isFinite ?? false) ? backend.currentTime!.seconds : 0 - var nowPlayingInfo: [String: AnyObject] = [ - MPMediaItemPropertyTitle: video.title as AnyObject, - MPMediaItemPropertyArtist: video.author as AnyObject, - MPNowPlayingInfoPropertyIsLiveStream: live as AnyObject, - MPNowPlayingInfoPropertyElapsedPlaybackTime: currentTime as AnyObject, - MPNowPlayingInfoPropertyPlaybackQueueCount: queue.count as AnyObject, - MPNowPlayingInfoPropertyPlaybackQueueIndex: 1 as AnyObject, - MPMediaItemPropertyMediaType: MPMediaType.anyVideo.rawValue as AnyObject - ] - - if !currentArtwork.isNil { - nowPlayingInfo[MPMediaItemPropertyArtwork] = currentArtwork as AnyObject - } - - if !video.live { - let itemDuration = (backend.playerItemDuration ?? .zero).seconds - let duration = itemDuration.isFinite ? Double(itemDuration) : nil - - if !duration.isNil { - nowPlayingInfo[MPMediaItemPropertyPlaybackDuration] = duration as AnyObject - } - } - - MPNowPlayingInfoCenter.default().nowPlayingInfo = nowPlayingInfo + #if os(tvOS) + guard activeBackend == .mpv else { return } #endif + guard let video = currentItem?.video else { + MPNowPlayingInfoCenter.default().nowPlayingInfo = .none + return + } + + let currentTime = (backend.currentTime?.seconds.isFinite ?? false) ? backend.currentTime!.seconds : 0 + var nowPlayingInfo: [String: AnyObject] = [ + MPMediaItemPropertyTitle: video.title as AnyObject, + MPMediaItemPropertyArtist: video.author as AnyObject, + MPNowPlayingInfoPropertyIsLiveStream: live as AnyObject, + MPNowPlayingInfoPropertyElapsedPlaybackTime: currentTime as AnyObject, + MPNowPlayingInfoPropertyPlaybackQueueCount: queue.count as AnyObject, + MPNowPlayingInfoPropertyPlaybackQueueIndex: 1 as AnyObject, + MPMediaItemPropertyMediaType: MPMediaType.anyVideo.rawValue as AnyObject + ] + + if !currentArtwork.isNil { + nowPlayingInfo[MPMediaItemPropertyArtwork] = currentArtwork as AnyObject + } + + if !video.live { + let itemDuration = (backend.playerItemDuration ?? .zero).seconds + let duration = itemDuration.isFinite ? Double(itemDuration) : nil + + if !duration.isNil { + nowPlayingInfo[MPMediaItemPropertyPlaybackDuration] = duration as AnyObject + } + } + + MPNowPlayingInfoCenter.default().nowPlayingInfo = nowPlayingInfo } func updateCurrentArtwork() { diff --git a/Shared/Player/PlayerBackendView.swift b/Shared/Player/PlayerBackendView.swift index e701101e..b13e3082 100644 --- a/Shared/Player/PlayerBackendView.swift +++ b/Shared/Player/PlayerBackendView.swift @@ -34,6 +34,8 @@ struct PlayerBackendView: View { .padding(.top, controlsTopPadding) .padding(.bottom, controlsBottomPadding) #endif + #else + hiddenControlsButton #endif } #if os(iOS) @@ -70,6 +72,22 @@ struct PlayerBackendView: View { } } #endif + + #if os(tvOS) + private var hiddenControlsButton: some View { + VStack { + Button { + player.controls.show() + } label: { + EmptyView() + } + .offset(y: -100) + .buttonStyle(.plain) + .background(Color.clear) + .foregroundColor(.clear) + } + } + #endif } struct PlayerBackendView_Previews: PreviewProvider {