EventBus3.0Demo 一处发送多处接收,post和postSticky的比较

先上效果图。
1.主界面发送消息给主界面和二界面(postSticky方式发送)
这里写图片描述
2.主界面和二界面两处接受主界面发送的消息
这里写图片描述
这里写图片描述
3.从主界面先跳到一节面,在一界面发送消息(post方式发送),在主界面和一界面本身接收
这里写图片描述
在一界面和主界面接收
这里写图片描述
这里写图片描述

好了效果图展示完,开始上代码和踩过的坑,希望对后来这有点用(至于EventBus3.0和之前的2.7啥的区别,去看鸿洋大神的博客去~)

MainActiviy中发送消息 (注意postSticky发送,不然二界面中接收不到消息)

public class MainActivity extends AppCompatActivity implements View.OnClickListener {

    private TextView tv_message;
    private Button toFirst;
    private Button sendMessage;
    private Button toSecond;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        tv_message = (TextView) this.findViewById(R.id.tv_show_result_main);
        tv_message.setText("MainActivity");
        sendMessage = (Button) this.findViewById(R.id.btn_main_sendMessage);
        toFirst = (Button) this.findViewById(R.id.btn_main_toFirst);
        toSecond = (Button) this.findViewById(R.id.btn_main_toSecond);
        sendMessage.setOnClickListener(this);
        toFirst.setOnClickListener(this);
        toSecond.setOnClickListener(this);
        EventBus.getDefault().register(this);
    }

    //处理事件
    @Subscribe(threadMode = ThreadMode.MAIN)
    public void onMoonEvent(MessageEvent messageEvent) {
        tv_message.setText(messageEvent.getNumber());
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();

    }

    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.btn_main_sendMessage:
                //发送消息
                String json = "老司机,开车了~快上车~";
                EventBus.getDefault().postSticky(new MessageEvent(json));
                break;
            case R.id.btn_main_toFirst:
                startActivity(new Intent(MainActivity.this, Show1Activity.class));
                break;
            case R.id.btn_main_toSecond:
                startActivity(new Intent(MainActivity.this, Show2Activity.class));
                break;
            default:
                break;
        }

    }
}

对应的布局
activity_main.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    >

    <TextView
        android:id="@+id/tv_show_result_main"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="显示数据" />

    <Button
        android:id="@+id/btn_main_sendMessage"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="发送消息" />

    <Button
        android:id="@+id/btn_main_toFirst"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="去一界面" />

    <Button
        android:id="@+id/btn_main_toSecond"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="去二界面" />
</LinearLayout>

在二界面中接收消息
Show2Activity

public class Show2Activity extends AppCompatActivity {

    private TextView result2;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_show2);
        result2 = (TextView) findViewById(R.id.tv_show_result2);
        //注册订阅者
        EventBus.getDefault().register(this);
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        //取消注册
        EventBus.getDefault().unregister(this);
    }

    //处理粘性消息
    @Subscribe(threadMode = ThreadMode.MAIN,sticky = true)
    public void onMoonEvent(MessageEvent messageEvent) {
        result2.setText(messageEvent.getNumber());
    }
}

对应的布局 activity_show2.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    >

    <TextView
        android:id="@+id/tv_show_result2"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="原始数据2" />

</LinearLayout>

跳到Show1Activity中发送消息,在主界面和一界面接收。 注意此处使用的post的方式发送的。为确保在mainActivity中能收到消息。mainActivity开启模式为 singleTask或者,singleInstancce,确保回去看到mainActivity为同一个实例。才能接收到消息。不然你就抓头想咋回事,咋有没有收到消息呢?。。。。。。。。。(其他人的demo回传消息的时候是把本身activity杀死了,直接回到了前面的MainActivity,还是保证是同一示例对象~~~)

Show1Activity

public class Show1Activity extends AppCompatActivity implements View.OnClickListener {

    private TextView result1;
    private Button sendBack;
    private Button back;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_show);
        result1 = (TextView) findViewById(R.id.tv_show_result1);
        sendBack = (Button) findViewById(R.id.btn_result1_send);
        sendBack.setOnClickListener(this);
        back = (Button) findViewById(R.id.btn_result1_back);
        back.setOnClickListener(this);
        //注册事件
        EventBus.getDefault().register(this);
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        //取消注册
        EventBus.getDefault().unregister(this);
    }

    //设置订阅者
    @Subscribe(threadMode = ThreadMode.MAIN)
    public void onMoonEvent(MessageEvent messageEvent) {
        result1.setText(messageEvent.getNumber());
    }


    @Override
    public void onClick(View v) {
        switch (v.getId()) {
            case R.id.btn_result1_send:
                EventBus.getDefault().post(new MessageEvent("我是天王老子,我怕啥~"));
//                finish();
                break;
            case R.id.btn_result1_back:
                startActivity(new Intent(this, MainActivity.class));
                break;
            default:
                break;

        }
    }
}

对应的布局
activity_show.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".Show1Activity">

    <TextView
        android:id="@+id/tv_show_result1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="原始数据1" />

    <Button
        android:id="@+id/btn_result1_send"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="发送消息回主界面" />

    <Button
        android:id="@+id/btn_result1_back"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="回到Main页" />

</LinearLayout>

写就写这些了,自己好好体会,post和postSticky的区别吧~还是参考鸿洋大神的博客去吧· 还不能实现的就来找我要Demo例子吧。要的留言,留QQ。留。。。。 额,其他的啥都别留了~

  • 7
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
EventBus是一种用于Android应用程序中发布/订阅事件的库。它遵循发布-订阅模式,允许不同组件之间进行松散耦合的通信。 在基于EventBus 3.0的APP开发中,你可以按照以下步骤进行: 1. 添加EventBus依赖 在项目的build.gradle文件中添加以下代码: ``` dependencies { implementation 'org.greenrobot:eventbus:3.2.0' } ``` 2. 创建事件类 创建一个事件类,它将包含你需要发送接收的数据。例如: ``` public class MessageEvent { public final String message; public MessageEvent(String message) { this.message = message; } } ``` 3. 注册订阅者 在需要接收事件的组件中,注册订阅者。例如,在Activity中: ``` @Override public void onStart() { super.onStart(); EventBus.getDefault().register(this); } @Override public void onStop() { EventBus.getDefault().unregister(this); super.onStop(); } ``` 4. 发布事件 在需要发送事件的组件中,发布事件。例如,在Activity中: ``` EventBus.getDefault().post(new MessageEvent("Hello, world!")); ``` 5. 理事件 在订阅者中,创建一个方法来接收到的事件。例如,在Activity中: ``` @Subscribe(threadMode = ThreadMode.MAIN) public void onMessageEvent(MessageEvent event) { // Do something with the event Toast.makeText(this, event.message, Toast.LENGTH_SHORT).show(); } ``` 以上就是基于EventBus 3.0的APP开发的基本步骤。通过使用EventBus,你可以轻松地在不同组件之间传递数据,从而实现应用程序中的松散耦合通信。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值