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