Wear Compose

  
Crie aplicativos do Jetpack Compose que funcionem com dispositivos, tamanhos, formas e gestos de navegação específicos para dispositivos wearable.
Atualização mais recente Versão estável Versão candidata a lançamento Versão Beta Versão Alfa
20 de março de 2024 1.3.0 - - 1.4.0-alpha05

Declarar dependências

Para adicionar uma dependência ao Wear, adicione o repositório Maven do Google ao seu projeto. Leia Repositório Maven do Google para ver mais informações.

Adicione as dependências dos artefatos necessários ao arquivo build.gradle do seu app ou módulo:

Groovy

dependencies {
    implementation "androidx.wear.compose:compose-foundation:1.3.0"

    // For Wear Material Design UX guidelines and specifications
    implementation "androidx.wear.compose:compose-material:1.3.0"

    // For integration between Wear Compose and Androidx Navigation libraries
    implementation "androidx.wear.compose:compose-navigation:1.3.0"

    // For Wear preview annotations
    implementation("androidx.wear.compose:compose-ui-tooling:1.3.0")
    
    // NOTE: DO NOT INCLUDE a dependency on androidx.compose.material:material.
    // androidx.wear.compose:compose-material is designed as a replacement
    // not an addition to androidx.compose.material:material.
    // If there are features from that you feel are missing from
    // androidx.wear.compose:compose-material please raise a bug to let us know.
}

Kotlin

dependencies {
    implementation("androidx.wear.compose:compose-foundation:1.3.0")

    // For Wear Material Design UX guidelines and specifications
    implementation("androidx.wear.compose:compose-material:1.3.0")

    // For integration between Wear Compose and Androidx Navigation libraries
    implementation("androidx.wear.compose:compose-navigation:1.3.0")
    
    // For Wear preview annotations
    implementation("androidx.wear.compose:compose-ui-tooling:1.3.0")

    // NOTE: DO NOT INCLUDE a dependency on androidx.compose.material:material.
    // androidx.wear.compose:compose-material is designed as a replacement
    // not an addition to androidx.compose.material:material.
    // If there are features from that you feel are missing from
    // androidx.wear.compose:compose-material please raise a bug to let us know.
}

Para mais informações sobre dependências, consulte Adicionar dependências de build.

Feedback

Seu feedback ajuda a melhorar o Jetpack. Avise se você descobrir novos problemas ou tiver ideias para melhorar esta biblioteca. Consulte os problemas conhecidos nesta biblioteca antes de criar um novo. Adicione seu voto a um problema clicando no botão de estrela.

Criar novo problema

Consulte a documentação do Issue Tracker para saber mais.

Wear Compose Material3: versão 1.0

Versão 1.0.0-alpha19

6 de março de 2024

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha19. A versão 1.0.0-alpha19 contém these confirmações.

Mudanças na API

  • Adicionamos TimeText à biblioteca Wear Compose Material3 Esse componente mostra o horário atual (e o status adicional) na parte superior da tela. A nova API Material3 é concisa e evita a duplicação entre conteúdos lineares e curvos. (I4d7c3).
  • Atualizamos os nomes dos parâmetros de onSelected para onSelect em RadioButton. (I1a971).
  • Tokenize RadioButton e SplitRadioButton e também refatore os métodos existentes para reduzir a quantidade de pesquisa de CompositionLocal, adicionando instâncias de cores em cache e criando métodos de RadioButtonColors e SplitRadioButtonColors internos. (I02b33).

Versão 1.0.0-alpha18

21 de fevereiro de 2024

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha18. A versão 1.0.0-alpha18 contém estas confirmações.

Mudanças na API

  • Refatoramos o padrão padrão para CardColors, ToggleButtonColors e SplitToggleButtonColors criando instâncias em cache internamente e reduzindo o uso de CompositionLocal (If3fec).

Versão 1.0.0-alpha17

7 de fevereiro de 2024

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha17. A versão 1.0.0-alpha17 contém estas confirmações.

Mudanças na API

  • Atualizamos a API Button para usar buttonColors por padrão e removemos o filledButtonColors duplicado (I4fe3b).
  • Refatoramos os padrões padrão para ButtonColors, IconButtonColors e TextButtonColors criando uma instância em cache internamente e reduzindo o uso de CompositionLocal (I5f51c).
  • Removemos a sobrecarga de rememberUpdatedState nas classes de cores específicas do componente e marcamos os métodos do acessador dentro das classes de cores como internos (If6571).

Correções de bugs

  • Atualizamos Modifier.minimumInteractiveComponentSize para usar Modifier.node (Iba6b7).

Versão 1.0.0-alpha16

24 de janeiro de 2024

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha16. A versão 1.0.0-alpha16 contém estas confirmações.

Novos recursos

  • Adicionamos CompactButton, que pode usar as mesmas cores preenchidas, tonais e destacadas que o Button (I05df0).

Mudanças na API

  • Adicionamos RadioButton/SplitRadioButton como contêineres para controles de seleção, como "Controle de rádio". Isso é diferente do ToggleButton já existente, em que RadioButton é selecionável (e opera dentro de um grupo de seleção), enquanto ToggleButton é alternável (e é independente). (I61275).
  • Vamos remover LocalContentAlpha da biblioteca Wear Compose Material3 para manter a consistência com a biblioteca Compose Material3 (I49a0a).
  • Os componentes do Material Design e do Wear Material3 que expõem uma MutableInteractionSource na API foram atualizados para expor um MutableInteractionSource anulável que tem como padrão nulo. Não há mudanças semânticas aqui: transmitir um valor nulo significa que você não quer elevar a MutableInteractionSource, que será criada dentro do componente, se necessário. Mudar para nulo permite que alguns componentes nunca aloquem uma MutableInteractionSource e que outros componentes só criem lentamente uma instância quando necessário, o que melhora o desempenho deles. Se você não estiver usando a MutableInteractionSource transmitida para esses componentes, é recomendável transmitir um valor nulo. Também é recomendável fazer alterações semelhantes nos seus próprios componentes. (Ib90fc, b/298048146).
  • Nova API de ondulação nas bibliotecas wear:compose-material e wear:compose-material3, que substitui a rememberRipple descontinuada Também foi adicionado um CompositionLocal temporário, LocalUseFallbackRippleImplementation, para reverter os componentes do Material Design para o uso das APIs rememberRipple/RippleTheme descontinuadas Ela vai ser removida na próxima versão estável e serve apenas como ajuda temporária na migração para casos em que você está fornecendo um RippleTheme personalizado. Acesse developer.android.com para conferir informações sobre a migração e mais informações contextuais por trás dessa mudança. (af92b21).
  • Fizemos pequenas melhorias na API HorizontalPageIndicator e na documentação dela. (I60efc).
  • Atualizamos ColorScheme para ser imutável, tornando as atualizações de cores individuais menos eficientes, mas tornando o uso mais comum de cores mais eficiente. O raciocínio por trás dessa mudança é que a maioria dos apps não teria que atualizar cores individuais como principal caso de uso. Isso ainda é possível, mas a recomposição vai ser maior do que antes. Por sua vez, vamos diminuir significativamente a quantidade de assinaturas de estado em todo o código do Material Design e afetar a inicialização e o custo de execução de mais casos de uso padrão. (Ibc2d6).
  • As APIs ToggleButton e SplitToggleButton foram atualizadas para permitir que cores desativadas sejam personalizadas Além disso, os tokens do Material Design agora são usados para valores de cor e tipografia. (If087c).
  • Atualização das cores do plano de fundo da imagem do botão para usar tokens do Material Design (Iba215).
  • Mudamos os componentes Checkbox, Switch e RadioButton para serem somente para exibição, removendo o processamento de cliques. O esperado é que esses componentes sejam usados no (Split)ToggleButton, que processa os cliques. Agora, os componentes estão mais claramente indicados como apenas para exibição e não se destinam ao uso independente no Wear. (I2322e).

Correções de bugs

  • Adicionamos tokens para valores de movimento de durações e easings no Wear Compose Material 3 (I437cd).
  • Corrigimos um bug em ToggleButton, SplitToggleButton, Checkbox, Switch e RadioButton para que os anúncios de acessibilidade não fossem repetidos (anteriormente, os papéis semânticos eram duplicados). (Ica281).
  • Removemos a camada MaterialCore de CompactButton para melhorar o desempenho (7902858).

Versão 1.0.0-alpha15

15 de novembro de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha15. A versão 1.0.0-alpha15 contém estas confirmações.

Mudanças na API

  • Renomeamos o nível básico SwipeToDismissBox para BasicSwipeToDismissBox. Isso deixa a distinção mais clara entre o componente do nível básico e o SwipeToDismissBox do nível do Material3. O último extrai cores da MaterialTheme para serem usadas em scripts e delega a implementação restante para o BasicSwipeToDismissBox. (Ibecfc).

Correções de bugs

  • Removemos a camada Material Core do botão do Material3 para melhorar o desempenho (I55555).

Versão 1.0.0-alpha14

18 de outubro de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha14. A versão 1.0.0-alpha14 contém estas confirmações.

Mudanças na API

  • Removemos o parâmetro indicatorStyle do HorizontalPageIndicator do Material3. Em vez disso, ele vai seguir o formato da tela do dispositivo (linear ou redondo). (I83728).
  • Separamos as cores de SplitToggleButton das cores ToggleButton ao adicionar uma nova classe SplitToggleButtonColors. (I78bee).

Versão 1.0.0-alpha13

4 de outubro de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha13. A versão 1.0.0-alpha13 contém estas confirmações.

Mudanças na API

  • Adicionamos um campo "Subtitle" opcional a TitleCard (Ifc45a).
  • Adicionamos tokens de cor do Material Design para TextButton (I769dc).

Versão 1.0.0-alpha12

20 de setembro de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha12. A versão 1.0.0-alpha12 contém estas confirmações.

Mudanças na API

  • Atualizamos IconButton para usar tokens do Material Design (I3f137).
  • Atualizamos IconToggleButton para usar tokens do Material Design (I7d263).
  • Tornamos públicos os construtores de CheckboxColors, RadioButtonColors e SwitchColors. (I82b73).

Versão 1.0.0-alpha11

6 de setembro de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha11. A versão 1.0.0-alpha11 contém estas confirmações.

Correções de bugs

  • Atualizamos a tipografia dos cards do Material3 para TitleMedium (I597bd).
  • Atualizamos a tipografia e o alinhamento do ListHeader e do ListSubheader do Material3 (Ib5ceb).

Versão 1.0.0-alpha10

23 de agosto de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha10. A versão 1.0.0-alpha10 contém estas confirmações.

Novos recursos

  • Adição de HorizontalPageIndicator à biblioteca Wear Material3 (Ifee99).

Mudanças na API

  • Atualização do código dos botões para usar tokens de design do Material3. (I92fe4).
  • Declarar as APIs Stepper e Slider do Wear Material 3 como experimentais, já que os detalhes da interface do usuário ainda estão sendo finalizados (I84d54).
  • Removemos os tamanhos ExtraSmall do TextButton e do TextToggleButton redondos, já que esse tamanho só se aplica ao IconButton (Ibc7d5).

Correções de bugs

  • Atualizamos a orientação sobre tipografia para TextToggleButton para usar LabelLarge em LargeButtonSize (Ib10fa).
  • Atualizamos a orientação sobre tipografia do TextButton para usar LabelLarge em LargeButtonSize (I8f3a7).
  • Definimos a área de toque mínima do cartão como 48 dp para acessibilidade. (Ieb9b1).
  • Adição de AppCard com demonstração de imagem, remoção de AppCard com demonstração em segundo plano (Id735f).
  • Correção de um bug nos botões redondos em que os modificadores não eram encadeados corretamente (I5e162).

Versão 1.0.0-alpha09

9 de agosto de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha09. A versão 1.0.0-alpha09 contém estas confirmações.

Novos recursos

  • Adicionamos ToggleButton para material3 (I6bed6).

Mudanças na API

  • Ativamos a anotação FloatRange como restrições de API , que foram mencionadas anteriormente nos comentários (Icb401).
  • Atualizamos a tipografia do Wear Material3 para seguir as diretrizes mais recentes do Material3. (I1bad6).

Correções de bugs

  • Atualizamos as cores de Button, IconButton e TextButton de acordo com o design do Material3 (Ib2495).
  • Corrigimos a visibilidade da marcação da caixa de seleção em estados desativados (Ib25bf).

Versão 1.0.0-alpha08

26 de julho de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha08. A versão 1.0.0-alpha08 contém estas confirmações.

Novos recursos

  • Adicionamos os seguintes controles de seleção para o Material3: Switch, Checkbox e RadioButton (Ib918c).
  • Adicionamos IconToggleButton e TextToggleButton ao Material3, um botão circular com um único slot para ícone e texto, respectivamente Para diferentes tamanhos de ToggleButton, recomendamos usar Modifier.touchTargetAwareSize com os tamanhos fornecidos nos respectivos botões de ativação. (I9f015).
  • Adicionamos ListHeader e ListSubheader aos componentes do Material3 (Ibaefe).
  • Adicionamos o SwipeToDismissBox do Material3, que chama o novo SwipeToDismissBox básico e fornece valores de cor padrão do tema (I275fb).
  • Adicionamos o InlineSlider do Material3 ao Wear Compose Ela permite que os usuários escolham um valor dentro de um intervalo. O intervalo é mostrado como uma barra entre os valores mínimo e máximo, em que os usuários podem selecionar um único valor InlineSlider é ideal para ajustar configurações como volume ou brilho. (I7085f).

Mudanças na API

  • Atualizamos o tema Shapes no Wear Material 3 para usar RoundedCornerShape em vez de Shape (Idb133).
  • Tornamos as constantes de altura para o botão público (Idbfde).
  • Atualização dos arquivos de API para anotar a supressão de compatibilidade (I8e87a, b/287516207).
  • Atualizamos o InlineSliderColors no Wear Compose Material 3 para ter construtor público e propriedades públicas (I6b632).
  • Atualizamos todas as classes de cores no Wear Compose Material 3 para ter construtores e propriedades públicas. (I17702).
  • As constantes de padding horizontal e vertical do botão foram publicadas (Ieeaf7).

Correções de bugs

  • Agora, o botão vai ajustar a altura para acomodar o conteúdo que cresceu devido a fontes grandes para acessibilidade, quando necessário (Iaf302).
  • Atualizamos várias demonstrações de botão para resolver problemas de acessibilidade. (I61ce9).
  • Stepper e InlineSlider agora são compatíveis com cliques repetidos ao tocar e manter pressionado para aumentar/diminuir rapidamente o valor de Stepper e InlineSlider segurando os botões + ou - (I27359).

Versão 1.0.0-alpha07

21 de junho de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha07. A versão 1.0.0-alpha07 contém estas confirmações.

Novos recursos

  • Adicionamos o componente Stepper à biblioteca Compose para Wear OS Material 3 Esse comportamento é semelhante à versão anterior do Material Design, mas omite a semântica de intervalo por padrão, seguindo o feedback dos desenvolvedores. Fornecemos a Modifier.rangeSemantics os casos em que a semântica de intervalo é obrigatória. (Ic39fd).
  • Adicionamos curvedText à biblioteca Compose para Wear OS Material 3 (Ia8ae3).

Correções de bugs

  • Atualizamos wear.compose.foundation para ser uma dependência de API de wear.compose.material3 (I72004, b/285404743).

Versão 1.0.0-alpha06

7 de junho de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha06. A versão 1.0.0-alpha06 contém estas confirmações.

Correções de bugs

  • Atualizamos o TextButton para usar a função de extensão toDisabledColor para valores Alfa desativados corretos. (I814c8).

Versão 1.0.0-alpha05

24 de maio de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha05. A versão 1.0.0-alpha05 contém estas confirmações.

Novos recursos

  • Adicionamos TextButton ao Material3, um botão circular com um único slot para texto Para diferentes tamanhos de TextButton, recomendamos usar Modifier.touchTargetAwareSize e ExtraSmallButtonSize, SmallButtonSize, DefaultButtonSize e LargeButtonSizeIcon fornecidos em TextButtonDefaults. A TextButton padrão não tem borda e tem um plano de fundo transparente para ações de baixa ênfase. Para ações que exigem alta ênfase, use filledTextButtonColors. Para uma ênfase média, delineado TextButton, defina a borda como ButtonDefaults.outlinedButtonBorder. Para um meio termo entre contorno e preenchido, use filledTonalTextButtonColors. (I667e4).
  • Adicionamos Card, OutlinedCard, AppCard e TitleCard à biblioteca do Wear Compose Material3 AppCard e TitleCard também podem receber a aparência delineada usando CardDefaults.outlinedCardColors e CardDefaults.outlinedCardBorder(I80e72).

Mudanças na API

  • Movemos o parâmetro de etiqueta do botão para o final para oferecer suporte à sintaxe de lambda final e removemos o parâmetro do papel, que pode ser substituído usando Modifier.semantics. Os construtores ButtonColors agora são públicos (Ie1b6d).

Versão 1.0.0-alpha04

10 de maio de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha04. A versão 1.0.0-alpha04 contém estas confirmações.

Novos recursos

  • Adicionamos IconButton ao Material3, um botão circular com um único slot para ícone/imagem Existem quatro variações: IconButton, FilledIconButton, FilledTonalIconButton e OutlinedIconButton. Para diferentes tamanhos de IconButton, recomendamos usar Modifier.touchTargetAwareSize e ExtraSmallButtonSize, SmallButtonSize, DefaultButtonSize e LargeButtonSizeIcon fornecidos em IconButtonDefaults. Também fornecemos IconButtonDefaults.iconSizeFor para determinar o tamanho recomendado do ícone para um determinado tamanho de botão. (I721d4).

Versão 1.0.0-alpha03

19 de abril de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha03. A versão 1.0.0-alpha03 contém estas confirmações.

Mudanças na API

  • Adicionamos o componente de botão do Material 3. Esse é o nosso botão em forma de estádio e era anteriormente chamado de Chip na biblioteca do Wear Compose Material. Ele foi renomeado como Botão para manter a consistência com a biblioteca Compose Material 3. O botão padrão tem um plano de fundo preenchido e há variações de botões para FilledTonal (plano de fundo silenciado), Contornado (transparente com borda fina) e Filho (plano de fundo transparente e sem borda, usado para ações complementares com o menor destaque). Botões redondos para conteúdo simples de ícone e texto vão ser adicionados em uma versão futura (Ia6942).

Versão 1.0.0-alpha02

5 de abril de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha02. A versão 1.0.0-alpha02 contém estas confirmações.

Correções de bugs

  • Adicionamos um DefaultTextStyle ao Wear Compose Material 3, que define PlatformTextStyle.includeFontPadding como "true" por padrão (a configuração atual). Isso vai permitir a sincronização da desativação do padding de fonte por padrão com as bibliotecas do Compose no futuro. Consulte Corrigir o padding de fonte no Compose para plano de fundo. (I7e461).

Versão 1.0.0-alpha01

22 de março de 2023

Lançamento de androidx.wear.compose:compose-material3:1.0.0-alpha01. A versão 1.0.0-alpha01 contém estas confirmações.

Novos recursos

  • O Material Design 3 é a próxima evolução do Material Design e inclui temas atualizados e componentes reformulados. O Material 3 no Wear Compose foi projetado para ser coeso com a biblioteca do Material 3 Compose no Android. Esta primeira versão alfa contém implementações práticas e funcionais do seguinte:

    • Tema do Material Design: configura o esquema de cores, a tipografia e as formas de maneira consistente nos componentes da biblioteca. O tema do Material3 foi revisado para cores que oferecem suporte ao contraste acessível. (I84005).
    • Texto/ícone: elementos básicos para apps do Wear Compose (I8e06a).
  • Vamos continuar a desenvolver o Wear Material (androidx.wear.compose:compose-material) e o Wear Material 3 (androidx.wear.compose:compose-material3) em paralelo. As próximas versões do Material3 vão ampliar o conjunto de widgets para incluir outros componentes conhecidos do Compose para Wear OS, como botões, seletores e controles deslizantes.

  • As bibliotecas Wear Material e Wear Material 3 são mutuamente exclusivas e não podem ser combinadas no mesmo app, principalmente porque fazem referência a diferentes temas, o que levaria a inconsistências inesperadas.

Versão 1.4

Versão 1.4.0-alpha05

20 de março de 2024

Lançamento de androidx.wear.compose:compose-*:1.4.0-alpha05. A versão 1.4.0-alpha05 contém these confirmações.

Mudanças na API

  • Tornamos as propriedades initialCenterItemIndex e initialCenterItemScrollOffset de ScalingLazyListState públicas (I0c616).
  • Tornamos o FullScreenStrokeWidth de ProgressIndicatorDefaults público. (Ibea23).

Correções de bugs

  • Melhoramos o desempenho do PositionIndicator, reduzindo o número de chamadas para layoutInfo de ScalingLazyColumn. (Idc83d).

Versão 1.4.0-alpha04

6 de março de 2024

Lançamento de androidx.wear.compose:compose-*:1.4.0-alpha04. A versão 1.4.0-alpha04 contém these commits.

Mudanças na API

  • Adicionamos uma nova sobrecarga para ToggleChip e SplitToggleChip, que usa um parâmetro selectionControl em vez de toggleControl Ela precisa ser usada com o controle RadioButton para fornecer semântica selecionável em vez de alternável para acessibilidade (I1d6d9).
  • Atualizamos os nomes dos parâmetros para a nova sobrecarga selectionControl de onSelected para onSelect em ToggleChip e SplitToggleChip (I1a971).

Versão 1.4.0-alpha03

21 de fevereiro de 2024

Lançamento de androidx.wear.compose:compose-*:1.4.0-alpha03. A versão 1.4.0-alpha03 contém estas confirmações.

Mudanças na API

  • O wrapper Modifier.inspectable foi descontinuado. Essa API vai criar mais invalidações do que o necessário. Por isso, o uso dessa API não é recomendado. Recomendamos que os desenvolvedores implementem o método inspectableProperties() no ModifierNodeElement se quiserem expor as propriedades modificadoras às ferramentas. (Ib3236).

Correções de bugs

  • Corrigimos um bug na documentação das anotações WearPreview* (Id526d).

Versão 1.4.0-alpha02

7 de fevereiro de 2024

Lançamento de androidx.wear.compose:compose-*:1.4.0-alpha02. A versão 1.4.0-alpha02 contém estas confirmações.

Correções de bugs

  • Corrigimos um bug no recurso de deslizar para revelar, em que era possível interagir (e cancelar) uma ação confirmada em um item começando a deslizar outro item (Ide059).
  • Atualizamos o ListHeader para oferecer suporte a ajustes de altura quando o conteúdo precisar de mais altura para acomodar tamanhos de fonte grandes (I7290c, b/251166127).

Versão 1.4.0-alpha01

24 de janeiro de 2024

Lançamento de androidx.wear.compose:compose-*:1.4.0-alpha01. A versão 1.4.0-alpha01 contém estas confirmações.

Novos recursos

  • Adicionamos uma animação de entrada a SwipeDismissableNavHost para transições no app (cfeb79a).
  • Agora, o PositionIndicator aparece por padrão quando uma tela é mostrada pela primeira vez. Essa mudança foi introduzida para ajudar a atender às diretrizes de qualidade do Wear. Infelizmente, isso significa que os testes de captura de tela vão precisar ser atualizados em telas que incluem PositionIndicator, porque o PositionIndicator não era mostrado anteriormente. (419cef7).

Mudanças na API

  • Adicionamos uma nova API de ondulação nas bibliotecas wear:compose-material e wear:compose-material3 que substitui a rememberRipple descontinuada Também foi adicionado um CompositionLocal temporário, LocalUseFallbackRippleImplementation, para reverter os componentes do Material Design para o uso das APIs rememberRipple/RippleTheme descontinuadas Ela vai ser removida na próxima versão estável e serve apenas como ajuda temporária na migração para casos em que você está fornecendo um RippleTheme personalizado. Acesse developer.android.com para conferir informações sobre a migração e mais informações contextuais por trás dessa mudança. (af92b21).
  • Atualizamos ColorScheme para ser imutável, tornando as atualizações de cores individuais menos eficientes, mas tornando o uso mais comum de cores mais eficiente. O raciocínio por trás dessa mudança é que a maioria dos apps não teria que atualizar cores individuais como principal caso de uso. Isso ainda é possível, mas a recomposição vai ser maior do que antes. Por sua vez, vamos diminuir significativamente a quantidade de assinaturas de estado em todo o código do Material Design e afetar a inicialização e o custo de execução de mais casos de uso padrão. (f5c48b7).
  • Os componentes do Material do Wear e do Material3 que expõem um MutableInteractionSource na API foram atualizados para expor um MutableInteractionSource anulável que tem como padrão nulo. Não há mudanças semânticas aqui: transmitir um valor nulo significa que você não quer elevar a MutableInteractionSource, que será criada dentro do componente, se necessário. Mudar para nulo permite que alguns componentes nunca aloquem uma MutableInteractionSource e que outros componentes só criem lentamente uma instância quando necessário, o que melhora o desempenho deles. Se você não estiver usando a MutableInteractionSource transmitida para esses componentes, é recomendável transmitir um valor nulo. Também é recomendável fazer alterações semelhantes nos seus próprios componentes. (f8fa920).
  • Atualizamos o rememberExpandableState para salvar o estado expansível Isso garante que os dados sejam armazenados ao navegar para outra tela e restaurados ao retornar à tela original. (5c80095).

Correções de bugs

  • Atualizamos a configuração ReduceMotion para usar um listener com reconhecimento de ciclo de vida (7c6b122).
  • Atualizamos o listener de TouchExplorationStateProvider para reconhecer o ciclo de vida (be28b01).
  • A camada do MaterialCore para CompactButton foi removida para melhorar o desempenho (25db8e9).
  • Tornamos BasicSwipeToDismissBox mais robusto para deslocamentos de NaN para evitar exceções (b983739).
  • Atualizamos BasicSwipeToDismissBox para garantir que os valores Alfa estejam dentro do intervalo 0,1
  • Correção de um bug em ToggleButton, SplitToggleButton, Checkbox, Switch e RadioButton para que os avisos de acessibilidade não sejam repetidos. Anteriormente, os papéis semânticos eram duplicados (d11eeb7).

Versão 1.3

Versão 1.3.0

24 de janeiro de 2024

Lançamento de androidx.wear.compose:compose-*:1.3.0. A versão 1.3.0 contém estas confirmações.

Mudanças importantes desde a versão 1.2.0

  • A classe SwipeToDismissBoxState, a enumeração SwipeToDismissValue e a função de extensão Modifier.edgeSwipeToDismiss agora fazem parte do pacote androidx.wear.compose.foundation, em vez do pacote androidx.wear.compose.material. Essa arquitetura atualizada permite implementar o processamento de gestos de forma independente de outras considerações de design. Os fluxos de trabalho do Material Design, como a aplicação de cores de um tema configurado, são tratados separadamente.
  • As classes SwipeToRevealCard e SwipeToRevealChip ajudam a implementar o recommended swipe-to-reveal guidance. A classe SwipeToRevealSample demonstra como usar esses componentes.
  • Nossa versão 1.3.0-alpha02 introduziu uma mudança que faz com que os objetos Chip e ToggleChip aumentem a altura para oferecer melhor suporte ao dimensionamento de fonte selecionado pelo usuário. Isso pode gerar alguns recortes. Para corrigir esse problema, a forma large para MaterialTheme agora usa um raio de canto maior (26 dp em vez de 24 dp). Os objetos Chip e ToggleChip usam esse novo raio de canto para evitar recortar o conteúdo nos cantos do ícone e do ToggleChip.

    • A maioria de Chips e ToggleChips não foi alterada, considerando a altura padrão de 52 dp. No entanto, objetos Chip e ToggleChip que contêm várias linhas de texto de rótulo principal ou secundário ou que tiveram a altura substituída podem causar falhas nos testes de captura de tela.

Outras mudanças

Para um conjunto mais completo das alterações introduzidas na versão 1.3.0, consulte as notas da versão beta01.

Recomendações para implementação

  • Se o app permitir que os usuários naveguem pelo conteúdo da tela, como em um app baseado em mapa, desative o gerenciamento de deslizar definindo userSwipeEnabled como false no elemento combinável SwipeDismissableNavHost e inclua um botão que permita que os usuários voltem para a tela anterior.
  • Para desativar as animações de um indicador de posição durante a exibição gradual e a mudança de posição em uma lista de rolagem, use um objeto SnapSpec.
  • Enquanto aguarda o carregamento do conteúdo para reprodução de um app de música, mostre um elemento combinável Placeholder em branco.
  • Para criar uma coleção de itens expansíveis sob demanda, use a classe experimental ExpandableStateMapping.

Versão 1.3.0-rc01

10 de janeiro de 2024

Lançamento de androidx.wear.compose:compose-*:1.3.0-rc01. A versão 1.3.0-rc01 contém estas confirmações.

Correções de bugs

  • Atualizamos a forma grande MaterialTheme para usar um raio de canto arredondado de 26 dp. Ela agora vai ser usada por Chip e ToggleChip Essa mudança é necessária para oferecer suporte a ajustes de altura quando o conteúdo precisar de mais altura para acomodar tamanhos de fonte grandes. Caso contrário, a forma existente do estádio corta parte do conteúdo de texto.

    Texto cortado nos cantos
    Figura 1: texto cortado nos cantos.
    Texto não cortado
    Figura 2: texto não cortado.

    Essa mudança pode causar uma falha nos testes de captura de tela. (I2e6ae).

Versão 1.3.0-beta02

13 de dezembro de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-beta02. A versão 1.3.0-beta02 contém estas confirmações.

Correções de bugs

  • Restauramos o movimento de deslizar pretendido em BasicSwipeToDismissBox Isso foi alterado em uma versão anterior, de modo que a parte de deslizar da transição ocorria enquanto o dedo tocava na tela. (Id8e76).

Versão 1.3.0-beta01

15 de novembro de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-beta01. A versão 1.3.0-beta01 contém estas confirmações.

A versão 1.3-beta01 do Compose para Wear OS indica que essa versão da biblioteca foi concluída, e a API está bloqueada, exceto quando marcada como experimental. O Wear Compose 1.3 inclui estas novas funcionalidades:

  • SwipeToDismissBoxState, SwipeToDismissValue e Modifier.edgeSwipeToDismiss foram migrados de androidx.wear.compose.material para androidx.wear.compose.foundation, assim como a implementação de deslizar para dispensar no BasicSwipeToDismissBox Isso permite que o processamento de gestos de deslizar para dispensar seja usado de forma independente do Material Design, por exemplo, do SwipeDismissableNavHost no androidx.wear.compose.navigation. O SwipeToDismissBox do androidx.wear.compose.material ainda é recomendado para ser usado com o Material Design, porque ele extrai cores do MaterialTheme e delega a implementação restante ao BasicSwipeToDismissBox.
  • SwipeDismissableNavHost agora oferece suporte a um novo parâmetro userSwipeEnabled para que o processamento de deslizar possa ser desativado nas telas em que não é necessário
  • BasicSwipeToDismissBox melhorou o processamento de foco usando HierarchicalFocusCoordinator
  • SwipeToReveal tem novos elementos combináveis SwipeToRevealCard e SwipeToRevealChip no Material Design que seguem a orientação de UX recomendada para Card e Chip. A ação secundária também pode ser desfeita.
  • O DefaultTextStyle agora desativa o padding da fonte para ser consistente em toda a Plataforma Android
  • Chip e ToggleChip agora ajustam a altura para acomodar o conteúdo que cresceu devido às fontes grandes para acessibilidade
  • PositionIndicator agora tem especificações de animação individuais para as animações de fade-in, fade-out e mudança de posição. Por motivos de desempenho, recomendamos que a exibição gradual e a mudança de posição sejam desativadas quando usadas com listas roláveis.
  • O ExpandableStateMapping oferece uma nova maneira de gerar ExpandableStates quando eles precisam ser criados sob demanda e não necessariamente com um escopo @Composable.
  • Agora, o Placeholder permite a redefinição se o conteúdo não estiver mais em estado pronto Além disso, a configuração de redução de movimento agora se aplica ao efeito de brilho e movimento de limpeza de dados no Placeholder

Problemas conhecidos

  • PositionIndicator não aparece inicialmente quando uma tela é mostrada pela primeira vez. Pretendemos fazer uma mudança em uma versão Alfa 1.4 inicial para que ela seja exibida inicialmente, mas sem nenhuma animação.

Mudanças na API

  • Renomeamos o nível básico SwipeToDismissBox para BasicSwipeToDismissBox. Isso deixa a distinção mais clara entre o componente do nível básico e o SwipeToDismissBox do nível do Material Design. O último extrai cores da MaterialTheme para serem usadas em scripts e delega a implementação restante para o BasicSwipeToDismissBox. (Ibecfc).
  • Marcamos o rememberExpandableStateMapping como experimental e melhoramos o desempenho do expandableItem (I5f6bc).
  • Substituímos a classe SwipeToRevealAction nas APIs Card e Chip do Material SwipeToReveal por uma API baseada em slot usando os elementos combináveis SwipeToRevealPrimaryAction, SwipeToRevealSecondaryAction e SwipeToRevealUndoAction Consulte o exemplo de código para obter exemplos de como usar a nova API. (Ia8943).
  • Substituímos as sinalizações de animação PositionIndicator por parâmetros AnimationSpec As animações individuais podem ser desativadas transmitindo snap como o AnimationSpec. (I6c523).

Correções de bugs

  • Correção de um bug acionado por texto curvo limitado quando o tamanho é limitado (I50efe).
  • Resolvemos uma possível falha do NaN relacionada ao curvedComposable (I970eb).
  • Revertemos a remoção da animação de destaque de mudança de posição em PositionIndicator (Ieb424).
  • Removemos a camada do Material Core para melhorar o desempenho do Chip (If2dcb).

Versão 1.3.0-alpha08

18 de outubro de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha08. A versão 1.3.0-alpha08 contém estas confirmações.

Mudanças na API

  • Adicionamos flags individuais a sobrecargas do PositionIndicator para controlar diferentes animações: showFadeInAnimation, showFadeOutAnimation e showPositionAnimation A API anterior foi descontinuada e encaminha as chamadas para a nova. Por motivos de desempenho e consistência na UX, quando o PositionIndicator é usado com uma lista rolável, recomendamos desativar as flags showFadeInAnimation e showPositionAnimation. Se o PositionIndicator for usado como um indicador independente, por exemplo, para mudança de volume, recomendamos que todas as três animações sejam ativadas. (I44294).
  • Descontinuamos os recursos SwipeToDismissBoxState, SwipeToDismissValue e edgeSwipeToDismiss do Material Design após a migração da funcionalidade "deslizar para dispensar" para wear.compose.foundation Substitua pelos equivalentes wear.compose.foundation. (Iee8c9).

Correções de bugs

  • Atualizamos os perfis de referência para as bibliotecas de base, material e navegação do Wear Compose. (Idb060).
  • Revertemos uma mudança de comportamento para a PositionIndicator introduzida em um CL anterior, de modo que o PositionIndicator era animado quando uma tela era mostrada inicialmente Pretendemos fazer uma mudança semelhante em uma versão Alfa 1.4 inicial, para que o PositionIndicator seja exibido inicialmente, mas sem nenhuma animação. (I41843).
  • Resolvemos alguns problemas de desempenho no PositionIndicator. (I1c654, b/302399827).
  • Otimizamos o desempenho da implementação padrão do provedor de estado de exploração de toque para que ela dependa de State<Boolean> em vez do estado derivado. (Ieec4d).
  • Definimos retângulos systemGestureExclusion para o Android 13 e versões mais recentes. (Ib1f4b).

Versão 1.3.0-alpha07

4 de outubro de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha07. A versão 1.3.0-alpha07 contém estas confirmações.

Mudanças na API

  • Adicionamos flags individuais a PositionIndicator para controlar diferentes animações: showFadeInAnimation, showFadeOutAnimation e showPositionAnimation A API anterior foi descontinuada e encaminha as chamadas para a nova. Por motivos de desempenho e consistência na UX, quando o PositionIndicator é usado com uma lista rolável, recomendamos desativar as flags showFadeInAnimation e showPositionAnimation. Se o PositionIndicator for usado como um indicador independente, por exemplo, para mudança de volume, recomendamos que todas as três animações sejam ativadas. (Ia2d63).

Correções de bugs

  • Fizemos melhorias no gesto de deslizar para revelar o movimento, adicionando uma animação de esmaecimento ao texto da ação principal e fazendo com que a ação secundária esmaeça/mudando a escala do ícone na expansão completa do gesto de deslizar. (Ib7223).
  • Recomendamos que as ações "Deslizar para revelar" sejam disponibilizadas e adicionamos ações de acessibilidade personalizadas aos nossos exemplos "Deslizar para revelar". (I42224).
  • Melhoramos o desempenho de SwipeToDismissBox, incluindo a refatoração para garantir que a lógica inicial não acione uma recomposição A SwipeToDismissBox agora é renderizada como tamanho de tela cheia. (Ie0aa2).
  • Corrigimos um bug quando o PositionIndicator desaparecia incorretamente (I2091a).
  • A performance de PositionIndicator foi melhorada pela otimização das recomposições Novas flags para controlar as animações (fadeIn, fadeOut e positionChange) foram adicionadas depois. Consulte as mudanças na API (Ifac7d).
  • Adicionamos testes de Microbenchmark para PositionIndicator (Idf875).

Versão 1.3.0-alpha06

20 de setembro de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha06. A versão 1.3.0-alpha06 contém estas confirmações.

Correções de bugs

  • Adicionamos suporte para Modifier.edgeSwipeToDismiss com SwipeToReveal (I95774, b/293444286).
  • Adicionamos exemplos para SwipeToRevealChip e SwipeToRevealCard do Material Design (Ieb974).
  • Atualizamos os perfis de referência para as bibliotecas Wear Compose Foundation e Material Design. (I1dd1f).

Versão 1.3.0-alpha05

6 de setembro de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha05. A versão 1.3.0-alpha05 contém essas confirmações.

Correções de bugs

  • Adicionamos o controle "Deslizar para revelar" que permite deslizar apenas um item por vez. (I3cd7a).
  • Melhoria na documentação de ScalingLazyColumnDefaults para corresponder melhor ao comportamento real (I886d3).

Versão 1.3.0-alpha04

23 de agosto de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha04. A versão 1.3.0-alpha04 contém essas confirmações.

Novos recursos

  • Adicionamos suporte à ação de desfazer para a ação secundária de SwipeToReveal (I7a22d).

Mudanças na API

  • Adição de HorizontalPageIndicator à biblioteca Wear Material3 (Ifee99).
  • As ferramentas de visualização do Wear Compose foram atualizadas para usar a biblioteca androidx.wear.tooling.preview. (Ib036e).

Correções de bugs

  • Correção de um bug nos botões redondos em que os modificadores não eram encadeados corretamente (I5e162).

Versão 1.3.0-alpha03

9 de agosto de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha03. A versão 1.3.0-alpha03 contém essas confirmações.

Mudanças na API

  • Adicionamos dois novos elementos combináveis no Material Design para implementar SwipeToReveal com cards e ícones. Esses elementos combináveis seguem as orientações de UX recomendadas sobre o componente e facilitam a implementação de SwipeToReveal com os componentes no Wear Material. (I7ec65).
  • Ativamos as anotações FloatRange como restrições de API, que foram declaradas anteriormente nos comentários (Icb401).

Correções de bugs

  • Movemos a lógica de rolagem inicial de ScalingLazyColumn para dentro de onGloballyPositioned() (Ic90f1).
  • Agora, estamos usando drawWithCache em PositionIndicator, ProgressIndicator e SelectionControls para otimizar as alocações de traços (I5f225, b/288234617).
  • Corrigimos a visibilidade da marcação da caixa de seleção em estados desativados (Ib25bf).
  • Atualizamos o Placeholder para permitir a redefinição para mostrar o marcador se o conteúdo não estiver mais em estado pronto (Ibd820).
  • Fizemos algumas correções para testes instáveis de Placeholder (Idb560).

Versão 1.3.0-alpha02

26 de julho de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha02. A versão 1.3.0-alpha02 contém estas confirmações.

Mudanças na API

  • Fornecemos ExpandableStateMapping, uma nova maneira de gerar ExpandableStates, para casos em que eles precisam ser criados sob demanda, não necessariamente em um escopo @Composable (Iff9e0).
  • SwipeToDismissBox foi migrado de androidx.wear.compose.material para o pacote androidx.wear.compose.foundation. (I275fb).
  • Atualização dos arquivos de API para anotar a supressão de compatibilidade. (I8e87a, b/287516207).
  • As constantes de altura para Chip, CompactChip e ToggleChip agora são públicas (Idbfde).
  • Os paddings horizontal e vertical de Chip e CompactChip agora são públicos (Ieeaf7).
  • Foi adicionada uma funcionalidade para desativar o processamento de deslizar no SwipeDismissableNavHost usando o novo parâmetro userSwipeEnabled (Id2a0b, b/230865655).
  • Atualizamos a biblioteca de navegação do Wear Compose para usar o novo SwipeToDismissBox da Wear Compose Foundation. (I4ff8e).

Correções de bugs

  • Corrigimos um bug de ordem z em que o expandedItem não mostrava o conteúdo correto depois de clicar no comportamento de um botão com botões (I1899d, b/289991514).
  • Melhoria no processamento de foco de SwipeToDismissBox (e, portanto, SwipeDismissableNavHost) usando HierarchicalFocusCoordinator (I45362, b/277852486).
  • Corrigimos o processamento de gestos em SwipeableV2 . (I89737).
  • Finalizamos os perfis de referência para a versão 1.2. (Id5740).
  • Após a migração de SwipeToDismissBox para o Foundation, a implementação de SwipeToDismissBox do Material Design agora encaminha para o Foundation e fornece valores de cor padrão do tema (If8451).
  • Adicionamos semântica de título a ListHeader (Ic5420).
  • Agora, Chip e ToggleChip vão ajustar a altura para acomodar o conteúdo que cresceu devido a fontes grandes para acessibilidade, quando necessário. (Iaf302).
  • Correção de um bug no papel semântico da área tocável de SplitToggleChip para acessibilidade (Ieed3a).
  • A configuração "Reduzir movimento" agora desativa o efeito de brilho e o movimento de transição nos marcadores de posição. (I91046).
  • Stepper e InlineSlider agora são compatíveis com cliques repetidos ao tocar e manter pressionado para aumentar/diminuir rapidamente o valor de Stepper e InlineSlider mantendo os botões + ou - pressionados. (I27359).

Versão 1.3.0-alpha01

21 de junho de 2023

Lançamento de androidx.wear.compose:compose-*:1.3.0-alpha01. A versão 1.3.0-alpha01 contém estas confirmações.

Correções de bugs

  • Conforme anunciado em 1.2.0-alpha07 e 1.2.0-alpha10, agora estamos mudando o DefaultTextStyle para desativar o padding da fonte para que seja consistente em toda a Plataforma Android. Isso resolverá alguns casos de recorte de texto com tamanhos de fonte grandes e pode afetar os layouts da tela. Portanto, os testes de captura de tela precisam ser atualizados. Por exemplo, observamos o recorte de texto aqui (Ic6a86).
Texto cortado com tamanho de fonte grande
Figura 1: texto cortado.
  • Ele não está mais presente quando o preenchimento de fonte é desativado:
Texto não cortado com tamanho de fonte grande
Figura 2: texto não cortado.
  • Atualizamos wear.compose.foundation para ser uma dependência de API de wear.compose.material (I72004, b/285404743).
  • Corrigimos um bug em SwipeToDismissBox As teclas de segundo plano e de conteúdo agora são passadas para o bloco remember para que novos modificadores sejam criados quando o conteúdo ou o plano de fundo mudar. (Ib876c, b/280392104).
  • Atualizamos TimeText para usar a localidade ao escolher o formato de 12 ou 24 horas (If4a3d).
  • Corrigimos uma inconsistência nos parâmetros padrão SwipeToDismissBox contentScrimColor (I2d70f).
  • Melhoramos o processamento de movimentos no SwipeToReveal (I28fb7).

Problemas conhecidos

  • Oferecer suporte a tamanhos de fonte configurados pelo usuário é um requisito de acessibilidade. Sabemos que ícones com várias linhas podem causar recorte de texto quando exibidos com tamanhos de fonte grandes. Por isso, vamos atualizar o ícone na versão Alfa 1.3 inicial para fazer ajustes de altura nesses casos.

Versão 1.2

Versão 1.2.1

18 de outubro de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.1. A versão 1.2.1 contém estas confirmações.

Correções de bugs

  • Correção de um bug quando o PositionIndicator desaparecia incorretamente (7a167f).

Versão 1.2.0

9 de agosto de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0. A versão 1.2.0 contém estas confirmações.

Mudanças importantes desde a 1.1.0

Versão 1.2.0-rc01

26 de julho de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-rc01. A versão 1.2.0-rc01 contém estas confirmações.

Correções de bugs

  • Finalizamos os perfis de referência para a versão 1.2 (Id5740).

Versão 1.2.0-beta02

7 de junho de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-beta02. A versão 1.2.0-beta02 contém estas confirmações.

Novos recursos

  • Adicionamos a nova variável experimental LocalReduceMotion CompositionLocal, que desativa o dimensionamento e o esmaecimento em ScalingLazyColumn (I58024).

Correções de bugs

  • Atualizamos os perfis de referência para as bibliotecas de base e Material do Wear Compose(I4725d).
  • Corrigimos uma inconsistência nos valores padrão dos parâmetros SwipeToDismissBox contentScrimColor (I2d70f).
  • Corrigimos o valor padrão de DefaultTextStyle usado para a configuração IncludeFontPadding (I737ed).

Versão 1.2.0-beta01

24 de maio de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-beta01. A versão 1.2.0-beta01 contém estas confirmações.

Novidades no Compose para Wear OS 1.2

A versão 1.2-beta01 do Compose para Wear OS indica que essa versão da biblioteca foi concluída, e a API está bloqueada, exceto quando marcada como experimental. O Wear Compose 1.2 inclui estas novas funcionalidades:

  • expandableItem e expandableItems são dois novos componentes Foundation compatíveis com a expansão de itens em uma ScalingLazyColumn. Use expandableItem para um único item expansível, como texto em que o número de linhas. Use expandableItems para um grupo de itens expansíveis e expandableButton para simplificar a criação de um botão que é recolhido após o conteúdo ser expandido.
  • HierarchicalFocusCoordinator: esse elemento combinável experimental permite marcar subárvores da composição como foco ativado ou desativado.
  • Picker: a API agora inclui userScrollEnabled para controlar se o seletor está ativo para a rolagem do usuário.
  • PickerGroup: um novo elemento combinável para processar vários seletores juntos. Ela processa o foco entre os seletores usando a API HierarchicalFocusCoordinator e ativa a centralização automática dos itens do seletor.
  • Placeholder: fizemos atualizações nas animações de brilho e exclusão permanente. O efeito de limpeza é aplicado imediatamente quando o conteúdo está pronto.
  • ScalingLazyColumn: migramos ScalingLazyColumn e as classes associadas de androidx.wear.compose.material.ScalingLazyColumn para androidx.wear.compose.foundation.lazy.ScalingLazyColumn. Atualize para usar a versão Foundation.Lazy.
  • SwipeToReveal: adicionamos suporte experimental ao gesto de deslizar para revelar como um meio de acessar ações secundárias, complementando o padrão "tocar e manter pressionado".
  • Stepper: agora tem uma sobrecarga com um parâmetro enableRangeSemantics extra para facilitar a desativação da semântica de intervalo padrão.
  • Previews: adicionamos as seguintes anotações personalizadas para visualizar elementos combináveis nas telas do Wear: WearPreviewSmallRound mostra o elemento em um dispositivo pequeno e redondo, WearPreviewLargeRound mostra o elemento em um dispositivo redondo grande e WearPreviewSquare mostra o elemento em um dispositivo quadrado. Além disso, as anotações a seguir e de várias visualizações: WearPreviewFontScales mostra os elementos combináveis em um dispositivo Wear com vários tamanhos de fonte, enquanto WearPreviewDevices mostra os elementos combináveis em diferentes dispositivos Wear.
  • Adicionamos um DefaultTextStyle ao Wear Compose, que define a propriedade PlatformTextStyle.includeFontPadding como verdadeira por padrão (essa é a configuração atual). Isso vai permitir sincronizar a desativação do padding de fonte por padrão com as bibliotecas do Compose em uma versão Alfa 1.3 do início. Consulte 1.2.0-alpha10 para saber mais.

Novos recursos

  • Adicionamos suporte experimental a dimensionamento e animação de esmaecimento desativados quando a configuração down_motion está ativada. (I58024).

Correções de bugs

  • Melhoria na documentação de angularWidthDp em CurvedSize.kt (Iab75c).
  • SwipeDismissableNavHost agora registra um aviso com possíveis causas de backstack vazia. Isso é feito para evitar falhas inesperadas causadas por IllegalArgumentException, geradas quando a pilha de retorno estava vazia. (I04a81, b/277700155).

Versão 1.2.0-alpha10

10 de maio de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha10. A versão 1.2.0-alpha10 contém estas confirmações.

Novos recursos

  • Adicionamos suporte ao recurso "Deslize para revelar", como um meio de acessar ações secundárias. Esse padrão complementa o padrão "tocar e manter pressionado", a forma que um usuário já poderia revelar (diferentes) ações secundárias. (I60862).

Mudanças na API

  • Adicionamos RevealScope aos elementos combináveis de ação em SwipeToReveal, que dá acesso ao deslocamento em que outras ações são reveladas (I3fd56).

Correções de bugs

  • Foi corrigido um problema em que o ScalingLazyColumn ficava travado na API Wear 33 após o deslizamento rápido (Ic4599).
  • Fizemos algumas melhorias de desempenho no PositionIndicator para reduzir a instabilidade (I35e92).
  • Correção de um bug no ícone e no CompactChip, em que o papel semântico não era mais definido como Role.Button (I93f91, b/277326264).

Problemas conhecidos

  • Identificamos um bug no Android Studio que causa falhas na visualização da renderização quando anotada com @WearPreviewDevices e @WearPreviewFontScales. Planejamos lançar uma correção em breve. As outras anotações de prévia do Wear funcionam conforme o esperado no Android Studio Giraffe 2022.3.1 e em versões mais recentes.

  • Na versão 1.2.0-alpha07, adicionamos DefaultTextStyle ao Wear Compose, mantendo o valor PlatformTextStyle.includeFontPadding como verdadeiro. Para segundo plano, consulte Corrigir o padding da fonte no Compose. Mudaremos o DefaultTextStyle para desativar o preenchimento de fonte em uma versão Alfa 1.3 anterior, para manter a consistência em toda a Plataforma Android. Isso resolverá alguns casos de recorte de texto com tamanhos de fonte grandes e também pode afetar os layouts da tela. Portanto, os testes de captura de tela precisam ser atualizados. Por exemplo, com tamanhos de fonte grandes, vemos recorte de texto aqui:

Texto cortado com tamanho de fonte grande
Figura 1: texto cortado.
  • Ele não está mais presente quando o preenchimento de fonte é desativado:
Texto não cortado com tamanho de fonte grande
Figura 2: texto não cortado.

A nova configuração pode ser adotada agora substituindo a tipografia no seu tema. Confira o exemplo de código.

Versão 1.2.0-alpha09

19 de abril de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha09. A versão 1.2.0-alpha09 contém estas confirmações.

Mudanças na API

  • Adição de angularSizeDp à API CurvedModifier para definir a largura angular no DP (I89a52).

Correções de bugs

  • Corrigimos problemas de acessibilidade nas demonstrações do seletor de horário(Id0eb7).

Versão 1.2.0-alpha08

5 de abril de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha08. A versão 1.2.0-alpha08 contém estas confirmações.

Mudanças na API

  • Renomeamos ExpandableItemsState como ExpandableState (If85ea).
  • Adicionamos expandableButton para simplificar a criação de um botão que é recolhido quando o conteúdo é expandido e também atualizamos os exemplos de expansíveis. (Iae309).

Correções de bugs

  • As amostras de expansíveis foram aprimoradas para mostrar mais possibilidades. Animação de expandableItem modificada para manter o conteúdo centralizado. (I2f637).
  • ToggleControls foi atualizado para evitar recomposições extras ao animar manualmente as cores usando State (I5d319).

Versão 1.2.0-alpha07

22 de março de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha07. A versão 1.2.0-alpha07 contém estas confirmações.

Mudanças na API

  • Movemos os componentes de item expansível (adicionados na versão 1.2.0-alpha06) do Material para a base, já que eles não tinham referência significativa ao MaterialTheme (Ib0525).

Correções de bugs

  • Corrigimos uma falha que ocorria em uma tela usando PickerGroup, garantindo que PickerGroup processe o foco corretamente quando nenhum seletor estiver em foco Também adicionamos suporte à rolagem RSB em nossas demonstrações do seletor. (If8c19).
  • Melhoramos as transições das caixas de diálogo. A transição de introdução agora está mais suave para acompanhar a transição no encerramento. (Ib5af9).
  • Adicionamos um DefaultTextStyle ao Wear Compose, que define a propriedade PlatformTextStyle.includeFontPadding como verdadeira por padrão (essa é a configuração atual). Isso vai permitir sincronizar a desativação do padding da fonte por padrão com as bibliotecas do Compose. Consulte Corrigir o padding de fonte no Compose para saber mais sobre o plano de fundo. (I2aee8).
  • Uma dependência de visualização do UpsideDownCake foi revertida com o activity-compose, e isso bloqueava a publicação de apps na Google Play Store. (I6443d).

Versão 1.2.0-alpha06

8 de março de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha06. A versão 1.2.0-alpha06 contém estas confirmações.

Mudanças na API

  • Foi adicionado o componente CurvedBox, que coloca componentes uns sobre os outros no mundo curvo. (I29200).
  • Adição de itens expansíveis: dois novos componentes para oferecer suporte a um grupo de itens expansíveis em uma ScalingLazyColumn ou a um único item expansível, como o texto, em que o número de linhas se expande. (I95dd5).
  • Adicionamos as seguintes anotações personalizadas para visualizar elementos combináveis em telas do Wear: WearPreviewSmallRound mostra o elemento em um dispositivo pequeno e redondo, WearPreviewLargeRound mostra o elemento em um dispositivo redondo grande, e WearPreviewSquare mostra o elemento em um dispositivo quadrado. Além disso, as anotações a seguir e de várias visualizações: WearPreviewFontScales mostra os elementos combináveis em um dispositivo Wear com vários tamanhos de fonte, enquanto WearPreviewDevices mostra os elementos combináveis em diferentes dispositivos Wear. Para usar essas prévias, é necessário ter a versão mais recente do Android Studio (Giraffe Canary 6) ou mais recente. Se essas anotações não forem adequadas ao seu objetivo, a visualização ainda poderá ser usada e será compatível com outras personalizações por meio de parâmetros. (I397ff).
  • Marcamos o HierarchicalFocusCoordinator como experimental, embora seja considerado um candidato a ser movido para as principais bibliotecas do Compose, devido à ampla aplicabilidade. (I3a768).

Correções de bugs

  • Correção de um bug em HierarchicalFocusCoordinator, quando o lambda transmitido para o parâmetro focusEnabled era mudado, agora usamos o novo corretamente (Icb353).
  • Atualizamos a cor padrão do conteúdo desativada para "Segundo plano" ao usar cores primárias como plano de fundo em Button, CompactButton, Chip, CompactChip e ToggleButton Isso melhora o contraste para acessibilidade. (I527cc).

Versão 1.2.0-alpha05

22 de fevereiro de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha05. A versão 1.2.0-alpha05 contém estas confirmações.

Mudanças na API

  • A API PickerGroup foi atualizada para permitir a propagação opcional das restrições mínimas para o elemento combinável Quando definida como verdadeira, as restrições mínimas transmitidas do elemento combinável pai serão permitidas no PickerGroup. Se for definida como falsa, PickerGroup redefinirá as restrições mínimas. (I3e046).
  • Adicionamos animateScrollToOption à API Picker para oferecer suporte à animação programática para uma opção específica do Picker (I6fe67).

Correções de bugs

  • Atualizamos o HorizontalPageIndicator para oferecer suporte a layouts da direita para a esquerda (Ia4359).
  • Foram adicionados testes de captura de tela para layout da direita para a esquerda em HorizontalPageIndicator (I6fbb8).
  • Foram adicionados mais testes à SwipeDismissableNavHostTest que usam TestNavHostController (I61d54).

Versão 1.2.0-alpha04

8 de fevereiro de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha04. A versão 1.2.0-alpha04 contém estas confirmações.

Novos recursos

  • Introdução de PickerGroup para gerenciar vários seletores usando a API de foco. Ele lida com o foco entre diferentes seletores, permite a centralização automática deles com base em parâmetros e deixa que os desenvolvedores mudem o foco entre seletores ao mesmo tempo em que lidam com os eventos do grupo. No modo Talkback, o PickerGroup processa o foco movendo-o para o seletor escolhido do grupo (I60840).

Mudanças na API

  • Adicionamos uma sobrecarga ao Stepper com um parâmetro enableRangeSemantics extra para facilitar a desativação da semântica de intervalo padrão (Ia61d4).

Correções de bugs

  • A ScalingLazyColumn agora pode ser aninhada em uma página de rolagem horizontal (Iec3f8, b/266555016).
  • Melhoria na limpeza dos kdocs do Stepper e dos testes StepperTest (Ic118e).
  • A dependência androidx.navigation foi atualizada para a versão 2.5.3 (If58ed).

Versão 1.2.0-alpha03

25 de janeiro de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha03. A versão 1.2.0-alpha03 contém estas confirmações.

Mudanças na API

  • Migramos ScalingLazyColumn (e as classes associadas) de androidx.wear.compose.material.ScalingLazyColumn para andrdoidx.wear.compose.foundation.lazy.ScalingLazyColumn. Confira este exemplo de migração. Esse novo local é mais parecido com o de compose.foundation.lazy.LazyColumn e é mais natural, já que não é um componente opinativo do Material Design. A mudança está acontecendo agora em preparação para uma nova biblioteca do Material3, em que vamos trabalhar em paralelo com a biblioteca atual (I060e7).

As mudanças a seguir fazem parte da migração de ScalingLazyColumn do Material para Foundation.Lazy:

  • As APIs PositionIndicator da ScalingLazyColumn do Material Design foram descontinuadas. Atualize para Foundation.Lazy ScalingLazyColumn. Além disso, o campo anchorType foi adicionado a ScalingLazyListLayoutInfo (I29d95).
  • A ScalingLazyColumn foi marcada como descontinuada no pacote do Wear Compose Material (I16d34).
  • Atualizamos o modificador ScrollAway para usar o ScalingLazyListState do Wear Compose Foundation.Lazy e descontinuamos a sobrecarga que ocupou ScalingLazyListState do Wear Compose Material (Ifc42c).
  • Atualizamos as APIs da caixa de diálogo para usar ScalingLazyListState do Foundation.Lazy e descontinuamos as sobrecargas que usavam o ScalingLazyListState do Material Design (Ic8960).
  • Atualizamos as APIs Picker para usar ScalingParams de Foundation.Lazy e descontinuamos as sobrecargas que usavam ScalingParams do Material Design (Idc3d8).

Correções de bugs

  • Corrigimos um bug que causava recomposições desnecessárias no ScalingLazyListState.centerItemIndex garantindo que ele só enviasse atualizações quando o valor realmente mudasse (Ia9f38).
  • Melhoramos o desempenho do SwipeToDismissBox (I3933b).
  • Foram adicionados testes comparativos para ScalingLazyColumn na Wear Compose Foundation (Ie00f9).
  • Atualizamos alguns métodos internos de classes ScalingLazyColumn no Material Design para usar os equivalentes de Foundation.Lazy (I38aab).
  • Corrigimos alguns problemas nos testes do seletor e adicionamos mais testes para verificar a rolagem com deslocamento (I6ac34).
  • Migramos as demonstrações de integração ScalingLazyColumn para depender de Foundation.Lazy em vez de ScalingLazyColumn do Material Design (Ic6caa).
  • Adicionamos parâmetros fromDate/toDate opcionais à demonstração DatePicker (I961cd).

Versão 1.2.0-alpha02

11 de janeiro de 2023

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha02. A versão 1.2.0-alpha02 contém estas confirmações.

Mudanças na API

  • Os testes de interface do Android Compose agora vão executar transmissões de layout para cada frame ao executar frames para ficar ociosos (por exemplo, com waitForIdle). Isso pode afetar testes que são executados em frames individuais de animações de layout (I8ea08, b/222093277).
  • O parâmetro minLines foi adicionado ao Wear Text para um comportamento consistente com BasicText (I24874).
  • O CompactChipTapTargetPadding foi disponibilizado ao público para que apareça na documentação (If1e70, b/234119038).

Correções de bugs

  • Desativação de builds multiplataforma para pacotes wear.compose (Iad3d7).
  • Correção de kdocs para scrollToOption (I6f9a0).
  • O PlaceholderState.rememberPlaceholderState() foi atualizado para usar rememberUpdatedState, e o estado vai ser atualizado se a lambda onContentReady também for (I02635, b/260343754).
  • Correção de um problema de instabilidade do texto no componente Picker ao aproveitar a nova estratégia de composição adicionada a Modifier.graphicsLayer (I99302).
  • Correção de um bug que causava oscilações na nossa demonstração do DatePicker (I660bd).
  • Melhoramos a acessibilidade das demonstrações do seletor de data e horário de 12 horas (I05e12).
  • Atualizamos as demonstrações dos seletores de data e horário para que eles não sejam afetados por mudanças de RSB quando não selecionados (I4aecb).

Versão 1.2.0-alpha01

7 de dezembro de 2022

Lançamento de androidx.wear.compose:compose-*:1.2.0-alpha01. A versão 1.2.0-alpha01 contém estas confirmações.

Novos recursos

  • Atualizamos a função experimental de marcador de posição para que o efeito "Apagar" seja aplicado imediatamente quando o conteúdo estiver pronto em vez de aguardar o início do próximo loop de animação. Também fizemos algumas atualizações nas animações de redução e apagar (I5a7f4).

Mudanças na API

  • Adicionamos um elemento combinável HierarchicalFocusCoordinator para ativar a marcação de subárvores da composição como foco ativado ou desativado (I827cb).
  • Adicionamos uma nova propriedade para substituir o papel semântico de ToggleButton (I67132).
  • Atualizamos TimeTextDefaults.TimeFormat12Hours para remover AM/PM em TimeText. Isso vai mudar o valor padrão dos parâmetros timeSource na API TimeText (I1eb7f).
  • Estendemos a API Picker para melhorar a acessibilidade de telas com vários seletores. Há uma nova propriedade userScrollEnabled para controlar se o seletor está ativo para a rolagem do usuário (I3c3aa).

Correções de bugs

  • Mudamos a largura da borda padrão de um OutlinedButton/OutlinedCompactButton de 2 dp para 1 dp, de acordo com as especificações finais da UX (Icf84d).
  • Para reduzir o efeito em que o primeiro item adicionado a uma ScalingLazyColumn vazia parece rolar para a tela, adicionamos um autoCentering topPadding estimado quando o conteúdo está vazio. Essa mudança calcula a quantidade de padding superior necessária, presumindo um item inicial de 0.dp de altura. Em ScalingLazyListAnchorType.ItemStart, isso vai calcular o padding superior correto. Em ScalingLazyListAnchorType.ItemCenter, esse cálculo vai ser incorreto, porque a altura dos itens é necessária para dimensionar corretamente o conteúdo, resultando em um pequeno efeito de rolagem com base na altura real dos itens (I239a4).
  • Atualizamos o scrim em segundo plano aplicado à animação SwipeToDismiss para corresponder à plataforma Wear (I9003e).
  • O processamento de LazyListState e ScalingLazyListState foi corrigido no PositionIndicator para itens de lista de tamanho 0 para evitar erros de divisão por zero (Ic28dd).

Versão 1.1

Versão 1.1.2

8 de fevereiro de 2023

Lançamento de androidx.wear.compose:compose-foundation:1.1.2, androidx.wear.compose:compose-material:1.1.2 e androidx.wear.compose:compose-navigation:1.1.2. A versão 1.1.2 contém estas confirmações.

Correções de bugs

  • Corrigimos um bug que causava recomposições desnecessárias no ScalingLazyListState.centerItemIndex garantindo que ele só enviasse atualizações quando o valor realmente mudasse (Ia9f38).

Versão 1.1.1

11 de janeiro de 2023

Lançamento de androidx.wear.compose:compose-foundation:1.1.1, androidx.wear.compose:compose-material:1.1.1 e androidx.wear.compose:compose-navigation:1.1.1. A versão 1.1.1 contém estas confirmações.

Correções de bugs

  • O PlaceholderState.rememberPlaceholderState() foi atualizado para usar rememberUpdatedState, e o estado vai ser atualizado se a lambda onContentReady também for (I02635, b/260343754).

Versão 1.1.0

7 de dezembro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0, androidx.wear.compose:compose-material:1.1.0 e androidx.wear.compose:compose-navigation:1.1.0. A versão 1.1.0 contém estas confirmações.

Mudanças importantes desde a versão 1.0.0

Novos recursos

  • Atualizamos a função experimental de marcador de posição para que o efeito "Apagar" seja aplicado imediatamente quando o conteúdo estiver pronto em vez de aguardar o início do próximo loop de animação. Também fizemos algumas atualizações nas animações de redução e apagar (I5a7f4).

Correções de bugs

  • Mudamos a largura da borda padrão de um OutlinedButton/OutlinedCompactButton de 2 dp para 1 dp, de acordo com as especificações finais da UX (Icf84d).
  • Para reduzir o efeito em que o primeiro item adicionado a uma ScalingLazyColumn vazia parece rolar para a tela, adicionamos um autoCentering topPadding estimado quando o conteúdo está vazio. Essa mudança calcula a quantidade de padding superior necessária, presumindo um item inicial de 0.dp de altura. Em ScalingLazyListAnchorType.ItemStart, isso vai calcular o padding superior correto. Em ScalingLazyListAnchorType.ItemCenter, esse cálculo vai ser incorreto, porque a altura dos itens é necessária para dimensionar corretamente o conteúdo, resultando em um pequeno efeito de rolagem com base na altura real dos itens (I239a4).
  • Atualizamos o scrim em segundo plano aplicado à animação SwipeToDismiss para corresponder à plataforma Wear (I9003e).
  • O processamento de LazyListState e ScalingLazyListState foi corrigido no PositionIndicator para itens de lista de tamanho 0 para evitar erros de divisão por zero (Ic28dd).

Versão 1.1.0-rc01

9 de novembro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-rc01, androidx.wear.compose:compose-material:1.1.0-rc01 e androidx.wear.compose:compose-navigation:1.1.0-rc01. A versão 1.1.0-rc01 contém estas confirmações.

Correções de bugs

  • Adicionamos regras de perfil de referência para Placeholders, ScrollAway, RadioButton, Switch, Checkbox, OutlinedButton, OutlinedCompactButton, OutlinedChip e OutlinedCompactChip (I8249c).
  • Corrigimos um bug no Modifier.scrollAway para que o TimeText ainda seja mostrado se o itemIndex especificado for inválido, por exemplo, caso o índice de itens esteja fora do intervalo (I2137a).
  • Atualizamos a animação SwipeToDismissBox para corresponder à implementação da plataforma. Após a animação inicial de apertar, a tela desliza para a direita quando a dispensa é acionada (I41d34).
  • Como otimização, atualizamos a Modifier.scrollAway para ler somente o scrollState dentro do bloco de medida para evitar que o modificador seja recomposto após cada nova medida (I4c6f1).
  • Adicionamos documentação e um exemplo aos marcadores de posição para mostrar a ordem correta de Modifier.placeholder e Modifier.placeholderShimmer quando aplicados ao mesmo elemento combinável (Ie96f4, b/256583229).
  • Mudamos a largura da borda padrão de um OutlinedCompactChip/OutlinedChip de 2 dp para 1 dp, de acordo com as especificações finais da UX (Ib3d8e).
  • Corrigimos um bug no rememberPickerState em que as entradas atualizadas não eram salvas, de modo que os elementos combináveis não eram atualizados após mudanças nas entradas (I49ff6, b/255323197).
  • Fizemos algumas atualizações na interface dos marcadores de posição: 1) mudamos o gradiente de brilho para 1,5 vez o tamanho da tela, 2) adicionamos easing (bézier cúbica) da progressão do brilho e 3) aceleramos a animação de deslizamento (250 ms) (Id29c1).
  • Corrigimos um bug na interface no efeito de marcador de posição "WipeOff" em que os planos de fundo dos ícones e cards eram apagados um pouco antes porque a posição do componente na tela não era considerada (I2c7cb).
  • Atualizamos a exibição do plano de fundo dos marcadores de posição para combinar cores em vez de adicioná-los a camadas quando possível. Isso reduz o risco de mistura alfa das diferentes camadas cortadas, impedindo que as cores vazem nas bordas do marcador (I2ea26).
  • Corrigimos o cálculo de ScalingLazyListState.centerItemIndex/centerItemOffset para que, se dois itens ficarem em um dos lados da linha central da janela de visualização, o que estiver mais próximo seja considerado como centerItem (I30709, b/254257769).
  • Corrigimos um bug no ScalingLazyListState.layoutInfo.visibleItemsInfo que informava deslocamentos incorretos durante a inicialização da ScalingLazyColumn. Agora, uma lista vazia será retornada até que todos os itens da lista fiquem visíveis e tenham os deslocamentos corretos. Confira se há ScalingLazyListState.layoutInfo.visibleItemsInfo.isNotEmpty(). Se houver, isso confirma que a inicialização do ScalingLazyColumn foi concluída e que os itens estão visíveis (I3a3b8).

Versão 1.1.0-beta01

24 de outubro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-beta01, androidx.wear.compose:compose-material:1.1.0-beta01 e androidx.wear.compose:compose-navigation:1.1.0-beta01. A versão 1.1.0-beta01 contém estas confirmações.

Novidades no Compose para Wear OS 1.1

A versão 1.1.0-beta01 do Compose para Wear OS indicou que esta versão da biblioteca está com todos os recursos e a API está bloqueada.

  • A versão do Wear Compose 1.1 inclui estas novas funcionalidades:
    • Picker: melhorias na acessibilidade do seletor para que as telas de vários seletores sejam navegáveis com os leitores de tela e a descrição do conteúdo seja acessível.
    • O parâmetro contentDescription do seletor agora é usado apenas para a opção selecionada e utiliza uma string anulável. Na confirmação anterior, era necessário transmitir um mapeamento de opção para a descrição do conteúdo, mas apenas a opção selecionada era usada.
    • Os itens do seletor agora estão sempre centralizados, corrigindo um bug que causava a mudança do alinhamento ao definir gradientRatio como zero.
    • Chip/ToggleChip: atualizamos os gradientes padrão de Chip/ToggleChip para alinhamento com a especificação de UX mais recente. ChipDefaults.gradientBackgroundChipColors foi atualizado para começar em 50% do principal em vez de 32,5%.
    • Chip/ToggleChip: foram adicionadas sobrecargas para modificar as formas dos ícones.
    • Chip/Button/ToggleButton: foi adicionado um novo estilo de contorno para ícones e botões, além de novos elementos combináveis OutlinedChip e OutlinedButton que fornecem um Chip/Button transparente com uma borda fina.
    • Card: os gradientes padrão dos cards foram atualizados para ficarem de acordo com a especificação mais recente da UX. CardDefaults.cardBackgroundPainter foi atualizado para começar em 30% do principal e terminar em 20% do onSurfaceVariant (anteriormente, o intervalo era de 20% a 10% do onSurfaceVariant). ToggleChip.toggleChipColors muda de um gradiente linear de 75% de superfície a 32,5% do principal para 0% de superfície a 50% do principal.
    • Button/ToggleButton: foram adicionadas propriedades para modificar formas de botão.
    • Theme: várias cores padrão do MaterialTheme foram atualizadas para melhorar a acessibilidade, já que as cores originais não tinham contraste suficiente, dificultando a diferenciação de ícones, cards e botões da cor de fundo do tema.
    • InlineSlider/Stepper: funções de botão foram adicionadas para que o Talkback possa reconhecê-las como botões.
    • Scaffold: o PositionIndicator agora está posicionado e dimensionado para ocupar apenas o espaço necessário. Isso é útil, por exemplo, quando informações semânticas são adicionadas a ele. O TalkBack agora vai mostrar os limites corretos de PositionIndicator na tela.
    • CurvedText/TimeText: foi adicionado Modifier.scrollAway, que rola um item verticalmente para dentro/fora da visualização com base no estado de rolagem (com sobrecargas para trabalhar com Column, LazyColumn e ScalingLazyColumn). O ScrollAway normalmente é usado para tirar um TimeText da visualização quando o usuário começa a rolar uma lista de itens para cima.
    • CurvedText/TimeText: foi adicionado suporte a fontFamily, fontStyle e fontSynthesis em CurvedTextStyle, utilizável em curvedText e basicCurvedText.
    • CurvedText/TimeText: foi adicionado fontWeight ao construtor e ao método de cópia em CurvedTextStyle.
    • ToggleControls: os controles de alternância animados Checkbox, Switch e RadioButton foram adicionados para uso com ToggleChip e SplitToggleChip. Eles podem ser usados em vez dos ícones estáticos fornecidos por ToggleChipDefaults (switchIcon, checkboxIcon e radioIcon).
    • Placeholder: foi adicionado suporte experimental a marcadores de posição. Três efeitos visuais distintos foram criados para trabalhar em conjunto.
    • O primeiro é um efeito temporário de pincel em segundo plano usado em contêineres, como ícones e cards, para desenhar sobre o plano de fundo normal enquanto o conteúdo é carregado.
    • O segundo é um modificador (Modifier.placeholder()) para mostrar um widget de marcador de posição em forma de estádio sobre o conteúdo que está sendo carregado.
    • O terceiro é um efeito de gradiente/brilho de modificador (Modifier.placeholderShimmer()) mostrado por cima dos outros efeitos para indicar aos usuários que estamos aguardando o carregamento dos dados.
      • Todos esses efeitos são projetados para serem coordenados, brilhar e se apagar de forma orquestrada.
  • As dependências do Core Compose foram atualizadas de 1.2 para 1.3.

Mudanças na API

  • Os parâmetros de fonte (fontFamily, fontWeight, fontStyle e fontSynthesis) agora podem ser especificados diretamente como parâmetros de curvedText (Idc422).

Correções de bugs

  • curveText e basicCurvedText agora vão funcionar corretamente com o TalkBack. Eles têm um nó do Compose bem-dimensionado e posicionado (mas vazio) com a UI associada a eles, usando o texto como descrição do conteúdo (I7af7c, b/210721259).
  • Foi corrigido um bug em Picker quando o PickerState.repeatedItems = false para adicionar uma configuração explícita de parâmetros autoCentering no ScalingLazyColumn interno dos seletores. Isso garante a possibilidade de rolar a opção zero até o centro da visualização (I8a4d7).

Versão 1.1.0-alpha07

5 de outubro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-alpha07, androidx.wear.compose:compose-material:1.1.0-alpha07 e androidx.wear.compose:compose-navigation:1.1.0-alpha07. A versão 1.1.0-alpha07 contém estas confirmações.

Novos recursos

  • Adicionamos suporte experimental a marcadores de posição. Três efeitos visuais distintos foram criados para trabalhar em conjunto. O primeiro é um efeito temporário de pincel em segundo plano usado em contêineres, como ícones e cards, para desenhar sobre o plano de fundo normal enquanto o conteúdo é carregado. O segundo é um modificador (Modifier.placeholder()) para mostrar um widget de marcador de posição em forma de estádio sobre o conteúdo que está sendo carregado. E o terceiro é um efeito de gradiente/brilho de modificador (Modifier.placeholderShimmer()) mostrado acima dos outros efeitos para indicar aos usuários que estamos aguardando o carregamento dos dados. Todos esses efeitos são projetados para serem coordenados, brilhar e se apagar de forma orquestrada (I3c339).

Mudanças na API

  • Foi adicionado suporte a fontWeight, fontFamily, fontStyle e fontSynthesis em CurvedTextStyle, utilizável em curvedText e basicCurvedText. Esse parâmetro pode ser usado para especificar a fonte e o estilo a serem usados no texto curvo (Iaa1a8, I72759).
  • O parâmetro de deslocamento de Modifier.scrollAway foi atualizado para Dp para consistência com Modifier.offset (antes, era em pixels). Além disso, foi refatorado como um LayoutModifier para aumentar a eficiência (I9f94b).
  • Como parte da nova API de controles de alternância, o elemento RadioButton’s circleColor foi renomeado como ringColor (I28fa9).
  • Adicionamos os controles de alternância animados Checkbox, Switch e RadioButton para uso com ToggleChip e SplitToggleChip. Eles podem ser usados em vez dos ícones estáticos fornecidos por ToggleChipDefaults (switchIcon, checkboxIcon e radioIcon) (I8a8c4).

Versão 1.1.0-alpha06

21 de setembro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-alpha06, androidx.wear.compose:compose-material:1.1.0-alpha06 e androidx.wear.compose:compose-navigation:1.1.0-alpha06. A versão 1.1.0-alpha06 contém estas confirmações.

Novos recursos

  • Adicionamos Modifier.scrollAway, que rola um item verticalmente dentro/fora da visualização, com base no estado de rolagem (com sobrecargas para trabalhar com Column, LazyColumn e ScalingLazyColumn). O ScrollAway normalmente é usado para tirar um TimeText da visualização, já que o usuário começa a rolar uma lista de itens para cima (I61766).

Correções de bugs

  • PositionIndicator agora está posicionado e dimensionado para ocupar apenas o espaço necessário. Isso é útil, por exemplo, quando informações semânticas são adicionadas a ele. O TalkBack agora vai mostrar os limites corretos de PositionIndicator na tela. (Ie6106, b/244409133).

Versão 1.1.0-alpha05

7 de setembro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-alpha05, androidx.wear.compose:compose-material:1.1.0-alpha05 e androidx.wear.compose:compose-navigation:1.1.0-alpha05. A versão 1.1.0-alpha05 contém estas confirmações.

Correções de bugs

  • Papéis de botão foram adicionados a InlineSlider e Stepper para que o TalkBack possa reconhecer essas funções como botões (Icb46c, b/244260275).
  • Corrigimos a ordem z da posição e os indicadores de página no Scaffold. Como os indicadores ficam na parte de cima, eles não ficam ocultos por uma possível vinheta (Ib988f, b/244207528).

Versão 1.1.0-alpha04

24 de agosto de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-alpha04, androidx.wear.compose:compose-material:1.1.0-alpha04 e androidx.wear.compose:compose-navigation:1.1.0-alpha04. A versão 1.1.0-alpha04 contém estas confirmações.

Mudanças na API

  • Atualizamos várias cores padrão do MaterialTheme para melhorar a acessibilidade, porque as cores originais não tinham contraste suficiente, dificultando a diferenciação de ícones, cards e botões da cor de fundo do tema. As cores atualizadas são surface(0xFF202124->0xFF303133), onPrimary(0xFF202124->0xFF303133), onSecondary(0xFF202124->0xFF303133), primaryVariant(0xFF669DF6->0xFF8AB4F8) e onError(0xFF202124->0xFF000000). Embora a mudança das cores seja relativamente sutil, ela pode afetar os testes de captura de tela atuais (81ab09).

Correções de bugs

  • Correção de um bug de lógica na função ScalingLazyColumn que podia resultar em listas com um número pequeno de itens (geralmente 2) incapazes de concluir a inicialização e que ficavam transparentes (504347).

Versão 1.1.0-alpha03

10 de agosto de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-alpha03, androidx.wear.compose:compose-material:1.1.0-alpha03 e androidx.wear.compose:compose-navigation:1.1.0-alpha03. A versão 1.1.0-alpha03 contém estas confirmações.

Novos recursos

  • Adicionamos um novo estilo delineado para Chips e Buttons, bem como novos elementos combináveis OutlinedChip e OutlinedButton que fornecem um Chip/Button transparente com uma borda fina (Id5972).

Mudanças na API

  • Foram adicionadas sobrecargas para modificar formas de botão (Icccde).

Correções de bugs

  • Corrigimos o tamanho da área de controle de alternância do ToggleChip, porque ela não correspondia à especificação da UX, que exige um espaçador de 4 dp entre o rótulo e uma área de ícone de controle de alternância de 24 x 24 dp, com uma largura total de 28 dp. No entanto, a implementação está fornecendo uma área de controle de alternância incorreta de 36 x 24 dp. Isso resulta na remoção de 8 dp da área útil do rótulo de texto. OBSERVAÇÃO: essa correção de bug dá mais espaço para o texto e, como resultado, pode afetar positivamente o layout do texto em excesso. Se você tem testes de capturas de tela com ToggleChips, talvez eles precisem ser atualizados (I514c8, b/240548670).

Versão 1.1.0-alpha02

27 de julho de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-alpha02, androidx.wear.compose:compose-material:1.1.0-alpha02 e androidx.wear.compose:compose-navigation:1.1.0-alpha02. A versão 1.1.0-alpha02 contém estas confirmações.

Novos recursos

  • Mudamos as dependências do Compose para o Wear OS nas principais bibliotecas do Compose da versão 1.2.0 a 1.3.0-alpha0X.

Mudanças na API

  • Adição de sobrecargas para modificar as formas dos ícones (I02e87).

Correções de bugs

  • Animamos a visibilidade da vinheta ao mostrar/ocultar a caixa de diálogo para que ela seja consistente com a animação de ampliação atual (Ida33e).
  • Corrigimos um bug em que uma divisão por zero podia ocorrer com alguns comportamentos de deslizar rapidamente durante a rolagem (I86cb6).
  • Correção de um bug em ChipDefaults.childChipColor() para garantir que a cor de plano de fundo desativada seja totalmente transparente (I2b3c3, b/238057342).

Versão 1.1.0-alpha01

29 de junho de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.1.0-alpha01, androidx.wear.compose:compose-material:1.1.0-alpha01 e androidx.wear.compose:compose-navigation:1.1.0-alpha01. A versão 1.1.0-alpha01 contém estas confirmações.

Mudanças na API

  • O parâmetro contentDescription do seletor agora é usado apenas para a opção selecionada e utiliza uma string anulável. Antes, era necessário transmitir um mapeamento de opção para a descrição do conteúdo, mas apenas a opção selecionada era usada (Ife6a7).
  • Fizemos melhorias na acessibilidade do seletor para que as telas de vários seletores sejam navegáveis com os leitores de tela e a descrição do conteúdo seja acessível (I64edb).

Correções de bugs

  • Atualizamos as regras de perfil de referência empacotadas com a biblioteca Wear Compose (I9c694).
  • Corrigimos a direção do gradiente para os ícones no modo da direita para a esquerda. Antes era "canto esquerdo de cima para canto direito de baixo", agora é "canto direito de cima para canto esquerdo de baixo" (Ic2e77).
  • Atualizamos os gradientes padrão de Chip/ToggleChip/Card para alinhamento com a especificação de UX mais recente. O ChipDefaults.gradientBackgroundChipColors foi atualizado para começar em 50% do principal, em vez de 32,5%. O CardDefaults.cardBackgroundPainter foi atualizado para começar em 30% do principal e terminar em 20% de onSurfaceVariant. Antes, a variação de onSurfaceVariant era de 20% a 10%. O ToggleChip.toggleChipColors muda de um gradiente linear de 75% a 32,5% de superfície ao principal para 0% a 50% (I43bbd).
  • Adicionamos uma cor de plano de fundo (MaterialTheme.color.surface) atrás dos Chip/ToggleChips que têm planos de fundo gradientes. Isso garante que eles fiquem visíveis corretamente no caso improvável de uma cor clara ser usada atrás deles (Ibe1a4, b/235937657).
  • Os itens do seletor agora estão sempre centralizados, corrigindo um bug que causava a mudança do alinhamento ao definir gradientRatio como zero (I712b8).

Versão 1.0

Versão 1.0.2

7 de setembro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.2, androidx.wear.compose:compose-material:1.0.2 e androidx.wear.compose:compose-navigation:1.0.2. A versão 1.0.2 contém estas confirmações.

Correções de bugs

  • Corrigimos a ordem z da posição e os indicadores de página no Scaffold. Como os indicadores ficam na parte de cima, eles não ficam ocultos por uma possível vinheta (Ib988f, b/244207528).

Versão 1.0.1

24 de agosto de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.1, androidx.wear.compose:compose-material:1.0.1 e androidx.wear.compose:compose-navigation:1.0.1. A versão 1.0.1 contém estas confirmações.

Correções de bugs

  • Foi corrigido um bug de lógica na função ScalingLazyColumn que podia resultar em listas com um número pequeno de itens (geralmente 2) incapazes de concluir a inicialização e que ficavam transparentes (076c61).

Versão 1.0.0

27 de julho de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0, androidx.wear.compose:compose-material:1.0.0 e androidx.wear.compose:compose-navigation:1.0.0. A versão 1.0.0 contém estas confirmações.

Principais recursos da versão 1.0.0

  • Esta é a primeira versão estável do Compose para Wear OS. Saiba mais.
  • O Compose para Wear OS tem como base as principais bibliotecas do Compose, fornecendo outros componentes específicos e, quando adequado, implementações alternativas de componentes essenciais personalizados para wearables.
  • Para ver uma lista dos principais componentes do Wear Compose, consulte as notas da versão do Compose para Wear OS Beta01.

Correções de bugs

  • Animamos a visibilidade da vinheta ao mostrar/ocultar a caixa de diálogo para que ela seja consistente com a animação de ampliação atual (Ida33e).
  • Corrigimos um bug em que uma divisão por zero podia ocorrer com alguns comportamentos de deslizar rapidamente durante a rolagem (I86cb6).
  • Correção de um bug em ChipDefaults.childChipColor() para garantir que a cor de plano de fundo desativada seja totalmente transparente (I2b3c3, b/238057342).

Versão 1.0.0-rc02

22 de junho de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-rc02, androidx.wear.compose:compose-material:1.0.0-rc02 e androidx.wear.compose:compose-navigation:1.0.0-rc02. A versão 1.0.0-rc02 contém estas confirmações.

Correções de bugs

  • Corrigimos a direção do gradiente para cards no modo da direita para a esquerda (RTL, na sigla em inglês). Ela era do canto superior esquerdo até o canto inferior direito, e agora está no canto superior direito e no canto inferior esquerdo. (Ic2e77).
  • Atualizamos os gradientes padrão de Chip/ToggleChip/Card para alinhamento com a especificação de UX mais recente. ChipDefaults.gradientBackgroundChipColors foi atualizado para começar em 50% do principal em vez de 32,5%. CardDefaults.cardBackgroundPainter foi atualizado para começar em 30% do principal e terminar em 20% de onSurfaceVariant (anteriormente a variação de término era de 20% a 10% de onSurfaceVariant). ToggleChip.toggleChipColors, que antes era um gradiente linear que variava de 75% a 32,5% da superfície do principal, agora varia entre 0% e 50% (I43bbd).
  • Adicionamos uma cor de plano de fundo (MaterialTheme.color.surface) atrás dos Chip/ToggleChips que têm planos de fundo gradientes. Isso garante que eles fiquem visíveis corretamente no caso improvável de uma cor clara ser usada atrás deles (Ibe1a4, b/235937657).
  • Atualizamos as regras de perfil de referência empacotadas com a biblioteca Wear Compose (I9c694).

Versão 1.0.0-rc01

15 de junho de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-rc01, androidx.wear.compose:compose-material:1.0.0-rc01 e androidx.wear.compose:compose-navigation:1.0.0-rc01. A versão 1.0.0-rc01 contém estas confirmações.

Mudanças na API

  • As interfaces em bibliotecas do Compose agora são criadas usando métodos de interface padrão do jdk8 (I5bcf1).

Correções de bugs

  • Removemos a chamada explícita para fillMaxWidth() no cabeçalho da lista, já que ela não é necessária e pode resultar em problemas se uma ScalinglazyColumn tiver uma combinação de componentes ListHeader() e Chip(), porque a largura tende a aumentar/reduzir à medida que os itens ListHeader são rolados para dentro/fora da área de visualização (I37144, b/235074035)
  • Corrigimos um bug na ScalingLazyColumn que podia fazer com que os itens da lista não fossem exibidos corretamente até que fossem rolados caso o item zero da lista fosse grande demais (considerando a área de padding) (Ic6159, b/234328517).
  • Fizemos um pequeno ajuste no easing da ScalingLazyColumn quando os itens alcançam a borda da tela para atender às atualizações de especificações de UX. Valores antigos: CubicBezierEasing(0.25f, 0.00f, 0.75f, 1.00f). Novos valores: CubicBezierEasing(0.3f, 0f, 0.7f, 1f). Para manter o comportamento antigo, é possível substituir os scalingParams da ScalingLazyColumn (Ie375c).
  • Adicionamos padding ao CompactChip para garantir que o tamanho da área de toque tenha pelo menos 48 dp de altura a fim de atender às diretrizes de acessibilidade do Material Design. Isso pode afetar os layouts que usam CompactChips, porque eles ocupam mais espaço (I3d57c).

Versão 1.0.0-beta03

1º de junho de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-beta03, androidx.wear.compose:compose-material:1.0.0-beta03 e androidx.wear.compose:compose-navigation:1.0.0-beta03. A versão 1.0.0-beta03 contém estas confirmações.

Novos recursos

  • Agora, a ScalingLazyColumn funciona no modo @Preview do Compose (I3b3b6, b/232947354).

Mudanças na API

  • Mudamos o valor padrão da propriedade ScalingLazyColumn.horizontalAlignment de "Start" para CenterHorizontally. O objetivo é garantir que, quando os itens da lista não preencherem a largura inteira da coluna, eles ficarão alinhados e terão o máximo de visibilidade. Para voltar a usar o comportamento anterior, defina horizontalAlignment = Alignment.Start (I9ed4b).

Problemas conhecidos

  • A altura de toque do CompactChip é inferior às diretrizes de acessibilidade do Material Design. Isso será corrigido na próxima versão (lançada em 15 de junho). Se você usa o CompactChip, isso afeta seus layouts, porque esse elemento inclui mais padding nas partes de cima e de baixo. Ajuste e teste seus layouts ou consulte os comentários sobre o bug para encontrar uma solução alternativa (b/234332135).

Correções de bugs

  • Nova demonstração para animar a adição ou remoção de um texto inicial em um TimeText (I16d75).
  • Foram adicionados testes a HorizontalPageIndicator.PagesState (I64ed0).
  • Atualização de TimeText, deixando-o mais próximo das especificações de UX (Ib7ea1).

Versão 1.0.0-beta02

18 de maio de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-beta02, androidx.wear.compose:compose-material:1.0.0-beta02 e androidx.wear.compose:compose-navigation:1.0.0-beta02. A versão 1.0.0-beta02 contém estas confirmações.

Novos recursos

  • Agora, o seletor sempre responde a eventos de rolagem, mesmo no modo somente leitura. Isso evita que os usuários precisem escolher um seletor antes de rolar a página. No modo somente leitura, as opções diferentes das selecionadas no momento são ocultadas por um paliativo em gradientColor (I72925).
  • Mudamos o comportamento da UX de Chip/ToggleChip/CompactChip/SplitToggleChip para impedir que fillMaxWidth aconteça por padrão. Em vez disso, ele se ajusta ao conteúdo. Para manter o comportamento anterior, basta adicionar modifier = Modifier.fillMaxWidth() (I60a2c, b/232206371).

Correções de bugs

  • O construtor CurvedTextStyle que usa um TextStyle agora também respeita o fontWeight. Isso pode ser adicionado aos métodos de construção e de cópia em futuras revisões da API (Ieebb9).
  • O recurso "deslizar da borda" foi melhorado. Quando o Modifier.edgeSwipeToDismiss é usado e um gesto de deslizar para a esquerda é acionado da área da borda, ele não aciona mais o recurso "deslizar para dispensar" quando a direção do gesto muda para a direita. Antes, era possível acionar o "deslizar para dispensar" deslizando para a esquerda e, em seguida, para a direita (I916ea).
  • Agora, o HorizontalPageIndicator mostra até seis páginas na tela. Se houver mais de seis páginas no total, ele vai mostrar um indicador com metade do próprio tamanho à esquerda ou à direita, com uma transição suave entre as páginas (I2ac29).
  • O comportamento de ajuste padrão foi melhorado em ScalingLazyColumn e Picker (I49539).
  • O recurso "deslizar da borda" foi melhorado. Quando o Modifier.edgeSwipeToDismiss é usado, o recurso "deslizar para dispensar" só é acionado quando o primeiro toque acontece na borda e é movido para a direita. Antes, era possível acionar o "deslizar para dispensar" deslizando de qualquer parte da tela quando a rolagem chegava ao início (I8ca2a).

Versão 1.0.0-beta01

11 de maio de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-beta01, androidx.wear.compose:compose-material:1.0.0-beta01 e androidx.wear.compose:compose-navigation:1.0.0-beta01. A versão 1.0.0-beta01 contém estas confirmações.

Novidades no Compose para Wear OS 1.0

A versão 1.0.0-beta01 do Compose para Wear OS é um marco importante porque a biblioteca tem todos os recursos e a API está bloqueada.

Os componentes do Compose Material para Wear na versão 1.0 incluem:

  • Material Theme: usado para substituir o MaterialTheme do Compose para dispositivos móveis. Fornece cores, formas e tipografia para a criação de componentes em wearables que implementam as diretrizes de UX do Material Design por padrão.
  • Button, CompactButton e ToggleButton: botões que oferecem um único slot para usar ícones, imagens ou textos curtos de no máximo três caracteres. De formato circular e em tamanhos recomendados para botões padrão, grandes ou pequenos. CompactButton oferece um único slot para usar qualquer conteúdo (ícone, imagem ou texto) e tem formato circular e com plano de fundo muito pequeno. CompactButton tem um preenchimento transparente opcional ao redor do plano de fundo que aumenta a área clicável. ToggleButton é um botão que oferece um único slot para qualquer conteúdo (texto curto, ícone ou imagem) e tem estados ativado/desativado (marcado/desmarcado) com cores e ícones diferentes para mostrar se está selecionado ou não.
  • Cards: usados para mostrar informações sobre apps, por exemplo, notificações. Design flexível para diferentes casos de uso com AppCard e TitleCard, oferecendo diferentes layouts e suporte para imagens como conteúdo ou plano de fundo do cartão.
  • Chips: componentes em forma de estádio semelhantes a botões, mas com uma área maior e vários slots para rótulos primários e secundários e ícones. Têm tamanhos diferentes e suporte para imagens como planos de fundo.
  • ToggleChips e SplitToggleChips: um ícone com um estado marcado/desmarcado e um slot ToggleControl adicionado para mostrar um ícone, como uma chave ou um botão de opção que exibe o estado marcado do componente. Além disso, o SplitToggleChip tem duas áreas tocáveis, uma clicável e uma alternável.
  • CircularProgressIndicator: indicador de progresso do Wear Material com duas variações. A primeira expressa a proporção de conclusão de uma tarefa em andamento e oferece suporte para uma lacuna na faixa circular entre os ângulos de início e fim. A segunda indica o progresso indeterminado de um tempo de espera não especificado.
  • curvedText: faz parte da DSL para descrever CurvedLayouts, junto com curvedRow e curvedColumn, e mostrar componentes em torno de dispositivos circulares. Confira a Wear Component Foundation abaixo para saber mais detalhes sobre CurvedLayout e CurvedModifier. Ela desempenha um papel semelhante aos modificadores para cenários não curvos e permite a configuração de vários aspectos de layout, padding, gradientes, entre outros.
  • Caixa de diálogo, alerta e confirmação: a caixa de diálogo aparece em tela cheia, sobreposta a qualquer outro conteúdo e oferece suporte ao recurso de deslizar para dispensar. É necessário um único slot que precisa ser um conteúdo específico de caixa de diálogo do Wear Material, como alerta ou confirmação. O alerta é um conteúdo específico de caixa de diálogo com espaços para ícone, título e mensagem. Ele tem sobrecargas para dois botões para aceitar ou recusar, mostrados lado a lado ou um slot para um ou mais chips empilhados verticalmente. A confirmação é um conteúdo específico de caixa de diálogo que mostra uma mensagem por uma determinada duração. Ela tem um espaço para um ícone ou uma imagem, que pode ser animada.
  • HorizontalPageIndicator: mostra a posição horizontal da página de forma adequada ao formato do wearable. Desenvolvido para usar a tela cheia e mostrar um indicador curvo em dispositivos redondos. Pode ser usado com o visualizador de páginas Accompanist.
  • Icon: uma implementação do Wear de "Icon" que usa cores e alfa do Wear Material Theme. Para ver um ícone clicável, consulte "Button" ou "Chip".
  • Picker: mostra uma lista rolável de itens para escolher. Por padrão, os itens são repetidos "infinitamente" nas duas direções. Pode aparecer no modo somente leitura para ocultar opções não selecionadas.
  • PositionIndicator: mostra a posição de rolagem ou outra indicação de posição de maneira adequada ao formato do wearable. Desenvolvido para usar a tela cheia e mostrar um indicador curvo em dispositivos redondos.
  • Scaffold: implementa a estrutura visual básica do layout do Material Design para Wear. Esse componente fornece uma API para reunir vários componentes do Wear Material, como TimeText, PositionIndicator e Vignette, que criam a tela, garantindo a estratégia de layout adequada e coletando os dados necessários para que eles funcionem juntos corretamente.
  • ScalingLazyColumn: um componente de lista de rolagem/olho de peixe que forma uma parte importante da linguagem do Material Design para Wear. Fornece efeitos de escalonamento e transparência aos itens de conteúdo. O componente ScalingLazyColumn foi projetado para processar um grande número de itens de conteúdo, que só são materializados e compostos quando necessário.
  • Slider: permite que os usuários escolham um valor em um intervalo. O intervalo é mostrado como uma barra, que pode ser exibida com separadores.
  • Stepper: um componente de tela cheia que permite aos usuários selecionar um intervalo de valores, usando os botões de aumentar/diminuir nas partes de cima e de baixo da tela, com um slot no meio para "Text" ou "Chip".
  • SwipeToDismissBox: processa o gesto de deslizar para dispensar. Ele usa um único slot para o plano de fundo, que aparece somente durante o gesto de deslizar, e o primeiro plano. Como opção, ele pode ser combinado com a biblioteca de navegação do AndroidX usando SwipeDismissableNavHost. Consulte a biblioteca Wear Compose Navigation abaixo.
  • Text: uma implementação do Wear do componente Compose Material Text, que usa cores e alfa do Wear Material Theme.
  • TimeText: um componente para mostrar o horário e o status do aplicativo na parte de cima da tela. Ajusta o formato da tela usando o texto curvado em telas redondas.
  • Vignette: um tratamento de tela para uso no Scaffold que desfoca as partes de cima e de baixo da tela quando o conteúdo rolável está em uso.

  • Os componentes abaixo também são incluídos na Wear Compose Foundation:

  • CurvedLayout: o CurvedLayout do Wear Foundation é um elemento combinável de layout que posiciona os filhos em um arco, girando-os conforme necessário. Isso é semelhante a um layout de linha curvado em um segmento de uma coroa circular. O conteúdo de um CurvedLayout não é uma lambda de composição, mas é uma linguagem específica do domínio (DSL, na sigla em inglês). Todos os elementos na DSL do CurvedLayout oferecem suporte a um parâmetro modificador opcional, criado de CurvedModifier.

  • basicCurvedText: um elemento da DSL do CurvedLayout, basicCurvedText permite que os desenvolvedores escrevam facilmente texto curvado seguindo a curvatura de um círculo, geralmente na borda de uma tela circular. O basicCurvedText só pode ser criado no CurvedLayout para garantir a melhor experiência, como a capacidade de especificar o posicionamento e usar CurvedModifiers. Na maioria dos casos, curvedText deve ser escolhido, já que usa temas do Material Design.

  • curvedComposable: envolve o conteúdo de composição normal para que possa ser usado com CurvedLayout. Se curvedComposable tiver vários elementos, eles vão ser mostrados uns sobre os outros, como uma caixa. Para colocar vários elementos combináveis em uma curva, envolva cada um com curvedComposable.

  • curvedRow e curvedColumn: semelhantes a Row e Column, curvedRow e curvedColumn podem ser aninhados em um CurvedLayout para dispor os elementos conforme necessário. Para um elemento curvedRow, a direção do layout angular e o alinhamento radial podem ser especificados. Para um elemento curvedColumn, o alinhamento angular e a direção radial podem ser especificados.

  • CurvedModifier: todos os componentes curvos aceitam um parâmetro modificador que pode ser criado usando CurvedModifier. Há suporte para planos de fundo, tamanho, peso e padding.

  • O componente abaixo também está incluído no Wear Compose Navigation.

  • SwipeDismissableNavHost: oferece um lugar na hierarquia do Compose para que a navegação independente ocorra, com a navegação para trás fornecida por um gesto de deslizar. O conteúdo aparece em uma SwipeToDismissBox, mostrando o nível de navegação atual. Durante um gesto de deslizar para dispensar, o nível de navegação anterior, se houver, aparece em segundo plano.

  • Consulte as notas das versões anteriores para ver mais detalhes sobre o que foi lançado.

Mudanças na API

  • Foram adicionadas funções CurvedModifier.padding*. Elas são usadas para especificar mais espaço a ser adicionado ao redor de um componente curvo (I4dbb4).
  • A classe interna CompositionLocal foi removida (I42490).
  • Adicionamos valores constantes para os tamanhos dos ícones Button, CompactButton e ToggleButton, conforme orientação (I57cab).
  • O parâmetro ativado foi adicionado a AppCard e TitleCard. Agora eles têm uma API semelhante a Cards do androidx.compose.material. Quando o parâmetro é definido como "false" (falso), o cartão não é clicável (Idc48d, b/228869805).

Correções de bugs

  • Agora, o Stepper desativa os botões de diminuir e aumentar quando os limites mínimo ou máximo são atingidos. Ele também aplica ContentAlpha.disabled ao iconColor (I4be9f).
  • Adicionamos padding de 1 dp ao conteúdo do Picker quando mostrado com um gradiente para evitar instabilidade no texto que aparece ao deslizar (I0b7b9).
  • Foram adicionados testes de captura de tela para PositionIndicator (I5e8bc).
  • Foram adicionados mais testes para AppCard e TitleCard (I85391, b/228869805).

Versão 1.0.0-alpha21

20 de abril de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha21, androidx.wear.compose:compose-material:1.0.0-alpha21 e androidx.wear.compose:compose-navigation:1.0.0-alpha21. A versão 1.0.0-alpha21 contém estas confirmações.

Novos recursos

  • Adicionados novos modificadores em curva para especificar o segundo plano de um elemento em curva: CurvedModifier.background, .radialGradientBackground e .angularGradientBackground (I8f392).
  • Permissão para que o modo flutuante de texto em curva (clip/reticências/visível) seja especificado (I8e7aa).
  • Adição do modificador CurvedModifier.weight, semelhante ao do Compose. Ele pode ser usado em filhos de curvadRow e CurvedLayout (para largura) e filhos de curvadColumn (para altura) (I8abbd).
  • Adição dos modificadores CurvedModifier.size, .angularSize e .radialSize para especificar o tamanho de um elemento em curva (I623c7).

Mudanças na API

  • Reordenação dos parâmetros para garantir que o segundo plano fique antes da cor de forma consistente em toda a API Wear Compose (I43208).
  • Remoção dos parâmetros insideOut e sentido horário e substituição por constantes mais expressivas em novas classes. A direção do layout em curva agora tem reconhecimento de LayoutDirection e é herdada quando não especificada (If0e6a).
  • Substituímos autoCenter: Boolean por autoCenter: AutoCentringParams para corrigir um problema de API no ScalingLazyColumn (Ia9c90).
  • Renomeamos iconTintColor e toggleControlTintColor como iconColor e toggleControlColor em toda a API (Chip/ToggleChip/Dialog/Slider/Stepper/...) quando a cor é aplicada ao slot icon/toggleControl (Ied238).
  • Reescreva o tipo enumerado PageIndicatorStyle na classe de valor (I2dc72).
  • Adicionamos RowScope/ColumnScope/BoxScope a alguns dos slots dos nossos Composables para indicar aos desenvolvedores quais são as suposições de layouts. Isso permite que os desenvolvedores usem outros modificadores em alguns conteúdos de slot e evita a necessidade de fornecer mais elementos de layout. Além disso, fizemos algumas pequenas atualizações nas cores do AppCard/TitleCard para que timeColor e appColor sejam padronizadas como contentColor. Essas propriedades ainda podem ser substituídas individualmente, se necessário (I26b59).
  • O objeto SwipeToDismissBoxState.Companion foi definido como privado (I39e84).
  • Correção da ordem dos parâmetros para InlineSlider e Stepper. Uma mudança simples para seguir as diretrizes da API (I11fec).
  • Removemos o objeto Saver para SwipeToDismissBoxState, porque ele não foi usado (Ifb54e).
  • Atualizamos CompactChip para alinhamento com a especificação de UX mais recente. O padding foi reduzido na horizontal = 12.dp e na vertical = 0.dp. A fonte do marcador foi alterada de botão para legenda 1. Os tamanhos recomendados de ícones são 20x20 quando o ícone e o rótulo estão presentes e 24x24 para um ícone compacto somente. Para o caso de uso de ícone somente, também garantimos que o ícone esteja alinhado no centro (Iea2be).
  • Adicionamos vários campos novos a ScalingLazyListLayoutInfo para permitir que os desenvolvedores saibam a quantidade de contentPadding e autoCenteringPadding que foi aplicada. Eles podem ser úteis para desenvolvedores ao calcular deslizamento/rolagem (I7577b).
  • Implementamos transições de entrada e saída na caixa de diálogo. Um parâmetro showDialog foi adicionado, e a caixa de diálogo agora controla a própria visibilidade. Isso permite que a caixa de diálogo execute as animações de introdução e conclusão quando estiver sendo mostrada/oculta. A animação "Outro" não é executada quando o usuário sai da caixa de diálogo pelo recurso de deslizar para dispensar. Também adicionamos um valor padrão para o estado na sobrecarga SwipeToDismissBox adicionada recentemente (I682a0).
  • Para oferecer melhor suporte à internacionalização e à acessibilidade, mudamos ToggleChip e SplitToggleChip para que não tenham mais um padrão para o slot toggleControl. Também mudamos ToggleChipDefaults para que os métodos a seguir retornem ImageVector em vez de Icon (como eles não retornam mais @Composables, foram modificados para começar com letra minúscula), SwitchIcon()->switchIcon(), CheckboxIcon->checkboxIcon() e RadioIcon()->radioIcon(). Isso permite e incentiva os desenvolvedores a criar os próprios Icon() combináveis com um conjunto contentDescription adequado (I5bb5b).
  • Adicionamos um parâmetro SwipeDismissableNavHostState a SwipeDismissableNavHost. Isso oferece suporte ao deslize de borda em telas usadas como destinos de navegação porque SwipeToDismissBoxState agora pode ser suspenso e usado para inicializar SwipeDismissableNavHostState e Modifier.edgeSwipeToDismiss em telas que exigem deslize de borda (I819f5, b/228336555).

Correções de bugs

  • Garanta que os layouts em curva sejam atualizados quando necessário (Ie8bfa, b/229079150).
  • Correção de bug para https://issuetracker.google.com/issues/226648931 (Ia0a0a, b/226648931).
  • Remoção de anotações experimentais desnecessárias (I88d7e).

Versão 1.0.0-alpha20

6 de abril de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha20, androidx.wear.compose:compose-material:1.0.0-alpha20 e androidx.wear.compose:compose-navigation:1.0.0-alpha20. A versão 1.0.0-alpha20 contém estas confirmações.

Novos recursos

  • Foi adicionado o modificador edgeSwipeToDismiss para SwipeToDismiss. Ele permite que swipeToDismiss fique ativo somente na borda esquerda da janela de visualização. Ele é usado quando o centro da tela precisa lidar com paginação horizontal, como rolar um mapa ou deslizar horizontalmente entre as páginas (I3fcec, b/200699800).

Mudanças na API

  • Implementação básica de CurvedModifiers. Isso abre uma forma de apresentar maneiras de personalização de conteúdo em curva. Porém, nenhum CurvedModifiers foi fornecido até agora, e a capacidade de criar modificadores personalizados pode estar disponível mais tarde (I9b8df).
  • A documentação do modificador EdgeSwipe e os valores padrão foram atualizados para melhor compreensão (I6d00d).
  • O slot PageIndicator foi adicionado ao Scaffold. Ao adicionar PageIndicator diretamente ao Scaffold, podemos garantir que ele vai ser mostrado corretamente em dispositivos circulares (Ia6042).
  • Removidos os ícones padrão dos parâmetros InlineSlider e Stepper. Isso ajuda os desenvolvedores a prestar mais atenção aos requisitos de localização e acessibilidade. Os usos de ícones padrão foram mostrados em demonstrações e exemplos (I7e6fd).
  • Os nomes dos parâmetros Trailing and Leading foram substituídos por Start e End em TimeText (Iaac32).
  • Adicionamos uma sobrecarga SwipeToDismissBox com um parâmetro onDismissed para oferecer suporte ao uso comum de acionar um evento de navegação quando o gesto de deslizar for concluído (I50353, b/226565726).
  • Removidas as anotações ExperimentalWearMaterialApi do uso de TimeText (Ide520).
  • Marcamos as interfaces de informações e o escopo ScalingLazyList/Column como selados, porque não se destinam a implementações de desenvolvedores externos. Isso permite que novos membros sejam adicionados no futuro, sem mudanças interruptivas binárias (I7d99f).
  • Adicionamos uma nova propriedade flingBehaviour ao seletor e um método PickerDefaults.flingBehaviour() para ativar a configuração do comportamento de rolagem, por exemplo, adicionar suporte a RSB. PickerState agora implementa a interface ScrollableState (Ib89c7).

Correções de bugs

  • Atualizadas as regras de perfil de valor de referência do Android Runtime (ART) para as bibliotecas do Wear Compose. O ART pode aproveitar as regras de perfil nos dispositivos para compilar um subconjunto específico do aplicativo com antecedência a fim de melhorar o desempenho dele. Isso não vai afetar aplicativos depuráveis (Iaa8ef).
  • Melhoria na documentação (I2c051).

Versão 1.0.0-alpha19

23 de março de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha19, androidx.wear.compose:compose-material:1.0.0-alpha19 e androidx.wear.compose:compose-navigation:1.0.0-alpha19. A versão 1.0.0-alpha19 contém estas confirmações.

Mudanças na API

  • Renomeação de CurvedRow para CurvedLayout e reformulação para ser um escopo com uma DSL. Com essa DSL, é possível especificar layouts curvos mais complexos, usando uma série de curvedRow e curvedColumn aninhadas, que são os equivalentes em layout curvo de Row e Column. Dentro desses elementos de layout, três elementos podem ser usados: curvedComposable, para adicionar qualquer @Composable; basicCurvedText, texto curvado da base; e curvedText, para usar texto curvado com reconhecimento do Material do Wear (Ib776a).
  • Lado do PositionIndicator tornou-se configurável. Agora, a posição básica de PositionIndicator pode ser configurada como End, que reconhece direção do layout; OppositeRsb, que considera a rotação da tela, para se posicionar em frente ao RSB físico; ou como as absolutas para a Left e Right (I2f1f3).
  • Para o SwipeToDismissBox, renomeamos o SwipeDismissTarget original para SwipeToDismissValue.Default e SwipeDismissTarget.Dismissal para SwipeToDismissValue.Dismissed. Também movemos SwipeToDismissBoxDefaults.BackgroundKey e SwipeToDismissBoxDefaults.ContentKey para SwipeToDismissKeys.Background, SwipeToDismissKeys.Content, respectivamente (I47a36).
  • Adicionamos um modo somente leitura ao Picker para telas com vários seletores em que apenas um seletor pode ser editado por vez. Quando o Seletor é somente leitura, ele mostra a opção selecionada e um rótulo, caso tenha sido fornecido (I879de).
  • O SwipeToDismissBoxState foi refatorado para restringir o escopo de ExperimentalWearMaterialApi a Modifier.swipeable e SwipeableState, que agora são usados internamente. SwipeToDismissBoxState agora tem currentValue, targetValue, isAnimationRunning e snapTo para oferecer suporte a casos de uso comuns. Informe caso precise de mais propriedades. Também foi corrigido o comportamento de SwipeableState no caso em que o deslocamento de deslize está dentro de um erro de arredondamento de uma âncora (I58302).

Correções de bugs

  • O código foi corrigido e simplificado para detectar se o conteúdo de uma ScalingLazyColumn pode ser rolado. Isso é usado para decidir se uma barra de rolagem vai ser exibida ou não (I7bce0).
  • Foi corrigido um bug no indicador de posição quando usado com mais de um estado e a alternando entre eles (I320b5).
  • Atualizamos as fontes de tipografia/fontes de tema padrão do Compose para Wear OS, de acordo com nossas orientações mais recentes de UX. Observe que display1 (40.sp) e display2 (34.sp) são menores que os valores anteriores, e várias outras pequenas atualizações na altura e no espaçamento entre linhas foram feitas (Ie3077).
  • Adicionamos resistência a SwipeToDismissBox para que o movimento só aconteça ao deslizar para dispensar e não na direção oposta (Ifdfb9).
  • Mudamos alguns dos valores padrão de parâmetro para que as funções CircularProgressIndicator fiquem de acordo com a orientação de UX do Material Design para Wear. Para a versão com controle Spinner/Indeterminant, o tamanho (40 -> 24 dp), o parâmetro indicatorColor (primary -> onBackground), a transparência trackColor (30% -> 10%) e a largura do traço (4 -> 3 dp) foram atualizados. Para a versão Progress/Determinate, a transparência trackColor (30%-> 10%) foi atualizada (I659cc).
  • Atualizamos os parâmetros de dimensionamento padrão do ScalingLazyColumn de acordo com as especificações de UX do Material Design mais recentes. Visualmente, isso faz com que os itens da lista comecem a ser dimensionados para o centro dela, mas que sejam menos dimensionados na borda do que antes (Ica8f3).
  • Alguns ajustes em ScalingLazyColumnDefaults.snapFlingBehavior para melhorar o final da animação (If3260).

Versão 1.0.0-alpha18

9 de março de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha18, androidx.wear.compose:compose-material:1.0.0-alpha18 e androidx.wear.compose:compose-navigation:1.0.0-alpha18. A versão 1.0.0-alpha18 contém estas confirmações.

Mudanças na API

  • Várias melhorias no PositionIndicator: ShowResult foi renomeado como PositionIndicatorVisibility. Melhorias de desempenho para evitar cálculos quando não são necessários (Iaed9d).
  • Atualização da cor recomendada para o SplitToggleChip. Agora, o SplitToggleChip tem um plano de fundo de cor sólida quando selecionado ou desmarcado. A cor do ToggleControl é a principal indicação de que o componente foi verificado ou não. Adicionamos um novo elemento ToggleDefaults.splitToggleChipColors() para oferecer suporte ao novo esquema de cores. Também simplificamos os métodos toggleChipColors() removendo a splitBackgroundOverlayColor (I7e66e).
  • Adicionamos unadjustedSize ao elemento ScalingLazyListItemInfo, porque não é seguro calcular o tamanho original do item usando o tamanho escalonado e o fator de escalonamento, devido à precisão matemática do ponto flutuante (I54657, b/221079441).
  • HorizontalPageIndicator foi adicionado. Ele representa o número total de páginas e uma página selecionada. O indicador pode ser linear ou curvado, dependendo da forma do dispositivo. Ele também oferece suporte à personalização da forma do indicador, que define como cada indicador é representado visualmente (Iac898).
  • Atualizamos PickerState para que o numberOfOptions possa ser atualizado. Ele oferece suporte a casos de uso, como um DatePicker, em que o número de dias no mês muda dependendo do mês selecionado. O parâmetro construtor do PickerState mudou para o initialNumberOfOptions correspondente (Iad066).
  • O PositionIndicator fica oculto quando ele é uma barra de rolagem que não pode rolar (Id0a7f).
  • Para manter a consistência com o Scaffold, nosso componente da caixa de diálogo em tela cheia agora mostra um PositionIndicator e uma Vignette. Também estamos usando a ScalingLazyColumn em vez da Column, o que significa que o conteúdo da caixa de diálogo agora está no ScalingLazyListScope e geralmente precisa ser incluído pelo item { /* content */ }. A caixa de diálogo oferece suporte ao parâmetro verticalArrangement conforme necessário (Idea13).
  • Mudamos o nome da propriedade toggleIcon de ToggleChip e SplitToggleChip para toggleControl, a fim de seguir melhor o Material Design e ajudar os designers e desenvolvedores a navegar pela API (If5921, b/220129803).
  • Adicionamos uma nova entrada caption3 à Typology.Caption3 do Wear Material Theme, que é uma fonte pequena usada para textos mais longos, como textos jurídicos (I74b13, b/220128356).

Correções de bugs

  • A animação de ajuste para quando chega ao destino (Idb69d).
  • Mudanças no PositionIndicator são animadas agora (I94cb9).
  • Com base no feedback da IU/UX, mudamos a propriedade autoCentering da ScalingLazyColumn para que ela forneça apenas o espaço suficiente de forma que os itens com índice ScalingLazyListState.initialCenterItemIndex ou mais recentes possam ser totalmente rolados até o centro da janela de visualização. Isso permite que os desenvolvedores posicionem no centro da tela um ou dois itens, que não podem ser rolados, sobre o item inicialmente no centro. Isso significa que uma ScalingLazyColumn da autoCentering não vai conseguir rolar acima do initialCenterItemIndex/initialCenterItemScrollOffset (I22ee2).
  • Adicionamos uma demonstração para o seletor de data e corrigimos um bug no PickerState, em que a initialSelectedOption não era aplicada até o seletor ser exibido (Id0d7e).
  • Para reduzir o corte de itens maiores da ScalingLazyColumn em telas redondas, aumentamos o preenchimento de conteúdo horizontal padrão de 8 para 10 dp (I0d609).
  • Confira se o PositionIndicator é exibido ao rolar (Ied9a2).

Versão 1.0.0-alpha17

23 de fevereiro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha17, androidx.wear.compose:compose-material:1.0.0-alpha17 e androidx.wear.compose:compose-navigation:1.0.0-alpha17. A versão 1.0.0-alpha17 contém estas confirmações.

Novos recursos

  • Adicionamos suporte a ajuste, que pode ser usado com o ScalingLazyColumn. Defina flingBehavior = ScalingLazyColumnDefaults.flingWithSnapBehavior(state) para ativar o suporte ao ajuste (I068d3, b/217377069).
  • Adicionamos demonstrações do seletor usado para selecionar um horário no relógio de 24 horas ou 12 horas (Ie5552).

Mudanças na API

  • Um problema com fontes e estilos personalizados do TimeText em dispositivos quadrados foi corrigido (Iea76e).
  • ScalingLazyListLayoutInfo agora tem reverseLayout, viewportSize e propriedades de orientação correspondentes àquelas de LazyListLayoutInfo (I4f258, b/217917020).
  • ScalingLazyColumn agora tem uma propriedade userScrollEnabled correspondente àquela da LazyList (I164d0, b/217912513).
  • Os seletores agora têm um gradiente na parte de cima e de baixo por padrão (Iab92a).

Correções de bugs

  • Modificamos ScalingLazyColumn para que não preencha mais todo o espaço no pai. Em vez disso, ela vai ficar com o tamanho do conteúdo. Isso a torna consistente com o comportamento da LazyColumn. Se você quiser restabelecer o comportamento antigo, transmita Modifier.fillMaxWidth()/width()/widthIn() para o ScalingLazyColumn (I51bf8).
  • Melhoramos a mensagem de exceção em SwipeDismissableNavHost.kt que era acionada se a backstack de navegação estivesse vazia (I1b1dc).

Versão 1.0.0-alpha16

9 de fevereiro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha16, androidx.wear.compose:compose-material:1.0.0-alpha16 e androidx.wear.compose:compose-navigation:1.0.0-alpha16. A versão 1.0.0-alpha16 contém estas confirmações.

Novos recursos

  • O CircularProgressIndicator foi adicionado. Os indicadores de progresso exibem a duração de um processo ou um tempo de espera não especificado. Eles oferecem suporte para uma lacuna (corte) para TimeText ou outros componentes, se usados em tela cheia (Iab8da).

Mudanças na API

  • Os seletores agora têm um parâmetro flingBehavior. O valor padrão os ajusta à opção mais próxima ao rolar ou deslizar (I09000).
  • Uma API de números inteiros foi acrescentada a InlineSlider e Stepper (I1b5d6).

Correções de bugs

  • O initialCenterItemIndex padrão foi alterado de ScalingLazyListState de 0 para maior que 1. Isso significa que, a menos que ele seja modificado na construção do estado para ScalingLazyListState.rememberScalingLazyListState(initialCenterItemIndex =), o segundo item da lista (índice = 1) vai ser colocado no centro da janela de visualização na inicialização, e o primeiro (índice = 0) vai ser colocado antes dele. Isso permite um melhor efeito visual padrão, já que a maior parte da janela de visualização será preenchida com itens de lista (I0c623, b/217344252).
  • Reduzimos de 10% para 5% o extraPadding padrão de ScalingLazyColumn, que é fornecido para garantir que haja vários itens de lista a serem mostrados, mesmo quando o tamanho de alguns deles é reduzido. Isso evita escrever itens adicionais na lista que podem não aparecer na janela de visualização. Se a função scalingParams não padrão estiver sendo usada (escalonamento mais extremo, por exemplo), o desenvolvedor vai poder ajustar o padding extra usando viewportVerticalOffsetResolver (I76be4).
  • Correção de um problema com TimeText em várias linhas no dispositivo quadrado (Ibd3fb).
  • Modificamos ScalingLazyColumn para que não preencha mais todo o espaço no pai. Em vez disso, ela vai ficar com o tamanho do conteúdo. Isso a torna consistente com o comportamento de LazyColumn. Se você quiser restabelecer o comportamento antigo, transmita Modifier.fillMaxSize() para ScalingLazyColumn. OBSERVAÇÃO: essa mudança está incompleta e vai ser resolvida em uma etapa posterior na próxima versão Alfa (I3cbfa).

Versão 1.0.0-alpha15

26 de janeiro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha15, androidx.wear.compose:compose-material:1.0.0-alpha15 e androidx.wear.compose:compose-navigation:1.0.0-alpha15. A versão 1.0.0-alpha15 contém estas confirmações.

Mudanças na API

  • Adicionamos uma nova propriedade autoCentering ao componente ScalingLazyColumn. Quando definida como verdadeira (o padrão), isso garante que todos os itens, incluindo o primeiro e o último, possam ser rolados de modo que fiquem visíveis no centro da janela de visualização das listas. Se você usa a centralização automática, é recomendável definir o padding de conteúdo vertical como 0.dp. Se a propriedade autoCentering e o padding de conteúdo vertical forem fornecidos, eles vão fazer com que mais espaço fique disponível antes do primeiro e depois do último item da lista, permitindo que eles sejam rolados ainda mais (I2a282, b/214922490).
  • Adicionamos um componente Dialog, que permite que qualquer elemento combinável acione uma caixa de diálogo em tela cheia sobre outro conteúdo. Quando a caixa é mostrada, é possível deslizar para dispensar e mostrar o conteúdo do pai dela em segundo plano durante o gesto de deslizar. É esperado que o conteúdo da caixa seja Alert ou Confirmation (renomeados dos componentes anteriores AlertDialog e ConfirmationDialog). Alert, Confirmation e Dialog estão todos no pacote androidx.wear.compose.material.dialog. Os alertas e a confirmação podem ser usados como destinos de navegação. Também há a adição de ColumnScope aos parâmetros Alert e Confirmation conforme necessário (Ia9014).
  • Removemos onSurfaceVariant2 do Compose para as cores de tema do Material do WearOS e substituímos os usos na biblioteca por onSurfaceVariant (Icd592).
  • Adição de um método para selecionar programaticamente uma opção no PickerState. A opção selecionada inicialmente agora também pode ser especificada ao criar um PickerState (I92bdf).
  • Adicionamos suporte à personalização do comportamento de deslizar rapidamente do componente ScalingLazyColumn (I1ad2e, b/208842968).
  • Adicionamos NavController.currentBackStackEntryAsState() à biblioteca Wear.Compose.Navigation (If9028, b/212739653).
  • Modifier.onRotaryScrollEvent() e Modifier.onPreRotaryScrollEvent() foram adicionados para dispositivos Wear com um botão lateral giratório (I18bf5, b/210748686).

Versão 1.0.0-alpha14

12 de janeiro de 2022

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha14, androidx.wear.compose:compose-material:1.0.0-alpha14 e androidx.wear.compose:compose-navigation:1.0.0-alpha14. A versão 1.0.0-alpha14 contém estas confirmações.

Novos recursos

  • Adicionamos vários métodos a ScalingLazyListState para permitir que o desenvolvedor controle a rolagem para itens específicos da lista, além de definir o deslocamento e o item inicial dela.

    Como parte dessa mudança, também modificamos o ScalingLazyList para que ele fique orientado próximo ao centro da janela de visualização do ScalingLazyList em vez de estar no início da janela de visualização.

    Uma nova propriedade anchorType: ScalingLazyListAnchorType = ScalingLazyListAnchorType.ItemCenter foi adicionada a ScalingLazyList para controlar se o centro (ScalingLazyListAnchorType.ItemCenter) ou a Edge (ScalingLazyListAnchorType.ItemStart) precisam estar alinhados à linha central da janela de visualização.

    Como resultado, ScalingLazyListItemInfo.offset e ScalingLazyListItemInfo.adjustedOffset mudaram e agora refletem o deslocamento do item em relação à posição dele e ao anchorType da lista. Por exemplo, para uma ScalingLazyColumn com um anchorType do ItemCenter e um item de lista posicionado no meio na linha central da janela de visualização, o deslocamento seria 0.

    Os novos métodos são scrollTo, animatedScrollTo, centerItemIndex e centerItemOffset (I61b61).

  • Adicionamos um gerenciador de botão "Voltar" ao SwipeDismissableNavHost para que, ao pressionar "Voltar", você navegue até o nível anterior na hierarquia de navegação (I5b086, b/210205624).

Versão 1.0.0-alpha13

15 de dezembro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha13, androidx.wear.compose:compose-material:1.0.0-alpha13 e androidx.wear.compose:compose-navigation:1.0.0-alpha13. A versão 1.0.0-alpha13 contém estas confirmações.

Mudanças na API

  • Tornamos o RangeIcons interno, referenciado internamente por InlineSlider e Stepper (I927ec).

Correções de bugs

  • Foi corrigido um problema em que o SwipeDismissableNavHost adicionava um destino à hierarquia do Compose antes de alcançar o estado de ciclo de vida CREATED (criado), resultando em uma IllegalStateException. Essa correção era um pré-requisito para atualizar a dependência de navigation-compose para 2.4.0-beta02 e muito mais (I40a2b, b/207328687).

  • Foi adicionada uma classe de tipo enumerado Drawables para receber recursos drawable dentro da biblioteca do Wear Compose. Assim, a reflexão não vai mais ser necessária. Isso corrige um bug em que os drawables de biblioteca eram removidos quando minifyEnabled=true ou shrinkResources=true (Ib2a98).

  • Foram adicionados testes para Stepper no Wear Compose (I2d03a).

  • Adição de amostras para SwipeDismissableNavHost na navegação do Wear Compose (I85f06).

Versão 1.0.0-alpha12

1º de dezembro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha12, androidx.wear.compose:compose-material:1.0.0-alpha12 e androidx.wear.compose:compose-navigation:1.0.0-alpha12. A versão 1.0.0-alpha12 contém estas confirmações.

Novos recursos

  • Adicionamos o componente Stepper, que permite aos usuários fazer uma seleção com base em um intervalo de valores. O Stepper é um controle de tela cheia com botões de aumentar e diminuir na parte de cima e de baixo e um slot no meio para receber ícones ou texto. Os ícones do botão podem ser personalizados, se necessário (I625fe).

  • Adicionamos dois novos elementos combináveis para mostrar caixas de diálogo: AlertDialog aguarda uma resposta do usuário e mostra um título, um ícone, uma mensagem e a) dois botões para opções simples de confirmação/recusa ou b) ícones empilhados verticalmente ou botões de alternância para opções mais flexíveis. O componente ConfirmationDialog mostra uma confirmação com um tempo limite. Essa caixa de diálogo simples tem slots para um título e um ícone (animado) (Ic2cf8).

Mudanças na API

  • Unidades (milissegundos) foram adicionadas aos valores sugeridos de duração da caixa de diálogo (I09b48).

Versão 1.0.0-alpha11

17 de novembro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha11, androidx.wear.compose:compose-material:1.0.0-alpha11 e androidx.wear.compose:compose-navigation:1.0.0-alpha11. A versão 1.0.0-alpha11 contém estas confirmações.

Novos recursos

  • Adicionamos um componente seletor que permite que o usuário selecione um item em uma lista de rolagem. Por padrão, a lista de itens selecionáveis é repetida "infinitamente" nas duas direções, para dar a impressão de um cilindro giratório visto da lateral. Dois recursos serão adicionados em versões futuras: o ajuste a um valor depois de deslizar e a adição de uma função ao PickerState para definir/rolar até o valor atual (I6461b).

Mudanças na API

  • Foi adicionado um ScalingLazyItemScope e alguns novos modificadores fillParentMaxSize/fillParentMaxWidth/fillParentMaxHeight para permitir que os itens da lista sejam dimensionados com base no tamanho do contêiner pai. Os itens podem ser definidos para preencher total ou parcialmente o tamanho do arquivo pai. Isso expõe a funcionalidade já disponível na LazyRow/Column (I4612f).
  • Adição de suporte à ScalingLazyColumn para permitir que os itens tenham uma chave. Também foram adicionados métodos de conveniência para permitir a adição de itens de matrizes e listas (Ic1f89).

Correções de bugs

  • Mais exemplos de TimeText (I8cb64).

Versão 1.0.0-alpha10

3 de novembro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha10, androidx.wear.compose:compose-material:1.0.0-alpha10 e androidx.wear.compose:compose-navigation:1.0.0-alpha10. A versão 1.0.0-alpha10 contém estas confirmações.

Novos recursos

  • Um InlineSlider foi adicionado para o Wear Compose. O InlineSlider permite que os usuários escolham um valor em um intervalo. O intervalo é mostrado como uma barra entre os valores mínimo e máximo, em que os usuários podem selecionar um único valor (If0148).

  • Confira o novo codelab do Compose para WearOS.

Mudanças na API

  • A minSdkVersion da Macrobenchmark agora é 23 (If2655).

Correções de bugs

  • O processamento de transição em SwipeDismissableNavHost de SideEffect foi atualizado (I04994, b/202863359).
  • O processamento de transição em SwipeDismissableNavHost foi atualizado (I1cbe0, b/202863359).

Versão 1.0.0-alpha09

27 de outubro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha09, androidx.wear.compose:compose-material:1.0.0-alpha09 e androidx.wear.compose:compose-navigation:1.0.0-alpha09. A versão 1.0.0-alpha09 contém estas confirmações.

Novos recursos

  • Lançamos a Prévia para desenvolvedores do Compose no Wear OS. Confira nossa postagem do blog (link em inglês), que fornece informações sobre os principais elementos combináveis e links para começar a usar outros recursos.

Mudanças na API

  • Adicionamos suporte à personalização de todas as cores no tema de cores do Material Design para Wear (I4759b, b/199754668).

Correções de bugs

  • Foram adicionados exemplos SwipeToDismissBox que mantêm o estado (Ibaffe).
  • Foram adicionados links para os guias do KDocs em developer.android.com para CurvedText, TimeText e SwipeToDismissBox (I399d4).
  • Agora, o SwipeDismissableNavHost é gerado quando não há um destino atual, o que indica que o NavGraph não foi criado usando a função utilitária wear.compose.navigation.composable (I91403).
  • Foram adicionadas mais documentações e exemplos do uso da fonte de tempo em TimeText (I4f6f0).

Versão 1.0.0-alpha08

13 de outubro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha08, androidx.wear.compose:compose-material:1.0.0-alpha08 e androidx.wear.compose:compose-navigation:1.0.0-alpha08. A versão 1.0.0-alpha08 contém estas confirmações.

Mudanças na API

  • Renomeamos as propriedades body do AppCard e do TitleCard como content e as movemos para o final da lista de propriedades para que elas sejam fornecidas como uma lambda final. Além disso, bodyColor foi renomeado como contentColor para consistência com os novos nomes de slot (I57e78).

Correções de bugs

  • Foram adicionados links para os guias do KDocs em developer.android.com para componentes de botão, cartão, ícone, tema, indicador de posição e escalonamento lento de colunas (I22428).
  • Foi corrigido o SwipeToDismissBox do WearOS, que às vezes não processava ações de deslizar (I9387e).
  • Foram acrescentados exemplos para Button, CompactButton, Chip, CompactChip, AppCard, TitleCard, ToggleButton, ToggleChip, SplitToggleChip (Iddc15).
  • Novos testes de desempenho de microbenchmark para Card, Chip, ToggleChip, TimeText e ScalingLazyColumn (If2fe9).

Versão 1.0.0-alpha07

29 de setembro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha07, androidx.wear.compose:compose-material:1.0.0-alpha07 e androidx.wear.compose:compose-navigation:1.0.0-alpha07. A versão 1.0.0-alpha07 contém estas confirmações.

Novos recursos

  • Acréscimo de um componente CurvedText ao Material Design, que permite aos desenvolvedores escrever facilmente um texto curvado seguindo a curvatura de um círculo, geralmente na borda de uma tela circular (I19593).

Mudanças na API

  • Adicionados testes para TimeText (Idfead).
  • Transforme ArcPaddingValues em uma interface (Iecd4c).
  • Adicionada animação ao SwipeToDismissBox (I9ad1b).
  • Adicionado parâmetro hasBackground à API SwipeToDismissBox para que o gesto de deslizar possa ser desativado quando não houver conteúdo em segundo plano para exibir (I313d8).
  • O método rememberNavController() agora usa um conjunto opcional de instâncias Navigator que vão ser adicionadas ao NavController retornado para oferecer melhor suporte a navegadores opcionais, como os do Material de navegação do Accompanist (link em inglês) (I4619e).
  • Referência do NamedNavArgument do navegação-common e remoção da cópia de wear.compose.navigation (I43af6).

Correções de bugs

  • Correção da inconsistência do teste do CurvedRow em dispositivos menores (If7941).
  • Corrigida possível oscilação na CurvedRow quando o conteúdo é atualizado, garantindo que a linha curva seja medida novamente (Ie4e06).
  • ChipDefaults.gradientBackgroundChipColors() foi atualizado de acordo com as mudanças na especificação da UX. O gradiente agora começa com MaterialTheme.colors.primary com Alfa 32,5% e termina com MaterialTheme.colors.surface com Alfa @ 0% em um plano de fundo do MaterialTheme.colors.surface @ 75% Alfa (Id1548).
  • Atualizamos as cores dos ToggleChips para que, quando estiverem no estado selecionado, correspondam à orientação mais recente de UX do Material Design para Wear. Os ToggleChips selecionados agora têm um plano de fundo gradiente de MaterialTheme.color.surface @ 0% Alfa, na parte superior esquerda, a MaterialTheme.color.primary @ 32% Alfa, na parte inferior direita, sobre um plano de fundo de MaterialTheme.color.surface @ 75% Alfa. Isso resulta em uma diferença mais sutil entre as caixas marcadas e desmarcadas para o ToggleChip (Idd40b).

Versão 1.0.0-alpha06

15 de setembro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha06, androidx.wear.compose:compose-material:1.0.0-alpha06 e androidx.wear.compose:compose-navigation:1.0.0-alpha06. A versão 1.0.0-alpha06 contém estas confirmações.

Novos recursos

  • Adicionamos o Scaffold, um elemento combinável para aplicativos de nível superior que oferece uma estrutura para processar a posição de PositionIndicators (como rolagem ou volume), uma área na parte de cima da tela para mostrar o horário e o status do aplicativo, além de também ter suporte a uma vinheta que desfoca a parte de cima e de baixo da tela para conteúdo rolável. A área principal do Scaffold é onde o conteúdo do aplicativo é colocado (I5e0bf).
  • Adição da implementação TimeText para o Wear Compose (I5654c).

Biblioteca Wear Compose Navigation

  • Adicionamos a primeira versão da biblioteca Wear Compose Navigation, que oferece integração entre as bibliotecas Wear Compose e Androidx Navigation. Ela proporciona uma forma simples de navegar entre funções @Composable, como os destinos no seu aplicativo.

  • Esta versão inicial oferece:

    • um elemento combinável SwipeDismissableNavHost, que hospeda um gráfico de navegação e tem navegação para trás com gestos de deslizar;
    • a extensão NavGraphBuilder.composable para ajudar na criação de gráficos de navegação;
    • o rememberSwipeDismissableNavController() para permitir a elevação de estado.
  • Exemplo de uso em que criamos duas telas e navegamos entre elas:

    val navController = rememberSwipeDismissableNavController()
    SwipeDismissableNavHost(
        navController = navController,
        startDestination = "start"
    ) {
        composable("start") {
            Column(
                horizontalAlignment = Alignment.CenterHorizontally,
                verticalArrangement = Arrangement.Center,
                modifier = Modifier.fillMaxSize(),
            ) {
                Button(onClick = { navController.navigate("next") }) {
                    Text("Go")
                }
            }
        }
        composable("next") {
            Column(
                horizontalAlignment = Alignment.CenterHorizontally,
                verticalArrangement = Arrangement.Center,
                modifier = Modifier.fillMaxSize(),
            ) {
                Text("Swipe to go back")
            }
        }
    }
    
  • O Wear Compose Navigation é um pacote que inclui uma biblioteca separada para que os aplicativos WearCompose simples que implementam a própria navegação manual não precisem depender da biblioteca AndroidX Navigation.

Mudanças na API

  • O componente SwipeDismissableNavHost foi atualizado para oferecer suporte a rememberSaveable, definindo a identidade-chave para o plano de fundo e o conteúdo (I746fd).
  • Adição de um adaptador PositionIndicator que possa lidar com LazyListState (I21b88).
  • Atualizado o componente SwipeToDismissBox para oferecer suporte a rememberSaveable (Ie728b).
  • Adicionamos suporte a reverseLayout para o componente ScalingLazyColumn. Isso permite a inversão da direção de rolagem e do layout (I9e2fc).
  • A função performGesture e a classe GestureScope foram descontinuadas e substituídas por performTouchInput e TouchInjectionScope (Ia5f3f, b/190493367).
  • Renomeação de VignetteValue como VignettePosition e de VignetteValue.Both como VignettePosition.TopAndBottom (I57ad7).
  • ScalingLazyColumnState foi renomeado como ScalingLazyListState, ScalingLazyColumnItemInfo foi renomeado como ScalingLazyListItemInfo, ScalingLazyColumnLayoutInfo foi renomeado como ScalingLazyListLayoutInfo e ScalingLazyColumnScope foi renomeado como ScalingLazyListScope para o caso de decidirmos adicionar uma implementação de ScalingLazyRow no futuro (I22734).

Correções de bugs

  • Atualização da documentação do CompactChip para descrever o que acontece quando nenhum ícone ou etiqueta é fornecido (I4ba88).
  • Fizemos alguns ajustes nos componentes do card do Wear (I6b3d0).
    1. O espaçamento de TitleCard entre o título e o corpo foi reduzido de 8 dp para 2 dp.
    2. A fonte do cabeçalho TitleCard mudou de body para title3.
    3. O gradiente do plano de fundo do card foi modificado para parecer mais escuro.

Versão 1.0.0-alpha05

1º de setembro de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha05 e androidx.wear.compose:compose-material:1.0.0-alpha05. A versão 1.0.0-alpha05 contém estas confirmações.

Mudanças na API

  • O elemento ArcPaddingValues foi marcado como @Stable (I57deb).
  • A classe ScalingLazyColumnState agora implementa a interface ScrollableState, oferecendo aos desenvolvedores acesso programático para rolar o componente (I47dbc).

Correções de bugs

  • Reduzimos o espaçamento entre o ícone e o texto nos elementos Chip e ToggleChip para deixá-los alinhados com as atualizações da especificação da UX (I83802).

Versão 1.0.0-alpha04

18 de agosto de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha04 e androidx.wear.compose:compose-material:1.0.0-alpha04. A versão 1.0.0-alpha04 contém estas confirmações.

Novos recursos

  • Adicionada uma API SwipeToDismissBox e um modificador deslizante que podem ser usados para oferecer suporte a um gesto de deslizar da esquerda para a direita a fim de dispensar um elemento. Embora sejam independentes dos componentes de navegação, esses elementos podem ser usados para sair de uma tela e navegar para a outra. Foram adicionados testes de integração à demonstração de deslizar para dispensar (I7bbaa).
  • As interfaces ScalingLazyColumnItemInfo e ScalingLazyColumnLayoutInfo foram adicionadas à classe ScalingLazyColumnState para permitir que os desenvolvedores saibam as posições e os tamanhos reais dos itens em ScalingLazyColumn após a aplicação do escalonamento. Também corrigimos um bug na forma como o escalonamento era calculado ao aplicar o preenchimento de conteúdo da parte superior ao componente ScalingLazyColumn (I27c07).

Mudanças na API

  • A classe CurvedTextStyle foi adicionada para especificar opções de estilo de texto curvado. Ela é semelhante a TextStyle, mas agora só oferece suporte aos elementos color, fontSize e background. Mais opções de estilo serão adicionadas no futuro (I96ac3).
  • As interfaces ScalingLazyColumnItemInfo e ScalingLazyColumnLayoutInfo foram adicionadas à classe ScalingLazyColumnState para permitir que os desenvolvedores saibam as posições e os tamanhos reais dos itens em ScalingLazyColumn após a aplicação do escalonamento. Também corrigimos um bug na forma como o escalonamento era calculado ao aplicar o preenchimento de conteúdo da parte superior ao componente ScalingLazyColumn (I27c07).
  • A anotação @ExperimentalWearMaterialApi foi adicionada à enumeração SwipeDismissTarget, parte da API SwipeToDismissBox (I48b5e).

Correções de bugs

  • Adicionado material de teste para a API SwipeToDismissBox (I9febc).

Versão 1.0.0-alpha03

4 de agosto de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha03 e androidx.wear.compose:compose-material:1.0.0-alpha03. A versão 1.0.0-alpha03 contém estas confirmações.

Mudanças na API

  • Foi adicionado o componente CurvedText, que permite que os desenvolvedores escrevam texto seguindo a curvatura de um círculo, geralmente na borda de uma tela circular (Id1267).
  • Renomeamos CardDefaults.imageBackgroundPainter() como CardDefaults.imageWithScrimBackgroundPainter() para deixar claro que a imagem de plano de fundo tem um scrim desenhado sobre ela (I53206).
  • Foi adicionado o componente ScalingLazyColumn. Com ele, é acrescentado um componente de lista para o Wear Material que oferece uma visualização olho de peixe, com o conteúdo da lista diminuindo de tamanho e ficando transparente à medida que a imagem é escalonada em direção à borda do componente (I7070c).

Correções de bugs

  • Mudamos a cor padrão do conteúdo do appName no AppCard em resposta a uma atualização das especificações de UX. A cor padrão do appName agora é MaterialTheme.colors.onSurfaceVariant. Além disso, adicionamos uma descrição do documento de parâmetro para o espaço do título (Ic4ad1).

Versão 1.0.0-alpha02

21 de julho de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha02 e androidx.wear.compose:compose-material:1.0.0-alpha02. A versão 1.0.0-alpha02 contém estas confirmações.

Novos recursos

  • Uma nova classe, CurvedRow, foi adicionada para dispor elementos combináveis em um arco (I29941).
  • Um novo tipo de card, TitleCard, foi acrescentado para uso em apps, além de oferecer suporte para imagens, como o plano de fundo em cards para enfatizar o conteúdo deles (I53b0f).

Mudanças na API

  • Adicionado suporte de CurvedRow com o alinhamento radial, semelhante ao alinhamento vertical em uma linha (Id9de5).
  • Adicionada uma nova classe, CurvedRow, para dispor elementos de composição em um arco (I29941).
  • Um novo tipo de card, TitleCard, foi acrescentado para uso em apps, além de oferecer suporte para imagens, como o plano de fundo em cards para enfatizar o conteúdo deles (I53b0f).
  • Adicionados ícones de alternância (caixa de seleção, chave e botões de opção) a ToggleChipDefaults para facilitar a configuração de ToggleChip e SplitToggleChips para os desenvolvedores (I7b639).
  • O padding do conteúdo inicial e final do Chips foi atualizado, para ficar sempre em 14 dp, independente do Chip ter um ícone ou não. Anteriormente, eram 12.dp, se o ícone estivesse presente, e 14.dp, se não estivesse (I34c86).

Correções de bugs

  • Foram adicionados testes à CurvedRow (I93cdb).
  • As dependências do Wear Compose foram vinculadas ao Compose 1.0.0-rc01 (Ie6bc9).
  • O processamento da pintura de imagens de plano de fundo em Cards e Chips mudou para que a imagem fosse cortada, em vez de esticada, para manter as proporções de imagem (I29b41).
  • Mais demonstrações e testes de integração foram acrescentados ao Button e ao SwitchButton (5e27ed2).
  • Mais testes de Chip foram adicionados para cobrir as cores de conteúdo para imageBackgroundChips (Ia9183).

Versão 1.0.0-alpha01

1º de julho de 2021

Lançamento de androidx.wear.compose:compose-foundation:1.0.0-alpha01 e androidx.wear.compose:compose-material:1.0.0-alpha01. A versão 1.0.0-alpha01 contém estas confirmações.

Novos recursos

O Wear Compose é uma biblioteca baseada em Kotlin, compatível com Compose e com Wear Material Design, uma extensão do Material Design para wearables WearOS. Esta primeira versão alfa contém implementações práticas e funcionais do seguinte:

  • Tema do Material Design: configura as cores, tipografia e formas de forma consistente nos componentes usados nessa biblioteca.
  • Chip, CompactChip: os chips têm forma de estádio e as variantes estão disponíveis para o conteúdo de ícones, rótulos e rótulos secundários.
  • - ToggleChip, SplitToggleChip: um tipo especializado de chip que inclui um slot para um ícone de alternância de dois estados, como um botão de opção ou caixa de seleção. Além disso, o SplitToggleChip tem duas áreas tocáveis, uma clicável e uma alternável.
  • Botão, CompactButton: os botões são circulares em forma, com um único slot de conteúdo para um ícone ou texto mínimo (máximo de três caracteres).
  • ToggleButton: um botão que ativa ou desativa uma ação, com um único slot para ícone ou mínimo de texto (máximo de três caracteres).
  • Card, AppCard: em forma retangular com cantos arredondados, oferecendo espaços para conteúdo como ícone, horário, título e corpo do app.

As versões futuras vão ampliar o conjunto de widgets para adicionar suporte a seletores, controles deslizantes, listas, indicadores de páginas, caixas de diálogo, indicadores de rolagem, avisos e outros componentes do Material Design.

Além disso, vai ser oferecido o suporte a outros recursos específicos de wearable, como layouts e textos curvos, além de scaffolding, para facilitar a criação de apps/sobreposições de desenvolvedores.

O Wear Compose Material foi projetado com os mesmos princípios do Compose Material, embora seja direcionado para wearables. A biblioteca Wear Compose Material deve ser usada no lugar da biblioteca Compose Material para criar um dispositivo wearable.

As duas bibliotecas "Material" precisam ser consideradas mutuamente exclusivas e não podem ser misturadas no mesmo app. Se os desenvolvedores incluem a biblioteca Compose Material nas dependências, isso sugere a) que há componentes ausentes na biblioteca Compose Material (nesse caso, fale para a gente sobre o que você precisa) ou b) o uso de um componente não recomendado para um dispositivo wearable.