废话不多说,先上效果图

下面来实现

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,集成环信实现简单聊天功能相关推荐

  1. Android Studio 4.0 集成环信sdk EaseUI全纪录

    因为B站尚硅谷Android视频教程<硅谷社交_项目实战>BV1cW411V7yd中的聊天室项目产生兴趣,所以想跟着写一下,但是众多观众在P6:集成环信sdk及EaseUI时遭遇挫折 网上 ...

  2. php 环信easyui_php集成环信IM即时通讯系统(大致流程方法)

    很多场景需要用到即时通讯,独立开发成本太高,选择第三方比较合适,就使用过的环信做一个大致流程介绍,不评价好坏 1,注册环信即时通讯云账号:官网.然后登录后台创建应用 注:开放注册是指不需要管理员授权同 ...

  3. 最新Android集成环信步骤详解

    前一阵时间一直以为环信不能被个人用户注册,结果现在想试试结果真的注册进来了,各种打脸.今天趁着晚上有时间把环信继承的步骤做一个记录,方便以后的童鞋们能够快速的集成. 1.第一步:肯定是创建应用喽 那么 ...

  4. 环信IM SDK使用(一):集成环信SDK及注意事项

    环信IM SDK可以帮助用户快速开发IM相关的应用.如何快速集成环信IM SDK呢? 首先附上环信官网的集成SDK的文档:Android SDK 介绍及导入 一.集成环信IM SDK 1.申请环信Ap ...

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

    0.关于注冊账号就不用说了. 1.创建应用.获取appkey 0.创建应用 1.填写信息 2.获取appkey 2.集成 0.首先新建一个project 1.这里主要介绍使用easeui来集成环信的即 ...

  6. Android集成环信easeui,设置圆形头像,修改气泡和扩展栏,跳过打包冲突

    初次集成环信的话还是有很多坑的, 我也是个新手,技术客服各种问,各种找人,才堪堪摸到门槛,记录下一点东西,希望给那些初次集成的朋友一点tips. 1,集成环信的时候,如果你不需要很多如视频聊天,等的功 ...

  7. 【快速搞定】教你如何快速集成环信(android端EaseUI),跳过我踩过的坑

    [快速搞定]教你如何快速集成环信(android端EaseUI),跳过我踩过的坑 一.前言 最近,公司准备集成一个即时通讯的功能,于是我找到了环信,于是我就这样被坑了,于是就有了本文来教大家如何跳出我 ...

  8. 李洪强iOS开发本人集成环信的经验总结_01环信SDK的导入

    李洪强iOS开发本人集成环信的经验总结_01环信SDK的导入 01 - 直接在项目中导入SDK和一些静态库 这个时候,没有错误的编译没有错误的话,就说明SDK已经配置成功 还有一种方法是用cocoap ...

  9. 环信是否支持html,VUE项目集成环信WebIM即时通信以及所遇到的问题

    功能背景: 以前和朋友一块儿作了一个wbe项目集成环信的即时通讯的功能,作的时候感叹web端文档太少,并且npm包有一些坑,记录下来写了这篇博客,以后不断有人加我微信问我,怎么集成.如今我再来重写一下 ...

最新文章

  1. ElasticSearch_查询过滤排序
  2. JNDI数据源的连接属性
  3. spring boot应用启动原理分析
  4. HighNewTech之5G网络:带你了解5G网络的前世今生—两张长图帮你捋清思路
  5. 官宣|Apache Flink 1.13.0 正式发布,流处理应用更加简单高效!
  6. 通电后第一次开机黑屏_电脑无法开机怎么办,8 种情况的修复方法
  7. (转)SQL 优化原则
  8. MySQL数据存储目录查找
  9. 《上海堡垒》改编电影发布 QQ阅读披露作者江南心声
  10. php里面用魔术方法和匿名函数闭包函数动态的给类里面添加方法
  11. JavaScript 模拟重载
  12. C#开源爬虫NCrawler源代码解读以及将其移植到python3.2(3)
  13. 大厂对学历的要求是什么?如果学历不够,有这些补救的办法!
  14. U牌“唤醒生命,未来可7”
  15. python学习之 re库 正则表达式
  16. soi cmos技术及其应用_航空制造业的激光焊接技术及其应用
  17. SecureFX之激活教程
  18. 通俗理解kaggle比赛大杀器xgboost
  19. unescape,escape加密解密js
  20. 洛谷P2489 [SDOI2011]迷宫探险

热门文章

  1. 谷歌又在开发新AI框架!这次瞄准的是:通用人工智能(AGI)
  2. 如何删除tmp计算机桌面,win10系统下tmp临时文件删除不了如何解决
  3. 手把手教你制作油管上30万播放的动态登录页面效果
  4. HTML音频:音乐播放网页
  5. 2021-05-12 MongoDB面试题 应该启动一个集群分片(sharded)还是一个非集群分片的 MongoDB 环境
  6. uwb室内定位应用DW1000 TWR测距
  7. 红帽linux7.2安装教程,RHEL 6.2安装(超级详细图解教程) | 系统运维
  8. 供应链管理的五大策略
  9. 剑指 Offer 05. 替换空格(完整代码)
  10. FileZilla软件的下载、服务器站点配置与数据传输方法