詳細画面を作成する

多くの TV アプリには、特定のコンテンツ(特定の映画など)に関連するメタデータを含むコンテンツ詳細ページが含まれています。詳細ページはコンポーズ可能な関数として実装し、選択したコンテンツのメタデータを引数として受け取ります。

次のコードは、詳細画面の一般的な実装です。このメソッドは、タイトルと説明とともに指定された映画の画像を読み込みます。ユーザーは、プレーヤー画面に画面を遷移できます。これは、動画の再生を開始するボタンをクリックしてトリガーできます。このアクションを処理して画面を遷移するには、コールバック関数を設定します。

@Composable
fun DetailsScreen(
  movie: Movie,
  modifier: Modifier = Modifier,
  onStartPlayback: (Movie) -> Unit = {}
) {
  Box(modifier = modifier.fillMaxSize()){
     AsyncImage(
       modifier = Modifier.fillMaxSize()
       model = movie.image,
       contentDescription = null,
       contentScale = ContentScale.Crop,
     )
     Column(modifier = Modifier.padding(32.dp)){
       Text(
         text = movie.title,
         style = MaterialTheme.typeography.heading2
       )
       Text(text = movie.description)
       Button(onClick = { onStartPlayBack(movie) }){
         Text(text = R.string.startPlayback)
       }
     }
  }
}