Introdução à interface baseada no Compose

Adicionar a dependência

A biblioteca Media3 inclui dois módulos de interface baseados no Jetpack Compose. Não é necessário adicionar os dois, porque o Material3 depende do principal.

Kotlin

// Include only one of the following dependencies
implementation("androidx.media3:media3-ui-compose:1.10.0")
implementation("androidx.media3:media3-ui-compose-material3:1.10.0")

Groovy

// Include only one of the following dependencies
implementation "androidx.media3:media3-ui-compose:1.10.0"
implementation "androidx.media3:media3-ui-compose-material3:1.10.0"

Recomendamos que você desenvolva seu app com o Compose em primeiro lugar ou migre do uso de visualizações.

App de demonstração totalmente do Compose

Embora a biblioteca media3-ui-compose não inclua elementos combináveis prontos para uso (como botões, indicadores, imagens ou caixas de diálogo), você pode encontrar um app de demonstração escrito totalmente no Compose que evita soluções de interoperabilidade , como o encapsulamento de PlayerView em AndroidView. O app de demonstração usa as classes de detentores de estado da interface do módulo media3-ui-compose e a biblioteca do Compose Material3.

De qual biblioteca eu preciso?

Dependendo do nível de personalização necessário, você pode escolher entre duas bibliotecas do Media3 Compose. Para entender a diferença, pense em o pipeline de produção do estado da interface: Business logic → UI logic → UI.

Use media3-ui-compose para ter controle total sobre os componentes da interface.

Essa biblioteca fornece a conexão Business logic → UI logic. Ela contém componentes básicos, como PlayerSurface e ContentFrame, além de classes de detentores de estado (por exemplo, PlayPauseButtonState) que convertem o estado Player em estado da interface.

Essa biblioteca não fornece componentes do Material Design prontos para uso. Você é responsável por criar seus próprios componentes de interface e estilizar. Ela oferece controle máximo sobre a aparência, o que é ideal se você tiver um sistema de design altamente personalizado.

Use media3-ui-compose-material3 para uma integração mais rápida com o Material Design.

Essa biblioteca fornece a parte final UI do pipeline. Ela depende de media3-ui-compose e inclui funções combináveis pré-criadas com estilo de componentes do Material3, incluindo o elemento combinável Player, que oferece uma experiência abrangente de reprodução de mídia com vídeo, controles e barra de progresso. Ela elimina a necessidade de criar seus próprios botões e outros elementos da interface do zero. Ainda é possível personalizar o tema, as cores e os ícones desses componentes, mas a implementação principal é fornecida para você.

Resumo

Recurso media3-ui-compose media3-ui-compose-material3
Componentes da interface Elementos básicos, como PlayerSurface e ContentFrame, mas sem botões ou controles pré-estilizados. Fornece o Player elemento combinável e um conjunto completo de elementos combináveis pré-criados com estilo do Material3, como PlayPauseButton, SeekBackButton, PositionAndDurationText etc.
Gerenciamento de estado Fornece detentores remember...State para gerenciar a lógica. Gerencia o estado internamente, mas ainda é possível acessar os detentores de estado, se necessário.
Dependências androidx.compose.foundation media3-ui-compose, androidx.compose.material3, com.google.android.material
Caso de uso principal Criar uma interface de player com um sistema de design personalizado. Controle total sobre a aparência. Criar rapidamente uma interface de player que siga as diretrizes do Material Design 3.