在即时通讯中需要不断接收服务端的消息。

JMessage提供了Event来匹配本地和服务端的消息接收。

在即时通讯项目中需要大量用到消息接收事件。所以结合项目简单分析下其实现的原理和过程。

#####事件接收类的注册

JMessageClient.registerEventReceiver(Object receiver);
JMessageClient.registerEventReceiver(Object receiver, int priority);

参数说明
Object receiver 消息接收类对象
int priority 定义事件接收者接收事件的优先级,默认值为0,优先级越高将越先接收到事件。(优先级只对同一个线程模式中的接收者有效)
#####事件接收类的解绑

JMessageClient.unRegisterEventReceiver(Object receiver);

#####事件接收
注册事件接收类之后,需要在消息接收类中实现如下方法来接收对应消息。sdk将根据实现方法的方法名来区分不同的线程模式,常用的线程模式有onEvent(默认线程模式)和onEventMainThread(主线程模式)两种。
可以通过定义不同类型的参数,来接收不同种类的事件
1、默认线程(子线程)模式

public void onEvent(EventEntity event){
  //do your own business
}

方法体将在默认线程(子线程)中被调用, 可以用来处理耗时操作。
参数定义
EventEntity event 事件对象。( 定义不同类型参数可以接收不同种类事件,具体用法可以参考“示例代码“。)
2、主线程模式

public void onEventMainThread(EventEntity event){
  //do your own business
}

#####源码
跟踪进入注册事件,发现其实注册事件是通过EventBus来完成

    public static void registerEventReceiver(Object var0, int var1) {
        if(var0 != null) {
            if(!EventBus.getDefault().isRegistered(var0)) {
                EventBus.getDefault().register(var0, var1);
            } else {
                j.h(TAG, z[19] + var0);
            }
        } else {
            j.j(TAG, z[20]);
        }
    }

    public static void unRegisterEventReceiver(Object var0) {
        if(var0 != null) {
            EventBus.getDefault().unregister(var0);
        } else {
            j.j(TAG, z[20]);
        }
    }

#####那么EventBus到底是个什么东西?

GreenDao和EventBus同属于一个开发者。
但是EventBus在GitHub的订阅量是GreenDao的两倍之多。可见应用之广泛,已经使用过GreenDao的开发者相信已经体会到了他的强大。

关于EventBus:

Android优化的事件总线,简化了活动,片段,线程,服务等之间的通信。较少的代码,更好的质量。

null

同样在JMessage中,也使用了EventBus作为事件接收的方法。

按照EventBus的使用方法,必须要做的三件事就是:
定义事件、消息订阅者、发送事件。

1、定义事件

用于消息的解析或者也可以说是消息的事件分类。
JMessage中已经定义了好了多个消息事件,用于即时通讯的事件处理。所以我们只需要去理解和应用。

常用的有:

  • MessageEvent 消息事件
  • MessageRetractEvent 撤回消息事件
  • ContactNotifyEvent 好友通知事件
  • ConversationRefreshEvent 消息漫游事件
  • OfflineMessageEvent 离线消息事件

定义消息示例代码:

public class MessageRetractEvent {
    private Conversation conversation;
    private Message message;

    public MessageRetractEvent(Conversation var1, Message var2) {
        this.message = var2;
        this.conversation = var1;
    }

    public Conversation getConversation() {
        return this.conversation;
    }

    public Message getRetractedMessage() {
        return this.message;
    }
}

2、 消息订阅者

在任何收到任何消息,并且想要对消息做处理之前,都需要先注册消息事件,
一般是在生命周期开始的地方注册,在结束的地方销毁。
这里用的方法都是JMessage封装后的,原始请参考EventBus官方文档
比如:

public void onStart() {
    super.onStart();
    //注册
    JMessageClient.registerEventReceiver(this);
}

        @Override
    protected void onDestroy() {
    super.onDestroy();
    //销毁
    JMessageClient.unRegisterEventReceiver(this);
    }

订阅者还需要一个消息接收的方法,用来匹配接收事件,所有的消息的操作都必须在注册了接收事件之后。

方法名是自定义的,在使用的时候要注意方法名的匹配,否则无法接收到消息。

在3.0以后使用了注解的方式,3.0之前必须要以onEvent为开头定义类。
所以从JMessage的方法定义来看,显然不是最新的。
建议在自己项目中使用的最新的EventBus

// 主线程
@Subscribe(threadMode = ThreadMode.MAIN)
public void onEventMainThread(MessageEvent event) {
    Toast.makeText(getActivity(), event.message, Toast.LENGTH_SHORT).show();
}

// 子线程
@Subscribe
public void onEvent(SomeOtherEvent event) {
    doSomethingWith(event);
}

3、发布者

如果直接使用EventBus,虽然能实现消息发送,但是对于复杂的消息分类无法区分,并且消息对话需要依赖服务端的实现。

EventBus.getDefault().post(new MessageEvent(0,"",message1));

所以只能用

JMessageClient.sendMessage(message1);
其它应用

上面只是对于在即时通讯中结合JMessage来简单了解EventBus的消息传递。

其他应用的地方还有:

  • 用于线程间的通讯代替handler或用于组件间的通讯代替Intent
  • 广泛用于团购,商城,社交等应用,比如易大师APP,易宸锋Application...
                                      ---------------来自百度百科

项目中引入EventBus的方法:

compile 'org.greenrobot:eventbus:3.0.0'

然后可以参照上面的使用步骤进行测试。


项目地址:https://github.com/wapchief/Android-IM

相关文章推荐