diff --git a/Shared/Constants.swift b/Shared/Constants.swift index 399a5896..4184073e 100644 --- a/Shared/Constants.swift +++ b/Shared/Constants.swift @@ -6,6 +6,7 @@ enum Constants { static let overlayAnimation = Animation.linear(duration: 0.2) static let aspectRatio16x9 = 16.0 / 9.0 static let aspectRatio4x3 = 4.0 / 3.0 + static let notificationCenterZoneHeight: Double = 60 static var isAppleTV: Bool { #if os(iOS) diff --git a/Shared/Player/Controls/TimelineView.swift b/Shared/Player/Controls/TimelineView.swift index 5a0b291a..3938002d 100644 --- a/Shared/Player/Controls/TimelineView.swift +++ b/Shared/Player/Controls/TimelineView.swift @@ -199,6 +199,16 @@ struct TimelineView: View { .gesture( DragGesture(minimumDistance: 5, coordinateSpace: .global) .onChanged { value in + #if os(iOS) + // In fullscreen, ignore gestures that start in the top notification center area + // to allow system notification center gesture to work + if player.playingFullScreen { + if value.startLocation.y < Constants.notificationCenterZoneHeight { + return + } + } + #endif + if !dragging { controls.removeTimer() draggedFrom = current diff --git a/Shared/Player/PlayerDragGesture.swift b/Shared/Player/PlayerDragGesture.swift index 696bd630..c6832fe2 100644 --- a/Shared/Player/PlayerDragGesture.swift +++ b/Shared/Player/PlayerDragGesture.swift @@ -16,6 +16,16 @@ extension VideoPlayerView { state = true } .onChanged { value in + #if os(iOS) + // In fullscreen, ignore gestures that start in the top notification center area + // to allow system notification center gesture to work + if player.playingFullScreen { + if value.startLocation.y < Constants.notificationCenterZoneHeight { + return + } + } + #endif + guard player.presentingPlayer, !controlsOverlayModel.presenting, dragGestureState,