android 环信 emmessagelistener,集成环信实现简单聊天功能
废话不多说,先上效果图
下面来实现
1.第一步导入jar or so
去环信下载sdk导入到我们的项目中
导入完成之后我们区项目的build文件中,android括号的最下方加上以下代码
不然jar无法使用
sourceSets {
main {
jniLibs.srcDir 'libs'
}
}
导入完jar包,我们来配置清单中配置环信所需的权限和服务
将以上内容全部添加到配置清单中之后将图中“你的APPK”处替换成你环信应用的APPK,
另外使用之前不要忘记初始化环信SDk哦
EMOptions options = new EMOptions();
options.setAcceptInvitationAlways(false);
EMClient.getInstance().init(this, options);
EMClient.getInstance().setDebugMode(true);
到此,配置和前期工作就做完啦,接下来就是撸码了
2.完善基本功能
首先我们先来写一个登陆页面xml
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main" android:orientation="vertical"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.crackgmkey.chat.LoginActivity">
android:background="@drawable/log_bg" android:layout_marginTop="5dp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/user_et" />
android:background="@drawable/log_bg"
android:layout_width="match_parent" android:layout_marginTop="5dp"
android:layout_height="wrap_content" android:id="@+id/pass_et"/>
android:layout_width="match_parent" android:padding="10dp"
android:layout_height="wrap_content">
android:id="@+id/bt_login" android:background="@drawable/dd_bg"
android:layout_width="0dp" android:text="登录"
android:layout_height="wrap_content" />
android:layout_width="2dp"
android:layout_height="match_parent"/>
android:id="@+id/bt_reg" android:background="@drawable/dd_bg"
android:layout_width="0dp" android:text="注册"
android:layout_height="wrap_content" />
登陆页面已经写好 下面来写代码
贴出LoginActivity的代码
package com.crackgmkey.chat;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;
import com.hyphenate.EMCallBack;
import com.hyphenate.chat.EMClient;
import com.hyphenate.exceptions.HyphenateException;
import rx.Observable;
import rx.Subscriber;
import rx.android.schedulers.AndroidSchedulers;
import rx.functions.Action1;
import rx.schedulers.Schedulers;
public class LoginActivity extends AppCompatActivity implements View.OnClickListener {
private EditText etUser,etPass;//用户名和密码窗口
private Button btReg,btLogin;//登录注册
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.login);
init();
}
//初始化控件
private void init(){
getLoginExit();
etUser = (EditText) findViewById(R.id.user_et);
etPass = (EditText) findViewById(R.id.pass_et);
btReg = (Button) findViewById(R.id.bt_reg);
btLogin = (Button) findViewById(R.id.bt_login);
btReg.setOnClickListener(this);
btLogin.setOnClickListener(this);
}
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.bt_reg:
regUser();
break;
case R.id.bt_login:
login();
break;
}
}
/**
* 注册用户(同步需注意)
*/
private void regUser(){
Observable.create(new Observable.OnSubscribe() {
@Override
public void call(Subscriber super String> subscriber) {
try {
EMClient.getInstance().createAccount(etUser.getText().toString().trim(), etPass.getText().toString().trim());//同步方法
subscriber.onNext("注册成功");
} catch (HyphenateException e) {
e.printStackTrace();
subscriber.onNext("注册失败错误码:"+e.getErrorCode());
}
}
}).subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Action1() {
@Override
public void call(String s) {
Toast.makeText(LoginActivity.this, s, Toast.LENGTH_SHORT).show();
}
});
}
/**
* 登录用户(异步)
*/
private void login(){
final String userName = etUser.getText().toString().trim();
final String password = etPass.getText().toString().trim();
Observable.create(new Observable.OnSubscribe() {
@Override
public void call(final Subscriber super String> subscriber) {
EMClient.getInstance().login(userName,password,new EMCallBack() {//回调
@Override
public void onSuccess() {
EMClient.getInstance().groupManager().loadAllGroups();
EMClient.getInstance().chatManager().loadAllConversations();
startActivity(new Intent(LoginActivity.this,MainActivity.class));
subscriber.onNext("登录聊天服务器成功");
}
@Override
public void onProgress(int progress, String status) {
}
@Override
public void onError(int code, String message) {
subscriber.onNext("登录聊天服务器失败:"+code);
}
});
}
}).subscribeOn(Schedulers.immediate())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(new Action1() {
@Override
public void call(String s) {
Toast.makeText(LoginActivity.this, s, Toast.LENGTH_SHORT).show();
}
});
}
/**
* 退出登录
*/
private void getLoginExit(){
EMClient.getInstance().logout(true, new EMCallBack() {
@Override
public void onSuccess() {
// TODO Auto-generated method stub
}
@Override
public void onProgress(int progress, String status) {
// TODO Auto-generated method stub
}
@Override
public void onError(int code, String message) {
// TODO Auto-generated method stub
}
});
}
}
该页面包含了登陆和注册,在登录成功的时候会跳转到Mainactivity中,接下来我们来写Mainactivity的代码,首先我们先写好布局文件
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.crackgmkey.chat.MainActivity">
android:layout_width="match_parent" android:hint="输入对方用户名" android:layout_marginTop="10dp"
android:layout_height="40dp" android:padding="10dp" android:layout_marginBottom="20dp"/>
android:layout_width="wrap_content" android:text="发起聊天" android:layout_marginLeft="40dp"
android:layout_height="wrap_content" android:background="@drawable/buttonbg" />
android:textColor="@android:color/white"
android:layout_width="wrap_content" android:text="退出登录" android:background="@drawable/buttonbg"
android:layout_height="wrap_content" android:layout_toRightOf="@+id/bt_startChat" />
效果图
很简单,就两个按钮和一个输入框,一个是发起聊天一个是退出登录,点击发起聊天的时候会跳转到一个新的聊天页面,我们来写代码
package com.crackgmkey.chat;
import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import com.hyphenate.EMCallBack;
import com.hyphenate.chat.EMClient;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private EditText etChatId;
private Button btStartChat,btExit;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
init();
}
/**
* 初始化组件
*/
private void init() {
etChatId = (EditText) findViewById(R.id.et_chatId);
btStartChat = (Button) findViewById(R.id.bt_startChat);
btExit = (Button) findViewById(R.id.bt_exit);
btStartChat.setOnClickListener(this);
btExit.setOnClickListener(this);
}
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.bt_exit:
getLoginExit();
break;
case R.id.bt_startChat:
Intent inetent = new Intent(this,UserChatActivity.class);
inetent.putExtra("userid",etChatId.getText().toString());
startActivity(inetent);
break;
}
}
/**
* 退出登录
*/
private void getLoginExit(){
EMClient.getInstance().logout(true, new EMCallBack() {
@Override
public void onSuccess() {
// TODO Auto-generated method stub
}
@Override
public void onProgress(int progress, String status) {
// TODO Auto-generated method stub
}
@Override
public void onError(int code, String message) {
// TODO Auto-generated method stub
}
});
}
}
可以看到代码也是比较简单,只有一个退出的方法和一个跳转的操作,接下来我们来看UserChatActivity的xml布局
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_user_chat"
android:layout_width="match_parent" android:orientation="vertical"
android:layout_height="match_parent"
tools:context="com.crackgmkey.chat.UserChatActivity">
android:layout_width="match_parent" android:layout_above="@+id/messagelay"
android:layout_height="match_parent" />
android:layout_width="match_parent" android:orientation="horizontal"
android:layout_height="wrap_content">
android:layout_width="270dp" android:id="@+id/et_chatmessage"
android:layout_height="40dp" />
android:layout_width="wrap_content" android:layout_toRightOf="@+id/et_chatmessage"
android:layout_height="wrap_content" />
基本就是这个样子,我们来看代码
package com.crackgmkey.chat;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;
import com.hyphenate.EMMessageListener;
import com.hyphenate.chat.EMClient;
import com.hyphenate.chat.EMMessage;
import com.hyphenate.chat.EMTextMessageBody;
import java.util.List;
import rx.Observable;
import rx.functions.Action1;
public class UserChatActivity extends AppCompatActivity implements View.OnClickListener,EMMessageListener {
private TextView tvMessageData;
private EditText etChatmess;
private Button btSent;
private String userId;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_user_chat);
userId = getIntent().getExtras().getString("userid");
init();
EMClient.getInstance().chatManager().addMessageListener(this);
}
/**
* 初始化控件
*/
private void init() {
tvMessageData = (TextView) findViewById(R.id.tv_messagedata);
etChatmess = (EditText) findViewById(R.id.et_chatmessage);
btSent = (Button) findViewById(R.id.bt_sent);
btSent.setOnClickListener(this);
}
@Override
public void onClick(View view) {
switch (view.getId()){
case R.id.bt_sent:
sendMessage();
break;
}
}
/**
* 发送消息
*/
private void sendMessage(){
String messageStr = etChatmess.getText().toString();
EMMessage messagelay = EMMessage.createTxtSendMessage(messageStr,userId);
EMClient.getInstance().chatManager().sendMessage(messagelay);
etChatmess.setText("");
tvMessageData.append("我:"+messageStr+"\n");
}
@Override
public void onMessageReceived(List messages) {
Observable.from(messages).subscribe(new Action1() {
@Override
public void call(EMMessage emMessage) {
EMTextMessageBody emtextmessage = (EMTextMessageBody) emMessage.getBody();
tvMessageData.append(emMessage.getFrom()+":"+emtextmessage.getMessage()+"\n");
}
});
}
@Override
public void onCmdMessageReceived(List messages) {
}
@Override
public void onMessageRead(List messages) {
}
@Override
public void onMessageDelivered(List messages) {
}
@Override
public void onMessageChanged(EMMessage message, Object change) {
}
@Override
protected void onDestroy() {
super.onDestroy();
EMClient.getInstance().chatManager().removeMessageListener(this);
}
}
接收消息的回调是onMessageReceived方法,返回的是一个List,到此基本功能就完成了,具体需求请查看环信官方文档
http://docs.easemob.com/im/200androidclientintegration/10androidsdkimport,写的非常靠谱
最后附上demo下载地址:https://download..net/download/crackgmkey/10644547
android 环信 emmessagelistener,集成环信实现简单聊天功能相关推荐
- Android Studio 4.0 集成环信sdk EaseUI全纪录
因为B站尚硅谷Android视频教程<硅谷社交_项目实战>BV1cW411V7yd中的聊天室项目产生兴趣,所以想跟着写一下,但是众多观众在P6:集成环信sdk及EaseUI时遭遇挫折 网上 ...
- php 环信easyui_php集成环信IM即时通讯系统(大致流程方法)
很多场景需要用到即时通讯,独立开发成本太高,选择第三方比较合适,就使用过的环信做一个大致流程介绍,不评价好坏 1,注册环信即时通讯云账号:官网.然后登录后台创建应用 注:开放注册是指不需要管理员授权同 ...
- 最新Android集成环信步骤详解
前一阵时间一直以为环信不能被个人用户注册,结果现在想试试结果真的注册进来了,各种打脸.今天趁着晚上有时间把环信继承的步骤做一个记录,方便以后的童鞋们能够快速的集成. 1.第一步:肯定是创建应用喽 那么 ...
- 环信IM SDK使用(一):集成环信SDK及注意事项
环信IM SDK可以帮助用户快速开发IM相关的应用.如何快速集成环信IM SDK呢? 首先附上环信官网的集成SDK的文档:Android SDK 介绍及导入 一.集成环信IM SDK 1.申请环信Ap ...
- Android 使用easeui 3.0 集成环信即时通讯 我踩过的坑
0.关于注冊账号就不用说了. 1.创建应用.获取appkey 0.创建应用 1.填写信息 2.获取appkey 2.集成 0.首先新建一个project 1.这里主要介绍使用easeui来集成环信的即 ...
- Android集成环信easeui,设置圆形头像,修改气泡和扩展栏,跳过打包冲突
初次集成环信的话还是有很多坑的, 我也是个新手,技术客服各种问,各种找人,才堪堪摸到门槛,记录下一点东西,希望给那些初次集成的朋友一点tips. 1,集成环信的时候,如果你不需要很多如视频聊天,等的功 ...
- 【快速搞定】教你如何快速集成环信(android端EaseUI),跳过我踩过的坑
[快速搞定]教你如何快速集成环信(android端EaseUI),跳过我踩过的坑 一.前言 最近,公司准备集成一个即时通讯的功能,于是我找到了环信,于是我就这样被坑了,于是就有了本文来教大家如何跳出我 ...
- 李洪强iOS开发本人集成环信的经验总结_01环信SDK的导入
李洪强iOS开发本人集成环信的经验总结_01环信SDK的导入 01 - 直接在项目中导入SDK和一些静态库 这个时候,没有错误的编译没有错误的话,就说明SDK已经配置成功 还有一种方法是用cocoap ...
- 环信是否支持html,VUE项目集成环信WebIM即时通信以及所遇到的问题
功能背景: 以前和朋友一块儿作了一个wbe项目集成环信的即时通讯的功能,作的时候感叹web端文档太少,并且npm包有一些坑,记录下来写了这篇博客,以后不断有人加我微信问我,怎么集成.如今我再来重写一下 ...
最新文章
- Python os库的使用
- 17 个品牌,113 款 5G 手机,5G 离我们越来越近
- [Python]理解 if __name__ == ‘__main__‘
- 释放千行百业数据价值,华为云DAYU有一套
- python连载第12篇 for循环 源码+ 答案
- 重置密码解决MySQL for Linux错误 ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using passwor
- 表达式求值(nyoj305)
- respberry pi VNC 连接设置
- c# 程序调试出现“未在本地计算机上注册“Microsoft.Jet.OLEDB.4.0”提供程序。”...
- Python之numpy模块array简短学习
- Set GlassFish Java EE Application Server Plugin for Eclipse
- 用电池给树莓派供电_3个用于便携式项目的树莓派电池组介绍
- (ISC)² 新增两家 CISSP 官方授权培训合作伙伴
- 2019-2020年目标跟踪论文汇总
- 阿尔伯塔计算机硕士要求,阿尔伯塔大学计算机硕士专业介绍
- 联想x240桌面没有计算机,联想X240笔记本怎样重新安装win7系统-图文教程 - 小众知识...
- 如何打开电脑c语言窗口,C语言控制台窗口图形界面编程(五). -电脑资料
- 字节跳动 Go RPC 框架 KiteX 性能优化实践
- 含并行连结的网络 GoogLeNet / Inception V3 动手学深度学习v2 pytorch
- 更换移动硬盘显示图标