يقدّم نظام التشغيل 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، مثل تطبيق مراسلة يعرض صورة مصغّرة واحدة بنطاق عالي الديناميكية، يمكن أن يؤدي هذا السلوك إلى التأثير سلبًا في السطوع المُلاحظ لمحتوى SDR. يتيح لك نظام التشغيل Android 15 التحكّم في الحد الأقصى لمستوى الإضاءة في تقنية HDR باستخدام رمز
setDesiredHdrHeadroom
لتحقيق التوازن بين المحتوى المعروض بتقنية SDR
وتقنية HDR.

التحكّم في مستوى الصوت
Android 15 引入了对 CTA-2075 响度标准的支持,可帮助您避免音频响度不一致,并确保用户在切换内容时不必不断调整音量。系统利用输出设备(头戴式耳机和扬声器)的已知特性以及 AAC 音频内容中提供的响度元数据,智能调整音频响度和动态范围压缩级别。
如需启用此功能,您需要确保 AAC 内容中提供响度元数据,并在应用中启用平台功能。为此,您可以通过使用关联的 AudioTrack
中的音频会话 ID 调用其 create 工厂方法来实例化 LoudnessCodecController
对象;这会自动开始应用音频更新。您可以传递 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
API,可实现无缝应用集成。
أجهزة MIDI 2.0 الافتراضية
أضاف نظام Android 13 إمكانية الاتصال ب أجهزة MIDI 2.0 باستخدام USB، والتي تتواصل باستخدام حِزم MIDI العالمية (UMP). يوفّر نظام التشغيل Android 15 دعمًا لبروتوكول UMP في تطبيقات MIDI الافتراضية، ما يتيح لتطبيقات إنشاء المحتوى التحكّم في تطبيقات المزج كجهاز MIDI 2.0 افتراضي تمامًا كما لو كانت تستخدم جهاز USB MIDI 2.0.
فك ترميز برامج AV1 بشكل أكثر فعالية
dav1d 是 VideoLAN 推出的热门 AV1 软件解码器,适用于不支持硬件 AV1 解码的 Android 设备。与旧版 AV1 软件解码器相比,dav1d 的性能最高可提升 3 倍,让更多用户(包括一些低端和中端设备)能够播放高清 AV1 视频。
您的应用需要选择启用 dav1d,方法是通过名称 "c2.android.av1-dav1d.decoder"
调用它。在后续更新中,dav1d 将成为默认的 AV1 软件解码器。此支持已标准化,并向后移植到收到 Google Play 系统更新的 Android 11 设备。
إنتاجية المطوّرين وأدواتهم
مع أنّ معظم جهودنا لتحسين إنتاجيتك تركّز على أدوات مثل استوديو Android وJetpack Compose ومكتبات Android Jetpack، نسعى دائمًا إلى إيجاد طرق في المنصة لمساعدتك في تحقيق أهدافك بسهولة أكبر.
تعديلات OpenJDK 17
Android 15 将继续更新 Android 的核心库,以与最新 OpenJDK LTS 版本中的功能保持一致。
其中包含以下主要功能和改进:
- 改进了 NIO 缓冲区的使用体验
- 数据流
- 其他
math
和strictmath
方法 util
软件包更新,包括顺序的collection
、map
和set
Deflater
中的ByteBuffer
支持- 安全更新,例如
X500PrivateCredential
和安全密钥更新
这些 API 会通过 Google Play 系统更新在搭载 Android 12(API 级别 31)及更高版本的 10 亿多部设备上更新,以便您以最新的编程功能为目标平台。
تحسينات على ملفات PDF
يتضمن Android 15 تحسينات مهمة على PdfRenderer
واجهات برمجة التطبيقات. يمكن للتطبيقات دمج ميزات متقدّمة، مثل عرض
الملفات المحمية بكلمة مرور والتعليقات التوضيحية وتعديل النماذج
والبحث والاختيار مع النسخ. ملف PDF بتنسيق المساواة بين نقاط الاتصال
يتم دعم التحسينات لتسريع عرض ملفات PDF المحلية وتقليل استخدام الموارد.
تستخدم مكتبة ملفات PDF في Jetpack واجهات برمجة التطبيقات هذه لتسهيل عملية إضافة ملفات 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
Android 15 提高了 OpenType 可变字体的易用性。您可以创建
来自可变字体的 FontFamily
实例,而不指定粗细轴
使用 buildVariableFamily
API。文本渲染程序会替换 wght
轴的值,以匹配显示的文本。
使用该 API 可以大大简化创建 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();
以下示例展示了同时使用旧版和新版 API 创建的 Typeface
的呈现方式:
在此示例中,使用旧 API 创建的 Typeface
不包含
为 350、450、550 和 650 创建准确的字体粗细
Font
实例,因此渲染程序会回退到最接近的权重。在
在此示例中,系统会渲染 300 而不是 350,渲染 400 而不是 450,
依此类推。相比之下,使用新 API 创建的 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>
يظهر الفرق في طريقة عرض هذه السلاسل في الصور التالية:

<nobreak>

<nobreak>
أرشفة التطبيقات
Android 和 Google Play 宣布支持最后的应用归档功能 年,这让用户可以通过移除部分内容来释放空间 通过 Android 应用发布的设备中不常用的应用 前往 Google Play 下载套装。Android 15 在操作系统级别支持应用归档和解压缩,让所有应用商店都能更轻松地实现归档和解压缩。
具有 REQUEST_DELETE_PACKAGES
权限的应用可以调用
PackageInstaller
requestArchive
方法请求归档
已安装的应用软件包,这会移除 APK 和所有缓存的文件,但会保留
用户数据已归档的应用会通过 LauncherApps
API 作为可显示的应用返回;用户会看到一个界面处理,以突出显示这些应用已归档。如果用户点按已归档的应用,负责安装的应用会收到解除归档请求,并且可以通过 ACTION_PACKAGE_ADDED
广播监控恢复过程。
تفعيل الوضع 16 كيلوبايت على جهاز باستخدام خيارات المطوّرين

فعِّل خيار المطوّر التشغيل مع صفحات حجمها 16 كيلوبايت لتشغيل الجهاز في الوضع الذي يستخدم صفحات بحجم 16 كيلوبايت.
بدءًا من الإصدار 1 من حزمة الإصدارات التجريبية العامة (QPR1) لنظام التشغيل Android 15، يمكنك استخدام خيار المطوّرين المتاح على أجهزة معيّنة لتشغيل الجهاز في وضع 16 كيلوبايت وإجراء اختبار على الجهاز. قبل استخدام خيار المطوّرين، انتقِل إلى الإعدادات > النظام > تحديثات البرامج وطبِّق أي تحديثات متوفّرة.
يتوفّر خيار المطوّر هذا على الأجهزة التالية:
Pixel 8 وPixel 8 Pro (مع الإصدار 1 من حزمة إصلاح الأخطاء QPR لنظام التشغيل Android 15 أو إصدار أحدث)
Pixel 8a (مع الإصدار 1 من حزمة الإصدارات ربع السنوية لنظام Android 15 أو إصدار أحدث)
Pixel 9 وPixel 9 Pro وPixel 9 Pro XL (مع الإصدار التجريبي 2 من حزمة QPR2 لنظام التشغيل Android 15 أو إصدار أحدث)
الرسومات
يوفّر Android 15 أحدث التحسينات على الرسومات، بما في ذلك ANGLE وإضافات إلى نظام رسومات Canvas.
تحديث طريقة وصول Android إلى وحدة معالجة الرسومات
لقد تطورت أجهزة Android كثيرًا منذ الأيام الأولى التي كان فيها تشغيل نظام التشغيل الأساسي على وحدة معالجة مركزية واحدة والوصول إلى وحدات معالجة الرسومات باستخدام واجهات برمجة التطبيقات المستندة إلى قنوات معالجة الوظائف الثابتة. أصبحت واجهة برمجة تطبيقات الرسومات Vulkan® متاحة في حزمة تطوير البرامج (NDK) منذ الإصدار 7.0 من نظام Android (المستوى 24 لواجهة برمجة التطبيقات) مع توفير مستوى أدنى من التجريد الذي يعكس بشكل أفضل الأجهزة الحديثة لوحدة معالجة الرسومات، ويتوافق بشكل أفضل مع وحدات المعالجة المركزية المتعدّدة، ويقلّل من وقت استجابة برنامج تشغيل وحدة المعالجة المركزية، ما يؤدي إلى تحسين أداء التطبيق. يتوافق Vulkan مع جميع محرّكات الألعاب الحديثة.
Vulkan هي واجهة Android المفضّلة لوحدة معالجة الرسومات. لذلك، يتضمّن الإصدار 15 من Android ANGLE كطبقة اختيارية لتشغيل OpenGL® ES على Vulkan. سيؤدي الانتقال إلى ANGLE إلى توحيد تنفيذ OpenGL في Android لتحسين التوافق، وفي بعض الحالات، تحسين الأداء. يمكنك اختبار ثبات تطبيق OpenGL ES وأدائه باستخدام ANGLE من خلال تفعيل خيار المطوّر في الإعدادات -> النظام -> خيارات المطوّرين -> ميزة تجريبية: تفعيل ANGLE على Android 15.
خارطة طريق Android ANGLE على Vulkan

كجزء من عملية تبسيط حِزم وحدة معالجة الرسومات، سنطرح من الآن فصاعدًا ANGLE كبرنامج تشغيل نظام GL على المزيد من الأجهزة الجديدة، مع توقّع أن يكون OpenGL/ES متاحًا في المستقبل من خلال ANGLE فقط. ومع ذلك، نخطّط ل مواصلة توفير OpenGL ES على جميع الأجهزة.
الخطوات التالية المقترحة
استخدِم خيارات المطوّر لاختيار برنامج تشغيل ANGLE لـ OpenGL ES واختبار تطبيقك. بالنسبة إلى المشاريع الجديدة، ننصحك بشدة باستخدام Vulkan لـ C/C++.
تحسينات على Canvas
Android 15 继续对 Android 的 Canvas 图形系统进行现代化改造,并新增了以下功能:
Matrix44
提供一个 4x4 矩阵来转换坐标,当您想在 3D 中操控画布时,应使用此矩阵。clipShader
会将当前剪裁区域与指定的着色器相交,而clipOutShader
会将剪裁区域设为当前剪裁区域与着色器的差值,每个操作都会将着色器视为一个 Alpha 遮罩。这支持高效地绘制复杂形状。
الأداء والبطارية
يواصل نظام التشغيل Android التركيز على مساعدتك في تحسين أداء تطبيقاتك وجودتها. يقدِّم نظام التشغيل Android 15 واجهات برمجة تطبيقات تساعد في تنفيذ المهام في تطبيقك بكفاءة أكبر، وتحسين أداء التطبيق، وجمع إحصاءات حول تطبيقاتك.
للاطّلاع على أفضل الممارسات التي تساهم في الحفاظ على عمر البطارية، وتصحيح أخطاء استخدام الشبكة والطاقة، والتفاصيل حول كيفية تحسين كفاءة البطارية عند تنفيذ العمليات في الخلفية في Android 15 والإصدارات الحديثة من Android، يمكنك مشاهدة جلسة تحسين كفاءة البطارية عند تنفيذ العمليات في الخلفية على Android من مؤتمر Google I/O.
ApplicationStartInfo API
في الإصدارات السابقة من Android، كان تشغيل التطبيقات عملية غير معروفة إلى حدٍ ما. كان من الصعوبة تحديد ما إذا كان تطبيقك قد بدأ من حالة التشغيل على البارد أو إعادة التشغيل البطيء
أو إعادة التشغيل السريع. كان من الصعب أيضًا معرفة المدة التي استغرقها تطبيقك أثناء
مراحل الإطلاق المختلفة: إنشاء نسخة من العملية، واستدعاء onCreate
، ورسم
الإطار الأول، وغير ذلك. عند إنشاء مثيل لفئة Application
، لم يكن لديك
طريقة لمعرفة ما إذا كان التطبيق قد بدأ من بث أو مقدّم محتوى أو
عملية أو خدمة احتياطية أو اكتمال عملية التمهيد أو منبّه أو Activity
.
توفّر واجهة برمجة التطبيقات ApplicationStartInfo
على Android 15 كل هذه الميزات والمزيد. يمكنك أيضًا اختيار إضافة الطوابع الزمنية الخاصة بك إلى السلسلة للمساعدة في جمع بيانات التوقيت في مكان واحد. بالإضافة إلى جمع القياسات، يمكنك استخدام ApplicationStartInfo
للمساعدة في تحسين بدء تشغيل التطبيق مباشرةً. على سبيل المثال، يمكنك إزالة عمليات إنشاء المثيلات المكلّفة للمكتبات ذات الصلة بواجهة المستخدم ضمن فئة Application
عند بدء تشغيل تطبيقك بسبب بث.
معلومات مفصّلة عن حجم التطبيق
从 Android 8.0(API 级别 26)开始,Android 包含 StorageStats.getAppBytes
API,该 API 会将应用的安装大小总结为一个字节数,该数值是 APK 大小、从 APK 中提取的文件的大小以及在设备上生成的文件(例如提前编译 [AOT] 代码)的总和。此数字对于了解应用的存储空间使用情况而言,没有太大帮助。
Android 15 添加了 StorageStats.getAppBytesByDataType([type])
API,可让您深入了解应用如何使用所有这些空间,包括 APK 文件分块、AOT 和加速相关代码、DEX 元数据、库和引导式配置文件。
تحديد المواصفات الشخصية لصاحب البيانات من خلال التطبيق
يتضمّن Android 15 فئة ProfilingManager
،
التي تتيح لك جمع معلومات الأداء من داخل تطبيقك، مثل ملف تفريغ ذاكرة heap
وملفات تعريف ذاكرة heap وتحليل تسلسل استدعاء الدوال البرمجية وغير ذلك. ويقدّم هذا الإجراء استدعاءً إلى
تطبيقك باستخدام علامة مقدَّمة لتحديد ملف الإخراج الذي يتم إرساله إلى دليل ملفات
تطبيقك. تفرض واجهة برمجة التطبيقات حدودًا على معدّل الإرسال لتقليل تأثير
الأداء.
لتبسيط إنشاء طلبات إنشاء ملفات شخصية في تطبيقك، ننصحك باستخدام واجهة برمجة التطبيقات المتوافقة مع Profiling
AndroidX API، والمتوفّرة في الإصدار Core 1.15.0-rc01 أو الإصدارات الأحدث.
تحسينات على قاعدة بيانات 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
Android 15 继续投资于 Android 动态性能框架 (ADPF),这是一组 API,可让游戏和性能密集型应用更为直接地与 Android 设备的电源和散热系统进行互动。在受支持的设备上,Android 15 添加了 ADPF 功能:
- 针对提示会话的节能模式,用于指明其关联的线程应优先节能而非性能,非常适合长时间运行的后台工作负载。
- 系统可以在提示会话中报告 GPU 和 CPU 工作时长,以便同时调整 CPU 和 GPU 频率,以最佳方式满足工作负载需求。
- 热余量阈值,用于根据余量预测来解读可能的热节流状态。
如需详细了解如何在应用和游戏中使用 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 通过 UriRelativeFilterGroup
支持更精确的 Intent
解析,UriRelativeFilterGroup
包含一组 UriRelativeFilter
对象,这些对象构成一组必须满足的 Intent
匹配规则,包括网址查询参数、网址片段以及屏蔽或排除规则。
您可以在 AndroidManifest
XML 文件中使用 <uri-relative-filter-group>
标记来定义这些规则,该标记可以包含 android:allow
标记。这些代码可以包含使用现有数据代码属性以及 android:query
和 android:fragment
属性的 <data>
代码。
下面是一个 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>
المساحة الخاصة
借助私密空间,用户可以在设备上创建一个单独的空间,在额外的身份验证层保护下,防止敏感应用遭到窥探。私密空间使用单独的用户个人资料。用户可以选择使用设备锁定方式或为私密空间使用单独的锁定方式。
私密空间中的应用会显示在启动器的单独容器中,并且当私密空间处于锁定状态时,这些应用不会显示在“最近用过”视图、通知、“设置”和其他应用中。用户生成的内容和下载的内容(例如媒体内容或文件)以及账号在私密空间和主空间之间是分开的。在私密空间处于解锁状态时,您可以使用系统 Sharesheet 和照片选择器向应用授予对各个空间中内容的访问权限。
用户无法将现有应用及其数据移至私密空间。相反,用户可以在私密空间中选择安装选项,以便使用他们偏好的任意应用商店安装应用。私密空间中的应用会作为主空间中任何应用的单独副本进行安装(同一应用的新副本)。
当用户锁定私密空间时,系统会停止该个人资料。在个人资料停止运行时,私密空间中的应用将不再处于活动状态,无法执行前台或后台活动,包括显示通知。
我们建议您使用私密空间测试应用,以确保应用能按预期运行,尤其是当您的应用属于以下某一类别时:
- 具有工作资料逻辑的应用:假定其应用的任何已安装副本(不在主资料中)均位于工作资料中。
- 医疗应用
- 启动器应用
- 应用商店应用
طلب البحث عن آخر اختيار للمستخدم في ما يخصّ "الوصول إلى الصور المحدّدة"
يمكن للتطبيقات الآن إبراز الصور والفيديوهات التي تم اختيارها مؤخرًا فقط عند منح التطبيقات
إذن وصول جزئي إلى أذونات الوصول إلى الوسائط. يمكن أن تحسِّن هذه الميزة
تجربة المستخدم للتطبيقات التي تطلب الوصول إلى الصور
والفيديوهات بشكل متكرر. لاستخدام هذه الميزة في تطبيقك، فعِّل الوسيطة
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 支持应用屏幕共享,因此用户可以仅共享或录制应用窗口,而不是整个设备屏幕。此功能首次在 Android 14 QPR2 中启用,包含 MediaProjection
回调,可让您的应用自定义应用屏幕共享体验。请注意,对于以 Android 14(API 级别 34)或更高版本为目标平台的应用,每个 MediaProjection
捕获会话都需要征得用户同意。
تجربة المستخدم وواجهة مستخدم النظام
يمنح نظام التشغيل Android 15 مطوّري التطبيقات والمستخدمين المزيد من التحكّم والمرونة في إعداد أجهزتهم بما يتناسب مع احتياجاتهم.
لمزيد من المعلومات حول كيفية استخدام أحدث التحسينات في Android 15 لتحسين تجربة المستخدم في تطبيقك، يمكنك الاطّلاع على جلسة تحسين تجربة المستخدم في تطبيق Android من مؤتمر Google I/O.
معاينات تطبيقات مصغّرة أكثر تفصيلاً باستخدام Generated Previews API
قبل الإصدار 15 من Android، كانت الطريقة الوحيدة لتقديم معاينات لأداة اختيار التطبيقات المصغّرة هي تحديد مصدر صورة أو تنسيق ثابت. غالبًا ما تختلف هذه المعاينات عن شكل التطبيق المصغّر الفعلي عند وضعه على الشاشة الرئيسية. بالإضافة إلى ذلك، لا يمكن إنشاء موارد ثابتة باستخدام Jetpack Glance، لذا كان على مطوّر Glance التقاط لقطة شاشة لأداة العرض أو إنشاء تنسيق XML للحصول على معاينة لأداة العرض.
يتيح نظام Android 15 استخدام معاينات تم إنشاؤها. وهذا يعني أنّه يمكن لموفّري التطبيقات المصغرة
إنشاء RemoteViews
لاستخدامها كمعاينة لأداة الاختيار، بدلاً من
مورد ثابت.

واجهة برمجة تطبيقات Push
يمكن للتطبيقات تقديم معاينات تم إنشاؤها من خلال واجهة برمجة تطبيقات Push. يمكن للتطبيقات تقديم
معاينات في أي مرحلة من مراحل نشاطها، وعدم تلقّي طلب صريح
من المضيف لتقديم معاينات. يتم الاحتفاظ بالمعاينات في AppWidgetService
،
ويمكن للمضيفين طلبها عند الطلب. المثال التالي يحمّل تطبيق مصغّر بتنسيق XML
تنسيق موارد التنسيق وتعيينه كمعاينة:
AppWidgetManager.getInstance(appContext).setWidgetPreview(
ComponentName(
appContext,
SociaLiteAppWidgetReceiver::class.java
),
AppWidgetProviderInfo.WIDGET_CATEGORY_HOME_SCREEN,
RemoteViews("com.example", R.layout.widget_preview)
)
التدفق المتوقع هو:
- في أي وقت، يستدعي موفّر التطبيق المصغّر
setWidgetPreview
. يتم الاحتفاظ بالمعاينات التي تم تقديمها فيAppWidgetService
مع معلومات مقدّم الخدمة الأخرى. - يرسل "
setWidgetPreview
" إشعارًا إلى المضيفين بمعاينة محدَّثة من خلالAppWidgetHost.onProvidersChanged
معاودة الاتصال. استجابةً لذلك، يُعيد مضيف التطبيقات المصغّرة تحميل جميع معلومات مقدّم الخدمة. - عند عرض معاينة التطبيق المصغّر، يتحقق المضيف من العنصر
AppWidgetProviderInfo.generatedPreviewCategories
، وإذا كانت الفئة التي تم اختيارها متوفرة، يتصل بالعنصرAppWidgetManager.getWidgetPreview
لعرض المعاينة المحفوظة لهذا الموفِّر.
حالات الاتصال بـ setWidgetPreview
وبما أنّه لا تتوفّر طلبات إعادة اتصال لتقديم المعاينات، يمكن للتطبيقات اختيار إرسال المعاينات في أي وقت أثناء تشغيلها. عدد مرات تعديل المعاينة على حالة استخدام الأداة.
توضِّح القائمة التالية الفئتَين الرئيسيتَين لحالات استخدام المعاينة:
- مقدمو الخدمات الذين يعرضون بيانات فعلية في معاينات الأدوات، مثل أو معلومات حديثة. يمكن لموفّري المحتوى هؤلاء ضبط المعاينة بعد تسجيل دخول المستخدم أو إجراء الإعدادات الأولية في تطبيقه. وبعد ذلك، يمكنهم إعداد مهمة دورية لتعديل المعاينات بالوتيرة التي يختارونها. ومن الأمثلة على هذا النوع من التطبيقات المصغّرة أداة مصوّرة أو أداة تقويم أو أداة طقس أو أداة أخبار.
- مقدّمو الخدمات الذين يعرضون معلومات ثابتة في معاينات التطبيقات المصغّرة أو التطبيقات المصغّرة للإجراءات السريعة ولا يعرضون أي بيانات يمكن لموفّري المحتوى هؤلاء ضبط المعاينات مرة واحدة عند بدء تشغيل التطبيق لأول مرة. تتضمن أمثلة هذا النوع من التطبيقات المصغّرة محرك أقراص تطبيق "الإجراءات" المصغّر أو تطبيق "اختصارات Chrome" المصغّر.
قد يعرض بعض مزوّدي الخدمة معاينات ثابتة في منتقي وضع الإرساء، ولكنّها في الواقع المعلومات الموجودة في منتقي الشاشة الرئيسية. على مقدّمي هذه الخدمات اتّباع الإرشادات لكلتا حالتَي الاستخدام هاتين لضبط المعاينات.
نافذة ضمن النافذة
Android 15 引入了画中画 (PiP) 方面的变更,确保实现 更流畅的过渡效果。对于在主界面上叠加界面元素的应用,这将非常有用,因为这些界面元素会进入 PiP。
开发者使用 onPictureInPictureModeChanged
回调来定义逻辑
用于切换叠加界面元素的可见性。此回调是
在画中画进入或退出动画播放完毕时触发。距离开始还有
Android 15 中,PictureInPictureUiState
类包含另一种状态。
在此界面状态下,以 Android 15(API 级别 35)为目标平台的应用将遵守
使用以下参数调用 Activity#onPictureInPictureUiStateChanged
回调:
isTransitioningToPip()
。还有
在画中画模式下,有很多与应用无关的界面元素,
包含建议、
评分和标题当应用进入画中画模式时,请使用
onPictureInPictureUiStateChanged
回调以隐藏这些界面元素。当
应用从画中画窗口进入全屏模式,使用
onPictureInPictureModeChanged
回调以取消隐藏这些元素,如
请参阅以下示例:
override fun onPictureInPictureUiStateChanged(pipState: PictureInPictureUiState) {
if (pipState.isTransitioningToPip()) {
// Hide UI elements
}
}
override fun onPictureInPictureModeChanged(isInPictureInPictureMode: Boolean) {
if (isInPictureInPictureMode) {
// Unhide UI elements
}
}
不相关界面元素的快速可见性切换(适用于画中画窗口)有助于 确保画中画播放动画更流畅、无闪烁。
قواعد محسّنة لميزة "عدم الإزعاج"
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 على تحسين تجربة الدفع بدون تلامس الأجهزة وجعلها أكثر سلاسة وموثوقية، مع مواصلة توفير منظومة التطبيقات المتكاملة لتقنية NFC القوية في Android. على
الأجهزة المتوافقة، يمكن للتطبيقات أن تطلب من NfcAdapter
الدخول إلى
وضع المراقبة، حيث يستمع الجهاز إلى قراء
NFC ولكنه لا يستجيب لهم، ويرسل خدمة NFC الخاصة بالتطبيق PollingFrame
العناصر لمعالجتها. يمكن استخدام عناصر PollingFrame
لمنح الإذن
قبل إجراء عملية التواصل الأولى مع قارئ NFC، ما يتيح إجراء معاملة
بنقرة واحدة في العديد من الحالات.
بالإضافة إلى ذلك، يمكن للتطبيقات تسجيل فلتر على الأجهزة المتوافقة لكي تتم إعلامها بنشاط حلقة الاستطلاع، ما يتيح التشغيل السلس مع تطبيقات متعددة متوافقة مع NFC.
دور المحفظة
يقدّم نظام التشغيل Android 15 دور "محفظة" يتيح دمجًا أكثر انسجامًا مع تطبيق المحفظة المفضّل لدى المستخدم. ويحلّ هذا الدور محلّ إعداد الدفع بدون تلامس الأجهزة التلقائي عبر تقنية NFC. يمكن للمستخدمين إدارة حامل دور "محفظة Google" من خلال الانتقال إلى الإعدادات > التطبيقات > التطبيقات التلقائية.
يتم استخدام دور "محفظة Google" عند توجيه عمليات النقر باستخدام تقنية NFC لأرقام تعريف العملاء المسجّلة في فئة الدفع. يتم دائمًا توجيه النقرات إلى حامل دور "محفظة Google" ما لم يكن هناك تطبيق آخر مسجَّل للمعرّف الإعلاني نفسه قيد التشغيل في المقدّمة.
ويُستخدَم هذا الدور أيضًا لتحديد مكان مربّع "الوصول السريع" في "محفظة Google" عند تفعيله. عند ضبط الدور على "بدون"، لا يكون مربّع "الوصول السريع" متاحًا ولا يتم إرسال نقرات NFC الخاصة بفئة الدفع إلا إلى التطبيق الذي يعمل في المقدّمة.
الأمان
يساعدك نظام التشغيل Android 15 في تعزيز أمان تطبيقك وحماية بياناته، كما يتيح للمستخدمين المزيد من الشفافية والتحكّم في بياناتهم. يمكنك مشاهدة جلسة الحفاظ على أمان المستخدمين على Android من مؤتمر Google I/O للتعرّف على المزيد من الإجراءات التي نتّخذها لتحسين وسائل حماية المستخدمين وحماية تطبيقك من التهديدات الجديدة.
دمج Credential Manager مع ميزة "الملء التلقائي"
بدءًا من الإصدار 15 من نظام التشغيل Android، يمكن للمطوّرين ربط طرق عرض معيّنة، مثل حقل اسم المستخدم أو حقل كلمة المرور بطلبات "مدير بيانات الاعتماد"، ما يسهّل تقديم تجربة مخصّصة للمستخدم أثناء عملية تسجيل الدخول. عندما يركز المستخدم على أحد هذه العروض، يتم إرسال طلب مقابل إلى مدير بيانات الاعتماد. يتم تجميع بيانات الاعتماد الناتجة على مستوى جميع مقدّمي الخدمات وعرضها في واجهات مستخدم النسخ الاحتياطي لملء البيانات تلقائيًا، مثل الاقتراحات المضمّنة أو الاقتراحات في القوائم المنسدلة. مكتبة Jetpack androidx.credentials هي نقطة النهاية المفضّلة للمطوّرين لاستخدامها، وستتوفّر قريبًا لتحسين هذه الميزة بشكلٍ أكبر في Android 15 والإصدارات الأحدث.
دمج ميزة "نقرة واحدة لتسجيل الدخول أو إنشاء حساب" مع طلبات المقاييس الحيوية
مدير بيانات الاعتماد يدمج طلبات المقاييس الحيوية في إنشاء بيانات الاعتماد وتسجيل الدخول، ما يغنيك عن حاجة مقدّمي الخدمات إلى إدارة طلبات المقاييس الحيوية. نتيجةً لذلك، ما على موفّري بيانات الاعتماد سوى التركيز على نتائج مسارات الإنشاء والحصول، بالإضافة إلى نتيجة مسار البيانات الحيوية. توفّر هذه العملية المبسّطة بيانات اعتماد أكثر كفاءة وسلاسة. عملية الإنشاء والاسترجاع.
إدارة المفاتيح للتشفير التام بين الأطراف
نقدّم 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 متغيّر
从 Android 15 开始,面向中文、日文和韩文 (CJK) 语言的字体文件 NotoSansCJK 现在是可变字体。可变字体为中日韩语言的创意排版提供了更多可能性。设计师可以探索更多样式的排版,并制作出以前难以实现或根本无法实现的视觉效果出色的布局。

ضبط المسافات بين الأحرف
从 Android 15 开始,可以通过
使用 JUSTIFICATION_MODE_INTER_CHARACTER
。“字词间的理由”原为
最初是在 Android 8.0(API 级别 26)中引入的,
Justifications 功能为使用
例如中文、日语等。

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(API 级别 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
会使用 no
换行字词样式,
LINE_BREAK_WORD_STYLE_NONE
,如
以下图片:

LINE_BREAK_WORD_STYLE_AUTO
应用不换行的字词样式,以提高文本的可读性。
这与应用
LINE_BREAK_WORD_STYLE_NONE
。خط إضافي للغة اليابانية Hentaigana
在 Android 15 中,旧版日语平假名(也称为 Hentaigana)字体文件 捆绑在一起半形人物的独特形状可以增加 风格或设计独特的风格 传播和理解古代日本文件的能力。

VideoLAN 圆锥图标 版权所有 (c) 1996-2010 VideoLAN。任何人都可以使用此徽标或修改版徽标来提及 VideoLAN 项目或 VideoLAN 团队开发的任何产品,但这并不表示该项目对其表示认可。
Vulkan 和 Vulkan 徽标是 Khronos Group Inc.的注册商标。
OpenGL 是注册商标,OpenGL ES 徽标是 Hewlett Packard Enterprise 的商标,已获得 Khronos 的许可。