服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Android - Flutter 实现虎牙/斗鱼 弹幕功能

Flutter 实现虎牙/斗鱼 弹幕功能

2022-12-09 13:39老孟程序员 Android

这篇文章主要介绍了Flutter 实现虎牙/斗鱼 弹幕功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

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

先来一张效果图:

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();
}

@override
 Widget 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),
);

效果如下:

Flutter 实现虎牙/斗鱼 弹幕功能

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

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

效果如下:

Flutter 实现虎牙/斗鱼 弹幕功能

给文字加个圆角背景:

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),
 ),
 ),
);

效果如下:

Flutter 实现虎牙/斗鱼 弹幕功能

创建一个送火箭的弹幕:

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),
  ),
  ],
 ),
 ),
);

效果如下:

Flutter 实现虎牙/斗鱼 弹幕功能

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

其实实现弹幕效果没有我开始想的那么简单,过程中也遇到了一些问题,不过好在最终都解决了,献上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 实现虎牙斗鱼 弹幕内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/mengqd/archive/2020/04/13/12694159.html

延伸 · 阅读

精彩推荐
  • Android更新您的 Widget 以适配 Android 12

    更新您的 Widget 以适配 Android 12

    很长一段时间来,微件 (widget) 一直是 Android 用户体验的核心组成部分,很多应用通过微件来提升用户黏度。用户乐于使用微件的原因是可以在不打开应用的...

    Android 开发者7692021-09-06
  • AndroidAndroid如何实现社交应用中的评论与回复功能详解

    Android如何实现社交应用中的评论与回复功能详解

    目前,各种App的社区或者用户晒照片、发说说的地方,都提供了评论功能,为了更好地学习,自己把这个功能实现了一下,下面这篇文章主要给大家介绍了...

    水月沐风7272022-03-09
  • AndroidAndroid实现热门标签的流式布局

    Android实现热门标签的流式布局

    这篇文章主要介绍了Android实现热门标签的流式布局的详细方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    ok53543712021-04-26
  • Android详解android.mk中引用第三方库的方法

    详解android.mk中引用第三方库的方法

    本篇文章主要介绍了详解android.mk中引用第三方库的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧...

    JNI10602022-02-16
  • AndroidAndroid实现离线缓存的方法

    Android实现离线缓存的方法

    离线缓存就是在网络畅通的情况下将从服务器收到的数据保存到本地,当网络断开之后直接读取本地文件中的数据。本文给大家介绍Android实现离线缓存的方...

    Leo.Han4042021-06-28
  • AndroidAndroid Studio 配置:自定义头部代码注释及添加模版方式

    Android Studio 配置:自定义头部代码注释及添加模版方式

    这篇文章主要介绍了Android Studio 配置:自定义头部代码注释及添加模版方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧...

    合抱之木,生于毫末,九层9242022-11-25
  • AndroidAndroid 测试入门篇

    Android 测试入门篇

    Android本身是一套软件堆叠(Software Stack),或者成为软件叠层架构,叠层主要分成三层:操作系统、中间件和应用程序...

    Android开发网5622021-02-28
  • AndroidAndroid开发笔记之:Handler Runnable与Thread的区别详解

    Android开发笔记之:Handler Runnable与Thread的区别详解

    本篇文章是对在Android中Handler Runnable与Thread的区别进行了详细的分析介绍,需要的朋友参考下...

    Android开发网4952021-01-20