Novidades sobre produtos

O Material 3 Adaptive 1.2.0 está estável

Leitura de 2 minutos
Acessar o perfil de Rob Orgiu
Rob Orgiu Engenheira de relações com desenvolvedores

Temos uma novidade incrível: o Material 3 Adaptive 1.2.0 agora está na versão estável.

Esta versão continua a se basear nos fundamentos das versões anteriores, ampliando o suporte a mais pontos de interrupção para classes de tamanho de janela e novas estratégias para posicionar painéis de exibição automaticamente.

Novidades no Material 3 Adaptive 1.2.0

Esta versão estável é criada com base no suporte do WindowManager 1.5.0 para pontos de interrupção grandes e extragrandes e apresenta as novas estratégias de reflow e levitate para ListDetailPaneScaffold e SupportingPaneScaffold

Novas classes de tamanho de janela: grande e extragrande

newwindow.png


O WindowManager 1.5.0 introduziu dois novos pontos de interrupção para a classe de tamanho de janela de largura, oferecendo suporte a janelas ainda maiores do que a classe de tamanho de janela expandida. Para ativar os pontos de interrupção grande (L) e extra grande (XL), adicione o seguinte parâmetro à chamada currentWindowAdaptiveInfo() na sua base de código:

currentWindowAdaptiveInfo(supportLargeAndXLargeWidth = true)

Essa flag permite que a biblioteca também retorne pontos de interrupção L e XL sempre que necessário.

Novas estratégias adaptativas: reflow e levitate

Organizar conteúdo e painéis de exibição em uma janela é uma tarefa complexa que precisa levar em consideração muitos fatores, começando pelo tamanho da janela. Com a nova biblioteca adaptável do Material 3, duas novas tecnologias podem ajudar você a criar um layout adaptável com o mínimo de esforço.

Com o reflow, os painéis são reorganizados quando o tamanho da janela ou a proporção mudam, colocando um segundo painel ao lado do primeiro quando a janela é larga o suficiente ou reflow o segundo painel abaixo do primeiro sempre que a janela é mais alta. Essa técnica também se aplica quando a janela diminui: o conteúdo é reajustado para a parte de baixo.

material.jpg

Refluxo de um painel com base no tamanho da janela

Embora o reflow seja uma opção incrível em muitos casos, pode haver situações em que o conteúdo precise ser ancorado em um lado da janela ou levitado sobre ela. A estratégia de levitação não apenas acopla o conteúdo, mas também permite personalizar recursos como capacidade de arrastar e redimensionar, além da tela de fundo.


 

material2.jpg

Levitar um painel da lateral para o centro com base na proporção

As estratégias de fluxo e levitação podem ser declaradas no construtor Navigator usando o parâmetro adaptStrategies, e ambas podem ser aplicadas aos painéis de detalhes e listas e de suporte scaffolds:

val navigator = rememberListDetailPaneScaffoldNavigator<Nothing>(
        adaptStrategies = ListDetailPaneScaffoldDefaults.adaptStrategies(
            detailPaneAdaptStrategy = AdaptStrategy.Reflow(
                reflowUnder = ListDetailPaneScaffoldRole.List
            ),
            extraPaneAdaptStrategy = AdaptStrategy.Levitate(
                alignment = Alignment.Center
            )
        )
    )


 

Para saber mais sobre como aproveitar essas novas estratégias adaptáveis, consulte o site do Material e o exemplo de código completo no GitHub.

Escrito por:
Continuar lendo