تغييرات السلوك: جميع التطبيقات

يتضمّن نظام التشغيل Android 15 تغييرات في السلوك قد تؤثر في تطبيقك. تنطبق تغييرات السلوك التالية على جميع التطبيقات عند تشغيلها على Android 15، بغض النظر عن targetSdkVersion. عليك اختبار تطبيقك ثم تعديله حسب الحاجة لتفعيل هذه الميزات بشكل صحيح، حيثما ينطبق ذلك.

احرص أيضًا على مراجعة قائمة التغييرات في السلوك التي تؤثر فقط في التطبيقات التي تستهدف الإصدار 15 من نظام التشغيل Android.

الوظيفة الأساسية

يعدّل نظام Android 15 أو يوسّع إمكانات نظام Android الأساسية المختلفة.

التغييرات في حالة الحزمة المتوقفة

يتمثل الغرض من حالة الحزمة FLAG_STOPPED (التي يمكن للمستخدمين المشاركة في إصدارات AOSP من خلال الضغط مع الاستمرار على رمز التطبيق واختيار "فرض الإيقاف") دائمًا في إبقاء التطبيقات في هذه الحالة إلى أن يزيلها المستخدم صراحةً من هذه الحالة من خلال تشغيل التطبيق مباشرةً أو التفاعل بشكل غير مباشر مع التطبيق (من خلال ورقة المشاركة أو التطبيق المصغّر أو اختيار التطبيق كخلفية متحركة، وما إلى ذلك). في Android 15، نجري تعديلات على سلوك النظام كي يتماشى مع هذا السلوك المقصود. يجب إزالة التطبيقات فقط من حالة التوقّف عن طريق اتخاذ إجراء مباشر أو غير مباشر من قِبل المستخدم.

لإتاحة السلوك المقصود، بالإضافة إلى القيود الحالية، يلغي النظام أيضًا كل عمليات الطلب قيد المراجعة عندما يبدأ التطبيق في حالة الإيقاف على جهاز يعمل بنظام التشغيل Android 15. عندما تؤدي إجراءات المستخدم إلى إزالة التطبيق من حالة الإيقاف، يتم إرسال بث ACTION_BOOT_COMPLETED إلى التطبيق، ما يتيح إعادة تسجيل أي نوايا في انتظار المراجعة.

يمكنك استدعاء طريقة ApplicationStartInfo.wasForceStopped() الجديدة للتأكد مما إذا تم إيقاف التطبيق.

إتاحة صفحات بحجم 16 كيلوبايت

Android 过去仅支持 4 KB 内存页面大小, 优化了系统内存性能,以针对 Android 设备通常具备的功能。从 Android 15 开始,AOSP 支持 配置为使用 16 KB (16 KB) 页面大小的设备 设备)。如果您的应用使用任何 NDK 库,请直接使用 或者通过 SDK 间接创建,那么,您需要重新构建自己的应用 支持这些 16KB 设备。

随着设备制造商不断打造出 物理内存 (RAM),许多此类设备都会采用 16KB(以及 页面大小以优化设备的性能。正在添加 支持 16 KB 页面大小的设备,可使您的应用在这些设备上运行 并有助于您的应用从相关的广告效果中获益 改进。如果不重新编译,应用可能无法在 16KB 设备上运行 在未来的 Android 版本中正式推出。

为帮助您为应用添加支持,我们提供了有关如何检查 如果您的应用受到影响 重新构建您的应用(如果适用),以及如何在 Google Play 中 使用模拟器(包括 Android 15)的 16 KB 环境 系统映像)。

优势和性能提升

配置为使用 16 KB 页面大小的设备平均会使用略多一些的内存,但系统和应用的性能也会得到各种提升:

  • 缩短了系统内存压力时的应用启动时间:平均降低了 3.16%;对于我们测试的某些应用而言,改进幅度更大(最高可达 30%)
  • 应用启动期间的功耗降低:平均降低了 4.56%
  • 相机启动更快:热启动速度平均提高了 4.48%,冷启动速度平均提高了 6.60%
  • 缩短了系统启动时间:平均缩短了 8%(约 950 毫秒)

这些改进基于我们的初始测试,实际设备上的结果可能会有所不同。随着测试的继续进行,我们将进一步分析应用的潜在收益。

检查您的应用是否受到影响

如果您的应用使用了任何原生代码,则应重新构建应用以支持 16 KB 设备。如果您不确定自己的应用是否使用了原生代码,可以使用 APK 分析器确定是否存在任何原生代码,然后检查您找到的任何共享库的 ELF 段对齐情况

如果您的应用仅使用以 Java 或 Kotlin 编程语言编写的代码(包括所有库或 SDK),则该应用已经支持 16 KB 设备。不过,我们建议您在 16 KB 环境中测试应用,以验证应用行为是否没有意外回归。

التغييرات المطلوبة لبعض التطبيقات لتتوافق مع المساحة الخاصة

المساحة الخاصة هي ميزة جديدة في Android 15 تتيح للمستخدمين إنشاء مساحة منفصلة على أجهزتهم لإبعاد التطبيقات الحساسة عنها من المتطفلين، تحت طبقة مصادقة إضافية. لأن التطبيقات في المساحة الخاصة قد حظرت أذونات الوصول، وتحتاج بعض أنواع التطبيقات إلى للتمكّن من الاطّلاع على التطبيقات والتفاعل معها في إعدادات خصوصية المستخدم مساحة.

جميع التطبيقات

ولأن التطبيقات في المساحة الخاصة يتم الاحتفاظ بها في ملف شخصي منفصل للمستخدم، إلى الملفات الشخصية للعمل، يجب ألا تفترض التطبيقات أن أي ملفات تم تثبيتها نُسخ من التطبيق غير الموجودة في الملف الشخصي الرئيسي متوفرة في ملف العمل. في حال حذف لتطبيقك منطق ذو صلة بتطبيقات ملف العمل التي تضع هذا الافتراض، ستحتاج إلى تعديل هذا المنطق.

تطبيقات طبية

عندما يقفل المستخدم المساحة الخاصة، يتم إيقاف جميع التطبيقات في المساحة الخاصة، ولا يمكن لهذه التطبيقات تنفيذ الأنشطة التي تعمل في المقدّمة أو في الخلفية، بما في ذلك: ويتم عرض الإشعارات. قد يؤثر هذا السلوك بشكل كبير على استخدام وظائف التطبيقات الطبية المثبتة في المساحة الخاصة.

تحذّر تجربة إعداد المساحة الخاصة المستخدمين من أنّ المساحة الخاصة ليست مناسب للتطبيقات التي تحتاج إلى أداء مهم في المقدّمة أو الخلفية الأنشطة، مثل عرض الإشعارات من التطبيقات الطبية ومع ذلك، لا تستطيع التطبيقات تحديد ما إذا كانت تُستخدم في المساحة الخاصة أم لا، لكي لا تتمكّن من عرض تحذير للمستخدم بخصوص هذه الحالة.

لهذه الأسباب، إذا طورت تطبيقًا طبيًا، راجِع الطريقة التي قد تظهر بها هذه الميزة. التأثير في تطبيقك واتخاذ الإجراءات المناسبة، مثل إعلام المستخدمين بعدم تثبيت تطبيقك في المساحة الخاصة لتجنُّب تعطُّل التطبيق المهم والإمكانات.

تطبيقات مشغّل التطبيقات

إذا طورت أحد تطبيقات المشغّل، يجب عليك القيام بما يلي قبل أن تكون التطبيقات في ستكون المساحة الخاصة مرئية:

  1. يجب تعيين تطبيقك كتطبيق مشغّل التطبيقات التلقائي للجهاز تمتلك دور ROLE_HOME.
  2. يجب أن يفصح تطبيقك عن ACCESS_HIDDEN_PROFILES. إذن عادي في ملف البيان لتطبيقك.

يجب أن تتعامل تطبيقات "مشغّل التطبيقات" التي تقدّم بيانًا عن إذن "ACCESS_HIDDEN_PROFILES" مع حالات استخدام المساحة الخاصة التالية:

  1. يجب أن يحتوي تطبيقك على حاوية مشغّل تطبيقات منفصلة للتطبيقات المثبَّتة في المساحة الخاصة. استخدِم الطريقة getLauncherUserInfo() من أجل تحديد نوع الملف الشخصي للمستخدم الذي تتم معالجته.
  2. يجب أن يكون المستخدم قادرًا على إخفاء حاوية المساحة الخاصة وإظهارها.
  3. يجب أن يتمكّن المستخدم من قفل حاوية المساحة الخاصة وفتح قفلها. استخدام طريقة requestQuietModeEnabled() للقفل (بحلول اجتياز true) أو فتح قفل المساحة الخاصة (من خلال تجاوز false)
  4. أثناء القفل، يجب ألا تكون أي تطبيقات في حاوية المساحة الخاصة مرئية أو قابلة للاكتشاف من خلال آليات مثل البحث. يجب أن يسجِّل تطبيقك المستلِم في ACTION_PROFILE_AVAILABLE و ACTION_PROFILE_UNAVAILABLE عمليات البث وتعديل واجهة مستخدم في تطبيقك عندما تكون المساحة الخاصة مقفلة أو مفتوحة تغييرات الحاوية. يتضمن كلا البثين EXTRA_USER، الذي يمكن لتطبيقك استخدامه للإشارة إلى مستخدم ملف شخصي خاص.

    يمكنك أيضًا استخدام الطريقة isQuietModeEnabled() لإجراء ما يلي: التحقّق مما إذا كان الملف الشخصي للمساحة الخاصة مقفلاً أم لا

تطبيقات متجر التطبيقات

تتضمن المساحة الخاصة الزر "تثبيت تطبيقات" الذي يطلق زرًا ضمنيًا نية تثبيت تطبيقات في المساحة الخاصة للمستخدم. ليتمكّن تطبيقك من الحصول على هذا الغرض الضمني، يُرجى الإفصاح عن <intent-filter> في ملف بيان تطبيقك الذي يحتوي على <category> من CATEGORY_APP_MARKET

إزالة خط رموز الإيموجي المستند إلى ملفات PNG

The legacy, PNG-based emoji font file (NotoColorEmojiLegacy.ttf) has been removed, leaving just the vector-based file. Beginning with Android 13 (API level 33), the emoji font file used by the system emoji renderer changed from a PNG-based file to a vector based file. The system retained the legacy font file in Android 13 and 14 for compatibility reasons, so that apps with their own font renderers could continue to use the legacy font file until they were able to upgrade.

To check if your app is affected, search your app's code for references to the NotoColorEmojiLegacy.ttf file.

You can choose to adapt your app in a number of ways:

  • Use platform APIs for text rendering. You can render text to a bitmap-backed Canvas and use that to get a raw image if necessary.
  • Add COLRv1 font support to your app. The FreeType open source library supports COLRv1 in version 2.13.0 and higher.
  • As a last resort, you can bundle the legacy emoji font file (NotoColorEmoji.ttf) into your APK, although in that case your app will be missing the latest emoji updates. For more information, see the Noto Emoji GitHub project page.

زيادة الحد الأدنى لإصدار حزمة تطوير البرامج (SDK) المستهدَف من 23 إلى 24

Android 15 builds on the the changes that were made in Android 14 and extends this security further. In Android 15, apps with a targetSdkVersion lower than 24 can't be installed. Requiring apps to meet modern API levels helps to ensure better security and privacy.

Malware often targets lower API levels in order to bypass security and privacy protections that have been introduced in higher Android versions. For example, some malware apps use a targetSdkVersion of 22 to avoid being subjected to the runtime permission model introduced in 2015 by Android 6.0 Marshmallow (API level 23). This Android 15 change makes it harder for malware to avoid security and privacy improvements. Attempting to install an app targeting a lower API level results in an installation failure, with a message like the following one appearing in Logcat:

INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 24, but found 7

On devices upgrading to Android 15, any apps with a targetSdkVersion lower than 24 remain installed.

If you need to test an app targeting an older API level, use the following ADB command:

adb install --bypass-low-target-sdk-block FILENAME.apk

الأمان والخصوصية

Android 15 introduces robust measures to combat one-time passcode (OTP) fraud and to protect the user's sensitive content, focusing on hardening the Notification Listener Service and screenshare protections. Key enhancements include redacting OTPs from notifications accessible to untrusted apps, hiding notifications during screenshare, and securing app activities when OTPs are posted. These changes aim to keep the user's sensitive content safe from unauthorized actors.

Developers need to be aware of the following to ensure their apps are compatible with the changes in Android 15:

OTP Redaction

Android will stop untrusted apps that implement a NotificationListenerService from reading unredacted content from notifications where an OTP has been detected. Trusted apps such as companion device manager associations are exempt from these restrictions.

Screenshare Protection

  • Notification content is hidden during screen sharing sessions to preserve the user's privacy. If the app implements setPublicVersion(), Android shows the public version of the notification which serves as a replacement notification in insecure contexts. Otherwise, the notification content is redacted without any further context.
  • Sensitive content like password input is hidden from remote viewers to prevent revealing the user's sensitive information.
  • Activities from apps that post notifications during screenshare where an OTP has been detected will be hidden. App content is hidden from the remote viewer when launched.
  • Beyond Android's automatic identification of sensitive fields, developers can manually mark parts of their app as sensitive using setContentSensitivity, which is hidden from remote viewers during screenshare.
  • Developers can choose to toggle the Disable screen share protections option under Developer Options to be exempted from the screenshare protections for demo or testing purposes. The default system screen recorder is exempted from these changes, since the recordings remain on-device.

الكاميرا والوسائط

يُجري نظام التشغيل Android 15 التغييرات التالية على سلوك الكاميرا والوسائط في جميع التطبيقات.

يؤدي تشغيل الصوت المباشر وتفريغه إلى إلغاء مقاطع الصوت المباشرة أو التي تم تفريغها والتي سبق فتحها عند بلوغ حدود الموارد.

Before Android 15, if an app requested direct or offload audio playback while another app was playing audio and the resource limits were reached, the app would fail to open a new AudioTrack.

Beginning with Android 15, when an app requests direct or offload playback and the resource limits are reached, the system invalidates any currently open AudioTrack objects which prevent fulfilling the new track request.

(Direct and offload audio tracks are typically opened for playback of compressed audio formats. Common use-cases for playing direct audio include streaming encoded audio over HDMI to a TV. Offload tracks are typically used to play compressed audio on a mobile device with hardware DSP acceleration.)

تجربة المستخدم وواجهة المستخدم للنظام

يتضمّن Android 15 بعض التغييرات التي تهدف إلى توفير تجربة مستخدم أكثر اتساقًا وسهولة.

تفعيل الصور المتحركة لإيماءة الرجوع إلى الخلف التنبؤية في التطبيقات التي فعّلت هذه الميزة

从 Android 15 开始,移除了预测性返回动画的开发者选项。现在,对于已完全或在 activity 级别选择启用预测性返回手势的应用,系统现在会显示“返回主屏幕”“跨任务”和“跨 activity”等系统动画。如果您的应用受到影响,请执行以下操作:

  • 确保您的应用已正确迁移,以使用预测性返回手势。
  • 确保您的 fragment 转换支持预测性返回导航。
  • 停止使用动画和框架转换,并改用 Animator 和 AndroidX 转换。
  • FragmentManager 不知道的返回堆栈中迁出。请改用由 FragmentManager 或 Navigation 组件管理的返回堆栈。

إيقاف التطبيقات المصغّرة عندما يوقف المستخدم أحد التطبيقات بشكلٍ قسري

如果用户在搭载 Android 15 的设备上强行停止某个应用,系统会暂时停用该应用的所有 widget。这些 widget 会灰显,用户无法与它们互动。这是因为,从 Android 15 开始,当应用被强行停止时,系统会取消应用的所有待处理 intent。

系统会在用户下次启动应用时重新启用这些 widget。

如需了解详情,请参阅对软件包停止状态的更改

شريحة شريط حالة عرض الوسائط لتنبيه المستخدمين بشأن مشاركة الشاشة وبث المحتوى وتسجيله

Benefits and performance gains

Check if your app is impacted

الميزات المتوقّفة نهائيًا

مع كل إصدار، قد تصبح واجهات برمجة تطبيقات Android معيّنة قديمة أو قد تحتاج إلى إعادة هيكلة لتوفير تجربة أفضل للمطوّرين أو إتاحة ميزات جديدة في النظام الأساسي. وفي هذه الحالات، نوقف رسميًا واجهات برمجة التطبيقات القديمة ونقترح على المطوّرين استخدام واجهات برمجة تطبيقات بديلة.

ويعني إيقاف الاستخدام نهائيًا أنّنا أوقفنا رسميًا دعم واجهات برمجة التطبيقات، ولكنّها ستظلّ متاحة للمطوّرين. للاطّلاع على مزيد من المعلومات حول الميزات التي سيتم إيقافها نهائيًا في هذا الإصدار من Android، يمكنك الاطّلاع على صفحة الميزات التي سيتم إيقافها نهائيًا.