【flutter better_player_plus实现普通播放器功能】

引入better_player_plus: ^1.1.5

dart 复制代码
import 'package:better_player_plus/better_player_plus.dart';

late BetterPlayerController _videoController;
@override
  void initState() {
    // TODO: implement initState
    super.initState();
    //BoxFit.contain + fullScreenByDefault=true + autoDetectFullscreenAspectRatio = true,设置后播放器播放时默认按视频的宽高比例放大填充父布局
    final betterPlayerConfiguration = BetterPlayerConfiguration(
          fit: BoxFit.contain,
          autoPlay: true,
          looping: true,
          fullScreenByDefault: true,
          autoDetectFullscreenAspectRatio: true,
          controlsConfiguration: const BetterPlayerControlsConfiguration(
            showControls: false, // 是否显示控制栏
            enableSkips: false, // 禁用快进/快退
          )
      );

     _videoController = BetterPlayerController(betterPlayerConfiguration,betterPlayerDataSource: dataSource);
     _videoController.addEventsListener(_videoListener);
    }

_videoListener(BetterPlayerEvent event) async {
    switch(event.betterPlayerEventType){
      case BetterPlayerEventType.initialized:
        setState(() {
          _isVideoInit = true;
          double? videoWidth = _videoController.videoPlayerController?.value.size?.width;
          double? videoHeight = _videoController.videoPlayerController?.value.size?.height;
          print('_videoWidth= $videoWidth  _videoHeight= $videoHeight');

          if(videoWidth != null && videoHeight != null){
            double aspectRatio = videoHeight / videoWidth;
            _logic.videoAspectRatio = aspectRatio;
          }
          _videoController.play();
        });
        break;
      case BetterPlayerEventType.progress:
        Duration res = _videoController.videoPlayerController!.value.position;
        Duration? totalDuration = _videoController.videoPlayerController?.value.duration;
        if (_videoController.isPlaying() == true && _key.currentState != null) {
          /// 减少build次数
          _key.currentState!.setPosition(
            position: res,
            totalDuration: totalDuration,
          );
        }
        break;
      case BetterPlayerEventType.bufferingStart:
        _isBuffering = true;
        break;
      case BetterPlayerEventType.bufferingEnd:
        _isBuffering = false;
        break;
        case BetterPlayerEventType.exception:
          esLoadingToast('视频加载失败');
          print('视频播放器问题:${_videoController.videoPlayerController!.value.errorDescription} =====');
        break;
        default:
          break;
    }
  }

@override
  void dispose() {
    // TODO: implement dispose
    _videoController.removeEventsListener(_videoListener);
    _videoController.dispose();
    super.dispose();
  }


@override
  Widget build(BuildContext context) {
    // TODO: implement build
    return Scaffold(
      backgroundColor: Colors.black,
      body: BetterPlayer(controller: _videoController),
    );
  }

只配置fit: BoxFit.contain时,播放时显示区域虽然按视频比例,但是不会尽可能大的充满屏幕

BoxFit.contain + fullScreenByDefault=true + autoDetectFullscreenAspectRatio = true,播放时显示区域按视频比例比例尽可能大的充满屏幕

相关推荐
GitLqr6 小时前
Flutter 3.44 插件内置 Kotlin (KGP) 双向兼容适配指南
android·flutter·dart
SoaringHeart2 天前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
月光下的丝瓜3 天前
Flutter 国内安装指南
前端·flutter
恋猫de小郭6 天前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter
张风捷特烈6 天前
Flutter 类库大揭秘#02 | path_provider 各平台实现
前端·flutter
TT_Close7 天前
别劝退了!5秒搞定 Flutter 鸿蒙 FVM 起跑线
flutter·harmonyos·visual studio code
你听得到117 天前
用户说 App 卡,但说不清在哪?我把 Flutter 监控 SDK 升级成了链路观测工作台
前端·flutter·性能优化
stringwu9 天前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter
程序员老刘9 天前
Flutter版本选择指南:3.44系列继续观望 | 2026年6月
flutter·ai编程·客户端
用户9655973619011 天前
Provider vs Bloc vs GetX vs Riverpod:Flutter 状态管理方案怎么选?
flutter