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:使用LocaleManager方法中的setOverrideLocaleConfig()和getOverrideLocaleConfig()可以在设备的系统设置中动态更新应用的受支持语言列表。有了这种灵活性,您可以按区域自定义支持的语言列表、运行 A/B 实验,或者如果您的应用通过服务器端推送进行本地化,则可以提供更新后的语言区域列表。输入法 (IME) 的应用语言可见性:IME 可以利用
getApplicationLocales()方法查看当前应用的语言,并将 IME 语言与该语言进行匹配。
Grammatical Inflection API
ผู้คนกว่า 3 พันล้านคนพูดภาษาที่มีเพศ ซึ่งเป็นภาษาที่คำในหมวดหมู่ทางไวยากรณ์ เช่น คำนาม คำกริยา คำคุณศัพท์ และคำบุพบท จะผันตามเพศของบุคคลและวัตถุที่คุณพูดด้วยหรือพูดถึง โดยทั่วไปแล้ว ภาษาที่มีเพศหลายเพศหลายภาษาใช้เพศทางไวยากรณ์เพศชายเป็นเพศเริ่มต้นหรือเพศทั่วไป
การเรียกผู้ใช้ด้วยเพศทางไวยากรณ์ที่ไม่ถูกต้อง เช่น การเรียกผู้หญิงด้วยเพศทางไวยากรณ์ของผู้ชาย อาจส่งผลเสียต่อประสิทธิภาพและทัศนคติของผู้ใช้ ในทางตรงกันข้าม UI ที่มีภาษาที่แสดงเพศตามไวยากรณ์ของผู้ใช้อย่างถูกต้องจะช่วยเพิ่มการมีส่วนร่วมของผู้ใช้ และมอบประสบการณ์การใช้งานที่ปรับให้เหมาะกับผู้ใช้แต่ละคนและฟังดูเป็นธรรมชาติมากขึ้น
为帮助您针对区分性别的语言构建以用户为中心的界面,Android 14 引入了 Grammatical Inflection API,让您无需重构应用便能添加对语法性别的支持。
ค่ากำหนดตามพื้นที่
Regional preferences enable users to personalize temperature units, the first day of the week, and numbering systems. A European living in the United States might prefer temperature units to be in Celsius rather than Fahrenheit and for apps to treat Monday as the beginning of the week instead of the US default of Sunday.
New Android Settings menus for these preferences provide users with a
discoverable and centralized location to change app preferences. These
preferences also persist through backup and restore. Several APIs and
intents—such as
getTemperatureUnit
and
getFirstDayOfWeek—
grant your app read access to user preferences, so your app can adjust how it
displays information. You can also register a
BroadcastReceiver on
ACTION_LOCALE_CHANGED
to handle locale configuration changes when regional preferences change.
To find these settings, open the Settings app and navigate to System > Languages & input > Regional preferences.
การช่วยเหลือพิเศษ
การปรับขนาดแบบอักษรที่ไม่ใช่แบบเชิงเส้นเป็น 200%
ตั้งแต่ Android 14 เป็นต้นไป ระบบจะรองรับการปรับขนาดแบบอักษรได้สูงสุด 200% เพื่อให้ผู้ใช้มีตัวเลือกการช่วยเหลือพิเศษเพิ่มเติม
ระบบจะใช้เส้นโค้งการปรับขนาดแบบไม่เชิงเส้นเพื่อป้องกันไม่ให้องค์ประกอบข้อความขนาดใหญ่บนหน้าจอมีขนาดใหญ่เกินไป กลยุทธ์การปรับขนาดนี้หมายความว่าข้อความขนาดใหญ่ จะไม่ปรับขนาดในอัตราเดียวกับข้อความขนาดเล็ก การปรับขนาดแบบอักษรที่ไม่ใช่แบบเชิงเส้นช่วย รักษาลำดับชั้นตามสัดส่วนระหว่างองค์ประกอบที่มีขนาดต่างกัน ขณะเดียวกันก็ ลดปัญหาเกี่ยวกับการปรับขนาดข้อความเชิงเส้นในระดับสูง (เช่น ข้อความถูก ตัดออกหรือข้อความที่อ่านยากขึ้นเนื่องจากขนาดจอแสดงผลที่ใหญ่มาก)
ทดสอบแอปด้วยการปรับขนาดแบบอักษรที่ไม่ใช่แบบเชิงเส้น
หากคุณใช้หน่วยพิกเซลที่รองรับการปรับขนาด (sp) เพื่อกำหนดขนาดข้อความอยู่แล้ว ระบบจะใช้ตัวเลือกเพิ่มเติมและการปรับปรุงการปรับขนาดเหล่านี้กับข้อความในแอปโดยอัตโนมัติ อย่างไรก็ตาม คุณยังคงควรทำการทดสอบ UI โดยเปิดใช้ขนาดแบบอักษรสูงสุด (200%) เพื่อให้แน่ใจว่าแอปใช้ขนาดแบบอักษรอย่างถูกต้องและรองรับขนาดแบบอักษรที่ใหญ่ขึ้นได้โดยไม่ส่งผลต่อความสามารถในการใช้งาน
หากต้องการเปิดใช้ขนาดแบบอักษร 200% ให้ทำตามขั้นตอนต่อไปนี้
- เปิดแอปการตั้งค่า แล้วไปที่การช่วยเหลือพิเศษ > ขนาดการแสดงผลและข้อความ
- สำหรับตัวเลือกขนาดแบบอักษร ให้แตะไอคอนบวก (+) จนกว่าจะเปิดใช้การตั้งค่าขนาดแบบอักษรสูงสุด ดังที่แสดงในรูปภาพที่มาพร้อมกับส่วนนี้
ใช้หน่วยพิกเซลที่ปรับขนาดแล้ว (sp) สำหรับขนาดข้อความ
โปรดอย่าลืมระบุขนาดข้อความในหน่วย sp เสมอ เมื่อ แอปใช้หน่วย sp ระบบ Android จะใช้ขนาดข้อความที่ผู้ใช้ต้องการและ ปรับขนาดอย่างเหมาะสมได้
อย่าใช้หน่วย sp สำหรับระยะห่างจากขอบหรือกำหนดความสูงของมุมมองโดยสมมติว่ามีระยะห่างจากขอบโดยนัย เมื่อใช้การปรับขนาดแบบไม่เชิงเส้นแบบอักษร ขนาด sp อาจไม่เป็นสัดส่วน ดังนั้น 4sp + 20sp อาจไม่เท่ากับ 24sp
แปลงหน่วยพิกเซลที่ปรับขนาด (sp)
ใช้ TypedValue.applyDimension() เพื่อแปลงจากหน่วย sp เป็นพิกเซล และใช้ TypedValue.deriveDimension() เพื่อแปลงพิกเซลเป็น sp วิธีการเหล่านี้จะใช้เส้นโค้งการปรับขนาดแบบไม่เชิงเส้นที่เหมาะสมโดยอัตโนมัติ
หลีกเลี่ยงการฮาร์ดโค้ดสมการโดยใช้
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) 显示这些图片。
当您的应用选择为其 activity 窗口使用 HDR 界面(通过清单条目或通过在运行时调用 Window.setColorMode())时,框架会自动在界面中以 HDR 格式渲染这些图片。您还可以在受支持的设备上拍摄压缩的 Ultra HDR 静态图片。从传感器中恢复的颜色越多,后期编辑的灵活性就越高。与 Ultra HDR 图片关联的 Gainmap 可用于使用 OpenGL 或 Vulkan 渲染这些图片。
ซูม โฟกัส ดูตัวอย่างหลังถ่าย และอื่นๆ ในส่วนขยายกล้อง
Android 14 อัปเกรดและปรับปรุงส่วนขยายกล้อง ซึ่งช่วยให้แอปประมวลผลได้นานขึ้น จึงให้รูปภาพที่ดีขึ้นโดยใช้อัลกอริทึมที่ต้องใช้การประมวลผลอย่างหนัก เช่น การถ่ายภาพในที่แสงน้อยในอุปกรณ์ที่รองรับ ฟีเจอร์เหล่านี้ช่วยให้ผู้ใช้ได้รับประสบการณ์การใช้งานที่มีประสิทธิภาพยิ่งขึ้นเมื่อใช้ความสามารถของส่วนขยายกล้อง ตัวอย่างการปรับปรุงเหล่านี้ ได้แก่
- การประมาณเวลาในการตอบสนองของการประมวลผลภาพนิ่งแบบไดนามิกจะให้ค่าประมาณเวลาในการตอบสนองของภาพนิ่งที่แม่นยำกว่ามากโดยอิงตามฉากปัจจุบันและสภาพสภาพแวดล้อม โทรไปที่
CameraExtensionSession.getRealtimeStillCaptureLatency()เพื่อรับออบเจ็กต์StillCaptureLatencyที่มีวิธีการประมาณเวลาในการตอบสนอง 2 วิธี เมธอดgetCaptureLatency()จะแสดงผลเวลาในการตอบสนองโดยประมาณระหว่างonCaptureStartedกับonCaptureProcessStarted()และเมธอดgetProcessingLatency()จะแสดงผลเวลาในการตอบสนองโดยประมาณระหว่างonCaptureProcessStarted()กับเวลาที่เฟรมที่ประมวลผลแล้วเฟรมสุดท้ายพร้อมใช้งาน - รองรับการเรียกกลับความคืบหน้าในการจับภาพเพื่อให้แอปแสดงความคืบหน้าปัจจุบันของการดำเนินการประมวลผลภาพนิ่งที่ทำงานต่อเนื่องเป็นเวลานาน คุณสามารถตรวจสอบว่าฟีเจอร์นี้พร้อมใช้งานใน
CameraExtensionCharacteristics.isCaptureProcessProgressAvailableหรือไม่ หากพร้อมใช้งาน คุณก็สามารถใช้การเรียกกลับonCaptureProcessProgressed()ซึ่งจะส่งความคืบหน้า (จาก 0 ถึง 100) เป็นพารามิเตอร์ ข้อมูลเมตาเฉพาะของชิ้นงาน เช่น
CaptureRequest.EXTENSION_STRENGTHสำหรับปรับระดับเอฟเฟกต์ของชิ้นงาน เช่น ระดับการเบลอพื้นหลังEXTENSION_BOKEHฟีเจอร์ดูภาพหลังถ่ายสําหรับการจับภาพนิ่งในส่วนขยายกล้อง ซึ่งจะแสดงภาพที่ประมวลผลน้อยลงได้เร็วกว่าภาพสุดท้าย หากชิ้นงานมีความล่าช้าในการประมวลผลเพิ่มขึ้น คุณอาจระบุรูปภาพหลังดูเป็นตัวยึดตําแหน่งเพื่อปรับปรุง UX และเปลี่ยนเป็นรูปภาพสุดท้ายในภายหลัง คุณสามารถตรวจสอบว่าฟีเจอร์นี้พร้อมใช้งานใน
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 คลาสนี้แสดงรูปแบบ เช่น มาสก์ช่อง อัตราตัวอย่าง และลักษณะการทำงานของมิกเซอร์เสียง คลาสนี้ช่วยให้ส่งเสียงได้โดยตรงโดยไม่ต้องผสม ปรับระดับเสียง หรือประมวลผลเอฟเฟกต์
ประสิทธิภาพการทำงานและเครื่องมือสำหรับนักพัฒนาซอฟต์แวร์
Credential Manager
Android 14 เพิ่ม Credential Manager เป็น API ของแพลตฟอร์ม โดยรองรับอุปกรณ์ Android 4.4 (API ระดับ 19) เพิ่มเติมผ่านคลัง Jetpack โดยใช้บริการ Google Play Credential Manager มีเป้าหมายเพื่อช่วยให้ผู้ใช้ลงชื่อเข้าใช้ได้ง่ายขึ้นด้วย API ที่ดึงข้อมูลและจัดเก็บข้อมูลเข้าสู่ระบบด้วยผู้ให้บริการข้อมูลเข้าสู่ระบบที่ผู้ใช้กําหนดค่าไว้ Credential Manager รองรับวิธีการลงชื่อเข้าใช้หลายวิธี รวมถึงชื่อผู้ใช้และรหัสผ่าน พาสคีย์ และโซลูชันการลงชื่อเข้าใช้แบบรวมศูนย์ (เช่น ฟีเจอร์ลงชื่อเข้าใช้ด้วย Google) ใน API เดียว
พาสคีย์มีข้อดีหลายประการ เช่น พาสคีย์สร้างขึ้นตามมาตรฐานอุตสาหกรรม ทำงานได้กับระบบปฏิบัติการและระบบนิเวศของเบราว์เซอร์ต่างๆ รวมถึงใช้ได้กับทั้งเว็บไซต์และแอป
ดูข้อมูลเพิ่มเติมได้ที่เอกสารประกอบเกี่ยวกับเครื่องมือจัดการข้อมูลเข้าสู่ระบบและพาสคีย์และบล็อกโพสต์เกี่ยวกับเครื่องมือจัดการข้อมูลเข้าสู่ระบบและพาสคีย์
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 สําหรับนักพัฒนาแอปและแพลตฟอร์ม
ฟีเจอร์และการปรับปรุงต่อไปนี้จะรวมอยู่ด้วย
- อัปเดตคลาส
java.baseประมาณ 300 คลาสให้รองรับ Java 17 - บล็อกข้อความ ซึ่งจะนําสตริงตัวอักษรหลายบรรทัดมาสู่ภาษาโปรแกรม Java
- การจับคู่รูปแบบสำหรับ instanceof ซึ่งช่วยให้ระบบถือว่าออบเจ็กต์มีประเภทที่เฉพาะเจาะจงใน
instanceofโดยไม่ต้องมีตัวแปรเพิ่มเติม - คลาสที่ปิด ซึ่งช่วยให้คุณจำกัดคลาสและอินเทอร์เฟซที่ขยายหรือนำไปใช้ได้
การอัปเดตระบบ Google Play (Project Mainline) ช่วยให้อุปกรณ์กว่า 600 ล้านเครื่องสามารถรับการอัปเดต Android Runtime (ART) ล่าสุดที่มีการเปลี่ยนแปลงเหล่านี้ ซึ่งเป็นส่วนหนึ่งของความมุ่งมั่นของเราที่จะมอบสภาพแวดล้อมที่ปลอดภัยและสอดคล้องกันมากขึ้นให้แก่แอปในอุปกรณ์ต่างๆ รวมถึงมอบฟีเจอร์และความสามารถใหม่ๆ ให้แก่ผู้ใช้โดยไม่ขึ้นอยู่กับรุ่นของแพลตฟอร์ม
Java และ OpenJDK เป็นเครื่องหมายการค้าหรือเครื่องหมายการค้าจดทะเบียนของ Oracle และ/หรือบริษัทในเครือ
การปรับปรุงสำหรับ App Store
Android 14 引入了多个 PackageInstaller API,可帮助应用商店改善其用户体验。
下载之前请求批准安装
安装或更新应用可能需要用户批准。例如,当使用 REQUEST_INSTALL_PACKAGES 权限的安装程序尝试安装新应用时。在之前的 Android 版本中,只有在将 APK 写入安装会话并且提交会话后,应用商店才能请求用户批准。
从 Android 14 开始,requestUserPreapproval() 方法可让安装程序在提交安装会话之前请求用户批准。此项改进可让应用商店将任何 APK 的下载操作推迟到用户批准安装之后。此外,用户批准安装后,应用商店可以在后台下载并安装应用,而不会干扰用户。
承担未来更新的责任
借助 setRequestUpdateOwnership() 方法,安装程序可以向系统表明它打算负责将被安装的应用未来的更新。此 capability 可实现更新所有权强制执行,即仅允许更新所有者为应用安装自动更新。更新所有权强制执行有助于确保用户仅收到来自预期应用商店的更新。
任何其他安装程序(包括使用 INSTALL_PACKAGES 权限的安装程序)都必须获得用户的明确批准,才能安装更新。如果用户决定继续从其他来源安装更新,则会失去更新所有权。
在干扰较少的时段更新应用
应用商店通常希望避免更新正在使用的应用,因为这会导致应用正在运行的进程被终止,而这可能会中断用户正在执行的操作。
从 Android 14 开始,InstallConstraints API 让安装程序可以确保其应用更新在适当的时机进行。例如,应用商店可以调用 commitSessionAfterInstallConstraintsAreMet() 方法来确保仅在用户不再与相应应用互动时才进行更新。
无缝安装可选拆分
借助拆分 APK,应用的功能可以通过单独的 APK 文件提供,而不是以单体式 APK 的形式提供。借助拆分 APK,应用商店可以优化不同应用组件的提供。例如,应用商店可能会根据目标设备的属性进行优化。自在 API 级别 22 中引入以来,PackageInstaller API 一直支持拆分。
在 Android 14 中,setDontKillApp() 方法可让安装程序指明在安装新的拆分项时应用的运行进程不应终止。应用商店可以使用此功能,在用户使用应用时无缝安装应用的新功能。
App Bundle ข้อมูลเมตา
ตั้งแต่ Android 14 เป็นต้นไป เครื่องมือติดตั้งแพ็กเกจ Android จะช่วยให้คุณระบุข้อมูลเมตาของแอป เช่น แนวทางปฏิบัติด้านความปลอดภัยของข้อมูล เพื่อรวมไว้ในหน้าร้านค้าแอป เช่น Google Play
ตรวจหาเวลาที่ผู้ใช้ถ่ายภาพหน้าจอของอุปกรณ์
为了打造更加标准化的屏幕截图检测体验,Android 14 引入了可保护隐私的屏幕截图检测 API。借助此 API,应用可以按 activity 注册回调。如果用户在该 activity 可见时截取屏幕截图,系统会调用这些回调并通知用户。
ประสบการณ์ของผู้ใช้
การทำงานที่กำหนดเองของชีตการแชร์และการจัดอันดับที่ดียิ่งขึ้น
Android 14 更新了系统 Sharesheet,以便为用户提供自定义应用操作和信息更丰富的预览结果。
添加自定义操作
对于 Android 14,您的应用可以向其调用的系统 Sharesheet 添加自定义操作。
提高直接共享目标的排名
Android 14 根据来自应用的更多信号来确定直接共享目标的排名,以便为用户提供更实用的结果。为了提供最实用的排名信号,请遵循提高直接共享目标排名的准则。通讯应用还可以报告出站和入站消息的快捷方式使用情况。
รองรับภาพเคลื่อนไหวในตัวและภาพเคลื่อนไหวที่กำหนดเองสำหรับท่าทางสัมผัสย้อนกลับแบบคาดเดา
Android 13 在开发者选项背后引入了预测性“返回主屏幕”动画。在已启用开发者选项的受支持应用中使用时,滑回手势会显示动画,表明返回手势会使应用退回到主屏幕。
Android 14 包含针对“预测性返回”的多项改进和新指南:
- 您可设置
android:enableOnBackInvokedCallback=true,以便为每个 activity 选择启用预测性返回系统动画,而不是为整个应用选择启用。 - 我们添加了新的系统动画,以配合 Android 13 中的“返回主屏幕”动画。新的系统动画是跨 activity 和跨任务的,您可在迁移到预测性返回后自动获得该动画。
- 我们为底部动作条、侧边动作条和搜索添加了新的 Material 组件动画。
- 我们制作了有关如何创建自定义应用内动画和转换的设计指南。
- 我们添加了许多新 API 来支持自定义的应用内转换动画:
在此 Android 14 预览版中,所有预测性返回功能都是位于开发者选项背后。请参阅与将您的应用迁移到预测性返回有关的开发者指南,以及与创建自定义应用内转换有关的开发者指南。
การลบล้างต่อแอปของผู้ผลิตอุปกรณ์ที่มีหน้าจอขนาดใหญ่
การลบล้างค่าแอปต่อแอปช่วยให้ผู้ผลิตอุปกรณ์เปลี่ยนลักษณะการทำงานของแอปในอุปกรณ์ที่มีหน้าจอขนาดใหญ่ได้ ตัวอย่างเช่น การลบล้าง FORCE_RESIZE_APP จะสั่งให้ระบบปรับขนาดแอปให้พอดีกับขนาดการแสดงผล (หลีกเลี่ยงโหมดความเข้ากันได้ของขนาด) แม้ว่าจะมีการตั้งค่า resizeableActivity="false" ในไฟล์ Manifest ของแอปก็ตาม
การลบล้างมีวัตถุประสงค์เพื่อปรับปรุงประสบการณ์ของผู้ใช้บนหน้าจอขนาดใหญ่
พร็อพเพอร์ตี้ไฟล์ Manifest ใหม่ช่วยให้คุณปิดใช้การลบล้างผู้ผลิตอุปกรณ์บางรายสำหรับแอปของคุณได้
การลบล้างต่อแอปสำหรับผู้ใช้หน้าจอขนาดใหญ่
การลบล้างในแต่ละแอปจะเปลี่ยนลักษณะการทำงานของแอปในอุปกรณ์หน้าจอขนาดใหญ่ ตัวอย่างเช่น ผู้ผลิตอุปกรณ์ OVERRIDE_MIN_ASPECT_RATIO_LARGE ลบล้างการตั้งค่าสัดส่วนภาพของแอปเป็น 16:9 โดยไม่คำนึงถึงการกำหนดค่าของแอป
Android 14 QPR1 ช่วยให้ผู้ใช้ใช้การลบล้างระดับแอปได้ผ่านเมนูการตั้งค่าใหม่ในอุปกรณ์หน้าจอขนาดใหญ่
การแชร์หน้าจอแอป
การแชร์หน้าจอแอปช่วยให้ผู้ใช้แชร์หน้าต่างแอปแทนหน้าจออุปกรณ์ทั้งหน้าจอได้ในระหว่างการบันทึกเนื้อหาหน้าจอ
เมื่อแชร์หน้าจอแอป ระบบจะไม่รวมแถบสถานะ แถบนําทาง การแจ้งเตือน และองค์ประกอบ UI อื่นๆ ของระบบไว้ในหน้าจอที่แชร์ ระบบจะแชร์เฉพาะเนื้อหาของแอปที่เลือกเท่านั้น
การแชร์หน้าจอแอปช่วยเพิ่มประสิทธิภาพการทำงานและความเป็นส่วนตัวโดยอนุญาตให้ผู้ใช้เรียกใช้แอปหลายแอป แต่จำกัดการแชร์เนื้อหาไว้เพียงแอปเดียว
ฟีเจอร์ช่วยตอบที่ทำงานด้วย LLM ใน Gboard บน Pixel 8 Pro
ในอุปกรณ์ Pixel 8 Pro ที่มีฟีเจอร์ใหม่ประจำเดือนธันวาคม นักพัฒนาแอปสามารถลองใช้ฟีเจอร์ช่วยตอบที่มีคุณภาพสูงขึ้นใน 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 对象:
Kotlin
val path = Path().apply { moveTo(1.0f, 1.0f) lineTo(2.0f, 2.0f) close() } val pathIterator = path.pathIterator
Java
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 对象,它会为您打包数据:
Kotlin
for (segment in pathIterator) { println("segment: ${segment.verb}, ${segment.points}") }
Java
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)的路径:
Kotlin
val interpolatedResult = Path() if (path.isInterpolatable(otherPath)) { path.interpolate(otherPath, .5f, interpolatedResult) }
Java
Path interpolatedResult = new Path(); if (path.isInterpolatable(otherPath)) { path.interpolate(otherPath, 0.5F, interpolatedResult); }
Jetpack graphics-path 库也为早期版本的 Android 启用了类似的 API。
Custom meshes with vertex and fragment shaders
Android 长期以来一直支持使用自定义着色绘制三角网格,但输入网格格式仅限于一些预定义的属性组合。Android 14 增加了对自定义网格的支持,可将其定义为三角形或三角形条,并且可以选择是否编入索引。这些网格是使用自定义属性、顶点步长、可变以及使用 AGSL 编写的顶点着色器和片段着色器指定的。
顶点着色器定义了位置和颜色等变量,而片段着色器可以选择为像素定义颜色,通常是使用顶点着色器创建的变量。如果片段着色器提供颜色,则系统会使用绘制网格时选择的混合模式将其与当前 Paint 颜色混合。Uniform 可以传递到片段着色器和顶点着色器,以提高灵活性。
เครื่องมือแสดงผลบัฟเฟอร์ฮาร์ดแวร์สำหรับ Canvas
协助使用 Android 的 Canvas API 通过
硬件加速至 HardwareBuffer、Android 14
引入了 HardwareBufferRenderer。如果您的用例涉及通过 SurfaceControl 与系统合成器通信以实现低延迟绘制,此 API 特别有用。