From 47b7f91bccaad5bd22aaeff542a54920c8147cc4 Mon Sep 17 00:00:00 2001 From: Aziz Marashly Date: Sat, 7 Jan 2023 10:56:02 +0300 Subject: [PATCH 1/3] Fix ui directionality in RTL apps --- .../pod_getx_video_controller.dart | 5 + lib/src/pod_player.dart | 5 +- lib/src/widgets/core/pod_core_player.dart | 238 +++++++++--------- 3 files changed, 127 insertions(+), 121 deletions(-) diff --git a/lib/src/controllers/pod_getx_video_controller.dart b/lib/src/controllers/pod_getx_video_controller.dart index 1197369b..6e240b99 100644 --- a/lib/src/controllers/pod_getx_video_controller.dart +++ b/lib/src/controllers/pod_getx_video_controller.dart @@ -19,6 +19,8 @@ part 'pod_video_controller.dart'; part 'pod_video_quality_controller.dart'; class PodGetXVideoController extends _PodGesturesController { + + ///main videoplayer controller VideoPlayerController? get videoCtr => _videoCtr; @@ -36,6 +38,9 @@ class PodGetXVideoController extends _PodGesturesController { /// Duration get videoPosition => _videoPosition; + ///Core video player ui directionality + TextDirection uiDirectionality = TextDirection.ltr; + bool controllerInitialized = false; late PodPlayerConfig podPlayerConfig; late PlayVideoFrom playVideoFrom; diff --git a/lib/src/pod_player.dart b/lib/src/pod_player.dart index 1148d485..bd97e3d4 100644 --- a/lib/src/pod_player.dart +++ b/lib/src/pod_player.dart @@ -45,6 +45,7 @@ class PodVideoPlayer extends StatefulWidget { final Widget? videoTitle; final Color? backgroundColor; final DecorationImage? videoThumbnail; + final TextDirection uiDirectionality; /// Optional callback, fired when full screen mode toggles. /// @@ -73,6 +74,7 @@ class PodVideoPlayer extends StatefulWidget { this.videoThumbnail, this.onToggleFullScreen, this.onLoading, + this.uiDirectionality = TextDirection.ltr, }) : super(key: key) { addToUiController(); } @@ -91,7 +93,8 @@ class PodVideoPlayer extends StatefulWidget { ..videoTitle = videoTitle ..onToggleFullScreen = onToggleFullScreen ..onLoading = onLoading - ..videoThumbnail = videoThumbnail; + ..videoThumbnail = videoThumbnail + ..uiDirectionality = uiDirectionality; } @override diff --git a/lib/src/widgets/core/pod_core_player.dart b/lib/src/widgets/core/pod_core_player.dart index a40ffa22..0be723ca 100644 --- a/lib/src/widgets/core/pod_core_player.dart +++ b/lib/src/widgets/core/pod_core_player.dart @@ -15,142 +15,140 @@ class _PodCoreVideoPlayer extends StatelessWidget { @override Widget build(BuildContext context) { final _podCtr = Get.find(tag: tag); - return Builder( - builder: (_ctrx) { - return RawKeyboardListener( - autofocus: true, - focusNode: - (_podCtr.isFullScreen ? FocusNode() : _podCtr.keyboardFocusWeb) ?? - FocusNode(), - onKey: (value) => _podCtr.onKeyBoardEvents( - event: value, - appContext: _ctrx, - tag: tag, - ), - child: Stack( - fit: StackFit.expand, - children: [ - Center( - child: AspectRatio( - aspectRatio: videoAspectRatio, - child: VideoPlayer(videoPlayerCtr), + return Directionality( + textDirection: _podCtr.uiDirectionality, + child: Builder( + builder: (_ctrx) { + return RawKeyboardListener( + autofocus: true, + focusNode: (_podCtr.isFullScreen ? FocusNode() : _podCtr.keyboardFocusWeb) ?? FocusNode(), + onKey: (value) => _podCtr.onKeyBoardEvents( + event: value, + appContext: _ctrx, + tag: tag, + ), + child: Stack( + fit: StackFit.expand, + children: [ + Center( + child: AspectRatio( + aspectRatio: videoAspectRatio, + child: VideoPlayer(videoPlayerCtr), + ), ), - ), - GetBuilder( - tag: tag, - id: 'podVideoState', - builder: (_) => GetBuilder( + GetBuilder( tag: tag, - id: 'video-progress', - builder: (_podCtr) { - if (_podCtr.videoThumbnail == null) { - return const SizedBox(); - } + id: 'podVideoState', + builder: (_) => GetBuilder( + tag: tag, + id: 'video-progress', + builder: (_podCtr) { + if (_podCtr.videoThumbnail == null) { + return const SizedBox(); + } - if (_podCtr.podVideoState == PodVideoState.paused && - _podCtr.videoPosition == Duration.zero) { - return SizedBox.expand( - child: TweenAnimationBuilder( - builder: (context, value, child) => Opacity( - opacity: value, - child: child, - ), - tween: Tween(begin: 0.7, end: 1), - duration: const Duration(milliseconds: 400), - child: DecoratedBox( - decoration: BoxDecoration( - image: _podCtr.videoThumbnail, + if (_podCtr.podVideoState == PodVideoState.paused && _podCtr.videoPosition == Duration.zero) { + return SizedBox.expand( + child: TweenAnimationBuilder( + builder: (context, value, child) => Opacity( + opacity: value, + child: child, + ), + tween: Tween(begin: 0.7, end: 1), + duration: const Duration(milliseconds: 400), + child: DecoratedBox( + decoration: BoxDecoration( + image: _podCtr.videoThumbnail, + ), ), - ), - ), - ); - } - return const SizedBox(); - }, - ), - ), - _VideoOverlays(tag: tag), - IgnorePointer( - child: GetBuilder( - tag: tag, - id: 'podVideoState', - builder: (_podCtr) { - final loadingWidget = _podCtr.onLoading?.call(context) ?? - const Center( - child: CircularProgressIndicator( - backgroundColor: Colors.transparent, - color: Colors.white, - strokeWidth: 2, ), ); - - if (kIsWeb) { - switch (_podCtr.podVideoState) { - case PodVideoState.loading: - return loadingWidget; - case PodVideoState.paused: - return const Center( - child: Icon( - Icons.play_arrow, - size: 45, + } + return const SizedBox(); + }, + ), + ), + _VideoOverlays(tag: tag), + IgnorePointer( + child: GetBuilder( + tag: tag, + id: 'podVideoState', + builder: (_podCtr) { + final loadingWidget = _podCtr.onLoading?.call(context) ?? + const Center( + child: CircularProgressIndicator( + backgroundColor: Colors.transparent, color: Colors.white, + strokeWidth: 2, ), ); - case PodVideoState.playing: - return Center( - child: TweenAnimationBuilder( - builder: (context, value, child) => Opacity( - opacity: value, - child: child, - ), - tween: Tween(begin: 1, end: 0), - duration: const Duration(seconds: 1), - child: const Icon( - Icons.pause, + + if (kIsWeb) { + switch (_podCtr.podVideoState) { + case PodVideoState.loading: + return loadingWidget; + case PodVideoState.paused: + return const Center( + child: Icon( + Icons.play_arrow, size: 45, color: Colors.white, ), - ), - ); - case PodVideoState.error: - return const SizedBox(); - } - } else { - if (_podCtr.podVideoState == PodVideoState.loading) { - return loadingWidget; + ); + case PodVideoState.playing: + return Center( + child: TweenAnimationBuilder( + builder: (context, value, child) => Opacity( + opacity: value, + child: child, + ), + tween: Tween(begin: 1, end: 0), + duration: const Duration(seconds: 1), + child: const Icon( + Icons.pause, + size: 45, + color: Colors.white, + ), + ), + ); + case PodVideoState.error: + return const SizedBox(); + } + } else { + if (_podCtr.podVideoState == PodVideoState.loading) { + return loadingWidget; + } + return const SizedBox(); } - return const SizedBox(); - } - }, + }, + ), ), - ), - if (!kIsWeb) - GetBuilder( - tag: tag, - id: 'full-screen', - builder: (_podCtr) => _podCtr.isFullScreen - ? const SizedBox() - : GetBuilder( - tag: tag, - id: 'overlay', - builder: (_podCtr) => _podCtr.isOverlayVisible || - !_podCtr.alwaysShowProgressBar - ? const SizedBox() - : Align( - alignment: Alignment.bottomCenter, - child: PodProgressBar( - tag: tag, + if (!kIsWeb) + GetBuilder( + tag: tag, + id: 'full-screen', + builder: (_podCtr) => _podCtr.isFullScreen + ? const SizedBox() + : GetBuilder( + tag: tag, + id: 'overlay', + builder: (_podCtr) => _podCtr.isOverlayVisible || !_podCtr.alwaysShowProgressBar + ? const SizedBox() + : Align( alignment: Alignment.bottomCenter, - podProgressBarConfig: - _podCtr.podProgressBarConfig, + child: PodProgressBar( + tag: tag, + alignment: Alignment.bottomCenter, + podProgressBarConfig: _podCtr.podProgressBarConfig, + ), ), - ), - ), - ), - ], - ), - ); - }, + ), + ), + ], + ), + ); + }, + ), ); } } From 1824be47e936f272ea0ead0734bd1d43dc73e4ae Mon Sep 17 00:00:00 2001 From: Aziz Marashly Date: Sat, 7 Jan 2023 18:45:13 +0300 Subject: [PATCH 2/3] Fix missing headers and other video player options when changing quality --- lib/src/controllers/pod_getx_video_controller.dart | 5 +++++ .../controllers/pod_video_quality_controller.dart | 13 +++++++++++-- 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/lib/src/controllers/pod_getx_video_controller.dart b/lib/src/controllers/pod_getx_video_controller.dart index 6e240b99..c43eae86 100644 --- a/lib/src/controllers/pod_getx_video_controller.dart +++ b/lib/src/controllers/pod_getx_video_controller.dart @@ -304,4 +304,9 @@ class PodGetXVideoController extends _PodGesturesController { keyboardFocusWeb?.addListener(keyboadListner); await videoInit(); } + + @override + Future changeVideoQuality(int? quality, {PlayVideoFrom? playVideoFromParam}) async { + return super.changeVideoQuality(quality, playVideoFromParam: playVideoFromParam ?? playVideoFrom); + } } diff --git a/lib/src/controllers/pod_video_quality_controller.dart b/lib/src/controllers/pod_video_quality_controller.dart index 9f4b8dee..121a1d6a 100644 --- a/lib/src/controllers/pod_video_quality_controller.dart +++ b/lib/src/controllers/pod_video_quality_controller.dart @@ -106,10 +106,13 @@ class _PodVideoQualityController extends _PodVideoController { []; } - Future changeVideoQuality(int? quality) async { + Future changeVideoQuality(int? quality, {PlayVideoFrom? playVideoFromParam}) async { if (vimeoOrVideoUrls.isEmpty) { throw Exception('videoQuality cannot be empty'); } + if (playVideoFromParam == null) { + throw Exception('playVideoFrom cannot be null'); + } if (vimeoPlayingVideoQuality != quality) { _videoQualityUrl = vimeoOrVideoUrls .where((element) => element.quality == quality) @@ -121,7 +124,13 @@ class _PodVideoQualityController extends _PodVideoController { podVideoStateChanger(PodVideoState.paused); podVideoStateChanger(PodVideoState.loading); playingVideoUrl = _videoQualityUrl; - _videoCtr = VideoPlayerController.network(_videoQualityUrl); + _videoCtr = VideoPlayerController.network( + _videoQualityUrl, + videoPlayerOptions: playVideoFromParam.videoPlayerOptions, + closedCaptionFile: playVideoFromParam.closedCaptionFile, + formatHint: playVideoFromParam.formatHint, + httpHeaders: playVideoFromParam.httpHeaders, + ); await _videoCtr?.initialize(); _videoDuration = _videoCtr?.value.duration ?? Duration.zero; _videoCtr?.addListener(videoListner); From f36fb7ff406677e2d77b742b17e6303a9a3d09ee Mon Sep 17 00:00:00 2001 From: Aziz Marashly Date: Sat, 7 Jan 2023 23:56:05 +0300 Subject: [PATCH 3/3] Fix 240p and aspect ratio problem by hardcoding 16/9 for now. To be fixed more properly later --- lib/src/controllers/pod_video_quality_controller.dart | 3 --- lib/src/widgets/full_screen_view.dart | 3 +-- 2 files changed, 1 insertion(+), 5 deletions(-) diff --git a/lib/src/controllers/pod_video_quality_controller.dart b/lib/src/controllers/pod_video_quality_controller.dart index 121a1d6a..ec4141f8 100644 --- a/lib/src/controllers/pod_video_quality_controller.dart +++ b/lib/src/controllers/pod_video_quality_controller.dart @@ -47,9 +47,6 @@ class _PodVideoQualityController extends _PodVideoController { ) { final _urls = urls; - ///has issues with 240p - _urls?.removeWhere((element) => element.quality == 240); - ///has issues with 144p in web if (kIsWeb) { _urls?.removeWhere((element) => element.quality == 144); diff --git a/lib/src/widgets/full_screen_view.dart b/lib/src/widgets/full_screen_view.dart index 98021ae0..a254ca55 100644 --- a/lib/src/widgets/full_screen_view.dart +++ b/lib/src/widgets/full_screen_view.dart @@ -68,8 +68,7 @@ class _FullScreenViewState extends State ? _PodCoreVideoPlayer( tag: widget.tag, videoPlayerCtr: _podCtr.videoCtr!, - videoAspectRatio: - _podCtr.videoCtr?.value.aspectRatio ?? 16 / 9, + videoAspectRatio: 16 / 9, ) : loadingWidget, ),