Flutter 實現(xiàn)虎牙/斗魚 彈幕功能
用Flutter實現(xiàn)彈幕功能,輕松實現(xiàn)虎牙、斗魚的彈幕效果。
先來一張效果圖:

實現(xiàn)原理
彈幕的實現(xiàn)原理非常簡單,即將一條彈幕從左側平移到右側,當然我們要計算彈幕垂直方向上的偏移,不然所有的彈幕都會在一條直線上,相互覆蓋。平移代碼如下:
@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;
}
這些準備好后,就是創(chuàng)建一條彈幕了,現(xiàn)創(chuàng)建一條最簡單的文字彈幕:
Text( text, style: TextStyle(color: Colors.white), );
效果如下:

創(chuàng)建一條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), ), ), );
效果如下:

創(chuàng)建一個送火箭的彈幕:
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),
),
],
),
),
);
效果如下:

火箭有點丑了,不過這不是重點。
其實實現(xiàn)彈幕效果沒有我開始想的那么簡單,過程中也遇到了一些問題,不過好在最終都解決了,獻上Github地址:https://github.com/781238222/flutter-do/tree/master/flutter_barrage_sample
如果覺得還不錯,給個小小的贊。
交流
Github地址:https://github.com/781238222/flutter-do
170+組件詳細用法:http://laomengit.com
總結
到此這篇關于Flutter 實現(xiàn)虎牙/斗魚 彈幕功能的文章就介紹到這了,更多相關Flutter 實現(xiàn)虎牙斗魚 彈幕內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Android 狀態(tài)欄虛擬導航鍵透明效果的實現(xiàn)方法
這篇文章主要介紹了Android 狀態(tài)欄虛擬導航鍵透明效果的實現(xiàn)方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-03-03
Android使用ViewPager實現(xiàn)滾動廣告
這篇文章主要為大家詳細介紹了Android使用ViewPager實現(xiàn)滾動廣告,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-11-11
Android編程實現(xiàn)在Activity中操作刷新另外一個Activity數(shù)據(jù)列表的方法
這篇文章主要介紹了Android編程實現(xiàn)在Activity中操作刷新另外一個Activity數(shù)據(jù)列表的方法,結合具體實例形式分析了2種常用的Activity交互實現(xiàn)技巧,需要的朋友可以參考下2017-06-06
Android實現(xiàn)動態(tài)自動匹配輸入內容功能
這篇文章主要為大家詳細介紹了Android實現(xiàn)動態(tài)自動匹配輸入內容功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
淺談Android Studio導出javadoc文檔操作及問題的解決
這篇文章主要介紹了淺談Android Studio導出javadoc文檔操作及問題的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-03-03

