Метод вызова в запущенном действии из службы
в настоящее время я работаю на Android-проекта.
до сих пор я реализовал Firebase, в частности FirebaseInstanceIdService и FirebaseMessagingService:
public class FirebaseIDService extends FirebaseInstanceIdService {
private static final String TAG = "FirebaseIDService";
private Context context;
@Override
public void onTokenRefresh() {
context = getApplicationContext();
// Get updated InstanceID token.
String refreshedToken = FirebaseInstanceId.getInstance().getToken();
Log.e(TAG, "Refreshed token: " + refreshedToken);
SharedPreferences sharedPreferences = context.getSharedPreferences("token", context.MODE_PRIVATE);
SharedPreferences.Editor editor = sharedPreferences.edit();
editor.putString("token", refreshedToken);
editor.commit();
sendRegistrationToServer(refreshedToken);
}
/**
* Persist token to backend.
* @param token The new token.
*/
private void sendRegistrationToServer(String token) {
SendRegistrationKey task = new SendRegistrationKey(context);
task.execute(token);
}
}
public class MessagingService extends FirebaseMessagingService {
private static final String TAG = "MsgService";
/**
* Called when message is received.
*
* @param remoteMessage Object representing the message received from Firebase Cloud Messaging.
*/
@Override
public void onMessageReceived(RemoteMessage remoteMessage) {
Log.e(TAG, "From: " + remoteMessage.getFrom());
// Check if message contains a data payload.
if (remoteMessage.getData().size() > 0) {
Log.e(TAG, "Message data payload: " + remoteMessage.getData());
}
// Check if message contains a notification payload.
if (remoteMessage.getNotification() != null) {
Log.e(TAG, "Message Notification Body: " + remoteMessage.getNotification().getBody());
sendNotification(remoteMessage);
}
// Also if you intend on generating your own notifications as a result of a received FCM
// message, here is where that should be initiated. See sendNotification method below.
}
// [END receive_message]
private void sendNotification(RemoteMessage remoteMessage) {
RemoteMessage.Notification notification = remoteMessage.getNotification();
PushNotificationManager PNManager = PushNotificationManager.getInstance(getApplicationContext());
PNManager.buildNotification(notification.getTitle(), notification.getBody());
}
чего я хочу добиться следующим образом:
когда приложение находится в фоновом режиме, я просто хочу простого уведомления в Центре уведомлений. (Это уже работает)
но, когда приложение находится в на переднем плане и в настоящее время работает, я хочу иметь другое поведение: Я хочу использовать push-уведомления и показывать предупреждение.
но мой вопрос: как я могу взаимодействовать с запущенной деятельностью из службы или каков правильный способ достижения предполагаемого поведения? Там должно быть простое soultion, верно?
спасибо заранее
4 ответов
напишите этот код в классе приложений
public Context currentactvity = null;
public Context getCurrentactvity() {
return currentactvity;
}
public void setCurrentactvity(Context currentactvity) {
this.currentactvity = currentactvity;
}
напишите этот код в каждом методе onResume действия и в методе onpause установите null
// in onresume
MyApplication.getInstance().setCurrentactvity(this);
// in onpause
MyApplication.getInstance().setCurrentactvity(null);
Теперь вы можете вызвать метод действия из класса службы
if (MyApplication.getInstance().getCurrentactvity() != null && MyApplication.getInstance().getCurrentactvity() instanceof youractivityname) {
((youractivityname) MyApplication.getInstance().getCurrentactvity()).youmethodname(parameter);
}
как я могу взаимодействовать с запущенной деятельностью из службы или каков правильный способ достижения предполагаемого поведения?
лучшим способом было бы просто использовать шину событий (т. е. GreenRobot-х или местный эфир). Ваша активность регистрирует слушателя в onResume()
(и отменяет регистрацию в onPause()
) и ваш сервис просто передает сообщение, когда придет время.
основным преимуществом является то, что вы держите оба элемента (услуги и деятельность) полностью отделяется. Вы также избегаете наихудшего возможного решения-прямого вызова методов Activity.
чтобы узнать, когда вы находитесь в фоновом режиме или нет, лучше всего использовать приложение GreenRobot-хActivityLifecycleCallbacks - нет смысла заставлять деятельность сообщать, что, поскольку нет никакой пользы от этого.
попробуйте с помощью этого:
этот метод проверяет все запущенные приложения и возвращает true или false, находится ли текущее приложение в фоновом режиме или на переднем плане.
public static boolean isAppIsInBackground(Context context) {
boolean isInBackground = true;
ActivityManager am = (ActivityManager) context.getSystemService(Context.ACTIVITY_SERVICE);
if (Build.VERSION.SDK_INT > Build.VERSION_CODES.KITKAT_WATCH) {
List<ActivityManager.RunningAppProcessInfo> runningProcesses = am.getRunningAppProcesses();
for (ActivityManager.RunningAppProcessInfo processInfo : runningProcesses) {
if (processInfo.importance == ActivityManager.RunningAppProcessInfo.IMPORTANCE_FOREGROUND) {
for (String activeProcess : processInfo.pkgList) {
if (activeProcess.equals(context.getPackageName())) {
isInBackground = false;
}
}
}
}
} else {
List<ActivityManager.RunningTaskInfo> taskInfo = am.getRunningTasks(1);
ComponentName componentInfo = taskInfo.get(0).topActivity;
if (componentInfo.getPackageName().equals(context.getPackageName())) {
isInBackground = false;
}
}
return isInBackground;
}
попробовать
1. Регистрация пользовательского широковещательного приемника в вашей деятельности
context.registerReceiver (myBroadcastReceiver, new IntentFilter ("CUSTOM_ACTION"));
private final BroadcastReceiver myBroadcastReceiver = new BroadcastReceiver () {
@Override
public void onReceive (Context context, Intent intent) {
//Do something
}
};
2. отправить трансляцию с вашего сервиса
Intent intent = new Intent ("CUSTOM_ACTION");
context.sendBroadcast (intent)