Android O 前台服务 - 如何处理与活动的通信,即使应用程序被从后台杀死或重新启动
创始人
2024-08-14 21:00:45
0

在 Android O 及更高版本中,应用程序在后台运行时,前台服务需要显示一个通知,以便用户知道服务正在运行。当应用程序被杀死或重新启动时,前台服务需要能够与活动进行通信。以下是一个处理与活动通信的示例:

首先,在 AndroidManifest.xml 文件中声明前台服务:


接下来,创建一个前台服务类 MyForegroundService:

public class MyForegroundService extends Service {
    private static final String CHANNEL_ID = "ForegroundServiceChannel";
    private static final String ACTION_STOP_SERVICE = "StopService";

    private MyBroadcastReceiver receiver;

    @Override
    public void onCreate() {
        super.onCreate();
        receiver = new MyBroadcastReceiver();
        registerReceiver(receiver, new IntentFilter(ACTION_STOP_SERVICE));
    }

    @Override
    public int onStartCommand(Intent intent, int flags, int startId) {
        createNotificationChannel();
        Intent notificationIntent = new Intent(this, MainActivity.class);
        PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, notificationIntent, 0);

        Intent stopIntent = new Intent(this, MyForegroundService.class);
        stopIntent.setAction(ACTION_STOP_SERVICE);
        PendingIntent stopPendingIntent = PendingIntent.getService(this, 0, stopIntent, 0);

        Notification notification = new NotificationCompat.Builder(this, CHANNEL_ID)
                .setContentTitle("Foreground Service")
                .setContentText("Service is running")
                .setSmallIcon(R.drawable.ic_notification)
                .setContentIntent(pendingIntent)
                .addAction(R.drawable.ic_stop, "Stop Service", stopPendingIntent)
                .build();

        startForeground(1, notification);

        // 在此处处理与活动的通信逻辑
        if (intent != null && intent.hasExtra("message")) {
            String message = intent.getStringExtra("message");
            sendMessageToActivity(message);
        }

        return START_NOT_STICKY;
    }

    @Override
    public void onDestroy() {
        super.onDestroy();
        unregisterReceiver(receiver);
    }

    private void createNotificationChannel() {
        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
            NotificationChannel channel = new NotificationChannel(CHANNEL_ID, "Foreground Service Channel",
                    NotificationManager.IMPORTANCE_DEFAULT);
            NotificationManager manager = getSystemService(NotificationManager.class);
            manager.createNotificationChannel(channel);
        }
    }

    private void sendMessageToActivity(String message) {
        Intent intent = new Intent(MainActivity.ACTION_MESSAGE_RECEIVED);
        intent.putExtra("message", message);
        sendBroadcast(intent);
    }

    @Nullable
    @Override
    public IBinder onBind(Intent intent) {
        return null;
    }

    private class MyBroadcastReceiver extends BroadcastReceiver {
        @Override
        public void onReceive(Context context, Intent intent) {
            if (intent.getAction().equals(ACTION_STOP_SERVICE)) {
                stopSelf();
            }
        }
    }
}

在活动 MainActivity 中,你可以接收来自前台服务的广播消息:

public class MainActivity extends AppCompatActivity {
    public static final String ACTION_MESSAGE_RECEIVED = "MessageReceived";
    private MyBroadcastReceiver receiver;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        receiver = new MyBroadcastReceiver();
        registerReceiver(receiver, new IntentFilter(ACTION_MESSAGE_RECEIVED));
    }

    @Override
    protected void onDestroy() {
        super.onDestroy();
        unregisterReceiver(receiver);
    }

    private class MyBroadcastReceiver extends BroadcastReceiver {
        @Override
        public void onReceive(Context context, Intent intent) {
            if (intent.getAction().equals(ACTION_MESSAGE_RECEIVED)) {
                String message = intent.getStringExtra("message");
                // 处理来自前台服务的消息
                Toast.makeText(MainActivity.this, "Received message: " + message, Toast.LENGTH_SHORT).show();
            }
        }
    }
}

这样,你就可以在前台服务中使用 sendMessageToActivity() 方法发送消息,然后在 MainActivity 中接收并处理这些消息了。

相关内容

热门资讯

黑科技脚本!智星德州菠萝有辅助... 黑科技脚本!智星德州菠萝有辅助器吗,哈糖大菠萝怎么拿好牌,从前是真的有挂(2021已更新)-哔哩哔哩...
黑科技安卓版!菠萝德州辅助神器... 黑科技安卓版!菠萝德州辅助神器,德扑之星安卓模拟器,最初有挂(2026已更新)-哔哩哔哩;(需添加指...
黑科技ai!菠萝德州辅助神器,... 黑科技ai!菠萝德州辅助神器,德扑计算软件,总是是有挂(2026已更新)-哔哩哔哩1、不需要AI权限...
黑科技ai代打!红龙扑克辅助器... 黑科技ai代打!红龙扑克辅助器功能,菠萝德州偷偷看功能,原先存在有挂(2026已更新)-哔哩哔哩;红...
黑科技脚本!红龙扑克app辅助... 1、黑科技脚本!红龙扑克app辅助器,cloudpoker外挂,原生是有挂(2026已更新)-哔哩哔...
黑科技真的!红龙扑克辅助工具免... 黑科技真的!红龙扑克辅助工具免费下载,德扑ai智能机器人平台安装,起初真的有挂(2020已更新)-哔...
黑科技安卓版!智星德州菠萝辅助... WePoke高级策略深度解析‌;黑科技安卓版!智星德州菠萝辅助器,推扑克辅助器,果然存在有挂(202...
黑科技软件!红龙扑克辅助,聚星... 黑科技软件!红龙扑克辅助,聚星扑克有没有挂,先前有挂(2023已更新)-哔哩哔哩;原来确实真的有挂(...
黑科技工具!智星德州菠萝辅助器... 1、黑科技工具!智星德州菠萝辅助器免费下载,xpoker透视辅助,先前是真的有挂(2021已更新)-...
黑科技辅助!智星菠萝辅助器,g... 黑科技辅助!智星菠萝辅助器,gg扑克发牌是不是有机制,固有真的是有挂(2022已更新)-哔哩哔哩;智...