From 6c3a7882e1bf7bc29ce593df99a38048b13e9052 Mon Sep 17 00:00:00 2001 From: Arkadiusz Fal Date: Sun, 29 May 2022 15:35:02 +0200 Subject: [PATCH] Player animation improvements --- Shared/Player/VideoPlayerView.swift | 38 ++++++++++++++--------------- 1 file changed, 19 insertions(+), 19 deletions(-) diff --git a/Shared/Player/VideoPlayerView.swift b/Shared/Player/VideoPlayerView.swift index 897bc097..14c9825d 100644 --- a/Shared/Player/VideoPlayerView.swift +++ b/Shared/Player/VideoPlayerView.swift @@ -8,9 +8,9 @@ import SwiftUI struct VideoPlayerView: View { #if os(iOS) - static let hiddenPlayerOffset = UIScreen.main.bounds.height + 100 + static let hiddenPlayerOffset = max(UIScreen.main.bounds.height, UIScreen.main.bounds.width) + 100 #else - static let hiddenPlayerOffset = 0.0 + static let hiddenPlayerOffset = 0.0 #endif static let defaultAspectRatio = 16 / 9.0 @@ -93,8 +93,7 @@ struct VideoPlayerView: View { motionManager?.stopAccelerometerUpdates() motionManager = nil - #else - playerOffset = Self.hiddenPlayerOffset + playerOffset = Self.hiddenPlayerOffset #endif } } @@ -155,46 +154,47 @@ struct VideoPlayerView: View { } #if !os(macOS) .gesture( - DragGesture(minimumDistance: 0) + DragGesture(coordinateSpace: .global) .onChanged { value in guard !fullScreenLayout else { - return + return // swiftlint:disable:this implicit_return } player.backend.setNeedsDrawing(false) let drag = value.translation.height guard drag > 0 else { - return + return // swiftlint:disable:this implicit_return } - withAnimation(.easeIn(duration: 0.2)) { + withAnimation(.easeInOut(duration: 0.2)) { playerOffset = drag } } .onEnded { _ in if playerOffset > 100 { - player.backend.setNeedsDrawing(true) + player.backend.setNeedsDrawing(false) player.hide() } else { - player.show() playerOffset = 0 + player.backend.setNeedsDrawing(true) + player.show() } } ) #else - .onAppear(perform: { - NSEvent.addLocalMonitorForEvents(matching: [.mouseMoved]) { - if hoveringPlayer { - playerControls.resetTimer() - } + .onAppear(perform: { + NSEvent.addLocalMonitorForEvents(matching: [.mouseMoved]) { + if hoveringPlayer { + playerControls.resetTimer() + } - return $0 - } - }) + return $0 + } + }) #endif - .background(Color.black) + .background(Color.black) #if !os(tvOS) if !playerControls.playingFullscreen {