老孟导读:用Flutter实现弹幕功能,轻松实现虎牙、斗鱼的弹幕效果。

先来一张效果图:

实现原理

弹幕的实现原理非常简单,即将一条弹幕从左侧平移到右侧,当然我们要计算弹幕垂直方向上的偏移,不然所有的弹幕都会在一条直线上,相互覆盖。平移代码如下:

@override
void initState() {_animationController =AnimationController(duration: widget.duration, vsync: this)..addStatusListener((status){if(status == AnimationStatus.completed){widget.onComplete('');}});var begin = Offset(-1.0, .0);var end = Offset(1.0, .0);_animation = Tween(begin: begin, end: end).animate(_animationController);//开始动画_animationController.forward();super.initState();
}@overrideWidget build(BuildContext context) {return SlideTransition(position: _animation,child: widget.child,);}

计算垂直方向的偏移:

_computeTop(int index, double perRowHeight) {//第几轮弹幕int num = (index / widget.showCount).floor();var top;top = (index % widget.showCount) * perRowHeight + widget.padding;if (num % 2 == 1 && index % widget.showCount != widget.showCount - 1) {//第二轮在第一轮2行弹幕中间top += perRowHeight / 2;}if (widget.randomOffset != 0 && top > widget.randomOffset) {top += _random.nextInt(widget.randomOffset) * 2 - widget.randomOffset;}return top;
}

这些准备好后,就是创建一条弹幕了,现创建一条最简单的文字弹幕:

Text(text,style: TextStyle(color: Colors.white),
);

效果如下:

创建一条VIP用户的弹幕,其实就是字体变下颜色:

Text(text,style: TextStyle(color: Color(0xFFE9A33A)),
)

效果如下:

给文字加个圆角背景:

return Center(child: Container(padding: EdgeInsets.only(left: 10, right: 10, top: 3, bottom: 3),decoration: BoxDecoration(color: Colors.red.withOpacity(.8),borderRadius: BorderRadius.circular(50)),child: Text(text,style: TextStyle(color: Colors.white),),),
);

效果如下:

创建一个送火箭的弹幕:

return Center(child: Container(padding: EdgeInsets.only(left: 10, right: 10, top: 3, bottom: 3),decoration: BoxDecoration(color: Colors.red.withOpacity(.8),borderRadius: BorderRadius.circular(50)),child: Row(mainAxisSize: MainAxisSize.min,children: <Widget>[Text(text,style: TextStyle(color: Colors.white),),Image.asset('assets/images/timg.jpeg',height: 30,width: 30,),Text('x $count',style: TextStyle(color: Colors.white, fontSize: 18),),],),),
);

效果如下:

火箭有点丑了,不过这不是重点。

其实实现弹幕效果没有我开始想的那么简单,过程中也遇到了一些问题,不过好在最终都解决了,献上Github地址:https://github.com/781238222/flutter-do/tree/master/flutter_barrage_sample

如果觉得还不错,给个小小的赞。

交流

Github地址:https://github.com/781238222/flutter-do

170+组件详细用法:http://laomengit.com

如果你对Flutter还有疑问或者技术方面的疑惑,欢迎加入Flutter交流群(微信:laomengit)。

同时也欢迎关注我的Flutter公众号【老孟程序员】,公众号首发Flutter的相关内容。

Flutter生态建设离不开你我他,需要大家共同的努力,点赞也是其中的一种,如果文章帮助到了你,希望点个赞。

Flutter 实现虎牙/斗鱼 弹幕效果相关推荐

  1. 直播代码Flutter 实现虎牙/斗鱼 弹幕效果

    实现原理 弹幕的实现原理非常简单,即将一条弹幕从左侧平移到右侧,当然我们要计算弹幕垂直方向上的偏移,不然所有的弹幕都会在一条直线上,相互覆盖.平移代码如下: @override void initSt ...

  2. flutter 弹幕插件_Flutter 实现虎牙/斗鱼 弹幕效果 | 秒速技术

    老孟导读:用Flutter实现弹幕功能,轻松实现虎牙.斗鱼的弹幕效果. 先来一张效果图: 实现原理 弹幕的实现原理非常简单,即将一条弹幕从左侧平移到右侧,当然我们要计算弹幕垂直方向上的偏移,不然所有的 ...

  3. java 弹幕 原理_Flutter 实现虎牙/斗鱼 弹幕效果

    老孟导读:用Flutter实现弹幕功能,轻松实现虎牙.斗鱼的弹幕效果. 先来一张效果图: 实现原理 弹幕的实现原理非常简单,即将一条弹幕从左侧平移到右侧,当然我们要计算弹幕垂直方向上的偏移,不然所有的 ...

  4. flutter 弹幕插件_Flutter 实现虎牙/斗鱼 弹幕功能

    用Flutter实现弹幕功能,轻松实现虎牙.斗鱼的弹幕效果. 先来一张效果图: 实现原理 弹幕的实现原理非常简单,即将一条弹幕从左侧平移到右侧,当然我们要计算弹幕垂直方向上的偏移,不然所有的弹幕都会在 ...

  5. Android弹幕功能实现,模仿斗鱼直播的弹幕效果

    转载请注明出处:http://blog.csdn.net/sinyu890807/article/details/51933728 本文同步发表于我的微信公众号,扫一扫文章底部的二维码或在微信搜索 郭 ...

  6. Android弹幕功能实现,模仿斗鱼直播的弹幕效果,跪了

    | View.SYSTEM_UI_FLAG_LAYOUT_FULLSCREEN | View.SYSTEM_UI_FLAG_HIDE_NAVIGATION | View.SYSTEM_UI_FLAG_ ...

  7. Android仿斗鱼直播的弹幕效果

    今天,我就带着大家一起来实现一个简单的Android端弹幕效果. 分析 首先我们来看一下斗鱼上的弹幕效果,如下图所示: 这是一个Dota2游戏直播的界面,我们可以看到,在游戏界面的上方有很多的弹幕,看 ...

  8. 仿斗鱼直播的弹幕效果实现

    今日科技快讯 这两天最大的科技新闻莫过于神舟十一号升空了.10月17日上午7点30分,神舟十一号于酒泉卫星发射中心顺利发射,航天员由景海鹏和陈冬二人组成.神舟十一号将会先和天宫二号完成对接,形成组合体 ...

  9. html弹幕效果加入视频,JS实现的视频弹幕效果示例

    本文实例讲述了JS实现的视频弹幕效果.分享给大家供大家参考,具体如下: 斗鱼弹幕 html,body{font-size:10px;overflow:hidden;margin:0;padding:0 ...

最新文章

  1. 怎么修改网页服务器数据库连接,如何修改网页服务器数据库连接
  2. 数据库优化(学习笔记)
  3. 最新最全GPT-3模型网络结构详细解析
  4. Focal Loss笔记
  5. 【技术原创】MailEnable开发指南
  6. Nginx 内置绑定变量的介绍
  7. 欠条和借条傻傻分不清?小心借出的钱要不回!
  8. 【渝粤题库】陕西师范大学209013 计量经济学 作业
  9. IDEA快捷键的使用成就手速之旅(要想手速变得快,快捷练习必须刚)
  10. 深入理解es module
  11. linux查看nec进程状态,【linux】 /proc/PID/stat
  12. C#泛型-小心使用静态成员变量
  13. startallback怎么用_startallback使用教程
  14. aria2Android服务器教程,Aria2自动更新BT Tracker服务器列表的方法
  15. 分享一个蛋白互作网站——String (一)
  16. 二维码收款系统即时到账个人码免签支付平台
  17. 对标RTX 3060,英特尔独显或将迎来第一波主流游戏玩家
  18. 不应忘却的纪念-小百合(Lilybbs)
  19. clip_gradient_norms()
  20. python显示血量条,利用Python绘制血药浓度-时间曲线——口服吸收一室模型

热门文章

  1. 关于高并发的一些解决办法(转载)
  2. 07_openstack之安全组与浮动IP
  3. Android黑名单来电管理
  4. uint8array 转buffer
  5. MATLAB图表样式设置
  6. 浅谈MVC三层架构(通俗易懂)
  7. 基于MATLAB的数字图像处理仿真软件
  8. git cherry-pick is a merge but no -m option was given.
  9. java代码获得公网ip_一、java获取公网ip和本地ip
  10. softmax函数的正推原理——softmax前世今生系列(1)