事件总线片段取消注册

时间:2015-07-19 09:42:05

标签: android android-fragments event-bus greenrobot-eventbus

我在事件总线上注册了一个splashscreen Fragment:

@Override
public void onStart() {
    super.onStart();
    EventBus.getDefault().register(this);
}

@Override
public void onStop() {
    EventBus.getDefault().unregister(this);
    super.onStop();
}

如果屏幕进入自动锁定(或任何其他可以调用onStop的事件),则容器活动将进入onStop,并且该片段不再能够接收(网络)事件。我正在考虑移动"取消注册"逻辑到onDestroy 方法。这是个好主意吗?

2 个答案:

答案 0 :(得分:11)

可以将事件总线事件移动到onStart()onStop(),但是你应该知道在onSaveInstanceState()之后无法调用某些方法(例如,解雇DialogFragment会让你崩溃。

因此,虽然这个示例是针对Otto的,但我将其切换到EventBus,我个人有一个包装器,可以在应用程序暂停时存储事件。

public enum SingletonBus {
    INSTANCE;

    private static String TAG = SingletonBus.class.getSimpleName();

    private final Vector<Object> eventQueueBuffer = new Vector<>();

    private boolean paused;

    public <T> void post(final T event) {
            if (paused) {
                eventQueueBuffer.add(event);
            } else {
                EventBus.getDefault().post(event);
            }
    }

    public <T> void register(T subscriber) {
        EventBus.getDefault().register(subscriber);
    }

    public <T> void unregister(T subscriber) {
        EventBus.getDefault().unregister(subscriber);
    }

    public boolean isPaused() {
        return paused;
    }

    public void setPaused(boolean paused) {
        this.paused = paused;
        if (!paused) {
            Iterator<Object> eventIterator = eventQueueBuffer.iterator();
            while (eventIterator.hasNext()) {
                Object event = eventIterator.next();
                post(event);
                eventIterator.remove();
            }
        }
    }
}

然后在各种各样的BaseActivity中

public class BaseActivity extends AppCompatActivity {
     @Override
     public void onPostResume() {
          super.onPostResume();
          SingletonBus.INSTANCE.setPaused(false);
     }

     @Override
     public void onPause() {
          SingletonBus.INSTANCE.setPaused(true);
          super.onPause();
     }
}

答案 1 :(得分:2)

我最近有类似的问题。 首先,我使用Otto然后切换到greenrobot的EventBus。 使用EventBus,您可以注册对象 sticky EventBus.getDefault().registerSticky(this) 也就是说,此对象将自动接收注册后等待的每个粘性事件。然后必须粘贴这些事件。 (EventBus.getDefault().postSticky(event)

如果您不再需要它们,请考虑删除粘性事件 (EventBus.getDefault().removeSticky(Event.class))。 因此,如果您只想在删除它之后才收到此事件。 也许这种方法可能符合您的需求。