نظرة عامة على الميزات وواجهات برمجة التطبيقات

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

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

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

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

لمزيد من المعلومات حول أحدث الميزات والحلول المتاحة للمطوّرين في ما يخص الوسائط والكاميرا على Android، يمكنك مشاهدة جلسة إنشاء تجارب حديثة في ما يخص الوسائط والكاميرا على Android من مؤتمر Google I/O.

تحسين الإضاءة المنخفضة

Android 15 引入了弱光增强功能,这是一种自动曝光模式,适用于 Camera 2夜间模式相机扩展。“弱光增强”功能可在光线昏暗的环境下调整预览画面的曝光度。这与夜间模式相机扩展程序创建静态图片的方式不同,因为夜间模式会将一系列照片组合起来,以创建一张经过增强的单张图片。虽然夜间模式非常适合拍摄静态图片,但无法创建连续的帧流,而“低光增强”功能可以。因此,弱光增强功能可启用相机功能,例如:

  • 提供增强型图片预览,以便用户更好地取景拍摄低光照片
  • 在光线不足的情况下扫描二维码

如果您启用“弱光增强”功能,该功能会在光线较弱时自动开启,在光线较强时关闭。

应用可以在光线昏暗的环境下录制预览画面,以保存经过亮度提升的视频。

如需了解详情,请参阅弱光增强

عناصر التحكّم في الكاميرا داخل التطبيق

يضيف نظام التشغيل Android 15 إضافة تتيح التحكّم بشكل أكبر في أجهزة الكاميرا و algoritms على الأجهزة المتوافقة:

  • تعديلات متقدّمة لقوة الفلاش تتيح التحكّم بدقة في كثافة الفلاش في كلا الوضعَين SINGLE و TORCH أثناء التقاط الصور

التحكّم في مساحة HDR

Android 15 会选择适合底层设备功能和面板位深的 HDR 余量。对于包含大量 SDR 内容的网页(例如显示单个 HDR 缩略图的消息应用),此行为最终可能会对 SDR 内容的感知亮度产生不利影响。在 Android 15 中,您可以使用 setDesiredHdrHeadroom 控制 HDR 余量,以便在 SDR 内容和 HDR 内容之间取得平衡。

左侧屏幕上的 SDR 界面元素的亮度似乎比右侧屏幕上的亮度更均匀,这模拟了混合 HDR 和 SDR 内容时可能出现的余量问题。通过调整 HDR 余量,您可以在 SDR 和 HDR 内容之间实现更好的平衡。

التحكّم في مستوى الصوت

يتيح نظام التشغيل Android 15 معيار CTA-2075 لمساعدتك في معرفة تجنب تناقضات ارتفاع الصوت والتأكد من عدم اضطرار المستخدمين إلى ضبط مستوى الصوت عند التبديل بين المحتوى. يستفيد النظام من البيانات خصائص أجهزة الإخراج (سماعات الرأس ومكبرات الصوت) إلى جانب البيانات الوصفية لارتفاع الصوت المتوفرة في محتوى الصوت بتنسيق AAC لضبط ارتفاع الصوت ومستويات ضغط النطاق الديناميكي

لتفعيل هذه الميزة، عليك التأكّد من توفّر البيانات الوصفية لمستوى الصوت في محتوى AAC وتفعيل ميزة النظام الأساسي في تطبيقك. ولإجراء ذلك، عليك إنشاء عنصر LoudnessCodecController من خلال استدعاء طريقة المصنع create مع معرّف جلسة المحتوى الصوتي من AudioTrack المرتبط، ما يؤدي بدوره إلى بدء تطبيق تعديلات الصوت تلقائيًا. يمكنك تمرير OnLoudnessCodecUpdateListener لتعديله أو فلترته معاملات ارتفاع الصوت قبل تطبيقها MediaCodec

// Media contains metadata of type MPEG_4 OR MPEG_D
val mediaCodec = 
val audioTrack = AudioTrack.Builder()
                                .setSessionId(sessionId)
                                .build()
...
// Create new loudness controller that applies the parameters to the MediaCodec
try {
   val lcController = LoudnessCodecController.create(mSessionId)
   // Starts applying audio updates for each added MediaCodec
}

سيتم أيضًا تحديث AndroidX media3 ExoPlayer لاستخدام واجهات برمجة تطبيقات LoudnessCodecController من أجل دمج سلس للتطبيقات

أجهزة MIDI 2.0 الافتراضية

Android 13 添加了对使用 USB 连接 MIDI 2.0 设备的支持,这些设备使用通用 MIDI 数据包 (UMP) 进行通信。Android 15 将 UMP 支持扩展到了虚拟 MIDI 应用,使作曲应用能够像使用 USB MIDI 2.0 设备一样,将虚拟 MIDI 2.0 设备用作控制合成器应用的设备。

فك تشفير برامج AV1 بشكل أكثر كفاءة

شعار dav1d

dav1d هو برنامج فك ترميز AV1 الرائج من VideoLAN، وهو متاح لأجهزة Android التي لا تتيح فك ترميز AV1 في الأجهزة. ويحقّق برنامج dav1d أداءً أفضل بثلاث مرات مقارنةً ببرنامج فك ترميز AV1 القديم، ما يتيح تشغيل محتوى AV1 بدقة عالية لعدد أكبر من المستخدمين، بما في ذلك بعض الأجهزة المنخفضة ومتوسطة المستوى.

يجب أن يوافق تطبيقك على استخدام dav1d من خلال استدعائه بالاسم "c2.android.av1-dav1d.decoder". سيتم استخدام dav1d كبرنامج الترميز والترميز التلقائي لبرنامج AV1 في تحديث لاحق. وتمّت إتاحة هذه الميزة بشكل موحّد ونشرها على أجهزة Android 11 التي تتلقّى تحديثات نظام Google Play.

إنتاجية المطوّرين وأدواتهم

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

تعديلات OpenJDK 17

Android 15 将继续更新 Android 的核心库,以与最新 OpenJDK LTS 版本中的功能保持一致。

其中包含以下主要功能和改进:

这些 API 会通过 Google Play 系统更新在搭载 Android 12(API 级别 31)及更高版本的 10 亿多部设备上更新,以便您以最新的编程功能为目标平台。

تحسينات على ملفات PDF

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

تشمل آخر التحديثات على ميزة عرض ملفات PDF ميزات مثل البحث في ملف PDF مضمّن.

تم نقل PdfRenderer إلى وحدة يمكن تحديثها باستخدام تحديثات نظام Google Play بغض النظر عن إصدار النظام الأساسي، وسنوفّر هذه التغييرات مرة أخرى لنظام التشغيل Android 11 (المستوى 30 من واجهة برمجة التطبيقات) من خلال إنشاء إصدار متوافق قبل Android 15 من واجهة برمجة التطبيقات، والذي يُعرف باسم PdfRendererPreV.

تحسينات على التبديل التلقائي للغات

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

تحسين واجهة برمجة التطبيقات OpenType Variable Font

يعمل نظام التشغيل Android 15 على تحسين سهولة استخدام الخط المتغيّر OpenType. يمكنك إنشاء مثيل FontFamily من خط متغيّر بدون تحديد محاور الوزن باستخدام واجهة برمجة التطبيقات buildVariableFamily. يلغي عارض النص القيمة من المحور wght لمطابقة النص المعروض.

يؤدي استخدام واجهة برمجة التطبيقات إلى تبسيط الرمز البرمجي لإنشاء Typeface بشكل كبير:

Kotlin

val newTypeface = Typeface.CustomFallbackBuilder(
            FontFamily.Builder(
                Font.Builder(assets, "RobotoFlex.ttf").build())
                    .buildVariableFamily())
    .build()

Java

Typeface newTypeface = Typeface.CustomFallbackBuilder(
            new FontFamily.Builder(
                new Font.Builder(assets, "RobotoFlex.ttf").build())
                    .buildVariableFamily())
    .build();

في السابق، لكي تتمكّن من إنشاء Typeface نفسها، كنت تحتاج إلى مزيد من الرموز البرمجية:

Kotlin

val oldTypeface = Typeface.CustomFallbackBuilder(
            FontFamily.Builder(
                Font.Builder(assets, "RobotoFlex.ttf")
                    .setFontVariationSettings("'wght' 400")
                    .setWeight(400)
                    .build())
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 100")
                        .setWeight(100)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 200")
                        .setWeight(200)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 300")
                        .setWeight(300)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 500")
                        .setWeight(500)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 600")
                        .setWeight(600)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 700")
                        .setWeight(700)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 800")
                        .setWeight(800)
                        .build()
                )
                .addFont(
                    Font.Builder(assets, "RobotoFlex.ttf")
                        .setFontVariationSettings("'wght' 900")
                        .setWeight(900)
                        .build()
                ).build()
        ).build()

Java

Typeface oldTypeface = new Typeface.CustomFallbackBuilder(
    new FontFamily.Builder(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 400")
            .setWeight(400)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 100")
            .setWeight(100)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 200")
            .setWeight(200)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 300")
            .setWeight(300)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 500")
            .setWeight(500)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 600")
            .setWeight(600)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 700")
            .setWeight(700)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 800")
            .setWeight(800)
            .build()
    )
    .addFont(
        new Font.Builder(assets, "RobotoFlex.ttf")
            .setFontVariationSettings("'wght' 900")
            .setWeight(900)
            .build()
    )
    .build()
).build();

في ما يلي مثال على كيفية عرض Typeface تم إنشاؤه باستخدام كلّ من واجهتَي برمجة التطبيقات القديمة والجديدة:

مثال على الاختلافات بين عرض الخط الطباعي باستخدام الإصدار الجديد والقديم
واجهات برمجة التطبيقات

في هذا المثال، لا تملك Typeface التي تم إنشاؤها باستخدام واجهة برمجة التطبيقات القديمة القدرة على إنشاء قيم دقيقة لوزن الخط لحالات Font التي تبلغ 350 و450 و550 و650 ، لذا يعود مُنشئ العرض إلى أقرب قيمة لوزن الخط. ففي في هذه الحالة، يتم عرض العدد 300 بدلاً من 350، ويتم عرض 400 بدلاً من 450، وهكذا. في المقابل، فإنّ Typeface الذي تم إنشاؤه باستخدام واجهات برمجة التطبيقات الجديدة ينشئ ديناميكيًا مثيل Font لوزن معين، لذا يتم عرض الترجيحات الدقيقة بقيمة 350، 450 و550 و650 أيضًا.

عناصر تحكّم دقيقة في فواصل الأسطر

بدءًا من Android 15، يمكن لرمز TextView وفاصل السطر الأساسي الحفاظ على الجزء المحدّد من النص في السطر نفسه لتحسين قراءة النص. يمكنك الاستفادة من هذا التخصيص لفاصل السطر باستخدام علامة <nobreak> في موارد السلاسل أو createNoBreakSpan. بالمثل، يمكنك منع الواصلة بين الكلمات باستخدام العلامة <nohyphen> أو العلامة createNoHyphenationSpan.

على سبيل المثال، لا يتضمّن مورد السلسلة التالي فاصل سطر، ويؤدي إلى عرض النص "Pixel 8 Pro" مقطوعًا في مكان غير مرغوب فيه:

<resources>
    <string name="pixel8pro">The power and brains behind Pixel 8 Pro.</string>
</resources>

في المقابل، يتضمّن مورد السلسلة هذا العلامة <nobreak> التي تلتف حول العبارة "Pixel 8 Pro" وتمنع استخدام فواصل الأسطر:

<resources>
    <string name="pixel8pro">The power and brains behind <nobreak>Pixel 8 Pro.</nobreak></string>
</resources>

يظهر الفرق في طريقة عرض هذه السلاسل في الصور التالية:

تنسيق لسطر نص لا يتم فيه لف العبارة "Pixel 8 Pro" باستخدام علامة <nobreak>
تنسيق لسطر النص نفسه الذي تم فيه لفّ العبارة "Pixel 8 Pro" باستخدام علامة <nobreak>

أرشفة التطبيقات

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

يمكن للتطبيقات التي لديها إذن REQUEST_DELETE_PACKAGES طلب البيانات من PackageInstaller requestArchive لطلب أرشفة حزمة تطبيق مثبَّتة تؤدي إلى إزالة حزمة APK وأي ملفات مخزَّنة مؤقتًا ولكنها تظل قائمة بيانات المستخدمين. يتم عرض التطبيقات المؤرشفة كتطبيقات قابلة للعرض من خلال واجهات برمجة التطبيقات LauncherApps، وسيظهر للمستخدمين تنسيق واجهة مستخدم يُبرز أنّه تم أرشفة هذه التطبيقات. إذا نقر أحد المستخدمين على تطبيق مؤرشَف، يكون أداة التثبيت المسؤولة طلبًا لـ إخراجه من الأرشيف، ويمكن إكمال عملية استعادته المراقبة بواسطة بث ACTION_PACKAGE_ADDED.

تفعيل الوضع 16 كيلوبايت على جهاز باستخدام خيارات المطوّرين

فعِّل خيار المطوّر التشغيل مع صفحات حجمها 16 كيلوبايت لتشغيل الجهاز في وضع 16 كيلوبايت.

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

يتوفّر خيار المطوّرين هذا على الأجهزة التالية:

  • ‫Pixel 8 وPixel 8 Pro (مع الإصدار 1 من حزمة إصلاح الأخطاء في نظام Android 15 أو إصدار أحدث)

  • ‫Pixel 8a (مع الإصدار 1 من حزمة إصلاح الأخطاء في نظام Android 15 أو إصدار أحدث)

  • ‫Pixel 9 و‎9 Pro و‎9 Pro XL (مع الإصدار التجريبي 2 من حزمة Android 15 QPR2 أو إصدار أحدث)

الرسومات

يوفّر Android 15 أحدث التحسينات على الرسومات، بما في ذلك ANGLE وإضافات إلى نظام رسومات Canvas.

تحديث طريقة وصول Android إلى وحدة معالجة الرسومات

Vulkan 徽标

与早期相比,Android 硬件已经有了很大的进步。早期,核心操作系统在单个 CPU 上运行,并且使用基于固定功能流水线的 API 访问 GPU。从 Android 7.0(API 级别 24)开始,NDK 中就提供了 Vulkan® 图形 API,其较低级别的抽象更好地反映了现代 GPU 硬件,可更好地扩缩以支持多个 CPU 核心,并可降低 CPU 驱动程序开销,从而提升应用性能。所有现代游戏引擎都支持 Vulkan。

Vulkan 是 Android 与 GPU 的首选接口。因此,Android 15 包含 ANGLE 作为可选层,用于在 Vulkan 基础上运行 OpenGL® ES。改用 ANGLE 将标准化 Android OpenGL 实现,提高兼容性,在某些情况下还有助于提升性能。在 Android 15 中,您可以依次前往设置 -> 系统 -> 开发者选项 -> 实验性功能:启用 ANGLE,启用开发者选项,以便通过 ANGLE 测试 OpenGL ES 应用的稳定性和性能。

Android ANGLE on Vulkan 路线图

Android GPU API 即将发生变更的路线图。

为了简化 GPU 堆栈,我们今后将在更多新设备上将 ANGLE 作为 GL 系统驱动程序提供,未来 OpenGL/ES 将只能通过 ANGLE 获得支持。尽管如此,我们计划继续在所有设备上支持 OpenGL ES

建议的后续措施

使用开发者选项为 OpenGL ES 选择 ANGLE 驱动程序,然后测试您的应用。对于新项目,我们强烈建议您为 C/C++ 使用 Vulkan。

تحسينات على Canvas

يواصل نظام Android 15 جهودنا لتطوير نظام الرسومات Canvas في Android من خلال إضافة ميزات إضافية:

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

الأداء والبطارية

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

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

ApplicationStartInfo API

في الإصدارات السابقة من Android، كان تشغيل التطبيقات عملية غير معروفة إلى حدٍ ما. كان من الصعوبة تحديد ما إذا كان تطبيقك قد بدأ من حالة التشغيل على البارد أو إعادة التشغيل البطيء أو إعادة التشغيل السريع. كان من الصعب أيضًا معرفة المدة التي استغرقها تطبيقك أثناء مراحل الإطلاق المختلفة: إنشاء نسخة من العملية، واستدعاء onCreate، ورسم الإطار الأول، وغير ذلك. عند إنشاء مثيل لفئة Application، لم يكن لديك طريقة لمعرفة ما إذا كان التطبيق قد بدأ من بث أو مقدّم محتوى أو عملية أو خدمة احتياطية أو اكتمال عملية التمهيد أو منبّه أو Activity.

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

معلومات مفصّلة عن حجم التطبيق

منذ الإصدار 8.0 من Android (المستوى 26 لواجهة برمجة التطبيقات)، يتضمّن Android واجهة برمجة التطبيقات StorageStats.getAppBytes التي تلخّص حجم التطبيق المثبَّت كعدد واحد من البايتات، وهو مجموع حجم حزمة APK وحجم الملفات المستخرَجة من حزمة APK والملفات التي تم إنشاؤها على الجهاز، مثل الرموز البرمجية المجمَّعة مسبقًا (AOT). لا يقدّم هذا الرقم معلومات مفيدة بشأن كيفية استخدام تطبيقك لمساحة التخزين.

يضيف نظام التشغيل Android 15 واجهة برمجة التطبيقات StorageStats.getAppBytesByDataType([type])، التي تتيح لك الحصول على إحصاءات عن كيفية استخدام تطبيقك لكل هذه المساحة، بما في ذلك عمليات تقسيم ملف APK، والرموز البرمجية ذات الصلة بميزة AOT والتسريع، والبيانات الوصفية لملف dex، والمكتبات، والملفات الشخصية الإرشادية.

تحديد المواصفات الشخصية لصاحب البيانات من خلال التطبيق

Android 15 includes the ProfilingManager class, which lets you collect profiling information from within your app such as heap dumps, heap profiles, stack sampling, and more. It provides a callback to your app with a supplied tag to identify the output file, which is delivered to your app's files directory. The API does rate limiting to minimize the performance impact.

To simplify constructing profiling requests in your app, we recommend using the corresponding Profiling AndroidX API, available in Core 1.15.0-rc01 or higher.

تحسينات على قاعدة بيانات SQLite

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

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

  • المعاملات المؤجلة للقراءة فقط: عند إصدار معاملات للقراءة فقط (لا تتضمّن عبارات كتابة)، استخدِم beginTransactionReadOnly() و beginTransactionWithListenerReadOnly(SQLiteTransactionListener) لإصدار معاملات DEFERRED للقراءة فقط. يمكن تنفيذ هذه المعاملات بالتزامن مع بعضها، وإذا كانت قاعدة البيانات في وضع WAL، يمكن تنفيذها بالتزامن مع معاملات IMMEDIATE أو EXCLUSIVE.
  • أعداد الصفوف وأرقام التعريف: تمت إضافة واجهات برمجة التطبيقات لاسترداد عدد الصفوف التي تم تغييرها أو رقم تعريف الصف الذي تم إدراجه مؤخرًا بدون إصدار طلب بحث إضافي. تعرض getLastChangedRowCount() عدد الصفوف التي قد تم إدراجها أو تحديثها أو حذفها من خلال أحدث عبارة SQL في المعاملة الحالية، في حين أنّ getTotalChangedRowCount() يعرض العدد على الاتصال الحالي. تعرض دالة getLastInsertRowId() rowid للصف الأخير لإدراجه في الربط الحالي.
  • الكشوف الأولية: إصدار عبارة SQlite أولية لتجاوز سهولة الاستخدام والبرامج الأخرى وأي نفقات معالجة إضافية قد تتكبدها.

تحديثات "إطار عمل الأداء الديناميكي" في Android

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

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

للاطّلاع على مزيد من المعلومات عن كيفية استخدام ميزة "الإعلانات الديناميكية على شبكة البحث" في تطبيقاتك وألعابك، يمكنك الانتقال إلى مستندات المساعدة.

الخصوصية

يتضمّن نظام التشغيل Android 15 مجموعة متنوّعة من الميزات التي تساعد مطوّري التطبيقات في حماية خصوصية المستخدمين.

رصد تسجيل الشاشة

Android 15 增加了对应用的支持,以检测 正在录制。每当应用转换时,系统都会调用回调 在屏幕录制内容中处于可见与隐藏状态之间。如果正在记录注册进程的 UID 拥有的 activity,则系统会将应用视为可见。这样一来,如果您的应用执行敏感操作,您就可以告知用户正在录制他们的操作。

val mCallback = Consumer<Int> { state ->
  if (state == SCREEN_RECORDING_STATE_VISIBLE) {
    // We're being recorded
  } else {
    // We're not being recorded
  }
}

override fun onStart() {
   super.onStart()
   val initialState =
      windowManager.addScreenRecordingCallback(mainExecutor, mCallback)
   mCallback.accept(initialState)
}

override fun onStop() {
    super.onStop()
    windowManager.removeScreenRecordingCallback(mCallback)
}

إمكانات IntentFilter الموسّعة

يتيح Android 15 توفير دقة Intent بدرجة أكبر من خلال واجهة برمجة التطبيقات UriRelativeFilterGroup التي تتضمّن مجموعة من عناصر UriRelativeFilter التي تشكّل مجموعة من قواعد Intent مطابقة يجب استيفاؤها، بما في ذلك مَعلمات طلب البحث لعناوين URL وأجزاء عناوين URL وقواعد الحظر أو الاستبعاد.

يمكن تحديد هذه القواعد في ملف XML الخاص بـ AndroidManifest باستخدام العلامة <uri-relative-filter-group> التي يمكن أن تتضمّن اختياريًا علامة android:allow. يمكن أن تحتوي هذه العلامات على علامات <data> تستخدِم سمات علامات بيانات الحالية بالإضافة إلى سمتَي android:query وandroid:fragment.

في ما يلي مثال على بنية AndroidManifest:

<intent-filter android:autoVerify="true">
  <action android:name="android.intent.action.VIEW" />
  <category android:name="android.intent.category.BROWSABLE" />
  <category android:name="android.intent.category.DEFAULT" />
  <data android:scheme="http" />
  <data android:scheme="https" />
  <data android:host="astore.com" />
  <uri-relative-filter-group>
    <data android:pathPrefix="/auth" />
    <data android:query="region=na" />
  </uri-relative-filter-group>
  <uri-relative-filter-group android:allow="false">
    <data android:pathPrefix="/auth" />
    <data android:query="mobileoptout=true" />
  </uri-relative-filter-group>
  <uri-relative-filter-group android:allow="false">
    <data android:pathPrefix="/auth" />
    <data android:fragmentPrefix="faq" />
  </uri-relative-filter-group>
</intent-filter>

المساحة الخاصّة

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

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

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

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

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

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

طلب آخر اختيار للمستخدم في ما يخصّ إذن الوصول إلى "الصور المحدّدة"

يمكن للتطبيقات الآن إبراز الصور والفيديوهات التي تم اختيارها مؤخرًا فقط عند منح التطبيقات إذن وصول جزئي إلى أذونات الوصول إلى الوسائط. يمكن أن تحسِّن هذه الميزة تجربة المستخدم للتطبيقات التي تطلب الوصول إلى الصور والفيديوهات بشكل متكرر. لاستخدام هذه الميزة في تطبيقك، فعِّل الوسيطة QUERY_ARG_LATEST_SELECTION_ONLY عند طلب MediaStore من خلال ContentResolver.

Kotlin

val externalContentUri = MediaStore.Files.getContentUri("external")

val mediaColumns = arrayOf(
   FileColumns._ID,
   FileColumns.DISPLAY_NAME,
   FileColumns.MIME_TYPE,
)

val queryArgs = bundleOf(
   // Return only items from the last selection (selected photos access)
   QUERY_ARG_LATEST_SELECTION_ONLY to true,
   // Sort returned items chronologically based on when they were added to the device's storage
   QUERY_ARG_SQL_SORT_ORDER to "${FileColumns.DATE_ADDED} DESC",
   QUERY_ARG_SQL_SELECTION to "${FileColumns.MEDIA_TYPE} = ? OR ${FileColumns.MEDIA_TYPE} = ?",
   QUERY_ARG_SQL_SELECTION_ARGS to arrayOf(
       FileColumns.MEDIA_TYPE_IMAGE.toString(),
       FileColumns.MEDIA_TYPE_VIDEO.toString()
   )
)

Java

Uri externalContentUri = MediaStore.Files.getContentUri("external");

String[] mediaColumns = {
    FileColumns._ID,
    FileColumns.DISPLAY_NAME,
    FileColumns.MIME_TYPE
};

Bundle queryArgs = new Bundle();
queryArgs.putBoolean(MediaStore.QUERY_ARG_LATEST_SELECTION_ONLY, true);
queryArgs.putString(MediaStore.QUERY_ARG_SQL_SORT_ORDER, FileColumns.DATE_ADDED + " DESC");
queryArgs.putString(MediaStore.QUERY_ARG_SQL_SELECTION, FileColumns.MEDIA_TYPE + " = ? OR " + FileColumns.MEDIA_TYPE + " = ?");
queryArgs.putStringArray(MediaStore.QUERY_ARG_SQL_SELECTION_ARGS, new String[] {
    String.valueOf(FileColumns.MEDIA_TYPE_IMAGE),
    String.valueOf(FileColumns.MEDIA_TYPE_VIDEO)
});

"مبادرة حماية الخصوصية" على Android

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

Health Connect

Android 15 集成了与 Health Connect by Android 相关的最新扩展程序。Health Connect by Android 是一个安全的集中式平台,可用于管理和共享应用收集的健康与健身数据。此次更新 增加了对健身营养、体表温度、训练计划等。

体表温度追踪功能让用户可以更精确地存储和分享体表温度 来自穿戴式设备或其他跟踪设备的体温数据。

训练计划是一种结构化的锻炼计划,可帮助用户实现健身目标。训练计划支持各种完成和表现目标:

如需详细了解 Android 中 Health Connect 的最新更新,请参阅 利用 Android 打造自适应体验 健康演讲。

مشاركة شاشة التطبيق

يتيح نظام التشغيل Android 15 مشاركة شاشة التطبيق كي يتمكّن المستخدمون من مشاركة أو تسجيل نافذة التطبيق فقط بدلاً من شاشة الجهاز بالكامل. تم تفعيل هذه الميزة لأول مرة في ملف APK لنظام التشغيل Android 14 QPR2، وتشمل MediaProjection طلبات إعادة الاتصال التي تسمح لتطبيقك بتخصيص تجربة مشاركة شاشة التطبيق. يُرجى العلم أنّه بالنسبة إلى التطبيقات التي تستهدف الإصدار 14 من Android (المستوى 34 لواجهة برمجة التطبيقات) أو الإصدارات الأحدث، يجب الحصول على موافقة المستخدم لكل جلسة رصد MediaProjection.

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

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

لمزيد من المعلومات حول كيفية استخدام أحدث التحسينات في Android 15 لتحسين تجربة المستخدم في تطبيقك، يمكنك مشاهدة جلسة تحسين تجربة المستخدم في تطبيق Android من مؤتمر Google I/O.

معاينات تطبيقات مصغّرة أكثر تفصيلاً باستخدام Generated Previews API

在 Android 15 之前,提供微件选择器预览的唯一方法是指定静态图片或布局资源。这些预览通常与放置在主屏幕上的实际 widget 的外观大不相同。此外,由于无法使用 Jetpack Glance 创建静态资源,因此“资讯一览” 开发者必须为其微件截屏或创建 XML 布局, 微件预览。

Android 15 添加了对生成的预览的支持。这意味着,应用微件提供程序可以生成 RemoteViews 以用作选择器预览,而不是静态资源。

应用可以向微件选择器提供远程视图, 更新选择器中的内容,使其更能代表用户的内容 看到的内容。

推送 API

应用可以通过推送 API 提供生成的预览。应用可以提供 预览,并且不会收到明确的请求, 以提供预览。预览会保留在 AppWidgetService 中,并且主持人可以按需请求预览。以下示例加载了一个 XML 微件 并将其设置为预览:

AppWidgetManager.getInstance(appContext).setWidgetPreview(
   ComponentName(
       appContext,
       SociaLiteAppWidgetReceiver::class.java
   ),
   AppWidgetProviderInfo.WIDGET_CATEGORY_HOME_SCREEN,
   RemoteViews("com.example", R.layout.widget_preview)
)

预期的流程如下:

  1. 任何时候,widget 提供程序都会调用 setWidgetPreview。提供的预览会与其他提供方信息一起保留在 AppWidgetService 中。
  2. setWidgetPreview 会通过 AppWidgetHost.onProvidersChanged 回调。作为回应,微件宿主会重新加载其所有提供方信息。
  3. 显示微件预览时,主机会检查 AppWidgetProviderInfo.generatedPreviewCategories,如果所选类别可用,则调用 AppWidgetManager.getWidgetPreview 以返回此提供程序的已保存预览。

何时调用 setWidgetPreview

由于没有用于提供预览的回调,因此应用可以选择在运行期间的任何时间发送预览。预览的更新频率取决于微件的用例。

以下列表介绍了两大类预览用例:

  • 在 widget 预览中显示真实数据(例如个性化数据)的提供程序 或最新信息。这些提供商可以设置预览 已登录 Google 账号或已在其应用中完成初始配置。之后 可以设置一项定期任务,按照所选的节奏更新预览。 此类 widget 的示例包括照片、日历、天气或新闻 widget。
  • 在预览中显示静态信息或不显示任何数据的快捷操作 widget 的提供程序。这些提供程序可以在应用首次启动时设置预览一次。例如,快速开车便是此类微件的示例 操作 widget 或 Chrome 快捷方式 widget。

某些提供商可能会在基座接入模式选择器上显示静态预览,但真实的 信息。这些提供商应遵循指南 设置预览

نافذة ضمن النافذة

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

يستخدم المطوّرون دالة استدعاء onPictureInPictureModeChanged لتحديد المنطق. يعمل على تبديل مستوى رؤية عناصر واجهة المستخدم المركّبة. يتم بدء عملية الاستدعاء هذه عند اكتمال الصورة المتحركة لدخول وضع "صورة في صورة" أو الخروج منه. تبدأ في Android 15، تتضمن فئة PictureInPictureUiState ولاية أخرى.

من خلال حالة واجهة المستخدم هذه، ستتتبّع التطبيقات التي تستهدف الإصدار 15 من نظام التشغيل Android (المستوى 35 لواجهة برمجة التطبيقات) تم استدعاء استدعاء Activity#onPictureInPictureUiStateChanged باستخدام isTransitioningToPip() عند بدء الصورة المتحركة في "نافذة ضمن النافذة" (PIP). هناك العديد من عناصر واجهة المستخدم التي لا تكون ملائمة للتطبيق عندما يكون في وضع "صورة في صورة"، على سبيل المثال، المعروضات أو التنسيقات التي تتضمّن معلومات مثل الاقتراحات والفيديوهات القادمة والتقييمات والعناوين. عند انتقال التطبيق إلى وضع "نافذة ضمن النافذة"، استخدِم onPictureInPictureUiStateChanged لإخفاء عناصر واجهة المستخدم هذه. عندما ينتقل التطبيق إلى وضع ملء الشاشة من نافذة "نافذة ضمن النافذة"، استخدِم استدعاء onPictureInPictureModeChanged لإظهار هذه العناصر، كما هو موضح في في ما يلي الأمثلة التالية:

override fun onPictureInPictureUiStateChanged(pipState: PictureInPictureUiState) {
        if (pipState.isTransitioningToPip()) {
          // Hide UI elements
        }
    }
override fun onPictureInPictureModeChanged(isInPictureInPictureMode: Boolean) {
        if (isInPictureInPictureMode) {
          // Unhide UI elements
        }
    }

يساعد هذا التبديل السريع لعناصر واجهة المستخدم غير ذات الصلة (لتشغيل نافذة PiP) في ضمان ظهور رسوم متحركة سلسة وبدون وميض عند تشغيل وضع PiP.

قواعد محسّنة لميزة "عدم الإزعاج"

AutomaticZenRule يسمح للتطبيقات بتخصيص "الانتباه" قواعد الإدارة (عدم الإزعاج) وتحديد وقت التفعيل أو الإيقاف معهم. ويقدم Android 15 تحسينات كبيرة على هذه القواعد بهدف تحسين تجربة المستخدم. تم تضمين التحسينات التالية:

  • إضافة أنواع إلى AutomaticZenRule، ما يسمح للنظام بتطبيق إجراءات خاصة التعامل مع بعض القواعد.
  • إضافة رمز إلى AutomaticZenRule، ما يساعد في تمييز الأوضاع بشكلٍ أفضل
  • إضافة سلسلة triggerDescription إلى AutomaticZenRule تصف الشروط التي يجب أن تصبح فيها القاعدة نشطة للمستخدم
  • تمت الإضافة ZenDeviceEffects على AutomaticZenRule، ما يسمح للقواعد بتشغيل أشياء مثل التدرج الرمادي العرض أو الوضع الليلي أو تعتيم الخلفية.

ضبط VibrationEffect لقنوات الإشعارات

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

شريحة شريط الحالة لعرض الوسائط والإيقاف التلقائي

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

شريحة شريط الحالة لمشاركة الشاشة والبث والتسجيل

الشاشات الكبيرة وأشكال الأجهزة

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

تحسين تعدُّد المهام على الشاشات الكبيرة

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

جلسات مؤتمر Google I/O حول تصميم Android التكيُّفي التطبيقات وواجهة مستخدم المبنى باستخدام Material 3 المكتبة التكيّفية التي يمكن أن تساعدك، كما توفر مستنداتنا المزيد من المساعدة لتصميم مواقع الشاشات

إمكانية استخدام الشاشة الخارجية

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

إمكانية الاتصال

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

التوافق مع الأقمار الصناعية

يواصل نظام Android 15 توسيع نطاق توفّر المنصة للاتصال عبر الأقمار الصناعية ويضمّ بعض عناصر واجهة المستخدم لضمان تجربة مستخدم متّسقة على مستوى منظومة الاتصال عبر الأقمار الصناعية.

يمكن للتطبيقات استخدام ServiceState.isUsingNonTerrestrialNetwork() لرصد الحالات التي يكون فيها الجهاز متصلاً بأحد الأقمار الصناعية، ما يمنح التطبيقات المزيد من المعلومات عن سبب عدم توفّر خدمات الشبكة الكاملة. بالإضافة إلى ذلك، يقدّم الإصدار 15 من Android توافقًا مع تطبيقات الرسائل القصيرة ورسائل الوسائط المتعددة، بالإضافة إلى تطبيقات RCS المحمَّلة مسبقًا لاستخدام الاتصال عبر الأقمار الصناعية لإرسال الرسائل واستلامها.

سيظهر إشعار عندما يتصل الجهاز بالقمر الصناعي.

تجارب أكثر سلاسة باستخدام تقنية NFC

Android 15 正在努力打造更顺畅、更可靠的感应式付款体验,同时继续支持 Android 强大的 NFC 应用生态系统。在受支持的设备上,应用可以请求 NfcAdapter 进入观察模式,在该模式下,设备会监听但不会响应 NFC 读卡器,并将应用的 NFC 服务 PollingFrame 对象发送以进行处理。PollingFrame 对象可用于在与 NFC 读卡器进行首次通信之前进行身份验证,在许多情况下,这支持一触式交易。

此外,应用可以在受支持的设备上注册过滤器,以便在有轮询循环活动时收到通知,从而能够与多个感知 NFC 的应用顺畅运行。

دور المحفظة

يقدّم نظام التشغيل Android 15 دور "محفظة" يتيح دمجًا أكثر انسجامًا مع تطبيق المحفظة المفضّل لدى المستخدم. ويحلّ هذا الدور محلّ إعداد الدفع بدون تلامس الأجهزة التلقائي عبر تقنية NFC. يمكن للمستخدمين إدارة حامل دور "محفظة Google" من خلال الانتقال إلى الإعدادات > التطبيقات > التطبيقات التلقائية.

يتم استخدام دور "محفظة Google" عند توجيه عمليات النقر باستخدام تقنية NFC لأرقام تعريف العملاء المسجّلة في فئة الدفع. يتم دائمًا توجيه النقرات إلى حامل دور "محفظة Google" ما لم يكن هناك تطبيق آخر مسجَّل للمعرّف الإعلاني نفسه قيد التشغيل في المقدّمة.

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

الأمان

يساعدك نظام التشغيل Android 15 في تعزيز أمان تطبيقك وحماية بياناته، كما يوفّر للمستخدمين المزيد من الشفافية والتحكّم في بياناتهم. يمكنك مشاهدة جلسة الحفاظ على أمان المستخدمين على Android من مؤتمر Google I/O للتعرّف على المزيد من الإجراءات التي نتّخذها لتحسين وسائل حماية المستخدمين وحماية تطبيقك من التهديدات الجديدة.

دمج Credential Manager مع ميزة "الملء التلقائي"

从 Android 15 开始,开发者可以将用户名或密码字段等特定视图与 Credential Manager 请求相关联,从而更轻松地在登录过程中提供量身定制的用户体验。当用户聚焦于其中一个视图时,系统会向 Credential Manager 发送相应请求。系统会汇总来自各个提供商的凭据,并在自动填充后备界面(例如内嵌建议或下拉菜单建议)中显示这些凭据。Jetpack androidx.credentials 库是开发者首选的端点,很快将在 Android 15 及更高版本中推出,以进一步增强此功能。

دمج ميزة "نقرة واحدة لتسجيل الدخول أو إنشاء حساب" مع طلبات المقاييس الحيوية

Credential Manager将生物识别提示集成到凭据创建过程中 和登录流程,这样提供商就无需管理 生物识别提示。因此,凭据提供程序只需专注于创建和获取流程的结果,并辅以生物识别流程结果。这一简化的流程创建了更高效、更精简的凭据 创建和检索过程。

إدارة المفاتيح للتشفير التام بين الأطراف

نقدّم E2eeContactKeysManager في Android 15، وهو تنسيق ملف يسهّل التشفير التام بين الأطراف (E2EE) في تطبيقات Android من خلال توفير واجهة برمجة تطبيقات على مستوى نظام التشغيل لتخزين المفاتيح العامة للتشفير.

تم تصميم E2eeContactKeysManager للدمج مع تطبيق جهات الاتصال في النظام الأساسي لمنح المستخدمين طريقة مركزية لإدارة مفاتيحهم المفتوحة لجهات الاتصال وإثبات ملكيتها.

عمليات التحقّق من الأذونات على معرّفات الموارد المنتظمة للمحتوى

يقدّم الإصدار 15 من Android مجموعة من واجهات برمجة التطبيقات التي تُجري عمليات التحقّق من الأذونات في عناوين محتوى URI:

  • Context.checkContentUriPermissionFull: يؤدي هذا الإجراء إلى التحقّق من الأذونات بالكامل في معرّفات الموارد المنتظمة للمحتوى.
  • Activity سمة البيان requireContentUriPermissionFromCaller: تفرض هذه السمة أذونات محدّدة على معرّفات الموارد المنتظمة للمحتوى المقدّمة عند بدء النشاط.
  • فئة ComponentCaller لمُتصلي Activity: يمثّل هذا التطبيق الذي بدأ النشاط.

تسهيل الاستخدام

يضيف Android 15 ميزات تعمل على تحسين إمكانية الوصول للمستخدمين.

تحسينات على لغة برايل

في الإصدار 15 من نظام التشغيل Android، أصبح بإمكان TalkBack إتاحة استخدام شاشات برايل التي تستخدم معيار HID عبر USB وBluetooth الآمن.

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

التوافق مع أسواق عالمية

يضيف Android 15 ميزات وإمكانات تكمل تجربة المستخدم عند استخدام الجهاز بلغات مختلفة.

خط CJK متغيّر

اعتبارًا من الإصدار 15 من Android، أصبح ملف الخط NotoSansCJK المخصّص للغات الصينية واليابانية والكورية (CJK) خطًا متغيّرًا. توفّر الخطوط المتغيّرة إمكانيات لتصميمات الطباعة الإبداعية بلغات CJK. يمكن للمصمّمين استكشاف مجموعة أوسع من الأنماط وإنشاء تنسيقات مميّزة من الناحية المرئية كانت في السابق صعبة أو مستحيلة.

طريقة ظهور الخط المتغيّر للغات الصينية واليابانية والكورية (CJK) بعرض خطوط مختلف

ضبط المسافة بين الأحرف

بدءًا من الإصدار 15 من Android، يمكن ضبط النص على الاتّجاه الأيمن باستخدام ميزة "محوّر المسافة بين الأحرف" من خلال استخدام JUSTIFICATION_MODE_INTER_CHARACTER. كان التبرير بين الكلمات تم تقديمه لأول مرة في Android 8.0 (المستوى 26 من واجهة برمجة التطبيقات)، وبين الأحرف التبرير إمكانات مماثلة للغات التي تستخدم حرف المسافة البيضاء للتقسيم، مثل الصينية واليابانية وغيرها.

تنسيق للنص الياباني باستخدام JUSTIFICATION_MODE_NONE
تنسيق للنص باللغة الإنجليزية باستخدام JUSTIFICATION_MODE_NONE


تنسيق للنص الياباني باستخدام JUSTIFICATION_MODE_INTER_WORD
تنسيق للنص باللغة الإنجليزية باستخدام JUSTIFICATION_MODE_INTER_WORD


تنسيق للنص الياباني باستخدام JUSTIFICATION_MODE_INTER_CHARACTER
تنسيق النص باللغة الإنجليزية باستخدام JUSTIFICATION_MODE_INTER_CHARACTER

إعدادات الفواصل التلقائية بين الأسطر

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

بالنسبة إلى الأسطر القصيرة من النص، يتم استخدام فواصل الأسطر المستندة إلى العبارة، وتعمل بالطريقة نفسها كـ LINE_BREAK_WORD_STYLE_PHRASE، كما هو موضح في الصورة التالية:

بالنسبة إلى سطور النص القصيرة، LINE_BREAK_WORD_STYLE_AUTO يطبق فواصل الأسطر المستندة إلى العبارة لتحسين سهولة قراءة النص. هذا مماثل لتطبيق LINE_BREAK_WORD_STYLE_PHRASE.

بالنسبة إلى أسطر النص الأطول، يستخدم LINE_BREAK_WORD_STYLE_AUTO نمط كلمات بدون فاصل سطر، ويعمل بالطريقة نفسها التي يعمل بها LINE_BREAK_WORD_STYLE_NONE، كما هو موضّح في الصورة التالية:

بالنسبة إلى سطور النص الطويلة، LINE_BREAK_WORD_STYLE_AUTO عدم تطبيق أي نمط من أنماط الكلمات بفواصل أسطر لتحسين إمكانية قراءة النص. هذا مماثل لتطبيق LINE_BREAK_WORD_STYLE_NONE.

خط إضافي للغة اليابانية Hentaigana

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

نمط الحروف والنص للغة الهنتايغانا اليابانية الخط.

VideoLAN cone Copyright (c) 1996-2010 VideoLAN. يمكن لأي شخص استخدام هذا الشعار أو نسخة معدَّلة منه أو تعديله للإشارة إلى مشروع VideoLAN أو أي منتج طوَّره فريق VideoLAN، ولكن لا يشير ذلك إلى موافقة المشروع.

Vulkan وشعار Vulkan علامتان تجاريتان مسجّلتان لشركة Khronos Group Inc.

OpenGL هي علامة تجارية مسجّلة وشعار OpenGL ES هو علامة تجارية تابعة للشركة Hewlett Packard Enterprise وتستخدمها شركة Khronos بموجب إذن.