Android Firebase Messaging:如何从onMessageReceived()

时间:2017-03-31 12:16:55

标签: android android-activity firebase firebase-notifications

我已在我的应用中成功实施了Firebase消息传递。在后台工作得很好,当应用程序在前台时,会调用onMessageReceived()(yippee!)。

我遇到的问题是我需要动态更新UI,并且我仍然坚持实现这一目标的最佳方法。我不想向用户发送应用程序内通知(如示例代码所示),我不确定是否要发送广播,我想要做的就是访问MainActivity以调用方法已经存在,但是我没有参考服务中的MainActivity。

@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
    if (remoteMessage.getNotification().getBody() != null) {
        Log.d(LOG_TAG, "Message received: " + remoteMessage.getNotification().getBody());
    } else {
        Log.d(LOG_TAG, "Message received: " + remoteMessage.getData().get("message"));
    }

    // Call method in MainActivity
    // <<< What goes Here?>>>>

}

这似乎是一个简单的用例,但我无法在网上找到任何帮助。

提前致谢

2 个答案:

答案 0 :(得分:13)

是的,您可以使用本地广播

更新用户界面并将价值传递给您的活动

onMessageReceived() Firebase服务中。

broadcaster = LocalBroadcastManager.getInstance(getBaseContext());

   Intent intent = new Intent(REQUEST_ACCEPT);
   intent.putExtra("Key", value);
   intent.putExtra("key", value);
   broadcaster.sendBroadcast(intent);

并在Activity或片段方法中注册本地广播

 @Override
    public void onStart() {
        super.onStart();
        LocalBroadcastManager.getInstance(getActivity()).registerReceiver((receiver),
                new IntentFilter(PushNotificationService.REQUEST_ACCEPT)
        );
    }



    @Override
        public void onStop() {
             super.onStop();
LocalBroadcastManager.getInstance(getActivity()).unregisterReceiver(receiver);

        }

并处理这样的更新事件,更新UI工作在这里,它会在收到通知时自动调用,而onMessageReceived()会发送广播。

receiver = new BroadcastReceiver() {
            @Override
            public void onReceive(Context context, Intent intent) {
                try {
                    String   value= intent.getStringExtra("key");
                    String value= intent.getStringExtra("key");

                } catch (Exception e) {
                    e.printStackTrace();
                }

            }
        };

答案 1 :(得分:1)

我相信您应该发送带有数据的本地广播,并在您想要使用数据的任何地方注册接收器。这是一个非常好的设计模式(Observer),因为它将Activity与服务分离。

如果活动想要对数据做一些事情,那么它就不会。它们都是独立的实体,据我所知,将来维护这些代码要容易得多。

希望这会有所帮助。