Notification及监听其点击事件

 //获取NotificationManager实例
        NotificationManager notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
        //点击广播监听
        Intent intentClick = new Intent(this, NotificationBroadcastReceiver.class);
        intentClick.setAction("notification_clicked");
        intentClick.putExtra(NotificationBroadcastReceiver.TYPE, type);
        intentClick.putExtra("MESSAGE","消息");
        PendingIntent pendingIntentClick = PendingIntent.getBroadcast(this, 0, intentClick, PendingIntent.FLAG_ONE_SHOT);
        //cancle广播监听
        Intent intentCancel = new Intent(this, NotificationBroadcastReceiver.class);
        intentCancel.setAction("notification_cancelled");
        intentCancel.putExtra(NotificationBroadcastReceiver.TYPE, type);
        PendingIntent pendingIntentCancel = PendingIntent.getBroadcast(this, 0, intentCancel, PendingIntent.FLAG_ONE_SHOT);

        Uri defaultSoundUri = RingtoneManager.getDefaultUri(RingtoneManager.TYPE_NOTIFICATION);
        NotificationCompat.Builder notificationBuilder = new NotificationCompat.Builder(this)
                .setSmallIcon(R.mipmap.ic_launcher)
                .setContentTitle("通知")
                .setContentText("工单提醒")
                .setSound(defaultSoundUri)
                .setAutoCancel(true) //点击后自动cancle
                .setContentIntent(pendingIntentClick)
                .setDeleteIntent(pendingIntentCancel);

        notificationManager = (NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
        notificationManager.notify(type /* ID of notification */, notificationBuilder.build());  //这就是那个type,相同的update,不同add

自定义NotificationBroadCastReceiver,可通过intent携带数据

public class NotificationBroadcastReceiver extends BroadcastReceiver {

    public static final String TYPE = "type"; //这个type是为了Notification更新信息的,这个不明白的朋友可以去搜搜,很多

    @Override
    public void onReceive(Context context, Intent intent) {
        String action = intent.getAction();
        int type = intent.getIntExtra(TYPE, -1);

        if (type != -1) {
            NotificationManager notificationManager = (NotificationManager) context.getSystemService(Context.NOTIFICATION_SERVICE);
            notificationManager.cancel(type);
        }

        if (action.equals("notification_clicked")) {
            //处理点击事件
            String message = intent.getStringExtra("MESSAGE");
            Toast.makeText(context, "clicked " + message, Toast.LENGTH_LONG).show();
            onClick(context);
        }

        if (action.equals("notification_cancelled")) {
            //处理滑动清除和点击删除事件
            Toast.makeText(context, "cancelled", Toast.LENGTH_LONG).show();
        }
    }
}

点击后的逻辑处理,先判断app是否在前台运行,若是打开相应界面,若不是启动应用

            //启动应用
            Intent launchIntent = context.getPackageManager().
                    getLaunchIntentForPackage("com.example.huaxin.notificationdemo");
            launchIntent.setFlags(
                    Intent.FLAG_ACTIVITY_NEW_TASK | Intent.FLAG_ACTIVITY_RESET_TASK_IF_NEEDED);
            Bundle args = new Bundle();
            context.startActivity(launchIntent);
判断app是否运行在前台方法.........
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在Android中,我们可以使用`NotificationCompat`来创建通知,通知可以根据需要展开或收缩。当通知被展开时,我们可以自定义通知的布局,并添加一些交互式组件,例如按钮、文本框等。 为了监听通知的展开和收缩事件,我们需要使用`NotificationCompat`提供的`setCustomBigContentView()`和`setCustomContentView()`方法,分别设置通知展开和收缩时的自定义布局。然后,我们可以在自定义布局中添加相应的交互式组件,并为其添加监听器。 示例代码: ``` // 创建通知的Builder NotificationCompat.Builder builder = new NotificationCompat.Builder(this, CHANNEL_ID) .setSmallIcon(R.drawable.notification_icon) .setContentTitle("My notification") .setContentText("Hello World!") .setPriority(NotificationCompat.PRIORITY_DEFAULT) .setAutoCancel(true); // 创建通知展开时的自定义布局 RemoteViews expandedView = new RemoteViews(getPackageName(), R.layout.notification_expanded); // 添加监听器 expandedView.setOnClickPendingIntent(R.id.button1, pendingIntent1); expandedView.setOnClickPendingIntent(R.id.button2, pendingIntent2); // 设置通知展开时的自定义布局 builder.setCustomBigContentView(expandedView); // 创建通知收缩时的自定义布局 RemoteViews collapsedView = new RemoteViews(getPackageName(), R.layout.notification_collapsed); // 添加监听器 collapsedView.setOnClickPendingIntent(R.id.button, pendingIntent); // 设置通知收缩时的自定义布局 builder.setCustomContentView(collapsedView); // 发送通知 NotificationManagerCompat notificationManager = NotificationManagerCompat.from(this); notificationManager.notify(notificationId, builder.build()); ``` 在上面的代码中,我们创建了一个通知的Builder,并设置了通知展开和收缩时的自定义布局。为了监听自定义布局中的按钮点击事件,我们使用`setOnClickPendingIntent()`方法为按钮添加了相应的`PendingIntent`。当用户点击按钮时,相应的`PendingIntent`会被触发。 需要注意的是,在自定义布局中添加的交互式组件的ID必须与布局文件中定义的ID一致。否则,添加的监听器将不会生效。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值