ชิป

คอมโพเนนต์ Chip เป็นองค์ประกอบ UI แบบอินเทอร์แอกทีฟขนาดกะทัดรัด โดยแสดงถึงเอนทิตีที่ซับซ้อน เช่น รายชื่อติดต่อหรือแท็ก มักมีไอคอนและป้ายกำกับ โดยอาจเป็นแบบเลือกได้ ปิดได้ หรือคลิกได้

ชิปทั้ง 4 ประเภทและตำแหน่งที่คุณสามารถใช้ได้มีดังนี้

  • ช่วย: แนะนำผู้ใช้ในระหว่างทำงาน มักปรากฏเป็นองค์ประกอบ UI ชั่วคราวเพื่อตอบสนองต่อข้อมูลจากผู้ใช้
  • กรอง: อนุญาตให้ผู้ใช้ปรับแต่งเนื้อหาจากชุดตัวเลือก โดยสามารถเลือกหรือยกเลิกการเลือกได้ และอาจมีไอคอนเครื่องหมายถูกเมื่อเลือก
  • อินพุต: แสดงข้อมูลที่ได้จากผู้ใช้ เช่น รายการที่เลือกในเมนู โดยอาจมีไอคอนและข้อความ รวมถึงมี "X" สำหรับการนําออก
  • คำแนะนำ: ให้คำแนะนำแก่ผู้ใช้ตามกิจกรรมหรือข้อมูลที่เพิ่งป้อนล่าสุด โดยปกติแล้วจะปรากฏใต้ช่องป้อนข้อมูลเพื่อแจ้งให้ผู้ใช้ดำเนินการ
ตัวอย่างคอมโพเนนต์ชิปแต่ละรายการ 4 รายการ โดยไฮไลต์ลักษณะเฉพาะของแต่ละรายการ
รูปที่ 1 องค์ประกอบทั้ง 4 ชิป

แพลตฟอร์ม API

Composable มี 4 รายการที่สอดคล้องกับชิปทั้ง 4 ประเภท ส่วนต่อไปนี้จะอธิบายคอมโพสิเบิลเหล่านี้และความแตกต่างอย่างละเอียด แต่แชร์พารามิเตอร์ต่อไปนี้

  • label: สตริงที่ปรากฏบนชิป
  • icon: ไอคอนที่แสดงที่จุดเริ่มต้นของชิป Composable บางรายการมีพารามิเตอร์ leadingIcon และ trailingIcon แยกกัน
  • onClick: LAMBDA ที่ชิปเรียกใช้เมื่อผู้ใช้กด

ชิปความช่วยเหลือ

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

@Composable
fun AssistChipExample() {
    AssistChip(
        onClick = { Log.d("Assist chip", "hello world") },
        label = { Text("Assist chip") },
        leadingIcon = {
            Icon(
                Icons.Filled.Settings,
                contentDescription = "Localized description",
                Modifier.size(AssistChipDefaults.IconSize)
            )
        }
    )
}

การใช้งานนี้จะปรากฏดังนี้

ชิปความช่วยเหลือแบบง่าย
รูปที่ 2 ชิปความช่วยเหลือ

ชิปตัวกรอง

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

@Composable
fun FilterChipExample() {
    var selected by remember { mutableStateOf(false) }

    FilterChip(
        onClick = { selected = !selected },
        label = {
            Text("Filter chip")
        },
        selected = selected,
        leadingIcon = if (selected) {
            {
                Icon(
                    imageVector = Icons.Filled.Done,
                    contentDescription = "Done icon",
                    modifier = Modifier.size(FilterChipDefaults.IconSize)
                )
            }
        } else {
            null
        },
    )
}

การใช้งานนี้จะปรากฏดังนี้เมื่อไม่ได้เลือก

ชิปตัวกรองที่ไม่ได้เลือก ซึ่งไม่มีการเลือกและพื้นหลังแผน
รูปที่ 3 ชิปตัวกรองที่ไม่ได้เลือก

และปรากฏดังต่อไปนี้เมื่อเลือก

ชิปฟิลเตอร์ที่เลือกพร้อมเครื่องหมายถูกและพื้นหลังสี
ภาพที่ 4 ชิปฟิลเตอร์ที่เลือก

ชิปอินพุต

คุณใช้ InputChip Composable เพื่อสร้างชิปที่เป็นผลมาจากการโต้ตอบของผู้ใช้ได้ เช่น ในโปรแกรมรับส่งอีเมล เมื่อผู้ใช้กำลังเขียนอีเมล ชิปอินพุตอาจแสดงบุคคลซึ่งมีที่อยู่ที่ผู้ใช้ได้ป้อนลงในช่อง "to:"

การใช้งานต่อไปนี้จะสาธิตชิปอินพุตที่อยู่ในสถานะที่เลือกอยู่แล้ว ผู้ใช้ปิดชิปเมื่อกดชิป

@Composable
fun InputChipExample(
    text: String,
    onDismiss: () -> Unit,
) {
    var enabled by remember { mutableStateOf(true) }
    if (!enabled) return

    InputChip(
        onClick = {
            onDismiss()
            enabled = !enabled
        },
        label = { Text(text) },
        selected = enabled,
        avatar = {
            Icon(
                Icons.Filled.Person,
                contentDescription = "Localized description",
                Modifier.size(InputChipDefaults.AvatarSize)
            )
        },
        trailingIcon = {
            Icon(
                Icons.Default.Close,
                contentDescription = "Localized description",
                Modifier.size(InputChipDefaults.AvatarSize)
            )
        },
    )
}

การใช้งานนี้จะปรากฏดังนี้

ชิปอินพุตที่มีรูปโปรไฟล์และไอคอนต่อท้าย
รูปที่ 5 ชิปอินพุต

ชิปคำแนะนำ

Composable ของ SuggestionChip เป็นคอมโพเนนต์พื้นฐานที่สุดของ Composable ที่แสดงในหน้านี้ ทั้งในคำจำกัดความของ API และกรณีการใช้งานทั่วไป ชิปคำแนะนำจะแสดงคำแนะนำที่สร้างขึ้นแบบไดนามิก เช่น ในแอปแชท AI คุณอาจใช้ชิปคำแนะนำเพื่อแสดงคำตอบที่เป็นไปได้สำหรับข้อความล่าสุด

ลองดูการใช้งาน SuggestionChip นี้

@Composable
fun SuggestionChipExample() {
    SuggestionChip(
        onClick = { Log.d("Suggestion chip", "hello world") },
        label = { Text("Suggestion chip") }
    )
}

การติดตั้งใช้งานนี้จะปรากฏดังนี้

ชิปผู้ช่วยที่ใช้งานง่าย
รูปที่ 6 ชิปความช่วยเหลือ

ชิปแบบยกขึ้น

ตัวอย่างทั้งหมดในเอกสารนี้ใช้คอมโพสิเบิลพื้นฐานที่มีรูปลักษณ์แบบแบน หากต้องการชิปที่มีรูปลักษณ์โดดเด่น ให้ใช้คอมโพสิเบิลอย่างใดอย่างหนึ่งต่อไปนี้

แหล่งข้อมูลเพิ่มเติม