Android 仿映客直播间给主播发送礼物(实现连击效果)
效果图
类库的介绍
org.dync.giftlibrary.widget
GiftAnimationUtil.java 动画类
GiftControl.java 给外部调用的类(核心)
GiftFrameLayout.java 礼物布局类
GiftModel.java 给礼物布局填充数据类
以上是礼物动画一(推荐使用礼物动画一,在demo中的Gift1Activity.java使用)LeftGiftControl.java 给外部调用的类(核心)
LeftGiftsItemLayout.java 礼物布局类
GiftModel.java 给礼物布局填充数据类
以上是礼物动画二(可以借鉴,在demo中的Gift2Activity.java使用)
个人建议使用Gift1Activity项目中的库,Gift2Activity项目中的库后面不怎么维护了
1:到GitHub 把项目clone到本地。
2: 把giftlibrary库依赖到你的项目中去
3:在你要显示的xml文件中添加展示礼物和礼物面板的地方 以项目中的activity_gift1.xml为例
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:scaleType="centerCrop"
android:src="@mipmap/ic_bg" />
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="100dp"
android:orientation="vertical">
<org.dync.giftlibrary.widget.GiftFrameLayout
android:id="@+id/gift_layout1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<org.dync.giftlibrary.widget.GiftFrameLayout
android:id="@+id/gift_layout2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
<Button
android:id="@+id/action"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="20dp"
android:text="礼物面板显示/隐藏" />
<LinearLayout
android:id="@+id/bottom"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:orientation="vertical">
<include layout="@layout/chat_tool_box" />
</LinearLayout>
</RelativeLayout>
上面的GiftFrameLayout是展示礼物的控件,我这里仅展示两条,你可以添加多个礼物同时展示,但是你需要GiftControl类中相应的修改代码来实现。同时礼物面板可以使用DialogFragment来替代我这里。
4:在activity中找到控件后就可以初始化礼物模块了。
a.礼物面板。
代码如下:
GiftPanelControl giftPanelControl = new GiftPanelControl(this, mViewpager, mRecyclerView, mDotsLayout);
giftPanelControl.setGiftListener(new GiftPanelControl.GiftListener() {
@Override
public void getGiftStr(String giftStr) {
giftstr = giftStr;
}
});
这里的giftStr参数我传的是资源文件中图片的名称,你也可以传的是图片的id,这里主要是辨别发送的那个礼物。
b.展示礼物
把礼物布局控件传递给礼物控制器
giftControl = new GiftControl(Gift1Activity.this);
giftControl.setGiftLayout(giftFrameLayout1, giftFrameLayout2);
c.显示礼物数量的面板
tvGiftNum.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(final View v) {
showGiftDialog();
}
});
d.礼物面板中发送按钮发送礼物的操作
btnGift.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if (TextUtils.isEmpty(giftstr)) {
Toast.makeText(getApplication(), "你还没选择礼物呢", Toast.LENGTH_SHORT).show();
} else {
String numStr = tvGiftNum.getText().toString();
if (!TextUtils.isEmpty(numStr)) {
int giftnum = Integer.parseInt(numStr);
if (giftnum == 0) {
return;
} else {
giftControl.loadGift(new GiftModel(giftstr, "安卓机器人", giftnum, "http://www.baidu.com", "123", "Lee123", "http://www.baidu.com"));
}
}
}
}
});
e.简单的操作了横竖屏显示不同的面板
在AndroidManifest.xml中给Activity配置
<activity
android:name=".Gift1Activity"
android:configChanges="orientation|keyboardHidden|screenSize" />
然后在Activity重写onConfigurationChanged(Configuration newConfig)方法
@Override
public void onConfigurationChanged(Configuration newConfig) {
super.onConfigurationChanged(newConfig);
if (this.getResources().getConfiguration().orientation == Configuration.ORIENTATION_LANDSCAPE) {// 横屏
// Log.e(TAG, "onConfigurationChanged: " + "横屏");
onConfigurationLandScape();
} else if (this.getResources().getConfiguration().orientation == Configuration.ORIENTATION_PORTRAIT) {
// Log.e(TAG, "onConfigurationChanged: " + "竖屏");
onConfigurationPortrait();
}
}
private void onConfigurationPortrait() {
ll_portrait.setVisibility(View.VISIBLE);
ll_landscape.setVisibility(View.GONE);
}
private void onConfigurationLandScape() {
ll_portrait.setVisibility(View.GONE);
ll_landscape.setVisibility(View.VISIBLE);
}
findViewById(R.id.action).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
if (giftLayout.getVisibility() == View.VISIBLE) {
giftLayout.setVisibility(View.GONE);
} else {
giftLayout.setVisibility(View.VISIBLE);
}
}
});
Android 仿映客直播间给主播发送礼物(实现连击效果)的更多相关文章
- 做一款仿映客的直播App
投稿文章,作者:JIAAIR(GitHub) 一.直播现状简介 1.技术实现层面 技术相对都比较成熟,设备也都支持硬编码.iOS还提供现成的Video ToolBox框架,可以对摄像头和流媒体数据结构 ...
- 做一款仿映客的直播App?看我就够了
来源:JIAAIR 链接:http://www.jianshu.com/p/5b1341e97757 一.直播现状简介 1.技术实现层面: 技术相对都比较成熟,设备也都支持硬编码.IOS还提供现成 ...
- 2019 映客直播java面试笔试题 (含面试题解析)
本人3年开发经验.18年年底开始跑路找工作,在互联网寒冬下成功拿到阿里巴巴.今日头条.映客直播等公司offer,岗位是Java后端开发,最终选择去了映客直播. 面试了很多家公司,感觉大部分公司考察的点 ...
- iOS 动画队列—仿映客刷礼物效果
http://www.cocoachina.com/ios/20160719/17101.html 最近在研究直播的相关知识,在网上看到了不少优秀的开源项目,但都没有看到映客那个刷礼物的效果,于是手痒 ...
- 用scrapy框架爬取映客直播用户头像
1. 创建项目 scrapy startproject yingke cd yingke 2. 创建爬虫 scrapy genspider live 3. 分析http://www.inke.cn/ ...
- 映客直播软开校招岗(go语言)
问题: 笔试: 比较简单,有一道题比较深刻: 内存1G,需要计算1G的数据排序,哪种排序方法效率最低,当时选的是冒泡,因为涉及到频繁的数据交换,其实应该是归并,因为归并不是原地排序,多占用的内存空间, ...
- 一个五年 Android 开发者百度、阿里、聚美、映客的面试心经
花絮 也许会有人感叹某些人的运气比较好,但是他们不曾知道对方吃过多少苦,受过多少委屈.某些时候就是需要我们用心去发现突破点,然后顺势而上,抓住机遇,那么你将会走向另外一条大道,成就另外一个全新的自我. ...
- iOS-实现映客首页TabBar和滑动隐藏NavBar和TabBar
之前在做直播的时候,参照了映客App,发现其首页的效果还挺不错,在网上找了一下相关仿映客App代码和博客,大部分都是说如何播放直播流和推流,对于UI这块甚少,所以我自己花了点时间研究了一下映客的首页U ...
- 从B站、爱奇艺、映客的IPO上市,看国内视频公司的内容审核现状
本文由 网易云发布. 3月30日,中央电视台<经济半小时>栏目讲述了网络上的一个顽症——色情内容.在这期主题为<互联网上的“色诱”>的节目中,央视的记者揭示了色情直播的猖獗. ...
随机推荐
- Android L(5.0)源码之图形与图像处理之绘图——Canvas
最近在研究android 5.0的gallery模块,学习了相关的知识点,准备写点博客总结一下,有时间了会补充完整
- IOS开发之IOS8.0最新UIAlertController 分类: ios技术 2015-01-20 14:24 144人阅读 评论(1) 收藏
最近苹果更新的IOS8 对以前进行了很大的修改, 更新的API也让人捉急,据说iOS 8的新特性之一就是让接口更有适应性.更灵活,因此许多视图控制器的实现方式发生了巨大的变化.比如全新的UIPrese ...
- Android学习笔记--处理UI事件
Handling UI Events 在Android里, 有不只一种方式可以截获用户与你的应用程序交互的事件. 在你的界面上处理事件时,你需要捕获用户与某个View实例交互时所产生的事件.View类 ...
- 解决eclipse报PermGen space异常的问题
开发中遇到Eclipse报错:java.lang.OutOfMemoryError: PermGen space. 网搜到三种解决方法,最终还是第三种方法起了作用.记录日志,备用. 原文地址: htt ...
- linux与windows回车换行符的区别
转自:http://www.cnblogs.com/dartagnan/archive/2010/12/14/2003499.html “回车”(carriage return)VS “换行”(li ...
- 今日头条视频Url嗅探
1.打开http://toutiao.com/a6309254755004875010/,查看网页源代码获取videoid = 0425d8f0c2bb425d9361c0eb2eeb4f16 2.拼 ...
- Xcode 之 snippet 代码重用
1. 选中代码 2. 拖入xcode 右下侧的 snippet 区域 3. 修改名称 4. 修改快捷输入 (shortcut) 5. <#content#> ,可选修改项
- UVa 10720 - Graph Construction
题目大意:给n个整数, 分别代表图中n个顶点的度,判断是否能构成一张图. 看到这个题后,除了所有数之和应该为偶数之外,没有别的想法了,只好在网上搜解题报告了.然后了解了Havel-Hakimi定理.之 ...
- Java获取异常堆栈信息
方法一: public static String getStackTrace(Throwable t) { StringWriter sw = new StringWriter(); PrintWr ...
- nginx集群tomcat
一.准备工作 下载nginx,http://nginx.org/,本文采用nginx-1.8.0,下载之后直接解压,免安装 下载tomcat,以配置3台tomcat服务器做负载均衡为例 二.修改tom ...