ปรับปรุงวิดเจ็ต

ลองใช้วิธีแบบ Compose
Jetpack Compose เป็นชุดเครื่องมือ UI ที่แนะนำสำหรับ Android ดูวิธีสร้างวิดเจ็ตโดยใช้ API สไตล์ Compose

หน้านี้มีรายละเอียดเกี่ยวกับการปรับปรุงวิดเจ็ตเพิ่มเติม ซึ่งพร้อมใช้งานตั้งแต่ Android 12 (ระดับ API 31) เป็นต้นไป ฟีเจอร์เหล่านี้เป็นฟีเจอร์เสริม แต่ใช้งานได้ง่ายและช่วยปรับปรุงประสบการณ์การใช้งานวิดเจ็ตของผู้ใช้

ดูวิธีอื่นๆ ในการปรับปรุงวิดเจ็ตได้ที่คู่มือ Compose เรื่อง ปรับปรุงวิดเจ็ต

ใช้สีแบบไดนามิก

ตั้งแต่ Android 12 เป็นต้นไป วิดเจ็ตสามารถใช้สีธีมของอุปกรณ์สำหรับปุ่ม พื้นหลัง และคอมโพเนนต์อื่นๆ ได้ ซึ่งจะช่วยให้การเปลี่ยนผ่านราบรื่นขึ้นและวิดเจ็ตต่างๆ มีความสอดคล้องกัน

คุณใช้สีแบบไดนามิกได้ 2 วิธีดังนี้

เมื่อตั้งค่าธีมในเลย์เอาต์รูทแล้ว คุณจะใช้แอตทริบิวต์สีทั่วไปในรูทหรือองค์ประกอบย่อยใดก็ได้เพื่อเลือกสีแบบไดนามิก

ตัวอย่างแอตทริบิวต์สีที่คุณใช้ได้มีดังนี้

  • ?attr/primary
  • ?attr/primaryContainer
  • ?attr/onPrimary
  • ?attr/onPrimaryContainer

ในตัวอย่างต่อไปนี้ที่ใช้ธีม Material 3 สีธีมของอุปกรณ์คือ "สีม่วง" สีเฉพาะจุดและพื้นหลังของวิดเจ็ตจะปรับตามโหมดสว่างและโหมดมืด ดังที่แสดงในรูปที่ 1 และ 2

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:background="?attr/colorPrimaryContainer"
  android:theme="@style/Theme.Material3.DynamicColors.DayNight">

  <ImageView
    ...
    app:tint="?attr/colorPrimaryContainer"
    android:src="@drawable/ic_partly_cloudy" />

    <!-- Other widget content. -->

</LinearLayout>
วิดเจ็ตในธีมโหมดสว่าง
รูปที่ 1 วิดเจ็ตในธีมสว่าง
วิดเจ็ตในธีมโหมดมืด
รูปที่ 2 วิดเจ็ตในธีมมืด

ความเข้ากันได้แบบย้อนหลังสำหรับสีแบบไดนามิก

สีแบบไดนามิกใช้ได้เฉพาะในอุปกรณ์ที่ใช้ Android 12 ขึ้นไป หากต้องการใช้ธีมที่กำหนดเองสำหรับเวอร์ชันที่ต่ำกว่า ให้สร้างธีมเริ่มต้นด้วยสีแบบกำหนดเองและตัวระบุใหม่ (values-v31) โดยใช้แอตทริบิวต์ธีมเริ่มต้น

ตัวอย่างการใช้ธีม Material 3 มีดังนี้

/values/styles.xml

<resources>
  <style name="MyWidgetTheme" parent="Theme.Material3.DynamicColors.DayNight">
    <!-- Override default colorBackground attribute with custom color. -->
    <item name="android:colorBackground">@color/my_background_color</item>

    <!-- Add other colors/attributes. -->

  </style>
</resources>

/values-v31/styles.xml

<resources>
  <!-- Do not override any color attribute. -->
  <style name="MyWidgetTheme" parent="Theme.Material3.DynamicColors.DayNight" />
</resources>

/layout/my_widget_layout.xml

<resources>
  <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    ...
    android:background="?android:attr/colorBackground"
    android:theme="@style/MyWidgetTheme" />
</resources>

เปิดใช้การรองรับเสียง

การดำเนินการของแอป ช่วยให้ Google Assistant แสดงวิดเจ็ตเพื่อตอบสนองต่อคำสั่งเสียงที่เกี่ยวข้องของผู้ใช้ การกำหนดค่าวิดเจ็ตให้ตอบสนองต่อ Intent ในตัว (BII) จะช่วยให้แอปแสดงวิดเจ็ตบนพื้นผิวของ Assistant เช่น Android และ Android Auto ได้อย่างรวดเร็ว ผู้ใช้มีตัวเลือกในการ ปักหมุดวิดเจ็ตที่ Assistant แสดงไว้ใน Launcher ซึ่งจะช่วยกระตุ้นให้เกิดการมีส่วนร่วมในอนาคต

ตัวอย่างเช่น คุณสามารถกำหนดค่าวิดเจ็ตสรุปการออกกำลังกายสำหรับแอปออกกำลังกายให้ตอบสนองต่อคำสั่งเสียงของผู้ใช้ที่ทริกเกอร์ GET_EXERCISE_OBSERVATION BII Assistant จะแสดงวิดเจ็ตของคุณอย่างรวดเร็วเมื่อผู้ใช้ทริกเกอร์ BII นี้ด้วยการ ส่งคำขอ เช่น "Ok Google ฉันวิ่งไปกี่ไมล์ในสัปดาห์นี้ใน ExampleApp?"

มี BII หลายสิบรายการที่ครอบคลุมการโต้ตอบของผู้ใช้หลายหมวดหมู่ ซึ่งช่วยให้แอป Android เกือบทุกแอปปรับปรุงวิดเจ็ตให้รองรับเสียงได้ หากต้องการเริ่มต้นใช้งาน โปรดดู ผสานรวมการดำเนินการของแอปกับวิดเจ็ต Android

เปิดใช้การเปลี่ยนผ่านที่ราบรื่นขึ้น

ตั้งแต่ Android 12 เป็นต้นไป Launcher จะมีการเปลี่ยนผ่านที่ราบรื่นขึ้นเมื่อผู้ใช้เปิดแอปจากวิดเจ็ต

หากต้องการเปิดใช้การเปลี่ยนผ่านที่ปรับปรุงแล้วนี้ ให้ใช้ @android:id/background หรือ android.R.id.background เพื่อระบุองค์ประกอบพื้นหลัง

// Top-level layout of the widget.
<LinearLayout
    android:id="@android:id/background">
</LinearLayout>

แอปสามารถใช้ @android:id/background ใน Android เวอร์ชันก่อนหน้าได้โดยไม่เกิดข้อผิดพลาด แต่ระบบจะละเว้น

ใช้การแก้ไข RemoteViews ในรันไทม์

ตั้งแต่ Android 12 เป็นต้นไป คุณสามารถใช้ประโยชน์จากเมธอด RemoteViews หลายรายการที่ช่วยให้แก้ไขแอตทริบิวต์ RemoteViews ในรันไทม์ได้ ดูรายการเมธอดที่เพิ่มทั้งหมดได้ที่ข้อมูลอ้างอิง API ของ RemoteViews

ตัวอย่างโค้ดต่อไปนี้แสดงวิธีใช้เมธอดบางรายการ

Kotlin

// Set the colors of a progress bar at runtime.
remoteView.setColorStateList(R.id.progress, "setProgressTintList", createProgressColorStateList())

// Specify exact sizes for margins.
remoteView.setViewLayoutMargin(R.id.text, RemoteViews.MARGIN_END, 8f, TypedValue.COMPLEX_UNIT_DP)

Java

// Set the colors of a progress bar at runtime.
remoteView.setColorStateList(R.id.progress, "setProgressTintList", createProgressColorStateList());

// Specify exact sizes for margins.
remoteView.setViewLayoutMargin(R.id.text, RemoteViews.MARGIN_END, 8f, TypedValue.COMPLEX_UNIT_DP);