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

يتضمّن نظام 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 كيلوبايت فقط، وقد تم تحسين أداء ذاكرة النظام لمتوسط إجمالي حجم الذاكرة الذي تستخدمه أجهزة 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. يجب أن يحتوي تطبيقك على حاوية مشغّل تطبيقات منفصلة للتطبيقات المثبّتة في المساحة الخاصّة.
  2. يجب أن يكون المستخدم قادرًا على إخفاء حاوية المساحة الخاصة وإظهارها.
  3. يجب أن يتمكّن المستخدم من قفل حاوية المساحة الخاصة وفتح قفلها.
  4. أثناء قفل الشاشة، يجب ألا تكون أي تطبيقات في حاوية المساحة الخاصة مرئية أو قابلة للاكتشاف من خلال آليات مثل البحث.

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

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

تمت زيادة الحد الأدنى لإصدار حزمة تطوير البرامج (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 بعض التغييرات التي تهدف إلى توفير تجربة مستخدم أكثر اتساقًا وبساطة.

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

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

  • يجب التأكّد من نقل تطبيقك بشكل صحيح لاستخدام إيماءة الرجوع التنبؤي.
  • تأكَّد من أنّ انتقالات الأجزاء تعمل مع ميزة التنقّل التنبؤي إلى الوراء.
  • ويمكنك الانتقال بعيدًا عن الرسوم المتحركة وإطار العمل واستخدام انتقالات الصور المتحركة وandroidx بدلاً من ذلك.
  • نقل البيانات بعيدًا عن الحِزم السابقة التي لا يعرفها "FragmentManager" يمكنك استخدام الحزم الخلفية التي يديرها FragmentManager أو من خلال مكوِّن التنقل بدلاً من ذلك.

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

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

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

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

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

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

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