Android 使用easeui 3.0 集成环信即时通信 我踩过的坑

0、关于注冊帐号就不用说了。

一、建立应用、获取appkey

0、建立应用java

建立应用

一、填写信息android

填写信息

二、获取appkey数据库

获取appkey

二、集成

0、首先新建一个projectmarkdown

一、这里主要介绍使用easeui来集成环信的即时通信功能,需要下载sdkapp

下载android sdk
easeui的位置

二、把easeui当作依赖导入到project其中。而后创建依赖关系curl

创建依赖关系

3在导入以后可能会出现的问题:
3.0ide

<uses-permission android:name="android.permission.ACCESS_MOCK_LACATTON>

这个权限报错,在咨询官方技术以后,获得的答复是,可以去掉该权限。详细的权限信息可以參考demo中的权限。布局


3.1 因为easeui里边包括v4包,致使V4包冲突,但是在删除掉项目的V4包以后。仍是报错。缘由是在project里边包括v7包,而v7包又包括v4。因此仍是会报错。
报错信息例如如下:post

这里写图片描写叙述

開始觉得是jdk的缘由。但是在查阅资料以后发现是包冲突的问题,解决方式:
解决:把项目中的v7删掉,而后把easeui里边的V4删掉,而后在easeui里边加入v7包。这样就不会报错了。ui

四、环境信息配置:

4.0:在AndroidManifest.xml文件里加入一下权限:

需要的权限

4.1:配置环信key

配置环信key

4.2初始化:这里写最简单的,其它的像好友验证等功能參考demo

这里写图片描写叙述

4.3 .0在easeui使用中,涉及到百度地图,在此需要自行到百度地图官网建立应用,申请appkey:
详细配置例如如下(在此处仅仅需要填写appkey,不需要初始化):

这里写图片描写叙述

4.3.1:在发送图片的时候可能会有看大图、查看地图的功能,在easeui中提提供了这些activity。咱们仅仅需要在本身的清单文件里注冊一下。详细代码例如如下:

这里写图片描写叙述

三、使用

在此处略过文档上有的登陆注冊功能。

在此介绍部分可能会有坑的地方。


注意:0、注冊功能通常需要server来实现;一、在使用初始化的时候。easeui默认有本身主动登陆功能,使用时需要注意,假设需要关闭此功能,在初始化部分加入例如如下代码:
//去取消本身主动登陆
options.setAutoLogin(false);

0、easeui 适配android6.0:
在下载好的demo中,找到runtimepermissions目录,(详细路径看图)。而后在MainActivity中加入一下代码(看图)

这里写图片描写叙述

在MainActivity中加入例如如下代码

一、在消息监听中如需需要查看有没有走到这里。不要使用Toast来验证,因为在监听中属于子线程。
二、使用到的头像、用户名这些信息。建议把头像的url和用户昵称存在本地数据库,这样不用每次都去后台取(取后台取的话,可能会出现一闪一闪的状况),假设用户信息发生变化了。可以让后台给发一个透传消息,而后去更新数据库里边的数据。
三、关于消息的置顶和取消置顶,可以经过扩展消息来实现,在环信里边,每一个消息可以附加扩展消息,咱们可以在扩展消息里边加一个属性,而后在设置适配器的时候依据这个属性去实现置顶,在发送消息的时候要给每一个置顶的会话中的消息,都附加上该扩展属性。
四、关于群聊天的禁言。可以在进入去聊天的时候先推断本身的禁言状态,而后当被禁言和被取消禁言的时候,让后台给发一个透传消息,来解决问题。


五、关于设置圆形头像,需要在布局文件里使用本身定义view去替换easeui中的ImageView;

六、本身定义消息列表,最后一条消息假设是表情,就加上这一句。就可以把最后表情表现出来了。

holder.messages_text.setText( EaseSmileUtils.getSmiledText(context, EaseCommonUtils
.getMessageDigest(listEMConversation.get(position).getLastMessage(), context)),BufferType.SPANNA
BLE);

位置:

if (listEMConversation.get(position).getLastMessage().getType() == EMMessage.Type.LOCATION) {
            holder.messages_text.setText("[位置]");
}

七、本身给本身发一条消息

// 删除和某个user会话,假设需要保留聊天记录。传false\
EMClient.getInstance().chatManager()
.deleteConversation(username, true);\
// 接收到好友请求 而后建立一个会话 加入一个扩展消息
EMMessage emMessage = EMMessage
.createReceiveMessage(EMMessage.Type.CMD);
emMessage.setFrom(username);//发送人
emMessage.addBody(new EMTextMessageBody("我请求加入您为好友"));//建立消息
emMessage.setUnread(true);//是否已读
emMessage.setChatType(EMMessage.ChatType.Chat);//聊天类型
emMessage.setMsgTime(System.currentTimeMillis());//消息时间
emMessage.setAttribute("messagetype", "FriendInvitation");//扩展消息
emMessage.setTo(PublicStaticData.prefreences.getString("ueserid", ""));//发送给
EMClient.getInstance().chatManager().saveMessage(emMessage);本身给本身发一条消息

八、本身定义消息条目,假设需要实现像QQ聊天页面的分享,就需要本身去定义一个这种条目的布局。额。不正确,因该是两个。一个接收的一个发送的。而后easeui给提供了一个接口(EaseCustomChatRowProvider),我们去实现这个接口接可以了。


关键代码例如如下:
8.0首先去写本身定义的条目数量(在需要的数量上*2。一个接收的,一个发送的)

定义接收和发送的消息类型

8.1去实现三个方法:

getCustomChatRowTypeCount() getCustomChatRowType(EMMessage message) getCustomChatRow(EMMessage message, intposition,BaseAdapter adapter)

getCustomChatRowType

在此方法中可以利用消息的扩展消息来实现,咱们先推断扩展消息的内容。而后去分别载入不一样的布局。

getCustomChatRow

去建立不一样的条目

本身定义条目代码例如如下(你们可以參照easeui自带的条目样式去实现,此处提供EaseChatRowPic.java代码)

importandroid.content.Context; importandroid.text.Spannable; importandroid.view.View; importandroid.widget.BaseAdapter; importandroid.widget.ImageView; importandroid.widget.TextView; importandroid.widget.TextView.BufferType; importcom.hyphenate.chat.EMClient; importcom.hyphenate.chat.EMMessage; importcom.hyphenate.chat.EMMessage.ChatType; importcom.hyphenate.easeui.R; importcom.hyphenate.easeui.publicData.StaticData; importcom.hyphenate.easeui.utils.EaseSmileUtils; importcom.hyphenate.exceptions.HyphenateException; importcom.lidroid.xutils.BitmapUtils; public classEaseChatRowOnePicextendsEaseChatRow { privateTextViewtitle; privateImageViewimg1; privateTextViewcontent; publicEaseChatRowOnePic(Contextcontext,EMMessage message, intposition,BaseAdapter adapter) { super(context,message,position,adapter); } @Override protected voidonInflatView() { inflater.inflate(message.direct() == EMMessage.Direct.RECEIVE?

R.layout.myease_row_received_picture2: R.layout.myease_row_sent_picture2, this); } @Override protected voidonFindViewById() { title= (TextView) findViewById(R.id.myease2_received_title); content= (TextView) findViewById(R.id.myease2_received_content); img1= (ImageView) findViewById(R.id.myease2_received_image132); } @Override public voidonSetUpView() { // 设置内容 String titleString =""; String contentString =""; String picurlString =""; //设置标题 try{ titleString =message.getStringAttribute("EXT_TITLE"); contentString =message.getStringAttribute("EXT_DETAIL"); picurlString =message.getStringAttribute("EXT_IMG1"); }catch(HyphenateException e) { e.printStackTrace(); } Spannable span; span = EaseSmileUtils.getSmiledText(context,titleString); title.setText(span,BufferType.SPANNABLE); //设置内容 span = EaseSmileUtils.getSmiledText(context,contentString); content.setText(span,BufferType.SPANNABLE); if(!picurlString.equals("")) { //设置图片 BitmapUtils bitmapUtils =newBitmapUtils(getContext(),StaticData.picpath); bitmapUtils.display(img1,picurlString); } handleTextMessage(); } protected voidhandleTextMessage() { if(message.direct() == EMMessage.Direct.SEND) { setMessageSendCallback(); switch(message.status()) { caseCREATE: progressBar.setVisibility(View.GONE); statusView.setVisibility(View.VISIBLE); // 发送消息 break; caseSUCCESS:// 发送成功 progressBar.setVisibility(View.GONE); statusView.setVisibility(View.GONE); break; caseFAIL:// 发送失败 progressBar.setVisibility(View.GONE); statusView.setVisibility(View.VISIBLE); break; caseINPROGRESS:// 发送中 progressBar.setVisibility(View.VISIBLE); statusView.setVisibility(View.GONE); break; default: break; } }else{ if(!message.isAcked() &&message.getChatType() == ChatType.Chat) { try{ EMClient.getInstance().chatManager().ackMessageRead(message.getFrom(),message.getMsgId()); }catch(HyphenateException e) { e.printStackTrace(); } } } } @Override protected voidonUpdateView() { adapter.notifyDataSetChanged(); } @Override protected voidonBubbleClick() {} }

使用:在fragment所在的activity中,设置聊天页面的属性,代码例如如下:
这里写图片描写叙述

使用本身定义的条目。假设小伙伴们没有看明确,就去看一下这个详细的介绍。

easeui本身定义消息布局

九、聊天界面的启动模式 使用singleTask 假设有界面反复跳转。就会出现页面跳转。


十、在集成easeui以后。发现一个问题。可能会出现在有些版本号的手机上一点桌面的图标,程序崩溃的状况,解决方式例如如下:
在libs下建立一个armeabi-v7a,将armeabi中的so在v7a复制一份。兼容不少其它版本号的手机。

解决点击图标崩溃问题

十一、 发现在聊天页面的语音播放功能不能使用,没有点击播放的效果,找了很久的缘由。

发现在进入聊天的fragment以前设置了点击头像的属性。

。。真是个坑,花了半天时间。。

messageList.setItemClickListener(new EaseChatMessageList.MessageListItemClickListener() {
                    @Override
                    public void onUserAvatarClick(String username) {
                        System.err.println("点击头像");
                        // 头像点击事件
                        PublicStaticData.thisFriendsId = Long
                                .parseLong(username);
                        System.err.println("username:"+Long.parseLong(username));
                        Intent intent = new Intent(XingActivity_01.this,
                                ShejiaoFriendDetailsActivity.class);
                        startActivity(intent);
                    }
                    @Override
                    public void onResendClick(final EMMessage message) {
                        // 重发消息button点击事件
                    }
                    @Override
                    public void onBubbleLongClick(EMMessage message) {
                        // 气泡框长按事件
                    }
                    @Override
                    public boolean onBubbleClick(EMMessage message) {
                        // 气泡框点击事件,EaseUI有默认实现这个事件。假设需要覆盖,return值要返回true
                        //注意这里。必定要返回false,不然点击事件就会覆盖了
                        return false;
                    }
                    @Override
                    public void onUserAvatarLongClick(String username) {
                        // TODO Auto-generated method stub
                    }
                });

消息的点击事件

好了,easeui部分就分享到这里。

但愿能帮你解决一部分坑。

谢谢。

文/李清Lin(简书做者)
原文连接:http://www.jianshu.com/p/fa36152f1d57# 著做权归做者所有,转载请联系做者得到受权,并标注“简书做者”。

相关文章
相关标签/搜索