From 7ceb4c01a1f5eaf2ba8c54f5a865c4ce129f0a74 Mon Sep 17 00:00:00 2001 From: Bruno D'Luka Date: Fri, 27 Jan 2023 15:24:21 -0300 Subject: [PATCH 1/6] Correctly dipose current players on close and correctly get current dataSource in media_kit impl --- lib/widgets/desktop_buttons.dart | 38 ++++++++++++++++++- .../lib/unity_video_player_desktop.dart | 5 ++- .../unity_video_player_desktop/pubspec.yaml | 2 - .../lib/unity_video_player_media_kit.dart | 18 +++++++-- .../lib/unity_video_player_mobile.dart | 5 ++- ...unity_video_player_platform_interface.dart | 11 ++++++ 6 files changed, 70 insertions(+), 9 deletions(-) diff --git a/lib/widgets/desktop_buttons.dart b/lib/widgets/desktop_buttons.dart index b60f4c5b..52b3a6b0 100644 --- a/lib/widgets/desktop_buttons.dart +++ b/lib/widgets/desktop_buttons.dart @@ -18,6 +18,7 @@ */ import 'dart:async'; +import 'dart:io'; import 'package:bluecherry_client/main.dart'; import 'package:bluecherry_client/models/device.dart'; @@ -27,6 +28,7 @@ import 'package:bluecherry_client/widgets/home.dart'; import 'package:bluecherry_client/widgets/misc.dart'; import 'package:flutter/material.dart'; import 'package:provider/provider.dart'; +import 'package:unity_video_player/unity_video_player.dart'; import 'package:window_manager/window_manager.dart'; final navigationStream = StreamController.broadcast(); @@ -83,7 +85,26 @@ class WindowButtons extends StatefulWidget { State createState() => _WindowButtonsState(); } -class _WindowButtonsState extends State { +class _WindowButtonsState extends State with WindowListener { + @override + void initState() { + windowManager.addListener(this); + _init(); + super.initState(); + } + + @override + void dispose() { + windowManager.removeListener(this); + super.dispose(); + } + + Future _init() async { + // Add this line to override the default close handler + await windowManager.setPreventClose(true); + setState(() {}); + } + @override Widget build(BuildContext context) { if (!isDesktop) return const SizedBox.shrink(); @@ -230,4 +251,19 @@ class _WindowButtonsState extends State { }, ); } + + @override + Future onWindowClose() async { + final isPreventClose = await windowManager.isPreventClose(); + // We ensure all the players are disposed in order to not keep the app alive + // in background, wasting unecessary resources! + if (isPreventClose) { + for (final player in UnityVideoPlayerInterface.players) { + debugPrint('Disposing player ${player.hashCode}'); + player.dispose(); + } + windowManager.destroy(); + exit(0); + } + } } diff --git a/packages/unity_video_player/unity_video_player_desktop/lib/unity_video_player_desktop.dart b/packages/unity_video_player/unity_video_player_desktop/lib/unity_video_player_desktop.dart index 88efc7b2..e3f6fa11 100644 --- a/packages/unity_video_player/unity_video_player_desktop/lib/unity_video_player_desktop.dart +++ b/packages/unity_video_player/unity_video_player_desktop/lib/unity_video_player_desktop.dart @@ -19,7 +19,9 @@ class UnityVideoPlayerDesktopInterface extends UnityVideoPlayerInterface { @override UnityVideoPlayer createPlayer({int? width, int? height}) { - return UnityVideoPlayerDesktop(); + final player = UnityVideoPlayerDesktop(width: width, height: height); + UnityVideoPlayerInterface.registerPlayer(player); + return player; } @override @@ -138,5 +140,6 @@ class UnityVideoPlayerDesktop extends UnityVideoPlayer { @override void dispose() { vlcPlayer.dispose(); + UnityVideoPlayerInterface.unregisterPlayer(this); } } diff --git a/packages/unity_video_player/unity_video_player_desktop/pubspec.yaml b/packages/unity_video_player/unity_video_player_desktop/pubspec.yaml index 39cb7dd5..dfb443a4 100644 --- a/packages/unity_video_player/unity_video_player_desktop/pubspec.yaml +++ b/packages/unity_video_player/unity_video_player_desktop/pubspec.yaml @@ -29,5 +29,3 @@ flutter: dartPluginClass: UnityVideoPlayerDesktopInterface macos: dartPluginClass: UnityVideoPlayerDesktopInterface - windows: - dartPluginClass: UnityVideoPlayerDesktopInterface diff --git a/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart b/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart index 2121a077..066f188b 100644 --- a/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart +++ b/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart @@ -16,7 +16,9 @@ class UnityVideoPlayerMediaKitInterface extends UnityVideoPlayerInterface { @override UnityVideoPlayer createPlayer({int? width, int? height}) { - return UnityVideoPlayerMediaKit(); + final player = UnityVideoPlayerMediaKit(width: width, height: height); + UnityVideoPlayerInterface.registerPlayer(player); + return player; } @override @@ -78,7 +80,8 @@ class __MKVideoState extends State<_MKVideo> { super.initState(); widget.videoController.then((value) { - setState(() => videoController = value); + videoController = value; + if (mounted) setState(() {}); }); } @@ -118,8 +121,14 @@ class UnityVideoPlayerMediaKit extends UnityVideoPlayer { } @override - String? get dataSource => - mkPlayer.state.playlist.medias[mkPlayer.state.playlist.index].uri; + String? get dataSource { + if (mkPlayer.state.playlist.medias.isEmpty) return null; + + var index = mkPlayer.state.playlist.index; + if (index.isNegative) return null; + + return mkPlayer.state.playlist.medias[index].uri; + } @override String? get error { @@ -188,5 +197,6 @@ class UnityVideoPlayerMediaKit extends UnityVideoPlayer { void dispose() async { await (await mkVideoController).dispose(); await mkPlayer.dispose(); + UnityVideoPlayerInterface.unregisterPlayer(this); } } diff --git a/packages/unity_video_player/unity_video_player_mobile/lib/unity_video_player_mobile.dart b/packages/unity_video_player/unity_video_player_mobile/lib/unity_video_player_mobile.dart index 1585e3ec..f2fd0045 100644 --- a/packages/unity_video_player/unity_video_player_mobile/lib/unity_video_player_mobile.dart +++ b/packages/unity_video_player/unity_video_player_mobile/lib/unity_video_player_mobile.dart @@ -15,7 +15,9 @@ class UnityVideoPlayerMobileInterface extends UnityVideoPlayerInterface { @override UnityVideoPlayer createPlayer({int? width, int? height}) { - return UnityVideoPlayerMobile(); + final player = UnityVideoPlayerMobile(); + UnityVideoPlayerInterface.registerPlayer(player); + return player; } /// Creates a video view @@ -120,5 +122,6 @@ class UnityVideoPlayerMobile extends UnityVideoPlayer { @override void dispose() { ijkPlayer.dispose(); + UnityVideoPlayerInterface.unregisterPlayer(this); } } diff --git a/packages/unity_video_player/unity_video_player_platform_interface/lib/unity_video_player_platform_interface.dart b/packages/unity_video_player/unity_video_player_platform_interface/lib/unity_video_player_platform_interface.dart index c5464345..33a93b5c 100644 --- a/packages/unity_video_player/unity_video_player_platform_interface/lib/unity_video_player_platform_interface.dart +++ b/packages/unity_video_player/unity_video_player_platform_interface/lib/unity_video_player_platform_interface.dart @@ -43,6 +43,17 @@ abstract class UnityVideoPlayerInterface extends PlatformInterface { UnityVideoPaneBuilder? paneBuilder, Color color = const Color(0xFF000000), }); + + static final _appPlayers = []; + static List get players => _appPlayers; + + static void registerPlayer(UnityVideoPlayer player) { + _appPlayers.add(player); + } + + static void unregisterPlayer(UnityVideoPlayer player) { + _appPlayers.remove(player); + } } // ignore: non_constant_identifier_names From dec8243ecbe911aa4fcbeb41790ca4932ba668c9 Mon Sep 17 00:00:00 2001 From: Bruno D'Luka Date: Fri, 27 Jan 2023 15:36:58 -0300 Subject: [PATCH 2/6] Show 'noDownloads' warning if there are no downloads --- lib/providers/downloads.dart | 5 +++++ lib/widgets/downloads_manager.dart | 6 ++++++ 2 files changed, 11 insertions(+) diff --git a/lib/providers/downloads.dart b/lib/providers/downloads.dart index fd0a0116..0cc50890 100644 --- a/lib/providers/downloads.dart +++ b/lib/providers/downloads.dart @@ -127,6 +127,11 @@ class DownloadsManager extends ChangeNotifier { } } + /// Whether there are no events downloaded, nor downloading events + bool get isEmpty { + return downloadedEvents.isEmpty && downloading.isEmpty; + } + /// Whether the given event is downloaded bool isEventDownloaded(int eventId) { return downloadedEvents.any((de) => de.event.id == eventId); diff --git a/lib/widgets/downloads_manager.dart b/lib/widgets/downloads_manager.dart index 3374a8a3..738685fe 100644 --- a/lib/widgets/downloads_manager.dart +++ b/lib/widgets/downloads_manager.dart @@ -59,6 +59,12 @@ class DownloadsManagerScreen extends StatelessWidget { ), ), body: LayoutBuilder(builder: (context, consts) { + if (downloads.isEmpty) { + return Center( + child: Text(AppLocalizations.of(context).noDownloads), + ); + } + final size = consts.biggest; return CustomScrollView( slivers: [ From faccd87a3ddc7f0ad66a9b5608d62752d6573240 Mon Sep 17 00:00:00 2001 From: Bruno D'Luka Date: Fri, 27 Jan 2023 15:50:19 -0300 Subject: [PATCH 3/6] Upgrade media_kit dependency --- .../unity_video_player_media_kit/pubspec.yaml | 6 +++--- pubspec.lock | 12 ++++++------ 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml b/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml index 9a2d91aa..22d50d53 100644 --- a/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml +++ b/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml @@ -15,17 +15,17 @@ dependencies: media_kit: git: url: https://github.com/alexmercerind/media_kit.git - ref: df91b60499e67229a1c95cd9048919500460e542 + ref: 20c46b58bb5c8a9e749b6b9760234281e7bf2e02 path: media_kit/ media_kit_video: git: url: https://github.com/alexmercerind/media_kit.git - ref: df91b60499e67229a1c95cd9048919500460e542 + ref: 20c46b58bb5c8a9e749b6b9760234281e7bf2e02 path: media_kit_video/ media_kit_libs_windows_video: git: url: https://github.com/alexmercerind/media_kit.git - ref: df91b60499e67229a1c95cd9048919500460e542 + ref: 20c46b58bb5c8a9e749b6b9760234281e7bf2e02 path: media_kit_libs_windows_video/ unity_video_player_platform_interface: path: ../unity_video_player_platform_interface/ diff --git a/pubspec.lock b/pubspec.lock index ca49858b..46b924c0 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -442,8 +442,8 @@ packages: dependency: transitive description: path: media_kit - ref: df91b60499e67229a1c95cd9048919500460e542 - resolved-ref: df91b60499e67229a1c95cd9048919500460e542 + ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" + resolved-ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" url: "https://github.com/alexmercerind/media_kit.git" source: git version: "0.0.1" @@ -451,8 +451,8 @@ packages: dependency: transitive description: path: media_kit_libs_windows_video - ref: df91b60499e67229a1c95cd9048919500460e542 - resolved-ref: df91b60499e67229a1c95cd9048919500460e542 + ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" + resolved-ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" url: "https://github.com/alexmercerind/media_kit.git" source: git version: "1.0.0" @@ -460,8 +460,8 @@ packages: dependency: transitive description: path: media_kit_video - ref: df91b60499e67229a1c95cd9048919500460e542 - resolved-ref: df91b60499e67229a1c95cd9048919500460e542 + ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" + resolved-ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" url: "https://github.com/alexmercerind/media_kit.git" source: git version: "0.0.1" From 54751e0aa30807247e160c2e9206fe259b139b85 Mon Sep 17 00:00:00 2001 From: Bruno D'Luka Date: Fri, 27 Jan 2023 15:55:10 -0300 Subject: [PATCH 4/6] Correct icons for layout manager --- lib/widgets/device_grid/layout_manager.dart | 20 ++++++++++---------- 1 file changed, 10 insertions(+), 10 deletions(-) diff --git a/lib/widgets/device_grid/layout_manager.dart b/lib/widgets/device_grid/layout_manager.dart index a4036854..917c22d2 100644 --- a/lib/widgets/device_grid/layout_manager.dart +++ b/lib/widgets/device_grid/layout_manager.dart @@ -208,25 +208,25 @@ class LayoutTile extends StatelessWidget { } } -IconData iconForLayout(DesktopLayoutType type) { +String textForLayout(BuildContext context, DesktopLayoutType type) { switch (type) { case DesktopLayoutType.singleView: - return Icons.crop_square; + return AppLocalizations.of(context).singleView; case DesktopLayoutType.multipleView: - return Icons.view_comfy_outlined; + return AppLocalizations.of(context).multipleView; case DesktopLayoutType.compactView: - return Icons.view_compact_outlined; + return AppLocalizations.of(context).compactView; } } -String textForLayout(BuildContext context, DesktopLayoutType type) { +IconData iconForLayout(DesktopLayoutType type) { switch (type) { case DesktopLayoutType.singleView: - return AppLocalizations.of(context).singleView; + return Icons.crop_square; case DesktopLayoutType.multipleView: - return AppLocalizations.of(context).multipleView; + return Icons.view_compact_outlined; case DesktopLayoutType.compactView: - return AppLocalizations.of(context).compactView; + return Icons.view_comfy_outlined; } } @@ -235,9 +235,9 @@ IconData selectedIconForLayout(DesktopLayoutType type) { case DesktopLayoutType.singleView: return Icons.square_rounded; case DesktopLayoutType.multipleView: - return Icons.view_comfy; - case DesktopLayoutType.compactView: return Icons.view_compact; + case DesktopLayoutType.compactView: + return Icons.view_comfy; } } From a50ede75989d5ca1126ef8e1e05340be8786785d Mon Sep 17 00:00:00 2001 From: Bruno D'Luka Date: Fri, 27 Jan 2023 17:25:35 -0300 Subject: [PATCH 5/6] Revert "Upgrade media_kit dependency" This reverts commit faccd87a3ddc7f0ad66a9b5608d62752d6573240. --- .../unity_video_player_media_kit/pubspec.yaml | 6 +++--- pubspec.lock | 12 ++++++------ 2 files changed, 9 insertions(+), 9 deletions(-) diff --git a/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml b/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml index 22d50d53..9a2d91aa 100644 --- a/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml +++ b/packages/unity_video_player/unity_video_player_media_kit/pubspec.yaml @@ -15,17 +15,17 @@ dependencies: media_kit: git: url: https://github.com/alexmercerind/media_kit.git - ref: 20c46b58bb5c8a9e749b6b9760234281e7bf2e02 + ref: df91b60499e67229a1c95cd9048919500460e542 path: media_kit/ media_kit_video: git: url: https://github.com/alexmercerind/media_kit.git - ref: 20c46b58bb5c8a9e749b6b9760234281e7bf2e02 + ref: df91b60499e67229a1c95cd9048919500460e542 path: media_kit_video/ media_kit_libs_windows_video: git: url: https://github.com/alexmercerind/media_kit.git - ref: 20c46b58bb5c8a9e749b6b9760234281e7bf2e02 + ref: df91b60499e67229a1c95cd9048919500460e542 path: media_kit_libs_windows_video/ unity_video_player_platform_interface: path: ../unity_video_player_platform_interface/ diff --git a/pubspec.lock b/pubspec.lock index 46b924c0..ca49858b 100644 --- a/pubspec.lock +++ b/pubspec.lock @@ -442,8 +442,8 @@ packages: dependency: transitive description: path: media_kit - ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" - resolved-ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" + ref: df91b60499e67229a1c95cd9048919500460e542 + resolved-ref: df91b60499e67229a1c95cd9048919500460e542 url: "https://github.com/alexmercerind/media_kit.git" source: git version: "0.0.1" @@ -451,8 +451,8 @@ packages: dependency: transitive description: path: media_kit_libs_windows_video - ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" - resolved-ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" + ref: df91b60499e67229a1c95cd9048919500460e542 + resolved-ref: df91b60499e67229a1c95cd9048919500460e542 url: "https://github.com/alexmercerind/media_kit.git" source: git version: "1.0.0" @@ -460,8 +460,8 @@ packages: dependency: transitive description: path: media_kit_video - ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" - resolved-ref: "20c46b58bb5c8a9e749b6b9760234281e7bf2e02" + ref: df91b60499e67229a1c95cd9048919500460e542 + resolved-ref: df91b60499e67229a1c95cd9048919500460e542 url: "https://github.com/alexmercerind/media_kit.git" source: git version: "0.0.1" From 301b26e828ed8ea5babf84bd31a33207e9f6d715 Mon Sep 17 00:00:00 2001 From: Bruno D'Luka Date: Fri, 27 Jan 2023 18:00:26 -0300 Subject: [PATCH 6/6] Update unity_video_player_media_kit.dart --- .../lib/unity_video_player_media_kit.dart | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart b/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart index 066f188b..4d41a9ee 100644 --- a/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart +++ b/packages/unity_video_player/unity_video_player_media_kit/lib/unity_video_player_media_kit.dart @@ -109,8 +109,8 @@ class UnityVideoPlayerMediaKit extends UnityVideoPlayer { UnityVideoPlayerMediaKit({int? width, int? height}) { mkVideoController = VideoController.create( mkPlayer.handle, - height: height, - width: width, + // height: height, + // width: width, ); }