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

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

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

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

يعمل Android 15 على تعديل الإمكانات الأساسية المتنوعة لنظام Android أو توسيعها.

التغييرات على حالة توقُّف الطرد

The intention of the package FLAG_STOPPED state (which users can engage in AOSP builds by long-pressing an app icon and selecting "Force Stop") has always been to keep apps in this state until the user explicitly removes the app from this state by directly launching the app or indirectly interacting with the app (through the sharesheet or a widget, selecting the app as live wallpaper, etc.). In Android 15, we are updating the behavior of the system to be aligned with this intended behavior. Apps should only be removed from the stopped state through direct or indirect user action.

To support the intended behavior, in addition to the existing restrictions, the system also cancels all pending intents when the app enters the stopped state on a device running Android 15. When the user's actions remove the app from the stopped state, the ACTION_BOOT_COMPLETED broadcast is delivered to the app providing an opportunity to re-register any pending intents.

You can call the new ApplicationStartInfo.wasForceStopped() method to confirm whether the app was put into the stopped state.

دعم أحجام الصفحات التي تبلغ 16 كيلوبايت

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

مع استمرار الشركات المصنّعة للأجهزة في إنشاء أجهزة ذات سعة أكبر من الذاكرة الفعلية (ذاكرة الوصول العشوائي)، من المرجَّح أن يتم ضبط العديد من هذه الأجهزة على أحجام صفحات بحجم 16 كيلوبايت (وفي النهاية أكبر) لتحسين أداء الأجهزة. تؤدي إضافة دعم إلى الأجهزة التي يبلغ حجمها 16 كيلوبايت إلى تمكين تطبيقك من العمل على هذه الأجهزة ومساعدة تطبيقك في الاستفادة من تحسينات الأداء المرتبطة به. لمساعدتك في حل هذه المشكلة، قدّمنا إرشادات حول كيفية التحقّق ممّا إذا كان تطبيقك قد تأثّر بهذا التغيير وكيفية إعادة إنشاء التطبيق (إن أمكن) وكيفية اختباره في بيئة بحجم 16 كيلوبايت باستخدام أدوات المحاكاة والأجهزة الفعلية.

الفوائد والمكاسب في الأداء

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

  • أوقات أقل لتشغيل التطبيقات أثناء تعرّض النظام لضغط الذاكرة: انخفاض بنسبة 3.16% في المتوسط، مع تحسينات أكثر أهمية (تصل إلى 30%) لبعض التطبيقات التي اختبرناها
  • استهلاك مخفض للطاقة أثناء تشغيل التطبيق: خفض بنسبة 4.56% في المتوسط
  • تشغيل أسرع للكاميرا: عند بدء تشغيل الجهاز باستخدام درجة حرارة أعلى بنسبة 4.48% في المتوسط، والتشغيل على البارد بسرعة أكبر بنسبة 6.60% في المتوسط
  • وقت تشغيل النظام المحسَّن: محسَّن بنسبة 1.5% (حوالي 0.8 ثانية) في المتوسط

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

التحقّق ممّا إذا كان تطبيقك متأثرًا بهذا التغيير

إذا كان تطبيقك يستخدم أي رموز برمجية أصلية، يجب عليك إعادة إنشاء تطبيقك مع دعم الأجهزة التي بحجم 16 كيلوبايت. إذا لم تكن متأكدًا مما إذا كان تطبيقك يستخدم رمزًا برمجيًا أصليًا، يمكنك استخدام أداة تحليل APK لتحديد ما إذا كان هناك أي رمز أصلي أم لا.

إذا كان تطبيقك لا يستخدم إلا رمزًا برمجيًا مكتوبًا بلغة برمجة Java أو بلغة Kotlin، بما في ذلك جميع المكتبات أو حِزم SDK، يعني ذلك أنّ تطبيقك سيكون متوافقًا مع الأجهزة التي يبلغ حجمها 16 كيلوبايت. ومع ذلك، ننصحك باختبار تطبيقك في بيئة بحجم 16 كيلوبايت للتأكّد من عدم حدوث تراجعات غير متوقّعة في سلوك التطبيق.

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

المساحة الخاصة هي ميزة جديدة في 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

تم استخدام ملف خط الرموز التعبيرية القديم (NotoColorEmojiLegacy.ttf) المستند إلى PNG إزالة الملف، مع ترك الملف القائم على المتجه فقط. بدءًا من نظام التشغيل Android 13 (واجهة برمجة التطبيقات) المستوى 33)، يتم تغيير ملف خط الرموز التعبيرية الذي يستخدمه عارض الرموز التعبيرية للنظام من ملف مستند إلى PNG إلى ملف مستند إلى متجه تم الاحتفاظ بالنظام ملف الخط القديم في Android 13 وAndroid 14 لأسباب تتعلق بالتوافق، يمكن للتطبيقات التي لديها برامج عرض خطوط خاصة بها مواصلة استخدام ملف الخطوط القديم حتى يتمكنوا من الترقية.

وللتحقّق مما إذا كان تطبيقك متأثرًا بالمشكلة، ابحث في رمز التطبيق عن مراجع إلى ملف NotoColorEmojiLegacy.ttf.

يمكنك اختيار تكييف تطبيقك بعدة طرق:

  • استخدِم واجهات برمجة التطبيقات للنظام الأساسي لعرض النص. يمكنك عرض النص على صورة نقطية Canvas واستخدِم هذه البيانات للحصول على صورة أولية إذا لزم الأمر.
  • أضِف دعم خط COLRv1 إلى تطبيقك. مكتبة FreeType المفتوحة المصدر يتوافق مع COLRv1 في الإصدار 2.13.0 أعلى.
  • كحلّ أخير، يمكنك تجميع ملف خطوط الرموز التعبيرية القديمة. (NotoColorEmoji.ttf) إلى حزمة APK، على الرغم من ذلك، لن يحصل تطبيقك على آخر تحديثات الرموز التعبيرية في هذه الحالة. بالنسبة لمزيد من المعلومات، يُرجى الاطّلاع على مشروع Noto Emoji GitHub .

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

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

غالبًا ما تستهدف البرامج الضارة مستويات أدنى من واجهات برمجة التطبيقات بهدف تجاوز إجراءات حماية الخصوصية والأمان التي تم تقديمها في إصدارات Android الأعلى. على سبيل المثال، تستخدم بعض تطبيقات البرامج الضارة targetSdkVersion من أصل 22 لتجنّب الخضوع لنموذج أذونات وقت التشغيل الذي تم تقديمه في عام 2015 في نظام Android 6.0 Marshmallow (مستوى واجهة برمجة التطبيقات 23). يُصعِّب هذا التغيير في نظام التشغيل Android 15 على البرامج الضارة تجنُّب التحسينات في الأمان والخصوصية. تؤدي محاولة تثبيت تطبيق يستهدف مستوى أقل لواجهة برمجة التطبيقات إلى إخفاق التثبيت، مع ظهور رسالة مثل الرسالة التالية في Logcat:

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

على الأجهزة التي تتم ترقيتها إلى Android 15، ستظلّ أي تطبيقات تتضمّن targetSdkVersion أقل من 24 مثبّتة.

إذا كنت بحاجة إلى اختبار تطبيق يستهدف مستوى واجهة برمجة تطبيقات أقدم، استخدِم أمر ADB التالي:

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

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

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

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

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

بدءًا من نظام التشغيل Android 15، عندما يطلب أحد التطبيقات التشغيل المباشر أو الإزالة وبلغ الحد الأقصى للموارد، يلغي النظام صلاحية أي عناصر AudioTrack مفتوحة حاليًا، ما يمنع تنفيذ طلب قناة الإصدار الجديد.

(عادةً ما يتم فتح المقاطع الصوتية المباشرة وتلك غير المستخدمة لتشغيل تنسيقات الصوت المضغوطة. تشمل حالات الاستخدام الشائعة لتشغيل الصوت المباشر بث الصوت المشفر عبر HDMI إلى التلفزيون. تُستخدم مسارات التفريغ عادةً لتشغيل صوت مضغوط على جهاز جوّال مزوَّد بتسريع نظام معالجة البيانات (DSP) للأجهزة).

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

يتضمن Android 15 بعض التغييرات التي تهدف إلى إنشاء صورة تجربة المستخدم السهلة.

ميزة "الصور المتحركة القائمة على التوقّعات" مفعَّلة للتطبيقات التي تم تفعيلها

Beginning in Android 15, the developer option for predictive back animations has been removed. System animations such as back-to-home, cross-task, and cross-activity now appear for apps that have opted in to the predictive back gesture either entirely or at an activity level. If your app is affected, take the following actions:

  • Ensure that your app has been properly migrated to use the predictive back gesture.
  • Ensure that your fragment transitions work with predictive back navigation.
  • Migrate away from animation and framework transitions and use animator and androidx transitions instead.
  • Migrate away from back stacks that FragmentManager doesn't know about. Use back stacks managed by FragmentManager or by the Navigation component instead.

يتم إيقاف التطبيقات المصغّرة عندما يفرض المستخدم إيقافًا لأحد التطبيقات

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

يعيد النظام تفعيل هذه التطبيقات المصغّرة في المرة التالية التي يشغِّل فيها المستخدم التطبيق.

لمزيد من المعلومات، يُرجى الاطّلاع على مقالة التغييرات في حالة إيقاف الطرد.

عمليات الإيقاف نهائيًا

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

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