ב-Android 14 יש תכונות וממשקי API מעולים למפתחים. אפשר להיעזר במקורות המידע הבאים תוכלו ללמוד על תכונות של האפליקציות ולהתחיל לעבוד עם ממשקי ה-API הקשורים.
רשימה מפורטת של ממשקי ה-API שנוספו, שונו והוסרו מפורטת בדוח ההבדלים של ממשקי ה-API. פרטים על ממשקי API שנוספו זמינים בחומר העזר בנושא Android API. לגבי Android 14, מחפשים ממשקי API שנוספו ברמת API 34. כדי לקבל מידע על תחומים שבהם שינויים בפלטפורמה עשויים להשפיע על האפליקציות שלכם, כדאי לעיין בשינויים בהתנהגות של Android 14 באפליקציות שמטרגטות ל-Android 14 ובכל האפליקציות.
אינטרנציונליזציה
העדפות שפה לכל אפליקציה
ב-Android 14 נוספו לתכונות של שפה לכל אפליקציה, שהוצגו ב-Android 13 (רמת API 33), היכולות הבאות:
יצירה אוטומטית של
localeConfig
של אפליקציה: החל מ-Android Studio Giraffe Canary 7 ו-AGP 8.1.0-alpha07, אפשר להגדיר את האפליקציה כך שתתמוך באופן אוטומטי בהעדפות שפה לכל אפליקציה. על סמך המשאבים של הפרויקט, הפלאגין של Android Gradle יוצר את הקובץLocaleConfig
ומוסיף לו הפניה בקובץ המניפסט הסופי, כך שאין יותר צורך ליצור או לעדכן את הקובץ באופן ידני. מערכת AGP משתמשת במשאבים בתיקיותres
של מודולי האפליקציה ובכל יחסי התלות של מודולי הספריות כדי לקבוע את האזורים הגיאוגרפיים שצריך לכלול בקובץLocaleConfig
.עדכונים דינמיים של
localeConfig
באפליקציה: משתמשים בשיטותsetOverrideLocaleConfig()
ו-getOverrideLocaleConfig()
שמפורטות ב-LocaleManager
כדי לעדכן באופן דינמי את רשימת השפות הנתמכות באפליקציה בהגדרות המערכת של המכשיר. הגמישות הזו מאפשרת לכם להתאים אישית את רשימת השפות הנתמכות לפי אזור, להריץ ניסויים מסוג A/B או לספק רשימה מעודכנת של אזורי זמן אם האפליקציה שלכם משתמשת בהעברות (push) בצד השרת לצורך לוקליזציה.הצגת שפת האפליקציה לעורכי שיטות קלט (IME): עורכי שיטות קלט יכולים להשתמש ב-method
getApplicationLocales()
כדי לבדוק את שפת האפליקציה הנוכחית ולהתאים את שפת ה-IME לשפה הזו.
Grammatical Inflection API
3 מיליארד אנשים דוברים שפות עם מגדר: שפות שבהן קטגוריות דקדוקיות – כמו שמות עצם, פעלים, שמות תואר ומילות יחס – משתנות בהתאם למגדר של האנשים והאובייקטים שאתם מדברים אליהם או עליהם. באופן מסורתי, בשפות רבות עם מגדר נעשה שימוש במגדר grammatcal masculine כמגדר ברירת המחדל או כמגדר כללי.
שימוש במגדר הדקדוקי הלא נכון למשתמשים, למשל שימוש במגדר הדקדוקי הזכרי לנשים, עלול להשפיע לרעה על הביצועים והגישה שלהם. לעומת זאת, ממשק משתמש עם שפה שמשקפת בצורה נכונה את המגדר הדקדוקי של המשתמש יכול לשפר את המעורבות של המשתמש ולספק חוויית משתמש מותאמת אישית יותר וטבעית יותר.
כדי לעזור לכם ליצור ממשק משתמש שמתמקד במשתמשים בשפות עם הבחנה בין מינים, ב-Android 14 מופיע Grammatical Inflection API, שמאפשר לכם להוסיף תמיכה בלשון מגדרית בלי לבצע רפאקציה לאפליקציה.
העדפות אזוריות
העדפות אזוריות מאפשרות למשתמשים להתאים אישית את יחידות הטמפרטורה, את היום הראשון בשבוע ואת מערכות המספור. אירופאי שגר בארצות הברית עשוי להעדיף יחידות טמפרטורה בצלזיוס ולא בפרנהייט אפליקציות להתייחס ליום שני כתחילת השבוע במקום כברירת המחדל בארה"ב יום ראשון.
תפריטי ההגדרות החדשים של Android עבור ההעדפות האלה מספקים למשתמשים מיקום מרכזי ונגיש לשינוי העדפות האפליקציות. האלה
גם בגיבוי ובשחזור. כמה ממשקי API וכוונות (intents) – כמו getTemperatureUnit
ו-getFirstDayOfWeek
– מעניקים לאפליקציה הרשאת קריאה להעדפות המשתמש, כדי שהיא תוכל לשנות את אופן הצגת המידע. אפשר גם לרשום
BroadcastReceiver
במצב פעיל
ACTION_LOCALE_CHANGED
כדי לטפל בשינויים בתצורת הלוקאל כשיש שינוי בהעדפות הפורמט והמידות.
כדי למצוא את ההגדרות האלה, צריך לפתוח את אפליקציית ההגדרות ולעבור אל מערכת > שפות קלט > העדפות אזוריות.


נגישות
הגדלת גופן לא לינארית ל-200%
החל מגרסה 14 של Android, המערכת תומכת בהגדלת גופן עד 200%, ומספקת למשתמשים עם לקות ראייה אפשרויות נוספות של נגישות בהתאם להנחיות הנגישות לתוכן אינטרנט (WCAG).
כדי למנוע הגדלה גדולה מדי של אלמנטים גדולים של טקסט במסך, המערכת מחילה עקומת שינוי לא לינארית. באמצעות אסטרטגיה זו של הגדלה באחוזים לא משתנה באותו קצב של טקסט קטן. שינוי גודל גופנים לא לינארי עוזר לשמר את ההיררכיה הפרופורציונלית בין רכיבים בגדלים שונים, צמצום בעיות עם שינוי גודל טקסט ליניארי במעלות גבוהות (למשל נחתך או טקסט שקשה יותר לקרוא עקב תצוגה גדולה מאוד גדלים).
בדיקת האפליקציה עם שינוי גודל גופן לא לינארי

אם אתם כבר משתמשים ביחידות פיקסלים (sp) מותאמות כדי להגדיר את גודל הטקסט, אפשרויות נוספות ושיפורים בהתאמה לעומס (scaling) מיושמים באופן אוטומטי טקסט באפליקציה. עם זאת, עדיין צריך לבצע בדיקת ממשק משתמש עם גודל הגופן הופעל (200%) כדי לוודא שהאפליקציה מחילה את גודלי הגופנים בצורה נכונה ויכולה להתאים לגופנים גדולים יותר בלי להשפיע על נוחות השימוש.
כדי להגדיל את גודל הגופן ל-200%:
- פותחים את אפליקציית ההגדרות ועוברים אל נגישות > גודל התצוגה ו text.
- באפשרות גודל הגופן, מקישים על סמל הפלוס (+) עד לגופן המקסימלי. הגדרת הגודל מופעלת, כפי שמוצג בתמונה הנלווית .
שימוש ביחידות של פיקסלים משוקללים (sp) לגודל הטקסט
חשוב לזכור תמיד לציין את גדלי הטקסט ביחידות sp. מתי באפליקציה שלך נעשה שימוש ביחידות sp, מערכת Android יכולה להחיל את גודל הטקסט המועדף על המשתמש וגם להתאים אותו לעומס.
לא להשתמש ביחידות sp למרווחים פנימיים או להגדיר גובה תצוגה בהנחה שיש מרווח פנימי משתמע: כשמשתמשים בהתאמת גודל גופן לא לינארית, יכול להיות שהמידות ב-sp לא יהיו פרופורציונליות, כך ש-4sp + 20sp לא יהיה שווה ל-24sp.
המרת יחידות פיקסלים (sp) מותאמות
כדי להמיר מיחידות sp, צריך להשתמש ב-TypedValue.applyDimension()
לפיקסלים, ומשתמשים ב-TypedValue.deriveDimension()
כדי
להמיר פיקסלים ל-sp. בשיטות האלה המערכת מיישמת את ההתאמה לעומס (scaling) המתאים
עקומה באופן אוטומטי.
מומלץ להימנע מכתיבת משוואות בתוך הקוד באמצעות
Configuration.fontScale
או
DisplayMetrics.scaledDensity
. מפני ששינוי גודל הגופן
שאינו לינארי, השדה scaledDensity
כבר לא מדויק. fontScale
יש להשתמש בשדה למטרות מידע בלבד, מאחר שהגופנים כבר לא קיימים
עם ערך סקלר יחיד.
שימוש ביחידות sp עבור lineHeight
תמיד צריך להגדיר android:lineHeight
באמצעות יחידות sp
של dp, כך שגובה השורה ישתנה בהתאם לטקסט. אחרת, אם הטקסט
הוא sp אבל הערך של lineHeight
הוא ב-dp או ב-px, הוא לא גדל ונראה דחוס.
TextView מתקן באופן אוטומטי את lineHeight
כדי לשמור על הפרופורציות הרצויות, אבל רק אם גם textSize
וגם lineHeight
מוגדרים ביחידות sp.
מצלמה ומדיה
Ultra HDR לתמונות

ב-Android 14 נוספה תמיכה בתמונות באיכות HDR (טווח דינמי גבוה), שמאפשרות לשמור יותר מידע מהחיישן בזמן הצילום, וכך לייצר צבעים עזים וניגודיות גבוהה יותר. ב-Android נעשה שימוש בפורמט Ultra HDR, שהוא תואם לאחור לתמונות JPEG. כך האפליקציות יכולות לפעול בצורה חלקה עם תמונות HDR ולהציג אותן בטווח דינמי סטנדרטי (SDR) לפי הצורך.
המערכת מבצעת את העיבוד של התמונות האלה בממשק המשתמש ב-HDR באופן אוטומטי כשהאפליקציה בוחרת להשתמש בממשק משתמש ב-HDR בחלון הפעילות שלה, דרך רשומה במניפסט או במהלך זמן הריצה על ידי קריאה ל-Window.setColorMode()
. אפשר גם לצלם תמונות סטילס דחוסות ב-Ultra HDR במכשירים נתמכים. כשהחיישן משחזר יותר צבעים, אפשר לערוך את התמונות בצורה גמישה יותר. אפשר להשתמש ב-Gainmap
שמשויך לתמונות Ultra HDR כדי ליצור רינדור שלהן באמצעות OpenGL או Vulkan.
תוספי מצלמה, זום, פוקוס, צפייה לאחר מכן ועוד
ב-Android 14 יש שיפורים בתוספים למצלמה, שמאפשרים לאפליקציות להתמודד עם זמני עיבוד ארוכים יותר. כך אפשר לצלם תמונות טובות יותר באמצעות אלגוריתמים שמבוססים על חישובים כבדים, כמו צילום בתאורה חלשה במכשירים נתמכים. התכונות האלה מספקות למשתמשים חוויה חזקה עוד יותר כשהם משתמשים ביכולות של התוספים למצלמה. דוגמאות לשיפורים האלה:
- אומדן זמן האחזור הדינמי של עיבוד התמונות הסטטיות מספק אומדנים מדויקים הרבה יותר של זמן האחזור של התמונות הסטטיות, על סמך תנאי הסביבה והסצנה הנוכחיים. קוראים ל-
CameraExtensionSession.getRealtimeStillCaptureLatency()
כדי לקבל אובייקטStillCaptureLatency
עם שתי שיטות להערכת זמן האחזור. השיטהgetCaptureLatency()
מחזירה את זמן האחזור המשוער ביןonCaptureStarted
ל-onCaptureProcessStarted()
, והשיטהgetProcessingLatency()
מחזירה את זמן האחזור המשוער ביןonCaptureProcessStarted()
לבין זמינות המסגרת הסופית שעברה עיבוד. - תמיכה בקריאות חזרה (callbacks) של התקדמות הצילום, כדי שאפליקציות יוכלו להציג את ההתקדמות הנוכחית של פעולות עיבוד ממושכות של צילומי סטילס. אפשר לבדוק אם התכונה הזו זמינה באמצעות
CameraExtensionCharacteristics.isCaptureProcessProgressAvailable
. אם כן, מטמיעים את פונקציית הקריאה החוזרתonCaptureProcessProgressed()
, שבה מועבר הפרמטר של ההתקדמות (מ-0 עד 100). מטא-נתונים ספציפיים לתוסף, כמו
CaptureRequest.EXTENSION_STRENGTH
כדי להזין את מידת האפקט של התוסף, למשל מידת הטשטוש של הרקע באמצעותEXTENSION_BOKEH
.התכונה 'תצוגה לאחר הצילום' לצילום סטילס בתוספים למצלמה, שמספקת תמונה שעברה עיבוד פחות מאשר התמונה הסופית, במהירות גבוהה יותר. אם תוסף מאריך את זמן האחזור לעיבוד, אפשר לספק תמונה שלאחר הצפייה כתמונה זמנית כדי לשפר את חוויית המשתמש, ולאחר מכן להחליף אותה בתמונה הסופית. אפשר לבדוק אם התכונה הזו זמינה באמצעות
CameraExtensionCharacteristics.isPostviewAvailable
. לאחר מכן תוכלו להעבירOutputConfiguration
אלExtensionSessionConfiguration.setPostviewOutputConfiguration
.תמיכה ב-
SurfaceView
שמאפשרת נתיב עיבוד נתונים יעיל יותר וחסכוני יותר באנרגיה לתצוגה מקדימה.תמיכה בהקשה כדי להתמקד ובשינוי מרחק התצוגה במהלך השימוש בתוסף.
זום בתוך החיישן
当 CameraCharacteristics
中的 REQUEST_AVAILABLE_CAPABILITIES_STREAM_USE_CASE
包含 SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW
时,您的应用可以使用高级传感器功能,将剪裁后的 RAW 数据流的像素与全视野范围相同,方法是将 CaptureRequest
与将数据流用例设置为 CameraMetadata.SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW
的 RAW 目标搭配使用。通过实现请求替换控件,更新后的相机可让用户在其他相机控件准备就绪之前使用缩放控件。
אודיו ב-USB ללא אובדן נתונים
ב-Android 14 יש תמיכה בפורמטים של אודיו ללא אובדן נתונים, כדי שתוכלו ליהנות מחוויית אודיו ברמה גבוהה באמצעות אוזניות קוויות עם חיבור USB. אפשר לשלוח שאילתה למכשיר USB כדי לקבל את מאפייני המיקסר המועדפים שלו, לרשום מאזין לשינויים במאפייני המיקסר המועדפים ולהגדיר את מאפייני המיקסר באמצעות הכיתה AudioMixerAttributes
. המחלקה הזו מייצגת את הפורמט, כמו מסכת הערוץ, קצב הדגימה וההתנהגות של מיקסר האודיו. הסוג הזה מאפשר לשלוח אודיו ישירות, בלי ערבוב, שינוי עוצמת קול או עיבוד אפקטים.
כלים וכלים למפתחים
מנהל פרטי הכניסה
ב-Android 14 נוספה התמיכה ב-Credential Manager כ-API בפלטפורמה, עם תמיכה נוספת במכשירי Android 4.4 (רמת API 19) דרך ספריית Jetpack באמצעות Google Play Services. המטרה של Credential Manager היא להקל על המשתמשים להיכנס באמצעות ממשקי API שמאחזרים ומאחסנים את פרטי הכניסה באמצעות ספקי פרטי כניסה שהמשתמשים מגדירים. Credential Manager תומך במספר שיטות כניסה, כולל שם משתמש וסיסמה, מפתחות גישה ופתרונות כניסה מאוחדת (כמו 'כניסה באמצעות חשבון Google') בממשק API אחד.
למפתחות הגישה יש יתרונות רבים. לדוגמה, מפתחות הגישה מבוססים על תקנים מקובלים בתחום, יכולים לפעול במגוון מערכות הפעלה וסביבות עסקיות בדפדפנים, ואפשר להשתמש בהם גם באתרים וגם באפליקציות.
למידע נוסף, עיינו במסמכי העזרה בנושא Credential Manager ומפתחות גישה ובפוסט בבלוג בנושא Credential Manager ומפתחות גישה.
Health Connect
Health Connect 是用户健康与健身数据的设备端仓库。借助该功能,用户可以在一个位置控制要与这些应用共享哪些数据,并在自己喜爱的应用之间共享数据。
在搭载 Android 14 之前的 Android 版本的设备上,Health Connect 可作为应用从 Google Play 商店下载。从 Android 14 开始,Health Connect 将成为 Android 平台的一部分,并通过 Google Play 系统更新接收更新,而无需单独下载。这样一来,Health Connect 就可以频繁更新,您的应用可以依赖于搭载 Android 14 或更高版本的设备上提供的 Health Connect。用户可以通过设备的“设置”访问 Health Connect,隐私控制功能集成到系统设置中。


Health Connect 在 Android 14 中包含多项新功能,例如锻炼路线,可让用户分享可在地图上直观呈现的锻炼路线。路线定义为在一定时间范围内保存的位置列表,您的应用可以将路线插入锻炼时段,将它们关联起来。为确保用户能够完全控制此类敏感数据,用户必须允许与其他应用共享单个路线。
如需了解详情,请参阅 Health Connect 文档以及有关 Android Health 中的新功能的博文。
עדכונים לגבי OpenJDK 17
Android 14 将继续更新 Android 的核心库,以与最新 OpenJDK LTS 版本中的功能保持一致,包括适合应用和平台开发者的库更新和 Java 17 语言支持。
其中包含以下功能和改进:
- 将大约 300 个
java.base
类更新为支持 Java 17。 - 文本块 - 为 Java 编程语言引入了多行字符串字面量。
- instanceof 模式匹配:可让对象在
instanceof
中被视为具有特定类型,而无需任何额外的变量。 - 密封类:允许您限制哪些类和接口可以扩展或实现它们。
得益于 Google Play 系统更新 (Project Mainline),6 亿多台设备能够接收包含这些更改的最新 Android 运行时 (ART) 更新。我们致力于为应用提供更加一致、安全的跨设备环境,并为用户提供独立于平台版本的新功能。
Java 和 OpenJDK 是 Oracle 及/或其关联公司的商标或注册商标。
שיפורים לחנויות אפליקציות
ב-Android 14 נוספו כמה ממשקי API של PackageInstaller
שמאפשרים לחנויות האפליקציות לשפר את חוויית המשתמש שלהן.
בקשה לאישור התקנה לפני ההורדה
יכול להיות שתצטרכו אישור משתמש כדי להתקין או לעדכן אפליקציה.
לדוגמה, כשתוכנית התקנה שמשתמשת בהרשאה REQUEST_INSTALL_PACKAGES
מנסה להתקין אפליקציה חדשה. בגרסאות קודמות של Android, חנויות אפליקציות יכולות לבקש אישור מהמשתמש רק אחרי שקבצי ה-APK נכתבים בסשן ההתקנה והסשן מוגדר.
החל מ-Android 14, השיטה requestUserPreapproval()
מאפשרת למתקינים לבקש אישור מהמשתמשים לפני ביצוע סשן ההתקנה. השיפור הזה מאפשר לחנות אפליקציות לדחות את הורדת חבילות ה-APK עד שהמשתמש יאשר את ההתקנה. בנוסף, אחרי שהמשתמש מאשר את ההתקנה, חנות האפליקציות יכולה להוריד ולהתקין את האפליקציה ברקע בלי להפריע למשתמש.
לטעון לבעלות על עדכונים עתידיים
השיטה setRequestUpdateOwnership()
מאפשרת למתקין להציין למערכת שהוא מתכוון להיות אחראי על עדכונים עתידיים לאפליקציה שהוא מתקין. היכולת הזו מאפשרת לאכוף את הבעלות על העדכון, כלומר רק בעל העדכון רשאי להתקין עדכונים אוטומטיים לאפליקציה. אכיפת הבעלות על העדכון עוזרת לוודא שהמשתמשים מקבלים עדכונים רק מחנות האפליקציות הצפויה.
כל מתקין אחר, כולל אלה שמשתמשים בהרשאה INSTALL_PACKAGES
, צריך לקבל אישור מפורש מהמשתמש כדי להתקין עדכון. אם משתמש מחליט להמשיך עם עדכון ממקור אחר, הבעלות על העדכון אבודה.
עדכון אפליקציות בזמנים פחות מפריעים
בדרך כלל, בחנויות האפליקציות לא רוצים לעדכן אפליקציה שבשימוש פעיל, כי זה מוביל לסגירת התהליכים שפועלים באפליקציה, ויכול להפריע למה שהמשתמש עושה.
החל מ-Android 14, ממשק ה-API של InstallConstraints
מאפשר למתקינים לוודא שהעדכונים של האפליקציות שלהם מתבצעים בזמן המתאים. לדוגמה, חנות אפליקציות יכולה להפעיל את השיטה commitSessionAfterInstallConstraintsAreMet()
כדי לוודא שהעדכון יאושר רק כשהמשתמש כבר לא יוצר אינטראקציה עם האפליקציה הרלוונטית.
התקנה חלקה של חלוקות אופציונליות
כשמשתמשים ב-APKs מפוצלים, אפשר לספק את התכונות של האפליקציה בקובצי APK נפרדים, במקום כ-APK מונוליתי. קובצי APK מפוצלים מאפשרים לחנויות אפליקציות לבצע אופטימיזציה של העברת הרכיבים השונים של האפליקציה. לדוגמה, חנויות אפליקציות עשויות לבצע אופטימיזציה על סמך המאפיינים של מכשיר היעד. ה-API של PackageInstaller
תומך בחלוקות מאז ההשקה שלו ברמת API 22.
ב-Android 14, השיטה setDontKillApp()
מאפשרת למנהל ההתקנה לציין שלא צריך להרוג את התהליכים שפועלים באפליקציה כשמתקינים פלחים חדשים. חנויות האפליקציות יכולות להשתמש בתכונה הזו כדי להתקין בצורה חלקה תכונות חדשות של אפליקציה בזמן שהמשתמש משתמש באפליקציה.
חבילות מטא-נתונים של אפליקציות
החל מ-Android 14, מנהל החבילות של Android מאפשר לציין מטא-נתונים של אפליקציות, כמו שיטות לאבטחת נתונים, כדי לכלול אותם בדפי החנות של האפליקציות, כמו Google Play.
זיהוי מקרים שבהם משתמשים מצלמים צילומי מסך של המכשיר
כדי ליצור חוויה סטנדרטית יותר לזיהוי צילומי מסך, ב-Android 14 כוללים תכונה של זיהוי צילומי מסך ששומרת על הפרטיות API. ה-API הזה מאפשר לאפליקציות לרשום קריאות חוזרות (callback) לפי פעילות. פונקציות ה-callbacks האלה מופעלות, והמשתמש מקבל הודעה, כשהמשתמש מצלם צילום מסך בזמן שהפעילות הזו גלויה.
חוויית משתמש
פעולות מותאמות אישית בגיליון שיתוף ודירוג משופר
ב-Android 14 מתבצע עדכון של גיליון השיתוף של המערכת כדי לתמוך בפעולות מותאמות אישית באפליקציות ובתצוגות מקדימות מפורטות יותר של תוצאות למשתמשים.
הוספת פעולות בהתאמה אישית
ב-Android 14, האפליקציה יכולה להוסיף פעולות בהתאמה אישית לגיליון השיתוף של המערכת שהיא מפעילה.

שיפור הדירוג של יעדים לשיתוף ישיר
ב-Android 14 נעשה שימוש באותות רבים יותר מאפליקציות כדי לקבוע את הדירוג של יעדי השיתוף הישיר, וכך לספק תוצאות מועילות יותר למשתמש. כדי לספק את האות הכי שימושי לדירוג, פועלים לפי ההנחיות לשיפור הדירוג של היעדים של שיתוף ישיר. אפליקציות תקשורת יכולות גם לדווח על שימוש במקשי קיצור להודעות יוצאות ונכנסות.

תמיכה באנימציות מובנות ומותאמות אישית עבור 'חזרה חזויה'
ב-Android 13 הוספנו את האפשרות להפעיל אנימציה חזרה למסך הבית באופן יזום, כאפשרות לפיתוח. כשמשתמשים בתנועת החלקה לאחור באפליקציה נתמכת עם אפשרות הפיתוח מופעלת, מוצגת אנימציה שמציינת שתנועת ההחלקה לאחור יוצאת מהאפליקציה ומחזירה למסך הבית.
Android 14 כולל כמה שיפורים והנחיות חדשות לגבי 'חזרה חזותית':
- אפשר להגדיר את
android:enableOnBackInvokedCallback=true
כדי להביע הסכמה לשימוש באנימציות מערכת לחיזוי תנועת החזרה לכל פעילות בנפרד, במקום לכל האפליקציה. - הוספנו אנימציות מערכת חדשות שיתלוו לאנימציה של החזרה למסך הבית מ-Android 13. אנימציות המערכת החדשות הן פעילות בכל פעילות ומשימות שונות, והן מופיעות באופן אוטומטי אחרי העברה ל'חזרה חזוי'.
- הוספנו אנימציות חדשות של רכיבי Material לגיליונות בתחתית המסך, לגיליונות צדדיים ולחיפוש.
- יצרנו הנחיות לעיצוב ליצירת אנימציות ומעברים מותאמים אישית באפליקציה.
- הוספנו ממשקי API חדשים שתומכים באנימציות מעבר בהתאמה אישית באפליקציה:
handleOnBackStarted
,handleOnBackProgressed
,handleOnBackCancelled
in
OnBackPressedCallback
onBackStarted
,onBackProgressed
,onBackCancelled
in
OnBackAnimationCallback
- משתמשים ב-
overrideActivityTransition
במקום ב-overridePendingTransition
כדי ליצור מעברים שתגובה כשהמשתמש מחליק חזרה.
בגרסה הזו של Android 14 בתצוגה מקדימה, כל התכונות של 'חזרה חזותית חזרה' נותרו מאחורי אפשרות למפתחים. כדאי לעיין במדריך למפתחים בנושא העברת האפליקציה לחזרה חזותית חזוי, וגם במדריך למפתחים בנושא יצירת מעברים מותאמים אישית באפליקציה.
שינויים מברירת המחדל של היצרן של מכשירים עם מסך גדול לאפליקציה
שינוי הגדרות ברמת האפליקציה מאפשר ליצרני המכשירים לשנות את ההתנהגות של האפליקציות במכשירים עם מסך גדול. לדוגמה, ההחרגה FORCE_RESIZE_APP
מורה למערכת לשנות את גודל האפליקציה כך שיתאים למימדי המסך (מבלי להשתמש במצב תאימות לגודל) גם אם הערך resizeableActivity="false"
מוגדר בקובץ המניפסט של האפליקציה.
השינויים מברירת המחדל נועדו לשפר את חוויית המשתמש במסכים גדולים.
מאפייני מניפסט חדשים מאפשרים להשבית חלק מהשינויים של יצרן המכשירים באפליקציה שלכם.
שינויים למשתמשים בכל אפליקציה במסך גדול
שינוי ההגדרות של כל אפליקציה בנפרד משנה את התנהגות האפליקציות במכשירים עם מסך גדול. לדוגמה, שינוי ברירת המחדל של יצרן המכשיר OVERRIDE_MIN_ASPECT_RATIO_LARGE
מגדיר את יחס הגובה-רוחב של האפליקציה ל-16:9, ללא קשר להגדרות האפליקציה.
ב-Android 14 QPR1, משתמשים יכולים להחיל שינויים ספציפיים לאפליקציות באמצעות תפריט הגדרות חדש במכשירים עם מסך גדול.
שיתוף מסך של אפליקציה
שיתוף מסך של אפליקציה מאפשר למשתמשים לשתף חלון של אפליקציה במקום את כל מסך המכשיר במהלך הקלטת תוכן המסך.
כשמשתפים את המסך של אפליקציה, סרגל הסטטוס, סרגל הניווט, ההתראות ואלמנטים אחרים בממשק המשתמש של המערכת לא נכללים במסך המשותף. רק התוכן של האפליקציה שנבחרה ישותף.
שיתוף המסך של אפליקציות משפר את הפרודוקטיביות והפרטיות, כי הוא מאפשר למשתמשים להפעיל כמה אפליקציות אבל להגביל את שיתוף התוכן לאפליקציה אחת.
תשובה מהירה מבוססת-LLM ב-Gboard ב-Pixel 8 Pro
במכשירי Pixel 8 Pro עם גרסת Feature Drop מדצמבר, מפתחים יכולים לנסות תשובות חכמות באיכות גבוהה יותר ב-Gboard שמבוססות על מודלים גדולים של שפה (LLM) במכשיר שפועלים על Google Tensor.
התכונה הזו זמינה בתור תצוגה מקדימה מוגבלת באנגלית (ארה"ב) ב-WhatsApp, ב-Line וב-KakaoTalk. כדי להשתמש בתכונה הזו, צריך מכשיר Pixel 8 Pro עם Gboard כמקלדת.
כדי לנסות את התכונה, קודם צריך להפעיל אותה בקטע הגדרות > אפשרויות למפתחים > הגדרות AICore > הפעלת AICore Persistent.
לאחר מכן, פותחים שיחה באפליקציה נתמכת כדי לראות את התשובות המהירות שמבוססות על LLM בשורת ההצעות של Gboard בתגובה להודעות נכנסות.
גרפיקה
אפשר לשלוח שאילתות לגבי נתיבים ולבצע בהם אינטרפולציה
Android 的 Path
API 是一种强大且灵活的机制,可用于创建和渲染矢量图形,能够描边或填充路径、根据线段或二次曲线或立方曲线构建路径、执行布尔运算以获取更复杂的形状,或同时执行所有这些操作。但有一个限制是,您无法了解 Path 对象中实际包含的内容;该对象的内部信息在创建后对调用方是不透明的。
如需创建 Path
,您可以调用 moveTo()
、lineTo()
和 cubicTo()
等方法来添加路径段。但是,无法询问该路径有哪些片段,因此您必须在创建时保留该信息。
从 Android 14 开始,您可以查询路径以了解其内部内容。首先,您需要使用 Path.getPathIterator
API 获取 PathIterator
对象:
val path = Path().apply { moveTo(1.0f, 1.0f) lineTo(2.0f, 2.0f) close() } val pathIterator = path.pathIterator
Path path = new Path(); path.moveTo(1.0F, 1.0F); path.lineTo(2.0F, 2.0F); path.close(); PathIterator pathIterator = path.getPathIterator();
接下来,您可以调用 PathIterator
逐个遍历片段,并检索每个片段的所有必要数据。以下示例使用了 PathIterator.Segment
对象,它会为您打包数据:
for (segment in pathIterator) { println("segment: ${segment.verb}, ${segment.points}") }
while (pathIterator.hasNext()) { PathIterator.Segment segment = pathIterator.next(); Log.i(LOG_TAG, "segment: " + segment.getVerb() + ", " + segment.getPoints()); }
PathIterator
还有一个非分配版 next()
,您可以在其中传入缓冲区来保存点数据。
查询 Path
数据的一个重要用例是插值。例如,您可能想在两个不同的路径之间添加动画(或变形)。为了进一步简化该用例,Android 14 针对 Path
还包含 interpolate()
方法。假设两个路径具有相同的内部结构,interpolate()
方法会使用该插值结果创建一个新的 Path
。以下示例返回了一个形状介于 path
和 otherPath
之间的一半(线性插值为 0.5)的路径:
val interpolatedResult = Path() if (path.isInterpolatable(otherPath)) { path.interpolate(otherPath, .5f, interpolatedResult) }
Path interpolatedResult = new Path(); if (path.isInterpolatable(otherPath)) { path.interpolate(otherPath, 0.5F, interpolatedResult); }
Jetpack graphics-path 库也为早期版本的 Android 启用了类似的 API。
רשתות מותאמות אישית עם שגיאות קודקוד ושבב מידע
כבר זמן רב יש ב-Android תמיכה בציור של רשתות משולשים עם הצללה בהתאמה אישית, אבל פורמט הרשת של הקלט היה מוגבל למספר שילובים מוגדרים מראש של מאפיינים. ב-Android 14 נוספה תמיכה במערכות רשת מותאמות אישית, שאפשר להגדיר כמשולשיים או כרצועות משולשים, ואפשר גם להוסיף אותן לאינדקס. המרקשים האלה מצוינים באמצעות מאפיינים מותאמים אישית, צעדים של קודקודים, משתנים ושגיאות של קודקודים וחלקיקים שנכתבו ב-AGSL.
ב-vertex shader מוגדרים המשתנים, כמו המיקום והצבע, ואילו ב-fragment shader אפשר להגדיר את הצבע של הפיקסל, בדרך כלל באמצעות המשתנים שנוצרו על ידי ה-vertex shader. אם הצבע מסופק על ידי ה-fragment shader, הוא מעורבב עם הצבע הנוכחי של Paint
באמצעות מצב המיזוג שנבחר בזמן ציור המכסה. אפשר להעביר מאפיינים אחידים לשדרוגים של הפיקסלים והקודקודים כדי לקבל גמישות נוספת.
כלי לעיבוד מאגר נתונים זמני של חומרה עבור לוח הציור
协助使用 Android 的 Canvas
API 通过
硬件加速至 HardwareBuffer
、Android 14
引入了 HardwareBufferRenderer
。如果您的用例涉及通过 SurfaceControl
与系统合成器通信以实现低延迟绘制,此 API 特别有用。