แอปสื่อที่ทำงานบนทีวีต้องอนุญาตให้ผู้ใช้เรียกดูข้อเสนอเนื้อหา เลือกเนื้อหา และเริ่มเล่นเนื้อหาได้ ประสบการณ์การเรียกดูเนื้อหาของแอปประเภทนี้ควรเรียบง่าย ใช้งานง่าย สวยงาม และน่าสนใจ
เบราว์เซอร์แคตตาล็อกสื่อมักประกอบด้วยหลายส่วน และแต่ละส่วนจะมีรายการเนื้อหาสื่อ ตัวอย่างส่วนต่างๆ ในแคตตาล็อกสื่อ ได้แก่ เพลย์ลิสต์ เนื้อหาที่โดดเด่น หมวดหมู่ที่แนะนำ
ใช้ฟังก์ชันที่ Compose for TV มีให้เพื่อสร้างอินเทอร์เฟซผู้ใช้สำหรับการเรียกดูเพลงหรือวิดีโอจากแคตตาล็อกสื่อของแอป
สร้างฟังก์ชันที่ประกอบกันได้สำหรับแคตตาล็อก
ทุกอย่างที่ปรากฏบนจอแสดงผลจะได้รับการติดตั้งใช้งานเป็นฟังก์ชันที่ประกอบกันได้ใน Compose for TV เริ่มต้นด้วยการกำหนดฟังก์ชันที่ใช้ร่วมกันได้สำหรับเบราว์เซอร์แคตตาล็อกสื่อ ดังนี้
@Composable
fun CatalogBrowser(
featuredContentList: List<Movie>,
sectionList: List<Section>,
modifier: Modifier = Modifier,
onItemSelected: (Movie) -> Unit = {},
) {
// ToDo: add implementation
}
CatalogBrowser เป็นฟังก์ชันที่ประกอบกันได้ซึ่งติดตั้งใช้งานเบราว์เซอร์แคตตาล็อกสื่อ ฟังก์ชันนี้ใช้การโต้แย้งต่อไปนี้
- รายการเนื้อหาที่โดดเด่น
- รายการส่วน
- ออบเจ็กต์ตัวปรับเปลี่ยน
- ฟังก์ชัน Callback ซึ่งทริกเกอร์การเปลี่ยนหน้าจอ
ตั้งค่าองค์ประกอบ UI
Compose for TV มีรายการแบบ Lazy ซึ่งเป็นคอมโพเนนต์สำหรับแสดงรายการจำนวนมาก (หรือรายการที่มีความยาวไม่ทราบ) เรียก
LazyColumn
เพื่อวางส่วนต่างๆ ในแนวตั้ง LazyColumn มี
LazyListScope.() -> Unit
บล็อก ซึ่งมี DSL สำหรับกำหนดเนื้อหารายการ ในตัวอย่างต่อไปนี้ แต่ละส่วนจะอยู่ในรายการแนวตั้งโดยมีช่องว่าง 16 dp ระหว่างส่วนต่างๆ
@Composable
fun CatalogBrowser(
featuredContentList: List<Movie>,
sectionList: List<Section>,
modifier: Modifier = Modifier,
onItemSelected: (Movie) -> Unit = {},
) {
LazyColumn(
modifier = modifier.fillMaxSize(),
verticalArrangement = Arrangement.spacedBy(16.dp)
) {
items(sectionList) { section ->
Section(section, onItemSelected = onItemSelected)
}
}
}
ในตัวอย่าง ฟังก์ชันที่ประกอบกันได้ Section จะกำหนดวิธีแสดงส่วนต่างๆ
ในฟังก์ชันต่อไปนี้ LazyRow จะแสดงให้เห็นว่าเวอร์ชันแนวนอนของ LazyColumn นี้ใช้ในลักษณะเดียวกันเพื่อกำหนดรายการแนวนอนด้วยบล็อก LazyListScope.() -> Unit โดยการเรียก DSL ที่ให้ไว้
@Composable
fun Section(
section: Section,
modifier: Modifier = Modifier,
onItemSelected: (Movie) -> Unit = {},
) {
Text(
text = section.title,
style = MaterialTheme.typography.headlineSmall,
)
LazyRow(
modifier = modifier,
horizontalArrangement = Arrangement.spacedBy(8.dp)
) {
items(section.movieList){ movie ->
MovieCard(
movie = movie,
onClick = { onItemSelected(movie) }
)
}
}
}
ในฟังก์ชันที่ใช้ร่วมกันได้ Section จะมีการใช้คอมโพเนนต์ Text
ข้อความและคอมโพเนนต์อื่นๆ ที่กำหนดไว้ใน Material Design มีให้ใช้งานในไลบรารี tv-material คุณสามารถ
เปลี่ยนสไตล์ของข้อความตามที่กำหนดไว้ใน Material Design ได้โดยอ้างอิงออบเจ็กต์
MaterialTheme
ไลบรารี tv-material ก็มีออบเจ็กต์นี้ให้ด้วย
Card เป็นส่วนหนึ่งของไลบรารี tv-material
MovieCard กำหนดวิธีแสดงข้อมูลภาพยนตร์แต่ละรายการในแคตตาล็อกที่กำหนดไว้เป็นข้อมูลโค้ดต่อไปนี้
@Composable
fun MovieCard(
movie: Movie,
modifier: Modifier = Modifier,
onClick: () -> Unit = {}
) {
Card(modifier = modifier, onClick = onClick){
AsyncImage(
model = movie.thumbnailUrl,
contentDescription = movie.title,
)
}
}
ไฮไลต์เนื้อหาที่โดดเด่น
ในตัวอย่างที่อธิบายไว้ก่อนหน้านี้ ภาพยนตร์ทั้งหมดจะแสดงเท่ากัน
โดยมีพื้นที่เท่ากันและไม่มีความแตกต่างด้านภาพ
คุณสามารถไฮไลต์ภาพยนตร์บางเรื่องด้วย Carousel.
Carousel จะแสดงข้อมูลในชุดรายการที่เลื่อน เฟด หรือเคลื่อนที่เข้าสู่มุมมองได้ คุณใช้คอมโพเนนต์นี้เพื่อไฮไลต์เนื้อหาที่โดดเด่น เช่น ภาพยนตร์ที่เพิ่งเปิดตัวหรือตอนใหม่ของรายการทีวี
Carousel
ต้องการให้คุณระบุจำนวนรายการที่ Carousel มีและวิธีวาดแต่ละรายการเป็นอย่างน้อย คุณระบุจำนวนรายการแรกได้ด้วย itemCount ส่วนรายการที่ 2 สามารถส่งผ่านเป็นแลมบ์ดาได้ ระบบจะส่งหมายเลขดัชนีของรายการที่แสดงไปยังแลมบ์ดา คุณสามารถกำหนดรายการที่แสดงด้วยค่าดัชนีที่กำหนดได้ดังนี้
@Composable
function FeaturedCarousel(
featuredContentList: List<Movie>,
modifier: Modifier = Modifier,
) {
Carousel(
itemCount = featuredContentList.size,
modifier = modifier,
) { index ->
val content = featuredContentList[index]
Box {
AsyncImage(
model = content.backgroundImageUrl,
contentDescription = content.description,
placeholder = painterResource(
id = R.drawable.placeholder
),
contentScale = ContentScale.Crop,
modifier = Modifier.fillMaxSize()
)
Text(text = content.title)
}
}
}
Carousel สามารถเป็นรายการของรายการแบบ Lazy เช่น TvLazyColumn
ข้อมูลโค้ดต่อไปนี้แสดงฟังก์ชันที่ใช้ร่วมกันได้ FeaturedCarousel ที่ด้านบนของฟังก์ชันที่ใช้ร่วมกันได้ Section ทั้งหมด
@Composable
fun CatalogBrowser(
featuredContentList: List<Movie>,
sectionList: List<Section>,
modifier: Modifier = Modifier,
onItemSelected: (Movie) -> Unit = {},
) {
TvLazyColumn(
modifier = modifier.fillMaxSize(),
verticalArrangement = Arrangement.spacedBy(16.dp)
) {
item {
FeaturedCarousel(featuredContentList)
}
items(sectionList) { section ->
Section(section, onItemSelected = onItemSelected)
}
}
}