Android集成腾讯云IM(中篇)

       上篇简单的讲述了云通信IM的集成;本篇将着重从代码上分析客户端获取消息基本的实现方法、自定义消息、发送emoji等;

       本篇将以我的项目为例来分析。废话不多说,直接上代码!

一、android端获取消息基本流程:

(一)会话列表页面获取消息;(MessageFragment)

1、MessageFragment需要实现ConversationView类;

Android集成腾讯云IM(中篇)_第1张图片
ConversationView接口

这个接口TIM的demo已经帮我们封装好了,在viewfeatures目录下,大家自行查阅;备注已经说得很明白,只需集成该类,在对应的方法中,实现消息的获取,刷新,删除等操作;

ConversationPresenter  presenter=new  ConversationPresenter(this);

presenter.getConversation(); 

接下来看看ConversationPresenter类,这是一个实现被观察者模式的类;这里就不截图了,demo里已经将这类封装好了。大家只需要知道,getConversation()方法会调用initview(),会获取所有的消息数据;这个时候大家可以根据自己的需求,对消息列表数据进行处理,包括头像、昵称;对指定发送者的消息进行屏蔽等等;具体方法相信大家能够足以解决,不细说。基本上就这个地方需要重点看看,其他地方可以copy demo里的代码;

2、ChatActivity单聊页面;demo中基本上功能已经帮我们实现了,而且已经帮我们处理了6.0以上运行时权限;但7.0以上并没有处理;所以需要大家自行处理一下

Android集成腾讯云IM(中篇)_第2张图片
7.0以上系统获取uri,使用fileprovider
Android集成腾讯云IM(中篇)_第3张图片
更改获取文件路径的办法

其他的demo中已经替我们处理了;至于小视频和文件上传,此项目未使用故直接屏蔽掉了;

再就是消息的收发,demo已经封装好了;主要就是使用了chatPresenter类需要实现chatview,重写对应方法即可,不细说!再接下来就是自定义消息

二、自定义消息

首先,大家可以自行研究一下封装好的代码,所有的消息都是继承自父类Message,然后再根据判断收发不同的消息类型使用对应的消息类型来加载不同布局。

云通信IM提供了一个类专门让我们来处理自定义消息——CustomeMessage;下面将以本项目中使用到的商品详情类消息为例:

需求:商品详情页面点击客服图标,跳转到单聊页面(chatActivity),当然得携带展示所需要的参数。

第一步还是得在customMessage中添加type:

Android集成腾讯云IM(中篇)_第4张图片
添加自定义消息的类型

先看跳转到聊天页面后,对intent进行判断处理:

Intent intent = getIntent();

if(intent ==null)return;

bundle= intent.getBundleExtra("bundle");

identify=bundle.getString("identify");                      //聊天对象的id

faceUrl=bundle.getString("faceUrl");                      //聊天对象的头像路径

shopName=bundle.getString("shopName");         //店铺名称

shopId=bundle.getString("shop_id","");                 //店铺的id

type= (TIMConversationType)bundle.getSerializable("type");                //聊天类型——枚举类型(目前都是C2C单聊模式)

fromType=bundle.getInt("fromType",FROM_DEFAULT);                        //来源类型

ImGoodsInfoBean goodsInfoBean = (ImGoodsInfoBean)bundle.getSerializable("goodsInfo");                    //封装好的商品消息,实体类

sendGoodsInfoMsg(goodsInfoBean);                      //发送商品类消息

Android集成腾讯云IM(中篇)_第5张图片
发送商品类消息

首先构造方法中,给消息赋值(其中info是一个json语句转成的string,里面包含所需要展示的字段):

Android集成腾讯云IM(中篇)_第6张图片
自定义消息的构造方法

那么接下来就是解析消息,展示消息了;重写showMessage(),根据不同的消息类型来填充不同的布局,并展示:

Android集成腾讯云IM(中篇)_第7张图片
将商品类型的布局填充进去,并展示

以上就是,我记得的步骤了!大致就是这样的!oh,不对,那个chatActivity的showMessage中也需要做一下处理,比较简单,就不贴出来了!

三、讲讲云通信IM的emoji表情吧!

想到这,我只能感叹,腾讯的android大神们,能否给我一份清晰度高一点emoji图,这个要求很过分么?提工单,让提供清晰点的,居然回复暂不支持。我已无力吐槽,大公司就是任性!!!

第一步:导入新的emoji表情资源,注意很多腾讯云服务端解析不了,所以请大家慎重找图;(PS:目前我也没找到非常合适的emoji图片资源,若谁有合适资源,也望大家能得以告知,感谢先!)

在demo的工具类中找到EmoticonUtil类,导入新的emoji图片资源id,存放在数组中,方便调用,并且对应的描述也得匹配;

Android集成腾讯云IM(中篇)_第8张图片
emoji表情资源id数组
Android集成腾讯云IM(中篇)_第9张图片
对应描述数组

然后在chatInPut控件类中修改prepareEmoticon方法:

Android集成腾讯云IM(中篇)_第10张图片
prepareEmoticon方法

这里面主要是将图片资源读取出来,然后压缩展示出来;压缩方法如下:

Android集成腾讯云IM(中篇)_第11张图片
Android集成腾讯云IM(中篇)_第12张图片

然后在textmessage(主要用于读取和解析文本消息和带有emoji的消息)中修改读取消息方法

Android集成腾讯云IM(中篇)_第13张图片
Android集成腾讯云IM(中篇)_第14张图片

这样发送和显示我们emoji表情,就可以了;但是,可能会出现有些资源服务器和ios解析出问题,所以,大家导入emoji资源时要慎重;

上述内容,可能有些许不完善的地方,仅供参考!!!

你可能感兴趣的:(Android集成腾讯云IM(中篇))