Flutter ListView播放视频列表(三)

96 阅读2分钟

); }

\

这段代码非常简单,通过Stack()配合Positioned()完成按钮的摆放

点击按钮跳转到另一个页面播放视频

跳转页面的时候需要传递2个值:

  • 当前播放视频Url
  • 是播放本地视频,还是播放网络视频.

跳转到第二个页面直接播放即可.(如您不知道如何播放可参考:Flutter 轮子:视频播放

横屏/竖屏

播放的时候就涉及到了屏幕是横屏还是竖屏

横屏代码为:

//横屏 static void setHorizontal(){ SystemChrome.setPreferredOrientations( [DeviceOrientation.landscapeLeft, DeviceOrientation.landscapeRight]); }

竖屏代码:

//竖屏 static void setVertical(){ // 强制竖屏 SystemChrome.setPreferredOrientations( [DeviceOrientation.portraitUp, DeviceOrientation.portraitDown]); }

这段代码思路:

在页面初始化时,将屏幕改为横屏,在播放结束时将屏幕改为竖屏.

@override void initState() { super.initState(); //设置横屏 EntityState.setHorizontal(); } @override void dispose() { //设置竖屏 EntityState.setVertical(); super.dispose(); }

右下角按钮切换横屏/竖屏

//是否是横屏 默认横屏 bool isHorizontal = true;

Widget initPosition() { return Positioned( right: 40, bottom: 40, // horizontal_rule child: GestureDetector( onTap: () { isHorizontal = !isHorizontal; if (isHorizontal) { EntityState.setHorizontal(); } else { EntityState.setVertical(); } setState(() {}); }, child: Container( width: 100, height: 45, alignment: Alignment.center, decoration: BoxDecoration( color: Colors.grey.withOpacity(0.8), borderRadius: BorderRadius.circular(10)), child: Text( isHorizontal ? "横屏" : "竖屏", style: TextStyle(color: Colors.white), ))), ); }

分析:

在右下角通过Stack()配合Positioned()来设置位置

因为在initState()方法初始化时已经设置了横屏,所以,默认为横屏

当点击文字横屏的时候,文字改变为竖屏,并调用竖屏的方法,改变手机朝向.

这段代码也没有什么难度.

效果图(1.3):
在这里插入图片描述

如果大家有什么地方不理解一定要在评论区留言哦~

右上角返回按钮

左上角通过Stack()配合Positioned()来设置位置

Widget initPopButton() { return Positioned( top: 25, left: 25, child: GestureDetector( onTap: () { Navigator.of(context).pop(); }, child: Container( width: 100, height: 45, alignment: Alignment.center, decoration: BoxDecoration( color: Colors.grey.withOpacity(0.8), borderRadius: BorderRadius.circular(10)), child: Icon(Icons.keyboard_return,color: Colors.white,), ), ), ); }

返回最简单,直接调用

Navigator.of(context).pop();

即可.

效果图(1.2):
在这里插入图片描述

视频播放结束返回

这个问题和上一章播放完重新播放思路一样.

@override void initState() { super.initState(); _controller.addListener(() { //当前进度 == 总进度 if (_controller.value.position == _controller.value.duration) { //表示已经播放完 Future.delayed(Duration.zero, () { Navigator.of(context).pop(); }); } }); }

  • _controller.value.position 为当前播放进度
  • _controller.value.duration 为总进度

当前进度 == 总进度说明播放完成,则直接

Navigator.of(context).pop();

即可.

这里要注意的是:

在initState()方法中context上下文还没有创建,所以不能直接使用,需要吧context放到队列之中.

改变状态栏颜色

//修改顶部状态栏颜色 static void setStatusBarColor(Color color){ SystemUiOverlayStyle systemUiOverlayStyle = SystemUiOverlayStyle(statusBarColor:color); SystemChrome.setSystemUIOverlayStyle(systemUiOverlayStyle); } 直接传一个颜色值即可. 在来看看效果图: 效果图(1.2): \ 完整代码 完整项目