From 720e9f0040156d895c9059976dd8467087da790d Mon Sep 17 00:00:00 2001 From: Riri Date: Sun, 29 Oct 2023 01:57:39 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=E4=BF=AE=E5=A4=8D=E4=B8=BB=E5=8A=A8?= =?UTF-8?q?=E6=9A=82=E5=81=9C=E5=90=8E=E5=85=B6=E4=BB=96=E9=9F=B3=E9=A2=91?= =?UTF-8?q?=E5=81=9C=E6=AD=A2=E5=AF=BC=E8=87=B4=E8=A7=86=E9=A2=91=E6=81=A2?= =?UTF-8?q?=E5=A4=8D=E6=92=AD=E6=94=BE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- lib/plugin/pl_player/controller.dart | 7 ++++++- lib/services/audio_session.dart | 2 +- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/lib/plugin/pl_player/controller.dart b/lib/plugin/pl_player/controller.dart index ec862738..73229b72 100644 --- a/lib/plugin/pl_player/controller.dart +++ b/lib/plugin/pl_player/controller.dart @@ -650,9 +650,14 @@ class PlPlayerController { } /// 暂停播放 - Future pause({bool notify = true}) async { + Future pause({bool notify = true, bool isInterrupt = false}) async { await _videoPlayerController?.pause(); playerStatus.status.value = PlayerStatus.paused; + + // 主动暂停时让出音频焦点 + if (!isInterrupt) { + audioSessionHandler.setActive(false); + } } /// 更改播放状态 diff --git a/lib/services/audio_session.dart b/lib/services/audio_session.dart index 3dd9db45..98707652 100644 --- a/lib/services/audio_session.dart +++ b/lib/services/audio_session.dart @@ -26,7 +26,7 @@ class AudioSessionHandler { break; case AudioInterruptionType.pause: case AudioInterruptionType.unknown: - player.pause(); + player.pause(isInterrupt: true); _playInterrupted = true; break; }