ปุ่มการทำงานแบบลอย (FAB) คือปุ่มที่เน้นสูงซึ่งช่วยให้ผู้ใช้ดำเนินการหลักในแอปพลิเคชันได้ โดยโปรโมตการกระทำเดียวที่มุ่งเน้นการกระทำซึ่งเป็นเส้นทางที่พบบ่อยที่สุดที่ผู้ใช้อาจทำและมักตรึงอยู่ที่ด้านขวาล่างของหน้าจอ
พิจารณากรณีการใช้งาน 3 กรณีต่อไปนี้ที่คุณอาจใช้ FAB
- สร้างรายการใหม่: ในแอปจดบันทึก ระบบอาจใช้ FAB เพื่อสร้างโน้ตใหม่อย่างรวดเร็ว
- เพิ่มผู้ติดต่อใหม่: ในแอปแชท FAB สามารถเปิดอินเทอร์เฟซที่ให้ผู้ใช้เพิ่มคนในการสนทนาได้
- ตำแหน่งศูนย์กลาง: ในอินเทอร์เฟซแผนที่ FAB สามารถตั้งศูนย์กลางของแผนที่ที่ตำแหน่งปัจจุบันของผู้ใช้ได้
FAB ใน Material Design มี 4 ประเภท ได้แก่
- FAB: ปุ่มการทำงานแบบลอยขนาดปกติ
- FAB ขนาดเล็ก: ปุ่มการทำงานแบบลอยขนาดเล็ก
- FAB ขนาดใหญ่: ปุ่มการทำงานแบบลอยที่ใหญ่ขึ้น
- FAB แบบขยาย: ปุ่มการทำงานแบบลอยที่มีมากกว่าแค่ไอคอน
แพลตฟอร์ม API
แม้ว่าจะมีคอมโพสิเบิลหลายรายการที่คุณสามารถใช้เพื่อสร้างปุ่มการดำเนินการแบบลอยตัว (Floating Action Button) ที่สอดคล้องตาม Material Design แต่พารามิเตอร์ของคอมโพสิเบิลเหล่านี้ก็ไม่ได้แตกต่างกันมากนัก พารามิเตอร์หลักที่ควรคำนึงถึงมีดังนี้
onClick
: ฟังก์ชันที่เรียกใช้เมื่อผู้ใช้กดปุ่มcontainerColor
: สีของปุ่มcontentColor
: สีของไอคอน
ปุ่มการทำงานแบบลอย
หากต้องการสร้างปุ่มการทำงานแบบลอยทั่วไป ให้ใช้ Composable ของ FloatingActionButton
พื้นฐาน ตัวอย่างต่อไปนี้แสดงการใช้งาน FAB ขั้นพื้นฐาน
@Composable fun Example(onClick: () -> Unit) { FloatingActionButton( onClick = { onClick() }, ) { Icon(Icons.Filled.Add, "Floating action button.") } }
การติดตั้งใช้งานนี้จะปรากฏดังนี้
ปุ่มขนาดเล็ก
หากต้องการสร้างปุ่มการดำเนินการแบบลอยขนาดเล็ก ให้ใช้คอมโพสิเบิล SmallFloatingActionButton
ตัวอย่างต่อไปนี้แสดงวิธีการโดยเพิ่มสีที่กำหนดเอง
@Composable fun SmallExample(onClick: () -> Unit) { SmallFloatingActionButton( onClick = { onClick() }, containerColor = MaterialTheme.colorScheme.secondaryContainer, contentColor = MaterialTheme.colorScheme.secondary ) { Icon(Icons.Filled.Add, "Small floating action button.") } }
การติดตั้งใช้งานนี้จะปรากฏดังนี้
ปุ่มขนาดใหญ่
หากต้องการสร้างปุ่มการดำเนินการแบบลอยตัวขนาดใหญ่ ให้ใช้คอมโพสิเบิล LargeFloatingActionButton
คอมโพสิเบิลนี้ไม่ได้แตกต่างไปจากตัวอย่างอื่นๆ มากนัก ยกเว้นว่าปุ่มจะใหญ่ขึ้น
ต่อไปนี้เป็นการใช้งาน FAB ขนาดใหญ่ที่ตรงไปตรงมา
@Composable fun LargeExample(onClick: () -> Unit) { LargeFloatingActionButton( onClick = { onClick() }, shape = CircleShape, ) { Icon(Icons.Filled.Add, "Large floating action button") } }
การติดตั้งใช้งานนี้จะปรากฏดังนี้
ปุ่มแบบขยาย
คุณสร้างปุ่มการดำเนินการแบบลอยตัวที่ซับซ้อนมากขึ้นได้โดยใช้คอมโพสิเบิล ExtendedFloatingActionButton
ความแตกต่างสําคัญระหว่าง FloatingActionButton
กับ FloatingActionButton
คือ FloatingActionButton
มีพารามิเตอร์ icon
และ text
โดยเฉพาะ ซึ่งช่วยให้คุณสร้างปุ่มที่มีเนื้อหาที่ซับซ้อนมากขึ้นซึ่งปรับขนาดให้พอดีกับเนื้อหาอย่างเหมาะสม
ตัวอย่างข้อมูลต่อไปนี้แสดงวิธีใช้ ExtendedFloatingActionButton
พร้อมค่าตัวอย่างที่ส่งสำหรับ icon
และ text
@Composable fun ExtendedExample(onClick: () -> Unit) { ExtendedFloatingActionButton( onClick = { onClick() }, icon = { Icon(Icons.Filled.Edit, "Extended floating action button.") }, text = { Text(text = "Extended FAB") }, ) }
การติดตั้งใช้งานนี้จะปรากฏดังนี้