Android各版本迭代改动与适配的方法

发布时间:2022-04-19 14:09:34 作者:iii
来源:亿速云 阅读:169

今天小编给大家分享一下Android各版本迭代改动与适配的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

Android 4.4

Android 5.0

Android 6.0

假如你的应用使用到了危险权限,比方在运行时进行检查和请求权限。checkSelfPermission() 方法用于检查权限,requestPermissions() 方法用于请求权限。

Android 6.0 版移除了对 Apache HTTP 相关类库的支持。要继续使用 Apache HTTP API,您必需先在 build.gradle 文件中公告以下编译时依赖项:

android {useLibrary 'org.apache.http.legacy'}

Apache HttpClient 是Apache开源组织提供的一个开源的项目,它是一个简单的HTTP用户端(并不是浏览器),可以发送HTTP请求,接受HTTP响应。

Android 7.0

其实就是限制了在应用间共享文件,假如需要在应用间共享,需要授予要访问的URI临时访问权限,我们要做的就是注册FileProvider:

1)公告FileProvider。

<provider    android:name="android.support.v4.content.FileProvider"    android:authorities="app的包名.fileProvider"    android:grantUriPermissions="true"    android:exported="false">    <meta-data        android:name="android.support.FILE_PROVIDER_PATHS"        android:resource="@xml/file_paths" /></provider><!--androidx版本类路径为:androidx.core.content.FileProvider-->

2)编写xml文件,确定可访问的目录

<paths xmlns:android="http://schemas.android.com/apk/res/android">    //代表设施的根目录new File("/");    <root-path name="root" path="." />     //context.getFilesDir()    <files-path name="files" path="." />     //context.getCacheDir()    <cache-path name="cache" path="." />     //Environment.getExternalStorageDirectory()    <external-path name="external" path="." />    //context.getExternalFilesDirs()    <external-files-path name="name" path="path" />    //getExternalCacheDirs()     <external-cache-path name="name" path="path" /></paths>

3)使用 FileProvider

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {    Uri uri = FileProvider.getUriForFile(CameraActivity.this, "app的包名.fileProvider", photoFile);} else {    Uri uri = Uri.fromFile(photoFile);}

Android 8.0

在 Android 8.0 之前,假如应用在运行时请求权限并且被授予该权限,系统会错误地将属于同一权限组并且在清单中注册的其余权限也一起授予应用。对于针对 Android 8.0 的应用,系统只会授予应用明确请求的权限。然而,一旦客户为应用授予某个权限,则所有后续对该权限组中权限的请求都将被自动批准。

也就是说,以前你申请了READ_EXTERNAL_STORAGE权限,应用会同时给你授予同权限组的WRITE_EXTERNAL_STORAGE权限。假如Android8.0以上,只会给你授予你请求的READ_EXTERNAL_STORAGE权限。假如需要WRITE_EXTERNAL_STORAGE权限,还要单独申请,不过系统会立即授予,不会提醒。

Android 8.0 对于通知修改了很多,比方通知渠道、通知标志、通知超时、背景颜色。其中比较重要的就是通知渠道,其允许您为要显示的每种通知类型创立客户可自己设置的渠道。

这样的好处就是对于某个应用可以把权限分成很多类,客户来控制能否显示哪些类别的通知。而开发者要做的就是必需设置这个渠道id,否则通知可能会失效。

     private void createNotificationChannel() {        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {            NotificationManager notificationManager = (NotificationManager)                    getSystemService(Context.NOTIFICATION_SERVICE);            //分组(可选)            //groupId要唯一            String groupId = "group_001";            NotificationChannelGroup group = new NotificationChannelGroup(groupId, "广告");            //创立group            notificationManager.createNotificationChannelGroup(group);            //channelId要唯一            String channelId = "channel_001";            NotificationChannel adChannel = new NotificationChannel(channelId,                    "推广信息", NotificationManager.IMPORTANCE_DEFAULT);            //补充channel的含义(可选)            adChannel.setDescription("推广信息");            //将渠道增加进组(先创立组才能增加)            adChannel.setGroup(groupId);            //创立channel            notificationManager.createNotificationChannel(adChannel);            //创立通知时,标记你的渠道id            Notification notification = new Notification.Builder(MainActivity.this, channelId)                    .setSmallIcon(R.mipmap.ic_launcher)                    .setLargeIcon(BitmapFactory.decodeResource(getResources(), R.mipmap.ic_launcher))                    .setContentTitle("一条新通知")                    .setContentText("这是一条测试消息")                    .setAutoCancel(true)                    .build();            notificationManager.notify(1, notification);        }    }
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {    mWindowParams.type = WindowManager.LayoutParams.TYPE_APPLICATION_OVERLAY}else {    mWindowParams.type = WindowManager.LayoutParams.TYPE_SYSTEM_ALERT}
    <uses-permission android:name="android.permission.REQUEST_INSTALL_PACKAGES"/>    private void installAPK(){        if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {            boolean hasInstallPermission = getPackageManager().canRequestPackageInstalls();            if (hasInstallPermission) {                //安装应用            } else {                //跳转至“安装未知应用”权限界面,引导客户开启权限                Uri selfPackageUri = Uri.parse("package:" + this.getPackageName());                Intent intent = new Intent(Settings.ACTION_MANAGE_UNKNOWN_APP_SOURCES, selfPackageUri);                startActivityForResult(intent, 100);            }        }else {            //安装应用        }    }    //接收“安装未知应用”权限的开启结果    @Override    protected void onActivityResult(int requestCode, int resultCode, Intent data) {        super.onActivityResult(requestCode, resultCode, data);        if (requestCode == 100) {            installAPK();        }    }

我们的解决办法就是要么去掉设置方向的代码,要么舍弃透明效果。

Android 9.0

<application android:networkSecurityConfig="@xml/network_security_config"><network-security-config> <base-config cleartextTrafficPermitted="true" /></network-security-config><!--或者者在AndroidManifest.xml中配置:android:usesCleartextTraffic="true"-->

在6.0中取消了对Apache HTTP 用户端的支持,Android9.0中直接移除了该库,要使用的话需要增加配置:

<uses-library android:name="org.apache.http.legacy" android:required="false"/>

Android 9.0 要求创立一个前端服务需要请求 FOREGROUND_SERVICE 权限,否则系统会引发 SecurityException。

<uses-permission android:name="android.permission.FOREGROUND_SERVICE" />if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.O) {    startForegroundService(intentService);} else {    startService(intentService);}

在9.0 中,不能直接非 Activity 环境中(比方Service,Application)启动 Activity,否则会崩溃报错,处理办法就是加上FLAG_ACTIVITY_NEW_TASK

Intent intent = new Intent(this, TestActivity.class);intent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);startActivity(intent);

Android 10

Android10 中默认开启了分区存储,也就是沙盒模式。应用只能看到本应用专有的目录(通过 Context.getExternalFilesDir() 访问)以及特定类型的媒体。

假如需要关闭这个功能可以配置:

android:requestLegacyExternalStorage="true"

分区存储下,访问文件的方法:

1)应用专属目录

//分区存储空间val file = File(context.filesDir, filename)//应用专属外部存储空间val appSpecificExternalDir = File(context.getExternalFilesDir(), filename)

2)访问公共媒体目录文件

val cursor = contentResolver.query(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, null, null, null, "${MediaStore.MediaColumns.DATE_ADDED} desc")if (cursor != null) {    while (cursor.moveToNext()) {        val id = cursor.getLong(cursor.getColumnIndexOrThrow(MediaStore.MediaColumns._ID))        val uri = ContentUris.withAppendedId(MediaStore.Images.Media.EXTERNAL_CONTENT_URI, id)        println("image uri is $uri")    }    cursor.close()}

3)SAF(存储访问框架--Storage Access Framework)

    val intent = Intent(Intent.ACTION_OPEN_DOCUMENT)    intent.addCategory(Intent.CATEGORY_OPENABLE)    intent.type = "image/*"    startActivityForResult(intent, 100)    @RequiresApi(Build.VERSION_CODES.KITKAT)    override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {        super.onActivityResult(requestCode, resultCode, data)        if (data == null || resultCode != Activity.RESULT_OK) return        if (requestCode == 100) {            val uri = data.data            println("image uri is $uri")        }    }

从Android10开始普通应用不再允许请求权限 android.permission.READ_PHONE_STATE。而且,无论你的App能否适配过Android Q(既targetSdkVersion能否大于等于29),均无法再获取到设施IMEI等设施信息。

假如Android10以下设施获取设施IMEI等信息,可以配置最大sdk版本:

<uses-permission android:name="android.permission.READ_PHONE_STATE"        android:maxSdkVersion="28"/>

Android 11

Android11 强制执行分区存储,也就是沙盒模式。这次真的没有关闭功能了,离Android11出来也有一段时间了,还是抓紧适配吧。

改动了两个API:getLine1Number()和 getMsisdn() ,需要加上READ_PHONE_NUMBERS权限

以上就是“Android各版本迭代改动与适配的方法”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

推荐阅读:
  1. 划分迭代版本的两个方法
  2. mysql分表程序改动方法

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

android

上一篇:怎么编译Android动态库

下一篇:es6模块化指的是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》