浅谈Service中实现弹出对话框的坑

  • 2020 年 4 月 10 日
  • 笔记

一、手机版本问题,大多数文章没有涉及这个点,导致他们的代码并无法正常使用

M版本以上需要使用的Type–> TYPE_APPLICATION_OVERLAY

AlertDialog.Builder builder=new AlertDialog.Builder(getApplicationContext());  builder.setTitle("提示");  builder.setMessage("service弹框");  builder.setNegativeButton("明白了",null);  Dialog dialog=builder.create();    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M){//6.0            dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY);          }else {            dialog.getWindow().setType(WindowManager.LayoutParams.TYPE_SYSTEM_ALERT);          }  dialog.show();

同时,因为涉及不同版本的Android系统

AndroidManifest.xml 中声明同时需要这两个类型对应的权限

    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW"/>      <uses-permission android:name="android.permission.SYSTEM_OVERLAY_WINDOW" />

二、权限问题,service中弹出的对话框为系统弹框,在M版本以上需要申请悬浮窗权限

Android 6.0 以前悬浮窗是默认允许的

注意Android 6.0以后的使用

因为悬浮窗权限 SYSTEM_ALERT_WINDOW 属于特殊权限 ,需要自己特别单独申请

特殊权限,顾名思义,就是一些特别敏感的权限,在Android系统中,主要由两个    SYSTEM_ALERT_WINDOW(设置悬浮窗,进行一些黑科技)  WRITE_SETTINGS (修改系统设置)  关于上面两个特殊权限的授权,做法是使用startActivityForResult启动授权界面来完成。

申请方式:

private static final int REQUEST_CODE = 1;  private  void requestAlertWindowPermission() {      Intent intent = new Intent(Settings.ACTION_MANAGE_OVERLAY_PERMISSION);      intent.setData(Uri.parse("package:" + getPackageName()));      startActivityForResult(intent, REQUEST_CODE);  }    @Override  protected void onActivityResult(int requestCode, int resultCode, Intent data) {      super.onActivityResult(requestCode, resultCode, data);      if (requestCode == REQUEST_CODE) {        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) {          if (Settings.canDrawOverlays(this)) {              Log.i("xqxinfo", "onActivityResult granted");       }     }    }  }