双击退出,Notitfcation通知栏的使用

双击退出

当按下BACK键时,会被onKeyDown捕获,判断是BACK键,则执行exit方法。
判断用户两次按键的时间差是否在一个预期值之内,是的话直接退出,不是的话提示用户再按一次后退键退出

@Override
    public boolean onKeyDown(int keyCode, KeyEvent event) {

        if(keyCode==KeyEvent.KEYCODE_BACK){
            /*
            * 如果是按得回退键,提示用户
            * */
            if(System.currentTimeMillis()-time>2000){
                /*
                * 两次按下的时候,在两秒之内*/
                Toast.makeText(this, "在按就退出", Toast.LENGTH_SHORT).show();
                time=System.currentTimeMillis();
                return true;
            }else{
                finish();
            }
        }
        return super.onKeyDown(keyCode, event);
    }

Notitfcation 通知

定义:是在系统的通知栏中呈现多样式持久性消息的类
1.在通知栏显示
2.消息持久性
3.种类多样性
用处:
1.显示客户端的推送消息
2.显示正在进行的事务
3.显示接收到短信息

常用的方法:

在这里插入图片描述

setSmallIcon() 与 setLargeIcon()

当 setSmallIcon() 与 setLargeIcon() 同时存在时, smallIcon 显示在通知的右下角, largeIcon 显示在左侧;当只设置 setSmallIcon() 时, smallIcon 显示在左侧。

在这里插入图片描述
举一个简单的例子

 //创建构造者
        Notification.Builder builder = new Notification.Builder(this);
        builder.setSmallIcon(R.mipmap.ic_launcher);//必须设置
        builder.setContentTitle("通知头");
        builder.setContentText("内容");
        builder.setWhen(System.currentTimeMillis());
        builder.setAutoCancel(true);  //阅读以后,自动消失

        //大图标
        builder.setLargeIcon(BitmapFactory.decodeResource(getResources(),R.mipmap.ic_launcher));

        Notification build = builder.build();
        //通知管理者
        NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
        //发送通知
        //不同id代表发送,相同id代表更新
        manager.notify(1,build);

自定义通知

其实就是加载一个自定义的布局,把想通知的内容展现在布局中。
加载布局用到了RemoteViews
RemoteViews设置的布局文件并不支持所有的View,以下是RemoteViews所支持的View布局:
FrameLayout,LinearLayout,RelativeLayout,GridLayout
支持的组件有:Button,ImageView,ImageButton,TextView,ProgressBar,ListView,GridView,StackView,ViewStub,AdapterViewFlipper,ViewFlipper,AnalogClock,Chronometer

package com.example.day03;

import androidx.appcompat.app.AppCompatActivity;

import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Intent;
import android.graphics.BitmapFactory;
import android.os.Bundle;
import android.view.View;
import android.widget.RemoteViews;

import java.util.Timer;
import java.util.TimerTask;

public class Main2Activity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main2);
    }
     //自定义通知栏
    public void zidignyi(View view) {
        Notification.Builder builder = new Notification.Builder(this);
        builder.setSmallIcon(R.mipmap.ic_launcher);


        //是在系统的通知栏中执行的,所以要远程访问我们的布局文件
        //RemoteViews是可以在别的进程(系统进程)中显示的View,并且提供了一组跨进程更新它界面的操作
        RemoteViews remoteViews = new RemoteViews(getPackageName(),R.layout.notify_layout);
        //加载一个布局文件
        builder.setCustomContentView(remoteViews);

        Notification build =builder.build();
        //通知管理者
        NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
        //发送通知
        //不同id代表发送,相同id代表更新
        manager.notify(1,build);
    }

注意:是在系统的通知栏中执行的,所以要远程访问我们的布局文件,所以要用RemoteViews

进度条通知

在这里插入图片描述

 public void progress_msg(View view) {
        final Notification.Builder builder = new Notification.Builder(this);
        //通知管理者
        final NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
        builder.setSmallIcon(R.mipmap.ic_launcher);
        builder.setContentTitle("通知头");
        builder.setContentText("内容");
        final Timer timer = new Timer();
        timer.schedule(new TimerTask() {
            int index=0;
            @Override
            public void run() {
                index+=10;
                builder.setProgress(100,index,false);//确定的进度条
                manager.notify(1,builder.build());
                if(index>=100){
                    builder.setContentText("正在安装");
                    builder.setProgress(100,index,true);//安装模糊
                    manager.notify(1,builder.build());
                    try {
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    manager.cancel(1);
                    timer.cancel();
                }
            }
        },0,1000);

        Notification build =builder.build();

        //发送通知
        //不同id代表发送,相同id代表更新
        manager.notify(1,build);
    }

通知分组

在这里插入图片描述

将App中的相同类型的信息可以合并

 public void group_notify(View view) {
        NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);

        Notification.Builder builder0 = new Notification.Builder(this);
        builder0.setGroup("2");
        builder0.setSmallIcon(R.mipmap.ic_launcher);
        //被设置setGroupSummary为true的信息为隐藏内容,其内容会显示另外分组成员信息
        builder0.setGroupSummary(true);
        builder0.setContentText("2222222");
        builder0.setContentTitle("111111");

        Notification.Builder builder1 = new Notification.Builder(this);
        builder1.setGroup("2");
        builder1.setSmallIcon(R.mipmap.ic_launcher);
        //被设置setGroupSummary为true的信息为隐藏内容,其内容会显示另外分组成员信息
        //builder1.setGroupSummary(true);
        builder1.setContentText("3333333");
        builder1.setContentTitle("444444");

        Notification.Builder builder2 = new Notification.Builder(this);
        builder2.setGroup("2");
        builder2.setSmallIcon(R.mipmap.ic_launcher);
        //被设置setGroupSummary为true的信息为隐藏内容,其内容会显示另外分组成员信息
        //builder2.setGroupSummary(true);
        builder2.setContentText("5555555");
        builder2.setContentTitle("6666666");
        manager.notify(0,builder0.build());
        manager.notify(1,builder1.build());
        manager.notify(2,builder2.build());


    }

锁屏通知

在android5.0之后,通过可以显示在锁屏上,通过设置选择是否允许敏感的通知内容显示在安全的锁屏上

//创建构建者,然后通过构建者使用方法
//通过 setVisibility() builde.setVisibility(VISIBILITY_PUBLIC).build();

setVisibility()方法共有三个选值:
1.VISIBILITY_PRIVATE : 显示基本信息,如通知的图标,但隐藏通知的全部内容;
2.VISIBILITY_PUBLIC : 显示通知的全部内容;
3.VISIBILITY_SECRET : 不显示任何内容,包括图标。

通知的样式

大图通知和列表通知
列表通知:
在这里插入图片描述

public void list_msg(View view) {
        final Notification.Builder builder = new Notification.Builder(this);
        //通知管理者
        final NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
        builder.setSmallIcon(R.mipmap.ic_launcher);
        //列表通知栏
        Notification.InboxStyle inboxStyle = new Notification.InboxStyle();
        inboxStyle.addLine("hahaha");
        inboxStyle.addLine("hahaha2");
        inboxStyle.addLine("hahaha3");
        builder.setStyle(inboxStyle);

        builder.setPriority(Notification.PRIORITY_MAX);
        builder.setDefaults(Notification.DEFAULT_ALL);


        Notification build =builder.build();

        //发送通知
        //不同id代表发送,相同id代表更新
        manager.notify(1,build);
    }

大图通知:
在这里插入图片描述

public void list_msg(View view) {
        final Notification.Builder builder = new Notification.Builder(this);
        //通知管理者
        final NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
        builder.setSmallIcon(R.mipmap.ic_launcher);

        //大图通知栏
        Notification.BigPictureStyle bigPictureStyle = new Notification.BigPictureStyle();
        bigPictureStyle.bigLargeIcon(BitmapFactory.decodeResource(getResources(),R.mipmap.ic_launcher));
        builder.setStyle(bigPictureStyle);
        builder.setPriority(Notification.PRIORITY_MAX);
        builder.setDefaults(Notification.DEFAULT_ALL);


        Notification build =builder.build();

        //发送通知
        //不同id代表发送,相同id代表更新
        manager.notify(1,build);
    }

设置 Notification 的通知效果 (震动需要真机,模拟机实现不了)

//让通知弹出来
        builder.setPriority(Notification.PRIORITY_MAX);
        //加上震动,灯光,声音
        builder.setDefaults(Notification.DEFAULT_ALL);

在这里插入图片描述

带有交互的通知栏(点击通知实现跳转)

public void btn(View view) {
        //创建构造者
        Notification.Builder builder = new Notification.Builder(this);
        builder.setSmallIcon(R.mipmap.ic_launcher);//必须设置
        builder.setContentTitle("通知头");
        builder.setContentText("内容");
        builder.setWhen(System.currentTimeMillis());
        builder.setAutoCancel(true);  //阅读以后,自动消失

        //让通知弹出来
        builder.setPriority(Notification.PRIORITY_MAX);
        //加上震动,灯光,声音
        builder.setDefaults(Notification.DEFAULT_ALL);

        //intent 页面中跳转问题. PendingIntent
        Intent intent = new Intent(this,MainActivity.class);
        PendingIntent pendingIntent = PendingIntent.getActivity(this,0,intent,0);
        builder.setContentIntent(pendingIntent);

        //大图标
        builder.setLargeIcon(BitmapFactory.decodeResource(getResources(),R.mipmap.ic_launcher));

        Notification build = builder.build();
        //通知管理者
        NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
        //发送通知
        //不同id代表发送,相同id代表更新
        manager.notify(1,build);
    }

PendingIntent

说明
PendingIntent 是一种特殊的 Intent ,字面意思可以解释为延迟的 Intent ,用于在某个事件结束后执行特定的 Action 。从上面带 Action 的通知也能验证这一点,当用户点击通知时,才会执行。
PendingIntent 是 Android 系统管理并持有的用于描述和获取原始数据的对象的标志(引用)。也就是说,即便创建该PendingIntent对象的进程被杀死了,这个PendingItent对象在其他进程中还是可用的。
日常使用中的短信、闹钟等都用到了 PendingIntent

如果当前系统中已经存在一个相同的 PendingIntent 对象,那么就将先将已有的 PendingIntent 取消,然后重新生成一个 PendingIntent 对象。

PendingIntent 具有以下几种 flag:
1.FLAG_CANCEL_CURRENT:
如果当前系统中已经存在一个相同的 PendingIntent 对象,那么就将先将已有的 PendingIntent 取消,然后重新生成一个 PendingIntent 对象。
2.FLAG_NO_CREATE:
如果当前系统中不存在相同的 PendingIntent 对象,系统将不会创建该 PendingIntent 对象而是直接返回 null 。
3.FLAG_ONE_SHOT:
该 PendingIntent 只作用一次。
4.FLAG_UPDATE_CURRENT:
如果系统中已存在该 PendingIntent 对象,那么系统将保留该 PendingIntent 对象,但是会使用新的 Intent 来更新之前 PendingIntent 中的 Intent 对象数据,例如更新 Intent 中的 Extras 。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值