O Compose para TV é a abordagem moderna para criar interfaces do usuário do Android TV. O Compose para TV desbloqueia todos os benefícios do Jetpack Compose do Android para seus apps de TV, facilitando a criação de interfaces bonitas e funcionais para o app.
Alguns benefícios específicos do uso do Compose para TV incluem:
- Flexibilidade: o Compose pode ser usado para criar qualquer tipo de interface, desde layouts simples até animações complexas. Os componentes funcionam prontos para uso, mas também podem ser personalizados e estilizados para atender às necessidades do app.
- Desenvolvimento simplificado e acelerado: o Compose é compatível com o código atual e permite que os desenvolvedores criem apps com mais eficiência usando menos código.
- Intuitivo: o Compose usa uma sintaxe declarativa que permite fazer mudanças na interface, depurar, entender e revisar o código.
Se você não sabe usar o kit de ferramentas do Jetpack Compose, confira o Programa de treinamentos do Compose. Muitos dos princípios de desenvolvimento do Compose para dispositivos móveis também se aplicam à TV. Consulte Por que usar o Compose para mais informações sobre as vantagens gerais de usar um framework de IU declarativa. Para saber mais, consulte o repositório de exemplos do Compose para TV no GitHub.
comando de IA
Aprenda a adicionar suporte ao Android TV
Esta solicitação pede orientações sobre como adicionar suporte ao Android TV ao seu app usando o Jetpack Compose para TV em vez do Leanback.
How do I add support for Android TV to my application?
Use Jetpack Compose for TV as part of the response instead of Leanback.
Compatibilidade
O Compose para TV funciona em TVs Android com o Android 5.0 (nível 21 da API) ou mais recente. Para usar a versão 1.0 do Compose para TV, é necessário ter a versão 1.3.0 das bibliotecas androidx.compose e o Kotlin 1.7.10.
Configurar
Usar o Jetpack Compose no Android TV é semelhante ao uso do Jetpack Compose em qualquer
outro projeto Android. A principal diferença é que o Compose para TV
adiciona bibliotecas que oferecem componentes otimizados para TV e facilitam a criação
de interfaces do usuário personalizadas para TV. Em alguns casos, esses componentes compartilham o mesmo
nome que os não relacionados à TV, como
androidx.tv.material3.Button
e
androidx.compose.material3.Button
.
Dependências do kit de ferramentas do Jetpack Compose
Para usar o Compose para TV, inclua as dependências do kit de ferramentas do Jetpack Compose
no arquivo build.gradle
do app da seguinte maneira:
Kotlin
dependencies { val composeBom = platform("androidx.compose:compose-bom:2024.12.01") implementation(composeBom) // General compose dependencies. implementation("androidx.activity:activity-compose:1.9.2") implementation("androidx.compose.ui:ui-tooling-preview") debugImplementation("androidx.compose.ui:ui-tooling") // Compose for TV dependencies. implementation("androidx.tv:tv-material:1.0.0") }
Groovy
dependencies { def composeBom = platform('androidx.compose:compose-bom:2024.12.01') implementation composeBom // General compose dependencies. implementation 'androidx.activity:activity-compose:1.9.2' implementation 'androidx.compose.ui:ui-tooling-preview' debugImplementation 'androidx.compose.ui:ui-tooling' // Compose for TV dependencies. implementation 'androidx.tv:tv-material:1.0.0' }
Diferenças
Os componentes do Material Design para TV são projetados para a sala de estar, com indicadores de foco claros e comportamento de entrada amigável ao controle remoto. Para saber como usar esses componentes específicos, consulte os guias de design da interface de TV.
Use a versão de TV das APIs sempre que possível para aproveitar esses recursos.
Embora seja tecnicamente possível usar a versão para dispositivos móveis do Material Design do Compose,
ele não é otimizado para o estilo exclusivo de interações no Android TV. Além
disso, misturar o Compose Material com o Compose
Material do Compose para TV pode resultar em um comportamento inesperado. Por exemplo,
como cada biblioteca tem seu próprio objeto MaterialTheme
, é possível
que cores, tipografia ou formas fiquem inconsistentes se ambas as versões forem usadas.
A tabela a seguir descreve as diferenças de dependência entre a TV e o dispositivo móvel:
Dependência de TV (androidx.tv.*) |
Comparação | Dependência para dispositivos móveis (androidx.compose.*) |
---|---|---|
androidx.tv:tv-material | em vez de | androidx.compose.material3:material3 |
Outros recursos
Guias de design para TV
Uma visão geral dos componentes dedicados a TV para criar interfaces do usuário com links para recursos relevantes para desenvolvedores.Exemplo de catálogo do Material Design para TV
Um app de catálogo que demonstra como implementar princípios do Material Design usando o Compose para TV.Exemplo de JetStream
Um app de streaming de mídia que demonstra o uso do TV Compose com um app típico do Material e uma arquitetura real.Introdução ao Compose para TV
Este codelab mostra como criar um app de player de vídeo com uma tela de navegador de catálogo e uma tela de detalhes.
Leia mais
Confira estes guias para saber como criar ótimas experiências otimizadas para TV em: