android 斗鱼礼物动画,GitHub - Yuphee/RewardLayout: 仿斗鱼直播送礼物和连击效果动画...
RewardLayout
仿斗鱼送礼物效果
本项目旨在提供实现参考,交流学习。
关于我,欢迎关注
有问题及时issue pr 或 email
如果对你有点帮助的话,点个star哦~
Screenshots
效果展示:
Getting started
Add it in your root build.gradle at the end of repositories:
allprojects {
repositories {
...
maven { url "https://jitpack.io" }
}
}
Add the dependency
dependencies {
implementation 'com.github.Yuphee:RewardLayout:1.0.6.4'
}
Apk
Statement
1.关于直播间布局
可以采用Activity+LiveFragment+ContainnerDialogFragment(Viewpager(EmptyFragment+LayerFragment));不一定要用DialogFragment,如果想上下滑流畅还是得用普通的Fragment
如果需要上下滑动切换直播间,可以套上verticalviewpager,可以参考我的另一个关于兼容上下左右滑动的Viewpager项目Bidirectio也可以是其它的VerticalViewpager,直播页单独在LiveFragment实现,HorizontalViewpager覆盖在LiveFragment之上,HorizontalViewpager中包含2个Fragment,一个是空的透明页,用于左右滑动实现沉浸式效果,另一个则是遮罩层,包含用户列表,头像,评论,礼物布局等一些悬浮在直播TextureView之上的布局
2.关于RewardLayout
可自定义礼物item布局,动画,最大条数,每种礼物持续时间,继承BaseGiftBean实现自定义的SendGiftBean,并实现相应接口方法,可轻松实现自定义的效果;最大礼物数可在xml上指定或者代码直接定义,其它参数可以在自定义SendGiftBean中指定,具体接入请参考demo
3.实践
本库用在项目《椰趣》中,可以自行到各大应用市场下载体验
Fast review
Activity
// 可以由服务器返回json解析得到
bean1 = new SendGiftBean(1,1,"林喵喵","糖果",R.mipmap.tg,2700);
bean2 = new SendGiftBean(2,2,"马甲","666",R.mipmap.good,3000);
bean3 = new SendGiftBean(3,3,"小梦梦","小香蕉",R.mipmap.banana,2500);
bean4 = new SendGiftBean(4,4,"大枫哥","鱼丸",R.mipmap.yw,2000);
bean5 = new SendGiftBean(4,1,"大枫哥","糖果",R.mipmap.tg,2700);
rewardLayout.setGiftAdapter(new RewardLayout.GiftAdapter() {
@Override
public View onInit(View view, SendGiftBean bean) {
//参考demo
return view
}
@Override
public View onUpdate(View view, SendGiftBean o,SendGiftBean t) {
//参考demo
o返回的数据对象为Rewardlayout内部存储过的该礼物的数据对象,t返回的对象为每次put进去的新对象
return view;
}
@Override
public void addAnim(final View view) {
//参考demo
}
@Override
public AnimationSet outAnim() {
return AnimUtils.getOutAnimation(MainActivity.this);
}
//判断礼物唯一性
@Override
public boolean checkUnique(SendGiftBean o, SendGiftBean t) {
return o.getTheGiftId() == t.getTheGiftId() && o.getTheUserId() == t.getTheUserId();
}
//礼物展示结束,可能由于送礼者过多,轨道被替换导致结束
@Override
public void onKickEnd(SendGiftBean bean) {
Log.e("zyf", "onKickEnd:" + bean.getTheGiftId() + "," + bean.getGiftName() + "," + bean.getUserName() + "," + bean.getTheGiftCount());
}
//礼物连击结束,即被系统自动清理时回调
@Override
public void onComboEnd(SendGiftBean bean) {
Log.e("zyf","onComboEnd:"+bean.getTheGiftId()+","+bean.getGiftName()+","+bean.getUserName()+","+bean.getTheGiftCount());
}
@Override
public SendGiftBean generateBean(SendGiftBean bean) {
try {
return (SendGiftBean) bean.clone();
} catch (CloneNotSupportedException e) {
e.printStackTrace();
}
return null;
}
});
@Override
protected void onPause() {
super.onPause();
if(rewardLayout != null) {
rewardLayout.onPause();
}
}
@Override
protected void onResume() {
super.onResume();
if(rewardLayout != null) {
rewardLayout.onResume();
}
}
@Override
protected void onDestroy() {
super.onDestroy();
if(rewardLayout != null) {
rewardLayout.onDestroy();
}
}
Just call ->
rewardLayout.put(bean1);
//手动刷新礼物过期时间,防止被礼物回收线程回收,可用于其它需要增加礼物停留时间的需求。
rewardLayout.updateRefreshTime(bean1,2000);
XML
android:id="@+id/llgiftcontent"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="100dp"
android:animateLayoutChanges="true"
app:max_gift="3"
app:gift_item_layout="@layout/gift_animation_item"
android:orientation="vertical" />
Todo
支持更多礼物替换规则(如贵重礼物展示优先,总价值礼物展示优先,最近最新优先,组合策略等)
Fixed
v1.0 已改进不同礼物消失机制,采用postHandler及removeCallbacks去更新和执行删除时机,可以通过config自定义每种礼物不同的持续时间,同时已优化不同人对同种礼物的区分
v1.1 修复快速送礼物重复问题,调整postDelay为ScheduledExecutorService去定时清除到期礼物,调整数据结构,用户自定义数据对象需继承BaseGiftBean并实现相应接口,取消GiftConfig配置
v1.2 增加礼物LinkedBlockingQueue队列,支持高并发礼物赠送,程序模拟礼物赠送确保礼物都能够被展现,修复部分bug
v1.3 生成lib库,gradle直接集成
v1.4 必须继承BaseGiftBean改为实现GiftIdentify接口,修复内存泄漏,礼物唯一条件判断由用户实现
v1.5 解决相同礼物单次赠送数目变化问题,修复其它问题
v1.5.1 降低礼物库的最低sdk版本至19
v1.5.2 修复内存泄漏
v1.5.4 增加送礼轨道被踢回调及系统判定结束连击回调
v1.5.8 增加手动刷新礼物过期时间
v1.6.0 minsdk降为14,修改某些代码
v1.6.1 修改礼物更新回调,返回新添加进去的礼物对象,tag更新内部完成,如需要更新原已展示对象的数据需自行手动更新
v1.6.2 修复礼物轨道概率不消失问题 见 issue#6
v1.6.3 修复轨道礼物消失时赠送同一种礼物,礼物轨道不显示问题
Thanks
感谢许同学提供的切图
赞赏
如果对大佬有用的话,赏杯下午茶吧。
赞赏鸣谢
磊
大不六
android 斗鱼礼物动画,GitHub - Yuphee/RewardLayout: 仿斗鱼直播送礼物和连击效果动画...相关推荐
- android 斗鱼礼物动画,GitHub - zy841336855/RewardLayout: 仿斗鱼直播送礼物和连击效果动画...
RewardLayout 仿斗鱼送礼物效果 本项目旨在提供实现参考,交流学习. 关于我,欢迎关注 有问题及时issue pr 或 email 如果对你有点帮助的话,点个star哦~ Screensho ...
- android动画送礼物,Android开发仿映客送礼物效果
这里写链接内容仿映客送小礼物的特效,顺便复习一下属性动画,话不多说先看效果图. 需求分析 可以看到整个动画有几部分组成,那我们就把每个部分拆分出来各个击破. 1.要显示那些内容以及内容间的位置关系? ...
- Android 调用12306接口,GitHub - AndroidyxChen/loading-12306: 仿PC端12306的刷新loading的自定义view...
loading-12306 仿PC端12306的刷新loading的自定义view 效果图: 核心代码及实现逻辑如下: mPaint.setColor(mColor); mPaint.setTextS ...
- Android-直播送礼物 仿斗鱼直播送礼物效果
20221031-181814 直接源码地址: 下载地址
- Android 每周一个小轮子之 学习仿网易云广场歌单的效果
这一篇Blog是学习自:Android自定义ViewGroup第十三式之移花接木 小缘老哥太顶了,写的东西都巨棒,关注Ta很久了,我决定向他学习,学着去像他那样思考问题. 建议各位老哥都去关注他! 这 ...
- Android 每周一个小轮子之 学习仿网易云广场歌单的效果
/** 这里要自己写一个ViewGroup的LayoutParams来记录 scale.alpha.from.to */ class RikkaLayoutParams extends MarginL ...
- 斗鱼直播flash怎么切换html5,GitHub - spacemeowx2/DouyuHTML5Player: 替换斗鱼的Flash弹幕播放器...
斗鱼HTML5播放器 基于 flv.js 的斗鱼HTML5播放器. 使用了 flv.js 内核提供的直播流播放, 用 JavaScript 实现了斗鱼的弹幕协议, 并支持发送弹幕和送礼物. 使用 不要 ...
- 斗鱼直播切换html5播放器,GitHub - gooyie/DouyuHTML5Player: 替换斗鱼的Flash弹幕播放器...
斗鱼HTML5播放器 基于 flv.js 的斗鱼HTML5播放器. 使用了 flv.js 内核提供的直播流播放, 用 JavaScript 实现了斗鱼的弹幕协议, 并支持发送弹幕和送礼物. 使用 不要 ...
- Android 仿斗鱼、映客 礼物打赏,包括连击、追加等功能
Android 仿斗鱼.映客 礼物打赏 公司之前需要对直播功能添加打赏模块,我把自己的方法以及参考的demo分享出来. 参考demo:https://github.com/Qiang3570/Liv ...
最新文章
- 北师大计算机网络原理和应用作业,北师大网络作业计算机组成原理 作业一(可编辑)...
- mysql的limit性能优化
- java中的易混问题收集
- 单片机裸机实用组件--LED
- C++命名空间namespace
- 量子计算入门-第二部分
- 利用Python实现用户群组分析!
- .NET Core 使用 Consul 服务注册发现
- [游戏开发-学习笔记]菜鸟慢慢飞(14)- ScrollView刷新
- 如何快速上手一个项目
- 用代码来理解 C#委托与事件
- openstack service glance-api/registry mysql of max_connection
- Ubuntu部署KVM服务器
- OpenCV的二值化处理函数threshold()详解
- tomcat启动过程报the JDBC Driver has been forcibly unregistered问题的修复过程
- 车牌识别系统原理及代码【YOLO+MLP】
- linux中vim编译器中复制粘贴,编辑器 - 如何从(并复制到)系统剪贴板进行vim粘贴?...
- CVPR 2019 论文汇总(按方向划分,0506 更新中)
- STM32学习笔记---触摸屏
- HDMI转换芯片——MS1858