اندروید 15 ویژگی ها و API های عالی را برای توسعه دهندگان معرفی می کند. بخشهای زیر این ویژگیها را خلاصه میکنند تا به شما در شروع کار با APIهای مرتبط کمک کنند.
برای فهرست دقیق APIهای اضافه شده، اصلاح شده و حذف شده، گزارش تفاوت API را بخوانید. برای جزئیات بیشتر در مورد APIهای اضافه شده به مرجع Android API مراجعه کنید — برای Android 15، به دنبال APIهایی بگردید که در سطح API 35 اضافه شده اند. برای اطلاع از مناطقی که تغییرات پلت فرم ممکن است بر برنامه های شما تأثیر بگذارد، حتماً تغییرات رفتار Android 15 را برای برنامه هایی که Android 15 و برای همه برنامه ها را هدف قرار می دهند بررسی کنید.
دوربین و رسانه
اندروید 15 شامل ویژگیهای مختلفی است که تجربه دوربین و رسانه را بهبود میبخشد و به شما امکان میدهد به ابزارها و سختافزارهایی برای حمایت از سازندگان برای زنده کردن دیدگاهشان در اندروید دسترسی داشته باشید.
برای اطلاعات بیشتر در مورد جدیدترین ویژگیها و راهحلهای برنامهنویس برای رسانه و دوربین Android، به بحث ساخت رسانهها و تجربههای دوربین مدرن Android از Google I/O مراجعه کنید.
تقویت نور کم
اندروید 15 کم نور ، حالت نوردهی خودکار را معرفی می کند که هم برای دوربین 2 و هم برای پسوند دوربین حالت شب در دسترس است. Low Light Boost نوردهی جریان پیش نمایش را در شرایط کم نور تنظیم می کند. این با نحوه ایجاد تصاویر ثابت توسط پسوند دوربین حالت شب متفاوت است، زیرا حالت شب مجموعه ای از عکس ها را برای ایجاد یک تصویر واحد و پیشرفته ترکیب می کند. در حالی که حالت شب برای ایجاد یک تصویر ثابت بسیار خوب عمل می کند، نمی تواند یک جریان مداوم از فریم ها ایجاد کند، اما Low Light Boost می تواند. بنابراین، Low Light Boost قابلیت های دوربین را فعال می کند، مانند:
- ارائه یک پیشنمایش تصویر پیشرفته، بنابراین کاربران بهتر میتوانند عکسهای خود را در نور کم قاب کنند
- اسکن کدهای QR در نور کم
اگر Low Light Boost را فعال کنید، هنگامی که سطح نور کم باشد به طور خودکار روشن می شود و زمانی که نور بیشتر باشد خاموش می شود.
برنامهها میتوانند جریان پیشنمایش را در شرایط کمنور ضبط کنند تا یک ویدیوی روشن را ذخیره کنند.
برای اطلاعات بیشتر، Low Light Boost را ببینید.
کنترل های دوربین درون برنامه ای
Android 15 adds an extension for more control over the camera hardware and its algorithms on supported devices:
- Advanced flash strength adjustments enabling precise control of flash
intensity in both
SINGLE
andTORCH
modes while capturing images.
کنترل فضای سر HDR
Android 15 会选择适合底层设备功能和面板位深的 HDR 余量。对于包含大量 SDR 内容的网页(例如显示单个 HDR 缩略图的消息应用),此行为最终可能会对 SDR 内容的感知亮度产生不利影响。在 Android 15 中,您可以使用 setDesiredHdrHeadroom
控制 HDR 余量,以便在 SDR 内容和 HDR 内容之间取得平衡。

کنترل بلندی صدا
Android 15 introduces support for the CTA-2075 loudness standard to help you avoid audio loudness inconsistencies and ensure users don't have to constantly adjust volume when switching between content. The system leverages known characteristics of the output devices (headphones and speaker) along with loudness metadata available in AAC audio content to intelligently adjust the audio loudness and dynamic range compression levels.
To enable this feature, you need to ensure loudness metadata is available in
your AAC content and enable the platform feature in your app. For this, you
instantiate a LoudnessCodecController
object by
calling its create factory method with the audio
session ID from the associated AudioTrack
; this
automatically starts applying audio updates. You can pass an
OnLoudnessCodecUpdateListener
to modify or filter
loudness parameters before they are applied on the
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 will also be updated to use the
LoudnessCodecController
APIs for a seamless app integration.
دستگاه های مجازی MIDI 2.0
Android 13 برای اتصال به دستگاههای MIDI 2.0 با استفاده از USB ، که با استفاده از بستههای جهانی MIDI (UMP) ارتباط برقرار میکنند، پشتیبانی اضافه کرد. Android 15 پشتیبانی UMP را به برنامههای MIDI مجازی گسترش میدهد، و برنامههای ترکیب را قادر میسازد تا برنامههای سینتیسایزر را بهعنوان یک دستگاه مجازی MIDI 2.0 مانند دستگاههای USB MIDI 2.0 کنترل کنند.
رمزگشایی نرم افزار AV1 کارآمدتر
dav1d, the popular AV1 software decoder from VideoLAN is available for Android devices that don't support AV1 decode in hardware. dav1d is up to 3x more performant than the legacy AV1 software decoder, enabling HD AV1 playback for more users, including some low and mid tier devices.
Your app needs to opt-in to using dav1d by invoking it by name
"c2.android.av1-dav1d.decoder"
. dav1d will be made the default AV1 software
decoder in a subsequent update. This support is standardized and backported to
Android 11 devices that receive Google Play system updates.
بهره وری توسعه دهندگان و ابزار
در حالی که بیشتر کار ما برای بهبود بهرهوری شما حول ابزارهایی مانند Android Studio ، Jetpack Compose ، و کتابخانههای Android Jetpack متمرکز است، ما همیشه به دنبال راههایی در این پلتفرم هستیم تا به شما کمک کند راحتتر به دیدگاه خود پی ببرید.
به روز رسانی OpenJDK 17
اندروید 15 به کار تازه سازی کتابخانه های اصلی اندروید برای هماهنگی با ویژگی های آخرین نسخه OpenJDK LTS ادامه می دهد.
ویژگیها و بهبودهای کلیدی زیر شامل میشوند:
- بهبود کیفیت زندگی در اطراف بافرهای NIO
- جریان ها
- روشهای اضافی
math
وstrictmath
-
util
بسته شاملcollection
متوالی،map
وset
- پشتیبانی
ByteBuffer
درDeflater
- به روز رسانی های امنیتی مانند
X500PrivateCredential
و به روز رسانی های کلید امنیتی
این APIها در بیش از یک میلیارد دستگاه دارای Android 12 (سطح API 31) و بالاتر از طریق بهروزرسانیهای سیستم Google Play بهروزرسانی میشوند، بنابراین میتوانید آخرین ویژگیهای برنامهنویسی را هدف قرار دهید.
پیشرفت های PDF
Android 15 对 PdfRenderer
API 进行了重大改进。应用可以整合呈现等高级功能
受密码保护的文件、注释、表单编辑、
searching,而 selection 则包含副本。支持线性化 PDF 优化,此功能可加快本地 PDF 查看速度并减少资源使用量。Jetpack PDF 库使用这些 API 来简化 PDF 的添加
查看功能。

PdfRenderer
已移至一个可使用 Google
Play 系统更新独立于平台版本,并且我们支持
将这些变更还原到 Android 11(API 级别 30),方法是创建兼容的
Android 15 之前版本的 API Surface,称为
PdfRendererPreV
。
اصلاحات تغییر خودکار زبان
اندروید 14 روی دستگاه، تشخیص چند زبانه در صدا با جابجایی خودکار بین زبانها را اضافه کرده است، اما این میتواند باعث حذف کلمات شود، به خصوص زمانی که زبانها با مکث کمتری بین دو گفته جابجا میشوند. Android 15 کنترلهای اضافی را اضافه میکند تا به برنامهها کمک کند این تغییر را در مورد استفاده خود تنظیم کنند. EXTRA_LANGUAGE_SWITCH_INITIAL_ACTIVE_DURATION_TIME_MILLIS
تغییر خودکار را به ابتدای جلسه صوتی محدود می کند، در حالی که EXTRA_LANGUAGE_SWITCH_MATCH_SWITCHES
تغییر زبان را پس از تعداد معینی سوئیچ غیرفعال می کند. این گزینهها مخصوصاً زمانی مفید هستند که انتظار دارید در طول جلسه یک زبان صحبت شود که باید به طور خودکار شناسایی شود.
API فونت متغیر 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
和底层行断开符可以将给定部分文本保留在同一行中,以提高可读性。您可以通过在字符串资源或 createNoBreakSpan
中使用 <nobreak>
标记来充分利用此换行符自定义功能。同样,您可以使用 <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>
标记封装“Pixel 8 Pro.”短语的同一行文本的布局。بایگانی برنامه
Android and Google Play announced support for app archiving last year, allowing users to free up space by partially removing infrequently used apps from the device that were published using Android App Bundle on Google Play. Android 15 includes OS level support for app archiving and unarchiving, making it easier for all app stores to implement it.
Apps with the REQUEST_DELETE_PACKAGES
permission can call the
PackageInstaller
requestArchive
method to request archiving an
installed app package, which removes the APK and any cached files, but persists
user data. Archived apps are returned as displayable apps through the
LauncherApps
APIs; users will see a UI treatment to highlight that those
apps are archived. If a user taps on an archived app, the responsible installer
will get a request to unarchive it, and the restoration process can be
monitored by the ACTION_PACKAGE_ADDED
broadcast.
使用开发者选项在设备上启用 16 KB 模式

切换以 16KB 页面大小启动设备开发者选项,以便在 16 KB 模式下启动设备。
从 Android 15 QPR1 开始,您可以使用某些设备上提供的开发者选项,以 16 KB 模式启动设备并执行设备端测试。在使用开发者选项之前,请依次前往“设置”->“系统”->“软件更新”,然后应用所有可用的更新。
此开发者选项适用于以下设备:
Pixel 8 和 Pixel 8 Pro(搭载 Android 15 QPR1 或更高版本)
警告:由于 Android 15 QPR2 Beta 版 3 存在已知问题,在安装 Android 15 QPR2 Beta 版 3 并以 16 KB 模式启动设备后,Pixel 8 设备上的触摸屏无法正常使用。此问题不会影响 Pixel 8 Pro 设备。
Pixel 8a(搭载 Android 15 QPR1 或更高版本)
警告:由于 Android 15 QPR2 Beta 版 3 存在已知问题,在安装 Android 15 QPR2 Beta 版 3 并以 16 KB 模式启动设备后,Pixel 8a 设备上的触摸屏无法正常使用。
Pixel 9、Pixel 9 Pro 和 Pixel 9 Pro XL(搭载 Android 15 QPR2 Beta 2 或更高版本)
گرافیک
اندروید 15 جدیدترین پیشرفتهای گرافیکی، از جمله ANGLE و اضافهشدهها به سیستم گرافیکی Canvas را به ارمغان میآورد.
مدرن کردن دسترسی به پردازنده گرافیکی اندروید
Android hardware has evolved quite a bit from the early days where the core OS would run on a single CPU and GPUs were accessed using APIs based on fixed-function pipelines. The Vulkan® graphics API has been available in the NDK since Android 7.0 (API level 24) with a lower-level abstraction that better reflects modern GPU hardware, scales better to support multiple CPU cores, and offers reduced CPU driver overhead — leading to improved app performance. Vulkan is supported by all modern game engines.
Vulkan is Android's preferred interface to the GPU. Therefore, Android 15 includes ANGLE as an optional layer for running OpenGL® ES on top of Vulkan. Moving to ANGLE will standardize the Android OpenGL implementation for improved compatibility, and, in some cases, improved performance. You can test out your OpenGL ES app stability and performance with ANGLE by enabling the developer option in Settings -> System -> Developer Options -> Experimental: Enable ANGLE on Android 15.
The Android ANGLE on Vulkan roadmap

As part of streamlining our GPU stack, going forward we will be shipping ANGLE as the GL system driver on more new devices, with the future expectation that OpenGL/ES will be only available through ANGLE. That being said, we plan to continue support for OpenGL ES on all devices.
Recommended next steps
Use the developer options to select the ANGLE driver for OpenGL ES and test your app. For new projects, we strongly encourage using Vulkan for C/C++.
بهبودهایی برای بوم
اندروید 15 به مدرن سازی سیستم گرافیکی Canvas اندروید با قابلیت های اضافی ادامه می دهد:
-
Matrix44
یک ماتریس 4x4 برای تبدیل مختصات ارائه می دهد که باید برای دستکاری بوم به صورت سه بعدی استفاده شود. -
clipShader
کلیپ فعلی را با سایهزن مشخص شده قطع میکند، در حالی کهclipOutShader
کلیپ را روی تفاوت کلیپ فعلی و سایهزن تنظیم میکند و هر کدام سایهزن را به عنوان یک ماسک آلفا در نظر میگیرند. این از ترسیم اشکال پیچیده به طور موثر پشتیبانی می کند.
عملکرد و باتری
Android به تمرکز خود بر کمک به شما در بهبود عملکرد و کیفیت برنامههایتان ادامه میدهد. Android 15 API هایی را معرفی می کند که به کارآمدتر کردن وظایف در برنامه شما برای اجرا، بهینه سازی عملکرد برنامه و جمع آوری اطلاعات بینش در مورد برنامه های شما کمک می کند.
برای بهترین شیوههای کارآمد باتری، اشکالزدایی شبکه و مصرف انرژی، و جزئیات نحوه بهبود کارایی باتری در کار پسزمینه در Android 15 و نسخههای اخیر Android، به بهبود کارایی باتری در کار پسزمینه در بحث Android از Google I/O مراجعه کنید.
ApplicationStartInfo API
In previous versions of Android, app startup has been a bit of a mystery. It was
challenging to determine within your app whether it started from a cold, warm,
or hot state. It was also difficult to know how long your app spent during the
various launch phases: forking the process, calling onCreate
, drawing the
first frame, and more. When your Application
class was instantiated, you had no
way of knowing whether the app started from a broadcast, a content provider, a
job, a backup, boot complete, an alarm, or an Activity
.
The ApplicationStartInfo
API on Android 15 provides
all of this and more. You can even choose to add your own timestamps into the
flow to help collect timing data in one place. In addition to collecting
metrics, you can use ApplicationStartInfo
to help directly optimize app
startup; for example, you can eliminate the costly instantiation of UI-related
libraries within your Application
class when your app is starting up due to a
broadcast.
اطلاعات دقیق اندازه برنامه
از Android 8.0 (سطح API 26)، Android دارای StorageStats.getAppBytes
API است که اندازه نصب شده یک برنامه را به صورت یک تعداد بایت خلاصه می کند، که مجموع اندازه APK، اندازه فایل های استخراج شده از APK است. و فایل هایی که روی دستگاه تولید شده اند مانند کدهای کامپایل شده پیش از زمان (AOT). این عدد از نظر نحوه استفاده برنامه شما از فضای ذخیرهسازی خیلی روشنکننده نیست.
Android 15 API StorageStats.getAppBytesByDataType([type])
را اضافه می کند، که به شما امکان می دهد بینشی در مورد نحوه استفاده برنامه شما از این فضا، از جمله تقسیم فایل های APK، AOT و کدهای مربوط به سرعت بخشیدن، داده های dex، کتابخانه ها و نمایه های هدایت شونده داشته باشید.
پروفایل مدیریت شده توسط برنامه
Android 15 包含 ProfilingManager
类,可让您从应用内部收集性能分析信息,例如堆转储、堆分析报告、堆栈采样等。它使用提供的标记为您的应用提供回调,以标识输出文件,该文件将传递给应用的文件目录。该 API 会进行速率限制,以尽可能降低对性能的影响。
为了简化在应用中构建性能分析请求的过程,我们建议您使用 Core 1.15.0-rc01 或更高版本中的相应 Profiling
AndroidX API。
بهبود پایگاه داده SQLite
Android 15 引入了 SQLite API,这些 API 可公开底层 SQLite 引擎的高级功能,以解决可能在应用中出现的特定性能问题。将 SQLite 更新到版本 3.44.3。
开发者应参阅 SQLite 性能最佳实践 以便充分利用其 SQLite 数据库,尤其是在处理大型 或运行对延迟敏感的查询时
- 只读延迟事务:在发出
只读(不包括写入语句),请使用
beginTransactionReadOnly()
和beginTransactionWithListenerReadOnly(SQLiteTransactionListener)
发出只读的DEFERRED
事务。此类事务 如果数据库处于 WAL 模式 与IMMEDIATE
或EXCLUSIVE
事务并发运行。 - 行数和 ID:添加了 API 以检索已更改的行数和 ID
行或最后插入的行 ID 而不发出额外的查询。
getLastChangedRowCount()
会返回当前事务中最近的 SQL 语句插入、更新或删除的行数,而getTotalChangedRowCount()
会返回当前连接的计数。getLastInsertRowId()
返回最后一行的rowid
以便在当前连接中插入 - 原始语句:发出原始 SQlite 语句,从而绕过便利 及其可能产生的任何额外处理开销。
بهروزرسانیهای چارچوب عملکرد پویا اندروید
Android 15 继续投资于 Android 动态性能框架 (ADPF),这是一组 API,可让游戏和性能密集型应用更为直接地与 Android 设备的电源和散热系统进行互动。在受支持的设备上,Android 15 添加了 ADPF 功能:
- 针对提示会话的节能模式,用于指明其关联的线程应优先节能而非性能,非常适合长时间运行的后台工作负载。
- 系统可以在提示会话中报告 GPU 和 CPU 工作时长,以便同时调整 CPU 和 GPU 频率,以最佳方式满足工作负载需求。
- 热余量阈值,用于根据余量预测来解读可能的热节流状态。
如需详细了解如何在应用和游戏中使用 ADPF,请参阅相关文档。
حریم خصوصی
اندروید 15 دارای ویژگی های مختلفی است که به توسعه دهندگان اپلیکیشن کمک می کند تا از حریم خصوصی کاربران محافظت کنند.
تشخیص ضبط صفحه
Android 15 adds support for apps to detect that they are being recorded. A callback is invoked whenever the app transitions between being visible or invisible within a screen recording. An app is considered visible if activities owned by the registering process's UID are being recorded. This way, if your app is performing a sensitive operation, you can inform the user that they're being recorded.
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>
<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:domain="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>
فضای خصوصی
فضای خصوصی به کاربران این امکان را می دهد که فضای جداگانه ای در دستگاه خود ایجاد کنند که در آن می توانند برنامه های حساس را از چشمان کنجکاو دور نگه دارند، زیر یک لایه دیگر از احراز هویت. فضای خصوصی از یک پروفایل کاربری مجزا استفاده می کند. کاربر می تواند انتخاب کند که از قفل دستگاه یا فاکتور قفل جداگانه برای فضای خصوصی استفاده کند.
برنامههای موجود در فضای خصوصی در یک محفظه جداگانه در راهانداز نمایش داده میشوند و وقتی فضای خصوصی قفل است از نمای اخیر، اعلانها، تنظیمات و از سایر برنامهها پنهان میشوند. محتوای تولید شده و دانلود شده توسط کاربر (مانند رسانه یا فایل ها) و حساب ها بین فضای خصوصی و فضای اصلی جدا می شوند. از اشتراکگذاری سیستم و انتخابگر عکس میتوان برای دسترسی برنامهها به محتوا در فضاهای مختلف زمانی که فضای خصوصی باز است استفاده کرد.
کاربران نمی توانند برنامه های موجود و داده های آنها را به فضای خصوصی منتقل کنند. در عوض، کاربران یک گزینه نصب را در فضای خصوصی برای نصب یک برنامه با استفاده از فروشگاه برنامه ای که ترجیح می دهند انتخاب می کنند. برنامههای موجود در فضای خصوصی بهعنوان نسخههای جداگانه از هر برنامهای در فضای اصلی (کپیهای جدید همان برنامه) نصب میشوند.
وقتی کاربر فضای خصوصی را قفل می کند، نمایه متوقف می شود. وقتی نمایه متوقف شده است، برنامههای موجود در فضای خصوصی دیگر فعال نیستند و نمیتوانند فعالیتهای پیشزمینه یا پسزمینه، از جمله نمایش اعلانها را انجام دهند.
توصیه می کنیم برنامه خود را با فضای خصوصی آزمایش کنید تا مطمئن شوید برنامه شما همانطور که انتظار می رود کار می کند، به خصوص اگر برنامه شما در یکی از دسته های زیر قرار می گیرد:
- برنامههایی با منطق برای نمایههای کاری که فرض میکنند هر نسخه نصبشده برنامهشان که در نمایه اصلی نیست، در نمایه کاری است.
- اپلیکیشن های پزشکی
- برنامه های راه اندازی
- اپلیکیشن های اپ استور
آخرین انتخاب کاربر را برای دسترسی به عکسهای انتخابی جستجو کنید
现在,如果应用获得了部分访问权限,则只能突出显示最近选择的照片和视频。此功能可以改善频繁请求访问照片和视频的应用的用户体验。如需在应用中使用此功能,请在通过 ContentResolver
查询 MediaStore
时启用 QUERY_ARG_LATEST_SELECTION_ONLY
参数。
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 15 includes the latest Android Ad Services extensions, incorporating the latest version of the Privacy Sandbox on Android. This addition is part of our work to develop technologies that improve user privacy and enable effective, personalized advertising experiences for mobile apps. Our privacy sandbox page has more information about the Privacy Sandbox on Android developer preview and beta programs to help you get started.
Health Connect
Android 15 integrates the latest extensions around Health Connect by Android, a secure and centralized platform to manage and share app-collected health and fitness data. This update adds support for additional data types across fitness, nutrition, skin temperature, training plans, and more.
Skin temperature tracking allows users to store and share more accurate temperature data from a wearable or other tracking device.
Training plans are structured workout plans to help a user achieve their fitness goals. Training plans support includes a variety of completion and performance goals:
- Completion goals around calories burned, distance, duration, repetition, and steps.
- Performance goals around as many repetitions as possible (AMRAP), cadence, heart rate, power, perceived rate of exertion, and speed.
Learn more about the latest updates to Health Connect in Android in the Building adaptable experiences with Android Health talk from Google I/O.
اشتراک گذاری صفحه نمایش برنامه
Android 15 supports app screen sharing so users can share or record just an
app window rather than the entire device screen. This feature, first enabled in
Android 14 QPR2, includes
MediaProjection
callbacks that allow your app
to customize the app screen sharing experience. Note that for apps targeting
Android 14 (API level 34) or higher,
user consent is required for each
MediaProjection
capture session.
تجربه کاربری و رابط کاربری سیستم
اندروید 15 به توسعه دهندگان و کاربران برنامه کنترل و انعطاف بیشتری را برای پیکربندی دستگاه خود مطابق با نیازهایشان می دهد.
برای کسب اطلاعات بیشتر در مورد نحوه استفاده از آخرین پیشرفتها در Android 15 برای بهبود تجربه کاربری برنامه، به بحث بهبود تجربه کاربری برنامه Android خود از Google I/O مراجعه کنید.
پیشنمایشهای غنیتر ویجت با Generated Previews API
Before Android 15, the only way to provide widget picker previews was to specify a static image or layout resource. These previews often differ significantly from the look of the actual widget when it is placed on the home screen. Also, static resources can't be created with Jetpack Glance, so a Glance developer had to screenshot their widget or create an XML layout to have a widget preview.
Android 15 adds support for generated previews. This means that app widget
providers can generate RemoteViews
to use as the picker preview, instead
of a static resource.

Push API
Apps can provide generated previews through a push API. Apps can provide
previews at any point in their lifecycle, and don't receive an explicit request
from the host to provide previews. Previews are persisted in AppWidgetService
,
and hosts can request them on-demand. The following example loads an XML widget
layout resource and sets it as the preview:
AppWidgetManager.getInstance(appContext).setWidgetPreview(
ComponentName(
appContext,
SociaLiteAppWidgetReceiver::class.java
),
AppWidgetProviderInfo.WIDGET_CATEGORY_HOME_SCREEN,
RemoteViews("com.example", R.layout.widget_preview)
)
The expected flow is:
- At any time, the widget provider calls
setWidgetPreview
. The provided previews are persisted inAppWidgetService
with other provider info. setWidgetPreview
notifies hosts of an updated preview through theAppWidgetHost.onProvidersChanged
callback. In response, the widget host reloads all of its provider information.- When displaying a widget preview, the host checks
AppWidgetProviderInfo.generatedPreviewCategories
, and if the chosen category is available, callsAppWidgetManager.getWidgetPreview
to return the saved preview for this provider.
When to call setWidgetPreview
Because there is no callback to provide previews, apps can choose to send previews at any point when they are running. How often to update the preview depends on the widget's use case.
The following list describes the two main categories of preview use cases:
- Providers that show real data in their widget previews, such as personalized or recent information. These providers can set the preview once the user has signed in or has done initial configuration in their app. After this, they can set up a periodic task to update the previews at their chosen cadence. Examples of this type of widget could be a photo, calendar, weather or news widget.
- Providers that show static information in previews or quick-action widgets that don't display any data. These providers can set previews once, when the app first launches. Examples of this type of widget include a drive quick actions widget or chrome shortcuts widget.
Some providers might show static previews on the hub mode picker, but real information on the homescreen picker. These providers should follow the guidance for both of these use cases to set previews.
تصویر در تصویر
Android 15 对画中画 (PiP) 模式进行了更改,确保在进入画中画模式时实现更流畅的转换。对于在主界面上叠加界面元素的应用,这将非常有用,因为这些元素会进入 PiP。
开发者使用 onPictureInPictureModeChanged
回调来定义用于切换叠加界面元素可见性的逻辑。当 PiP 进入或退出动画完成时,系统会触发此回调。从 Android 15 开始,PictureInPictureUiState
类包含另一种状态。
在这种界面状态下,以 Android 15(API 级别 35)为目标平台的应用会在画中画动画开始后立即观察到使用 isTransitioningToPip()
调用的 Activity#onPictureInPictureUiStateChanged
回调。在 PiP 模式下,许多界面元素与应用无关,例如包含建议、即将播放的视频、评分和标题等信息的视图或布局。当应用进入画中画模式时,请使用 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 15 为用户提供了在大屏设备上更好地进行多任务处理的方式。对于 例如,用户可以保存自己喜爱的分屏应用组合, 访问并固定屏幕上的任务栏,以便在应用之间快速切换。这意味着 让应用具备自适应能力比以往任何时候都更加重要。
Google I/O 大会上有一些关于构建自适应 Android 的会议 应用和使用 Material 3 构建界面 自适应库 我们的文档中提供了更多帮助信息,帮助您针对大型语言 。
پشتیبانی از صفحه نمایش پوششی
برنامه شما میتواند ویژگیای را اعلام کند که Android 15 از آن استفاده میکند تا به Application
یا Activity
شما اجازه دهد روی صفحهنمایشهای کوچک روی جلد دستگاههای قابل انعطاف پشتیبانیشده ارائه شود. این صفحهها بسیار کوچک هستند و نمیتوان آنها را بهعنوان اهداف سازگار برای اجرای برنامههای Android در نظر گرفت، اما برنامه شما میتواند از آنها پشتیبانی کند و برنامه شما را در مکانهای بیشتری در دسترس قرار دهد.
قابلیت اتصال
Android 15 پلتفرم را به روز می کند تا برنامه شما به آخرین پیشرفت ها در زمینه ارتباطات و فناوری های بی سیم دسترسی داشته باشد.
پشتیبانی ماهواره ای
Android 15 به گسترش پشتیبانی پلت فرم برای اتصال ماهوارهای ادامه میدهد و شامل برخی از عناصر رابط کاربری برای اطمینان از تجربه کاربری ثابت در سراسر چشمانداز اتصال ماهوارهای است.
برنامهها میتوانند از ServiceState.isUsingNonTerrestrialNetwork()
برای تشخیص اینکه یک دستگاه به یک ماهواره متصل است، استفاده کنند و به آنها آگاهی بیشتری نسبت به اینکه چرا خدمات شبکه کامل ممکن است در دسترس نباشد، میدهند. علاوه بر این، اندروید 15 از برنامه های SMS و MMS و همچنین برنامه های RCS از پیش بارگذاری شده برای استفاده از اتصال ماهواره ای برای ارسال و دریافت پیام پشتیبانی می کند.

تجربه های روان تر NFC
Android 15 در تلاش است تا تجربه پرداخت یکپارچهتر و قابلاطمینانتر را ایجاد کند و در عین حال به پشتیبانی از اکوسیستم قدرتمند برنامه NFC اندروید ادامه دهد. در دستگاههای پشتیبانیشده، برنامهها میتوانند از NfcAdapter
درخواست کنند تا وارد حالت مشاهده شود، جایی که دستگاه گوش میدهد اما به خوانندههای NFC پاسخ نمیدهد و اشیاء PollingFrame
سرویس NFC برنامه را برای پردازش ارسال میکند. اشیاء PollingFrame
را می توان برای احراز هویت قبل از اولین ارتباط با خواننده NFC استفاده کرد که در بسیاری از موارد امکان تراکنش با یک ضربه را فراهم می کند.
علاوه بر این، برنامهها میتوانند فیلتری را روی دستگاههای پشتیبانیشده ثبت کنند تا بتوانند از فعالیت حلقه نظرسنجی مطلع شوند، که امکان عملکرد روان با چندین برنامه کاربردی NFC آگاه را فراهم میکند.
نقش کیف پول
Android 15 introduces a Wallet role that allows tighter integration with the user's preferred wallet app. This role replaces the NFC default contactless payment setting. Users can manage the Wallet role holder by navigating to Settings > Apps > Default Apps.
The Wallet role is used when routing NFC taps for AIDs registered in the payment category. Taps always go to the Wallet role holder unless another app that is registered for the same AID is running in the foreground.
This role is also used to determine where the Wallet Quick Access tile should go when activated. When the role is set to "None", the Quick Access tile isn't available and payment category NFC taps are only delivered to the foreground app.
امنیت
Android 15 به شما کمک می کند امنیت برنامه خود را افزایش دهید، از داده های برنامه خود محافظت کنید، و به کاربران شفافیت و کنترل بیشتری بر روی داده های خود می دهد. برای اطلاعات بیشتر در مورد کارهایی که برای بهبود ایمنی کاربر و محافظت از برنامه شما در برابر تهدیدات جدید انجام می دهیم، گفتگوی حفاظت از امنیت کاربر در Android را از Google I/O ببینید.
مدیریت اعتبار را با تکمیل خودکار ادغام کنید
با شروع Android 15، توسعهدهندگان میتوانند نماهای خاصی مانند فیلدهای نام کاربری یا گذرواژه را با درخواستهای Credential Manager پیوند دهند ، که ارائه یک تجربه کاربری مناسب در طول فرآیند ورود به سیستم را آسانتر میکند. هنگامی که کاربر روی یکی از این نماها تمرکز می کند، درخواست مربوطه به Credential Manager ارسال می شود. اعتبارنامههای بهدستآمده در بین ارائهدهندگان جمعآوری میشوند و در رابطهای کاربری جایگزین تکمیل خودکار، مانند پیشنهادات درون خطی یا پیشنهادات کشویی نمایش داده میشوند. کتابخانه Jetpack androidx.credentials نقطه پایانی ترجیحی برای استفاده توسعه دهندگان است و به زودی برای بهبود بیشتر این ویژگی در اندروید 15 و بالاتر در دسترس خواهد بود.
ثبتنام و ورود با یک ضربه را با اعلانهای بیومتریک ادغام کنید
Credential Manager اعلانهای بیومتریک را در فرآیندهای ایجاد اعتبار و ورود به سیستم ادغام میکند و نیاز ارائهدهندگان را برای مدیریت درخواستهای بیومتریک از بین میبرد. در نتیجه، ارائه دهندگان اعتبار فقط باید بر نتایج ایجاد و دریافت جریان ها، به همراه نتیجه جریان بیومتریک تمرکز کنند. این فرآیند ساده، فرآیند ایجاد و بازیابی اعتبار کارآمدتر و کارآمدتر را ایجاد می کند.
مدیریت کلید برای رمزگذاری سرتاسر
We are introducing the E2eeContactKeysManager
in Android 15, which
facilitates end-to-end encryption (E2EE) in your Android apps by providing an
OS-level API for the storage of cryptographic public keys.
The E2eeContactKeysManager
is designed to integrate with the platform
contacts app to give users a centralized way to manage and verify their
contacts' public keys.
مجوزهای URI محتوا را بررسی می کند
Android 15 introduces a set of APIs that perform permission checks on content URIs:
Context.checkContentUriPermissionFull
: This performs a full permission check on content URIs.Activity
manifest attributerequireContentUriPermissionFromCaller
: This enforces specified permissions on the provided content URIs at activity launch.ComponentCaller
class forActivity
callers: This represents the app that launched the activity.
دسترسی
اندروید 15 ویژگی هایی را اضافه می کند که دسترسی کاربران را بهبود می بخشد.
خط بریل بهتر
در Android 15، ما این امکان را برای TalkBack فراهم کردهایم که از نمایشگرهای بریل که از استاندارد HID از طریق USB و بلوتوث ایمن استفاده میکنند، پشتیبانی کند.
این استاندارد، دقیقاً مشابه استانداردی که توسط ماوس ها و صفحه کلیدها استفاده می شود، به اندروید کمک می کند تا در طول زمان از طیف وسیع تری از نمایشگرهای بریل پشتیبانی کند.
بین المللی شدن
اندروید 15 ویژگیها و قابلیتهایی را اضافه میکند که تجربه کاربر را در هنگام استفاده از دستگاه به زبانهای مختلف تکمیل میکند.
فونت متغیر CJK
با شروع Android 15، فایل فونت برای زبان های چینی، ژاپنی و کره ای (CJK)، NotoSansCJK، اکنون یک فونت متغیر است. فونت های متغیر فرصت هایی را برای تایپوگرافی خلاقانه در زبان های CJK باز می کنند. طراحان میتوانند طیف وسیعتری از سبکها را بررسی کنند و طرحبندیهای بصری چشمگیری ایجاد کنند که قبلاً دستیابی به آنها دشوار یا غیرممکن بود.

توجیه بین شخصیتی
Starting with Android 15, text can be justified utilizing letter spacing by
using JUSTIFICATION_MODE_INTER_CHARACTER
. Inter-word justification was
first introduced in Android 8.0 (API level 26), and inter-character
justification provides similar capabilities for languages that use the
whitespace character for segmentation, such as Chinese, Japanese, and others.

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
از سبک کلمه بدون خطشکن استفاده میکند، مانند 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. This logo or a modified version may be used or modified by anyone to refer to the VideoLAN project or any product developed by the VideoLAN team, but does not indicate endorsement by the project.
Vulkan and the Vulkan logo are registered trademarks of the Khronos Group Inc.
OpenGL is a registered trademark and the OpenGL ES logo is a trademark of Hewlett Packard Enterprise used by permission by Khronos.