Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?

这篇具有很好参考价值的文章主要介绍了Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

好久不见~ 最近几个月变化挺大的,不论是自己的家庭还是社会环境,把我们能做的做好,慢慢适应新的变化,这也是一种不可或缺的能力吧!

Android14 即将正式发布,作为开发者需要注意哪些内容?长话短说,一起来看看吧~

主要分为两部分:
一是影响所有的 Android 应用,这些改动会影响所有的 App,只要你的 App 安装在了 Android14 的设备上,都会受到这些影响;
二是当 targetSdkVersion 升级到 34 后,我们的 App 所受到的影响。这一篇先来说说第一部分的内容,即现有 App 安装到 Android14 手机上,会有哪些影响

1. SCHEDULE_EXACT_ALARM 权限默认关闭

这个权限的全称是 android.permission.SCHEDULE_EXACT_ALARM,用于是否开启设置精确闹钟的权限。精确的闹钟适用于用户指定时间的通知,或是在确切的时间需要执行的操作。

如果 App 的 targetSdkVersion 设置的是 33(Android13)或更高,在 Android14 的设备上运行时,这个权限就是默认关闭的。所以,当 App 中有用到精确闹钟,需要在确切的时间点去做操作,那么就需要在 Manifest 文件中显式地申请这个权限并需要在使用时动态向用户获取该权限。

具体地说就是,当使用 AlarmManager 中的
setExact(int type, long triggerAtMillis, PendingIntent operation)
setExactAndAllowWhileIdle(int type, long triggerAtMillis, PendingIntent operation)
setAlarmClock(AlarmManager.AlarmClockInfo info, PendingIntent operation)
这三个函数时,如果 targetSdkVersion >= 33,且在 Android14 设备上没有显式申请该权限,则会抛出一个 SecurityException 异常。

特殊情况:
1)如果用户通过“备份与恢复”功能将 App 传输到一个 Android14 的设备上,则此 App 的该权限默认仍是关闭的;
2)如果一个 App 已经开启了该权限,当设备升级到 Android14 后,此 App 的该权限是开启的状态;
3)当精确闹钟是通过 OnAlarmListener 设置的,则无需申请该权限。例如:setExact(int type, long triggerAtMillis, String tag, AlarmManager.OnAlarmListener listener, Handler targetHandler) 这个方法就无需申请。

用的比较多的 API:
1)boolean canScheduleExactAlarms() 判断是否可以设置精确闹钟(API >= 31 才有此判断方法);
2)AlarmManager.ACTION_SCHEDULE_EXACT_ALARM_PERMISSION_STATE_CHANGED 广播消息常用来监听用户开启或关闭该权限的回调(API >= 31 才有此广播消息类型)。

不建议的使用场景:
1)如果 App 在生命周期内安排重复性的操作,可以使用 Handler 中的 postAtTime 等来替代。相反,如果是要设置 30min 后或者明天下午 2 点的操作,则建议使用;
2)安排在后台进行的一些操作,例如:下载更新App或者上传日志等。建议使用 WorkManager 而不是精确闹钟;
3)当系统处于空闲时,在大概的时间点处理事务,则可以调用非精确闹钟的一些 API 处理,例如使用 setAndAllowWhileIdle() 而不是 setExactAndAllowWhileIdle() 方法;
4)用户指定的在大概特定时间点发生的,或者在一个时间窗口内发生的事务;

适配流程:
1)调用 alarmManager.canScheduleExactAlarms() 检查是否有该权限;
2)如果没有权限,则需要通过 Intent,设置 ActionACTION_REQUEST_SCHEDULE_EXACT_ALARM 并加上应用包名调起设置页面,让用户赋予权限,返回后在 onResume 回调中判断是否权限是否已申请。

下面是一个例子:

// code 1
// MyFragment.kt 中的代码
    private val ALARM_REQUEST_CODE = 123
    private var getExactSchedulePermission = false
    @RequiresApi(Build.VERSION_CODES.S)
    private fun scheduleAlarm() {
        // 创建一个 Intent,用于指定定时任务触发时要执行的操作
        val intent = Intent(requireContext(), AlarmReceiver::class.java)
        val pendingIntent = PendingIntent.getBroadcast(
            requireContext(),
            ALARM_REQUEST_CODE,
            intent,
            PendingIntent.FLAG_IMMUTABLE
        )

        // 获取 AlarmManager 实例
        val alarmManager = requireActivity().getSystemService(Context.ALARM_SERVICE) as AlarmManager

        // 触发时间(这里使用相对时间)
        val triggerTime = SystemClock.elapsedRealtime() + 5000 // 5秒后触发

        // 设置定时任务
        if (alarmManager.canScheduleExactAlarms()) {
            alarmManager.setExact(AlarmManager.ELAPSED_REALTIME_WAKEUP, triggerTime, pendingIntent)
        } else {
            // 如果没有权限则打开设置页,让用户授予该 App 的精确闹钟权限
            startActivity(Intent(Settings.ACTION_REQUEST_SCHEDULE_EXACT_ALARM))
            getExactSchedulePermission = true
        }
    }

    @RequiresApi(Build.VERSION_CODES.S)
    override fun onResume() {
        super.onResume()
        if (getExactSchedulePermission) {
            scheduleAlarm()
            getExactSchedulePermission = false
        }
    }

// AlarmReceiver.kt
class AlarmReceiver: BroadcastReceiver() {
    override fun onReceive(context: Context, intent: Intent) {
        Toast.makeText(context, "Alarm triggered!", Toast.LENGTH_SHORT).show()
    }
}

当运行 scheduleAlarm() 方法后,过 5 秒就会有 Toast 出现~

日历或闹钟应用需要在应用停止运行时发送日历提醒、唤醒闹钟或提醒。这些应用可以请求 USE_EXACT_ALARM 常规权限。系统将在安装时授予 USE_EXACT_ALARM 权限,拥有此权限的应用将能够像具有 SCHEDULE_EXACT_ALARM 权限的应用一样设置精确闹钟。

小结:能不用就不用。如果之前已用到精确闹钟,则需要新增权限获取逻辑。

2. 动态广播当 App 进入缓存态时将会入队保存

在 Android14 中,我们使用 Context 上下文注册的动态广播接收器,可以在 App 进入缓存状态时,将已发送还未接收的广播放入到一个队列中保存。当 App 离开缓存状态(比如进入前台),则系统会传递所有已加入队列的广播。某些广播的多个实例可以合并为一个广播。

而在 Manifest 文件中注册的静态广播接收器,则不能进入队列,它们会在 App 从缓存状态中被移除销毁时,进行广播传递。

什么是缓存状态下的 App?简单理解就是在后台的 App,目前不在前台的进程,因此,如果系统其他地方需要内存,系统可以根据需要自由地终止这些进程。当然终止的顺序是最老未使用的最先被终止。

3. App 只能终止自己的后台进程

从 Android14 开始,调用 killBackgroundProcesses() 时,只能终止自己应用的后台进程。如果传入另一个应用的软件包名称,此方法对该应用的后台进程没有影响,并且 Logcat 中会显示以下消息:

Invalid packageName: com.example.anotherapp

官方给出的解释是:

您的应用不应使用 killBackgroundProcesses() API,也不得以其他方式尝试影响其他应用的进程生命周期,即使在旧版操作系统上也是如此。Android 旨在让缓存应用在后台运行,并在系统需要内存时自动终止它们。如果您的应用不必要地终止其他应用,则由于之后需要完全重启这些应用,因此可能会降低系统性能并增加耗电量,这比恢复现有缓存应用所消耗的资源要多得多。

该 API 是 ActivityManager 提供的,完整的方法声明:

// code 2
public void killBackgroundProcesses (String packageName)

此外,使用它还需要在 Manifest 文件中申请权限 Manifest.permission.KILL_BACKGROUND_PROCESSES.

经测试,我发现这个 API 有点奇怪:被杀死的后台进程马上又会重启,额。。。这是什么操作??

测试代码比较简单,就是在另外一个进程中开启一个 Service,然后调用 killBackgroundProcesses 方法即可,根据打印的 Service 生命周期可看出,该 Service 确实先被杀死然后又走了一次 onCreateonStartCommand 生命周期,代码和结果如下所示:

// code 3
// Manifest 文件声明 Service 在另一个进程中启动
<uses-permission android:name="android.permission.KILL_BACKGROUND_PROCESSES" />
<service
    android:name=".MyService"
    android:process="com.secondProcess" />

// 启动 Service
startService(Intent(requireContext(), MyService::class.java))
// 杀死后台进程
val activityManager = context.getSystemService(Context.ACTIVITY_SERVICE) as ActivityManager
activityManager.killBackgroundProcesses(context.packageName)

log 打印结果:
Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?,Android,Kotlin,智能手机,vscode,ide
从图上可知,在 Android14 的设备上,调用 killBackgroundProcesses 方法可以杀死自己 App 的后台进程,但会立即重新启动。在源码中也找到了下面的代码,虽然已被废弃:

// code 3
    @Deprecated
    public void restartPackage(String packageName) {
        killBackgroundProcesses(packageName);
    }

看来这个 API 就是用来重启 App 的后台进程的?

试了下在 Android14 设备上的 A App 中调用此 API 去杀死 B App 的后台进程,确实没有任何作用;但如果是在 Android14 以下的设备上调用,确实可以杀死 B App 的后台进程。感兴趣的同学也可试一试。

小结:killBackgroundProcesses API 并没有什么卵用~(欢迎大佬指点)

4. 安全方面

在 Android14 系统手机上,将无法安装 targetSdkVersion < 23(低于Android6.0)的 App。

媒体包名称在 Android14 上可能会被隐藏。目前媒体库支持按照 OWNER_PACKAGE_NAME 列查询某包名下的所有媒体文件,一个应用存储的媒体文件是带有它自己的包名信息的。这些信息将在 Android14上被隐藏,除非满足以下条件之一:
1)存储媒体文件的应用包名称始终对其他应用可见(自己开放给所有其他 App);
2)查询媒体库的应用获得了 QUERY_ALL_PACKAGES 权限(其他 App 向用户申请获得了权限)。

举个栗子:
当一个应用存储了一个媒体文件(例如一张照片或一个视频),它会在媒体库中记录该文件的信息,包括该文件的所有者包名。其他应用可以查询媒体库以获取这些信息,以便在自己的应用中显示该文件或与之交互。

在 Android14 及以后的版本中,如果存储媒体文件的应用的包名不是始终对其他应用程序可见的,则在查询媒体库时,所有者包名将被隐藏或替换为匿名值。例如,如果一个应用包名为“com.example.app”,它存储了一个媒体文件,但它的包名被隐藏了,那么在查询媒体库时,所有者包名可能会被替换为“com.android.providers.media”。

但是,如果存储媒体文件的应用具有始终对其他应用可见的包名,或者查询媒体库的应用程序具有QUERY_ALL_PACKAGES 权限,则可以看到媒体库中的完整所有者包名。例如,一个应用名为“com.example.app”,它存储了一个媒体文件,并且它的包名始终对其他应用程序可见,那么在查询媒体库时,所有者包名将显示为“com.example.app”。

5. 用户体验方面

5.1 可单独对照片和视频访问权限进行授权

如果你的 App 以 Android13 或更高版本为目标平台(即 targetSdkVersion >= 33),且在 Android14 的设备上运行时,用户可以授予对其照片和视频的部分访问权限,即单独设置 READ_MEDIA_IMAGESREAD_MEDIA_VIDEO

即申请 READ_MEDIA_IMAGES 权限时,仅会显示手机上所有图片给用户进行选择;申请 READ_MEDIA_VIDEO 权限时,仅会显示手机上所有的视频给用户进行选择。用户可以更加细致地选择将哪些照片或视频授权给 App 读取使用。

新的系统对话框长这样:
Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?,Android,Kotlin,智能手机,vscode,ide

1)选择照片和视频: Android14 中的新功能。用户选择希望提供给应用的具体照片和视频。
2)全部允许:用户授予对设备上的所有照片和视频的完整访问权限。
3)不允许:用户拒绝授予所有访问权限。

注意:
1)当应用已经在使用系统的 照片选择器,则无需执行任何操作即可支持此变更;
2)READ_MEDIA_IMAGESREAD_MEDIA_VIDEO 仅在 Android13 或以上的版本才能使用;

新增了一个 READ_MEDIA_VISUAL_USER_SELECTED 权限,属于 Dangerous 级别。用于在用户点击自定义的照片选择器需要申请访问照片和视频的权限时使用,这样就不用去申请 READ_MEDIA_IMAGESREAD_MEDIA_VIDEO 这两个权限了。

小结:开发者不用管,新的权限很鸡肋,暂时用不上,之前读取照片和视频的相关逻辑也不用改。

5.2 更安全的全屏通知展示

在 Android11(API level 30)上就可以调用 Notification.Builder.setFullScreenIntent 方法在锁屏上展示一些全屏的通知了,不过得在 Manifest 文件中申请 USE_FULL_SCREEN_INTENT 权限。

全屏通知是为了让用户立即注意到的高优先级通知而设计的,例如来电或用户配置的闹钟,在展示全全屏通知时,用户只能上滑退出,如下图所示的系统提示。

Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?,Android,Kotlin,智能手机,vscode,ide

从 Android14 开始,允许使用此权限的应用程序仅限于那些只提供通话和警报的应用。对于其他应用,Google Play 商店会撤销它们默认的 USE_FULL_SCREEN_INTENT 权限。

可以使用新的 API NotificationManager.canUseFullScreenIntent() 检查应用是否有权限;如果没有,可以用新的 ACTION_MANAGE_APP_USE_FULL_SCREEN_INTENT 来启动用户可以授予该权限的设置页面。

奇怪的是我在 Android14 官方的虚拟机上并没有打开通知成功,更不用说打开全屏通知了。不过确实可以打开设置全屏通知权限开关的页面,如下是全屏通知权限设置图及主要相关代码:

Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?,Android,Kotlin,智能手机,vscode,ide

// code 4
val notificationBuilder = NotificationCompat.Builder(requireContext())
    .setSmallIcon(R.drawable.ic_lock_idle_alarm)
    .setContentTitle("Notification Title")
    .setContentText("Notification text")
// 创建一个PendingIntent,点击Notification时打开指定页面
val intent = Intent(context, NotificationFullActivity::class.java)
val fullScreenIntent =
    PendingIntent.getActivity(context, 1, intent, PendingIntent.FLAG_MUTABLE)
	notificationBuilder.setFullScreenIntent(fullScreenIntent, true)  // 打开全屏通知
//            notificationBuilder.setContentIntent(fullScreenIntent)  // 打开普通页面

val notificationManager =
    requireContext().getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
// Android 8.0 Oreo以上需要设置通知渠道
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
    val channelId = "your_channel_id"
    val channelName: CharSequence = "Your Channel Name"
    val importance = NotificationManager.IMPORTANCE_HIGH
    val channel = NotificationChannel(channelId, channelName, importance)
    channel.description = "Channel description"
    notificationManager.createNotificationChannel(channel)
    notificationBuilder.setChannelId(channelId)
}
notificationManager.notify(5, notificationBuilder.build())
if (notificationManager.canUseFullScreenIntent()) {
    notificationManager.notify(5, notificationBuilder.build())
} else {
    // 打开设置页
    val intent = Intent(Settings.ACTION_MANAGE_APP_USE_FULL_SCREEN_INTENT)
    intent.data = Uri.fromParts("package", requireActivity().packageName, null)
    startActivity(intent)
}

如果哪位大佬在 Android14 设备上成功地打开了全屏通知,麻烦交流一下,谢谢。

小结:大部分 App 用不上这个全屏通知功能,个人觉得并不是很重要。。。

5.3 关于不可关闭通知用户体验方式的变更

如果应用向用户显示不可关闭的前台通知的话需要注意:Android14 中允许用户关闭此类通知。即之前通过 Notification.Builder#setOngoing(true)NotificationCompat.Builder#setOngoing(true) 设置 Notification.FLAG_ONGOING_EVENT 来阻止用户关闭前台通知的应用要小心了。FLAG_ONGOING_EVENT 的行为已发生变化,用户在 Android14 上可以关闭此类通知。

以下情况,此类通知仍不可关闭:
1)当手机处于锁定状态时;
2)如果用户选择全部清除通知操作(有助于防止意外关闭);

此外,下列的几种情况并没有变更:
1)使用 CallStyle 创建的通知,即来电通知的样式;
2)设备策略控制器(DPC)和针对企业的支持包;

小结:Android 的通知管理只会越来越严格,早就应该管管了。其实就算 Android14 手机上没有这个功能,目前绝大多数手机厂商已经都可以禁止 App 弹出通知了,所以这个也没啥。。。

以上就是本篇的所有内容,主要根据官方文档自己实践操作了一番,可以看出,现有的 App 如果直接安装到 Android14 的手机上,并不会有太多的问题,许多东西其实并不用另外处理,当然建议还是根据本篇内容查漏补缺比较好。如果还想了解 targetSdkVersion 升级到 34(Android14)还需要注意哪些内容,欢迎关注我,咱们下篇见!

更多内容,欢迎关注公众号:修之竹
或者查看 修之竹的 Android 专辑

赞人玫瑰,手留余香!欢迎点赞、转发~ 转发请注明出处~文章来源地址https://www.toymoban.com/news/detail-754142.html

参考文献

  1. Android 14 官方文档 https://developer.android.com/about/versions/14
  2. https://developer.android.google.cn/about/versions/14/behavior-changes-all?hl=zh-cn
  3. https://developer.android.google.cn/about/versions/14/changes/schedule-exact-alarms?hl=zh-cn
  4. https://developer.android.google.cn/guide/components/activities/process-lifecycle?hl=zh-cn
  5. https://developer.android.google.cn/about/versions/14/behavior-changes-14
  6. Android 14 快速适配要点; 恋猫de小郭; https://juejin.cn/post/7231835495557890106?searchId=202307240025039D8229C74EA62159077B

到了这里,关于Android14 适配之——现有 App 安装到 Android14 手机上需要注意些什么?的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Android 14适配

    Google I/O 2023 发布的 Android beta2 ,Android 14 将在2023年第三季度发布。Google Play 已经开始强制要求targetSdkVersion 33适配,所以 targetSdkVersion 34适配也是非常有必要的。 前台服务类型(foregroundServiceType)是在 Android 10 引入的,通过 android:foregroundServiceType 可以指定 service 的服务类型,

    2024年02月16日
    浏览(37)
  • Android 14 适配指南

    Google2月按时发布了第一个开发者预览版本,正式版会在8-9月份发布。 按照惯例,Android更新了可以刷机的手机型号,Pixel 4仅支持4a(5G)版本: Pixel 4a (5G) Pixel 5 and 5a Pixel 6 and 6 Pro Pixel 6a Pixel 7 and 7 Pro 开发者可以参考Android官网(https://developer.android.com/about/versions/14/get)进行刷机

    2024年02月06日
    浏览(60)
  • 鸿蒙APP上线需要注意的问题

    在将鸿蒙(HarmonyOS)应用上线的过程中,开发者需要注意一系列问题,以确保应用能够成功发布并在用户设备上正常运行。以下是上线过程中需要注意的一些关键问题,希望对大家有所帮助。北京木奇移动技术有限公司,专业的软件外包开发公司,欢迎交流合作。 1.鸿蒙版本

    2024年02月02日
    浏览(43)
  • 是时候适配android14了

    1、原来老项目中有用到前台Service的功能的app,需要在14当中制定服务类型,类型分类如下所示: 使用方式如下: 如果以 Android 14 为目标平台的应用未在清单中定义给定服务的类型,系统会在调用 startForeground() 时引发  MissingForegroundServiceTypeException 。 2、原来老项目存在隐士

    2024年02月10日
    浏览(38)
  • Android14前台服务适配指南

    Android 10引入了 android:foregroundServiceType 属性,用于帮助开发者更有目的地定义前台服务。这个属性在Android 14中被强制要求,必须指定适当的前台服务类型。以下是可选择的前台服务类型: camera : 相机应用。 connectedDevice : 与连接的设备相关的应用。 dataSync : 数据同步应用。

    2024年01月22日
    浏览(41)
  • uniapp小技巧之选择本地文件(注意这个方法只适配微信小程序和h5,app端未适配)

    注意注意一定注意app端不能用,想要app端选择上传文件去插件市场寻找,或私信我,我告诉你方法

    2024年02月12日
    浏览(44)
  • Android Studio项目打包生成可安装在自己手机上的App安装包文件

    点击上方 “ 码农的后花园 ”, 选择 “ 星标 ”  公众号 精选文章,第一时间送达 Android 打包 其实我们现在Android手机上所有的应用都是.apk文件,只不过分为系统自带和第三方,一个.apk文件本质其实就对应于你手机上的一个应用App程序,比如支付宝,淘宝。 .apk文件就是一个

    2024年02月05日
    浏览(97)
  • 【Android逆向】9年前的旧手机任性安装最新app?可以的,方法很简单

    目录 前言 二、执行步骤 1.反编译apk 2.修改apktool.yml中的minSdkVersion 3.保存、回编译、签名 4.重新安装 9年前的旧手机任性安装最新的app?可以的,方法很简单 智能手机更新换代太快,用户的换机周期也越来越短,7年以上的手机一般就会被厂家认定为过时产品,不再提供技术支

    2024年02月11日
    浏览(40)
  • Android 适配手机和平板

    一、屏幕适配限定符 Android 系统加载应用资源时 , 会根据当前运行应用的设备的相关属性 , 如 : 屏幕尺寸 / 屏幕像素密度 / 宽高比 / 屏幕方向 等属性 , 加载不同的屏幕适配限定符目录下的资源 ; 如 : 横竖屏切换时 , res/layout-land 目录中 , 存放的是横屏布局 , res/layout-port 目录中

    2024年02月05日
    浏览(62)
  • Android 手机屏幕适配方式和原理

    其适配原理主要是根据dp/sp与px的转换,而dp/sp与px的转换又与DisplayMetrics的density相关,所以可以通过改变DisplayMetrics的density,scaledDensity和densityDpi的值来适配不同分辨率机型。 在开始分析之前,我们需要了解一些概念,如: DisplayMetrics:是Android屏幕显示的信息描述,如尺寸

    2024年02月04日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包