يتضمّن نظام 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، يتوافق "بروتوكول AOSP" مع الأجهزة التي تم إعدادها لاستخدام حجم صفحة يبلغ 16 كيلوبايت (16 كيلوبايت) الأجهزة). إذا كان تطبيقك يستخدم أي مكتبات NDK، سواء بشكل مباشر أو بشكل غير مباشر من خلال إحدى حِزم SDK، ستحتاج إلى إعادة إنشاء التطبيق يعمل على هذه الأجهزة التي يبلغ حجمها 16 كيلوبايت.
مع استمرار الشركات المصنّعة للأجهزة في تصميم أجهزة تحتوي على كميات أكبر من ذاكرة فعلية (RAM)، ستعتمد العديد من هذه الأجهزة على سعة 16 كيلوبايت ( أكبر في النهاية) لتحسين أداء الجهاز. جارٍ الإضافة بالنسبة إلى الأجهزة التي حجمها 16 كيلوبايت، يمكن تشغيل تطبيقك على هذه الأجهزة وتساعد تطبيقك على الاستفادة من الأداء المرتبط التحسينات. قد لا تعمل التطبيقات على الأجهزة التي يبلغ حجمها 16 كيلوبايت بدون إعادة التجميع. عند إنتاجها في إصدارات Android المستقبلية.
ولمساعدتك على توفير الدعم لتطبيقك، قدّمنا إرشادات حول كيفية التحقق من إذا تأثّر تطبيقك إعادة إنشاء تطبيقك (إن أمكن)، وكيفية اختبار تطبيقك في بيئة بحجم 16 كيلوبايت باستخدام أدوات المحاكاة (بما في ذلك Android 15) صور النظام لمحاكي Android).
الفوائد والمكاسب في الأداء
إنّ الأجهزة التي تم ضبطها بأحجام صفحات تبلغ 16 كيلوبايت تستخدِم ذاكرة أكبر قليلاً في المتوسط، ولكنّها تحصل أيضًا على تحسينات أداء متنوعة لكل من النظام والتطبيقات:
- أوقات أقل لتشغيل التطبيقات أثناء تعرّض النظام لضغط الذاكرة: انخفاض بنسبة 3.16% في المتوسط، مع تحسينات أكثر أهمية (تصل إلى 30%) لبعض التطبيقات التي اختبرناها
- استهلاك مخفض للطاقة أثناء تشغيل التطبيق: خفض بنسبة 4.56% في المتوسط
- تشغيل أسرع للكاميرا: عند بدء تشغيل الجهاز باستخدام درجة حرارة أعلى بنسبة 4.48% في المتوسط، والتشغيل على البارد بسرعة أكبر بنسبة 6.60% في المتوسط
- وقت تشغيل النظام المحسَّن: محسَّن بنسبة 1.5% (حوالي 0.8 ثانية) في المتوسط
تستند هذه التحسينات إلى اختبارنا الأولي، ومن المحتمل أن تختلف النتائج على الأجهزة الفعلية. سنقدم تحليلاً إضافيًا للمكاسب المحتملة للتطبيقات بينما نواصل اختبارنا.
التحقّق ممّا إذا كان تطبيقك متأثرًا بهذا التغيير
如果您的应用使用任何原生代码,则您应重新构建支持 16 KB 设备的应用。如果您不确定自己的应用是否使用了原生代码,可以使用 APK 分析器来确定是否存在任何原生代码。
如果您的应用仅使用以 Java 编程语言或 Kotlin 编写的代码(包括所有库或 SDK),那么该应用已经支持 16 KB 设备。不过,我们建议您在 16 KB 的环境中测试应用,以确认应用行为是否存在意外回归问题。
تغييرات مطلوبة في بعض التطبيقات لإتاحة المساحة الخاصة
المساحة الخاصة هي ميزة جديدة في Android 15 تتيح للمستخدمين إنشاء مساحة منفصلة على أجهزتهم لإبعاد التطبيقات الحساسة عنها من المتطفلين، تحت طبقة مصادقة إضافية. لأن التطبيقات في المساحة الخاصة قد حظرت أذونات الوصول، وتحتاج بعض أنواع التطبيقات إلى للتمكّن من الاطّلاع على التطبيقات والتفاعل معها في إعدادات خصوصية المستخدم مساحة.
جميع التطبيقات
ولأن التطبيقات في المساحة الخاصة يتم الاحتفاظ بها في ملف شخصي منفصل للمستخدم، إلى الملفات الشخصية للعمل، يجب ألا تفترض التطبيقات أن أي ملفات تم تثبيتها نُسخ من التطبيق غير الموجودة في الملف الشخصي الرئيسي متوفرة في ملف العمل. في حال حذف لتطبيقك منطق ذو صلة بتطبيقات ملف العمل التي تضع هذا الافتراض، ستحتاج إلى تعديل هذا المنطق.
تطبيقات طبية
عندما يقفل المستخدم المساحة الخاصة، يتم إيقاف جميع التطبيقات في المساحة الخاصة، ولا يمكن لهذه التطبيقات تنفيذ الأنشطة التي تعمل في المقدّمة أو في الخلفية، بما في ذلك: ويتم عرض الإشعارات. قد يؤثر هذا السلوك بشكل كبير على استخدام وظائف التطبيقات الطبية المثبتة في المساحة الخاصة.
تحذّر تجربة إعداد المساحة الخاصة المستخدمين من أنّ المساحة الخاصة ليست مناسب للتطبيقات التي تحتاج إلى أداء مهم في المقدّمة أو الخلفية الأنشطة، مثل عرض الإشعارات من التطبيقات الطبية ومع ذلك، لا تستطيع التطبيقات تحديد ما إذا كانت تُستخدم في المساحة الخاصة أم لا، لكي لا تتمكّن من عرض تحذير للمستخدم بخصوص هذه الحالة.
لهذه الأسباب، إذا طورت تطبيقًا طبيًا، راجِع الطريقة التي قد تظهر بها هذه الميزة. التأثير في تطبيقك واتخاذ الإجراءات المناسبة، مثل إعلام المستخدمين بعدم تثبيت تطبيقك في المساحة الخاصة لتجنُّب تعطُّل التطبيق المهم والإمكانات.
تطبيقات مشغّل التطبيقات
إذا طورت أحد تطبيقات المشغّل، يجب عليك القيام بما يلي قبل أن تكون التطبيقات في ستكون المساحة الخاصة مرئية:
- يجب تعيين تطبيقك كتطبيق مشغّل التطبيقات التلقائي للجهاز
تمتلك دور
ROLE_HOME
. - يجب أن يفصح تطبيقك عن
ACCESS_HIDDEN_PROFILES
. إذن عادي في ملف البيان لتطبيقك.
يجب أن تتعامل تطبيقات "مشغّل التطبيقات" التي تقدّم بيانًا عن إذن "ACCESS_HIDDEN_PROFILES
" مع
حالات استخدام المساحة الخاصة التالية:
- يجب أن يحتوي تطبيقك على حاوية مشغّل تطبيقات منفصلة للتطبيقات المثبَّتة في
المساحة الخاصة. استخدِم الطريقة
getLauncherUserInfo()
من أجل تحديد نوع الملف الشخصي للمستخدم الذي تتم معالجته. - يجب أن يكون المستخدم قادرًا على إخفاء حاوية المساحة الخاصة وإظهارها.
- يجب أن يتمكّن المستخدم من قفل حاوية المساحة الخاصة وفتح قفلها. استخدام
طريقة
requestQuietModeEnabled()
للقفل (بحلول اجتيازtrue
) أو فتح قفل المساحة الخاصة (من خلال تجاوزfalse
) أثناء القفل، يجب ألا تكون أي تطبيقات في حاوية المساحة الخاصة مرئية أو قابلة للاكتشاف من خلال آليات مثل البحث. يجب أن يسجِّل تطبيقك المستلِم في
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 على
التغييرات التي تمّ إجراؤها في Android 14، وتوسِّع نطاق
لتعزيز الأمان. في نظام التشغيل 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، يمكنك الاطّلاع على صفحة عمليات الإيقاف النهائي.