UI Dinâmica

Aprenda como tornar UIs dinâmicas, respondendo a mudanças nos dados.

Você pode definir uma UI que inclui elementos dinâmicos, que são atualizados a cada tick. Você só precisa manipular a atualização da variável que representa esses dados, e a UI se adaptará em resposta aos novos valores.

Isso é muito útil para incluir elementos como um cronômetro, a pontuação de um jogador, etc. Mas você pode ir além e definir estruturas inteiras de UI com base no estado.

Variáveis de referência

Você pode simplesmente referenciar uma variável em qualquer propriedade de um dos componentes em um uiEntity. À medida que a variável muda de valor, a UI se adaptará consequentemente.

O exemplo abaixo define uma variável playerCurrentPosition e a referencia como parte de uma string em um uiText componente. Um system então atualiza o valor dessa variável a cada tick, usando a posição atual do jogador. À medida que o valor da variável muda, a UI é atualizada em conformidade, sem nunca precisar modificar a UI explicitamente.

arquivo ui.tsx:

import { UiEntity, ReactEcs } from '@dcl/sdk/react-ecs'
import { playerCurrentPosition } from '/index.ts'
import { Color4 } from '@dcl/sdk/math'

// desenhar UI
export const uiMenu = () => (
  <UiEntity
    uiTransform={{
			width: '100%',
			height: '100px',
			justifyContent: 'center',
			alignItems: 'center',
    }}
    uiText={{ value: `Player: `+  playerCurrentPosition, fontSize: 40 }}
    uiBackground={{ color: Color4.create(0.5, 0.8, 0.1, 0.6) }}
  />
)

arquivo index.ts:

No exemplo acima, você também poderia incluir a variável como parte da string, sinalizando a variável com um $.

Chamar funções de dentro de uma UI

Você também pode chamar uma função de dentro de uma definição JSX, retornando um valor para usar em uma propriedade da UI. Funções que são chamadas de dentro dessa definição JSX são chamadas recorrentemente, a cada tick do game loop.

No exemplo abaixo, um uiText componente chama a getPlayerPosition() função para definir parte da string a ser exibida.

Este exemplo é similar ao da seção anterior, mas ao chamar uma função de dentro da definição da UI evitamos declarar uma variável separada e definir um system para alterar essa variável. Note que getPlayerPosition() é chamado a cada tick do game loop, sem precisar declarar explicitamente um system.

arquivo ui.tsx:

arquivo index.ts:

Alternar uma UI ligada/desligada

A maneira mais simples de alternar uma UI ligada e desligada é usar uma variável para o valor da display propriedade na uiTransform. O display propriedade torna uma entidade de UI e todos os seus filhos invisíveis se definida como none.

O exemplo a seguir usa uma variável para definir o display campo de uma parte da UI. O valor dessa variável pode ser alternado clicando em outro elemento de UI.

arquivo ui.tsx:

arquivo index.ts:

Entidades de UI dinâmicas

Os exemplos nas seções acima mostram como alterar dinamicamente uma única propriedade em uma entidade, mas você também pode definir estruturas inteiras de entidades que podem escalar com base em dados que mudam dinamicamente. Esse tipo de padrão é comum no desenvolvimento web ao usar bibliotecas como React, e é extremamente poderoso. Com isso você pode definir aplicações de UI extremamente flexíveis e escaláveis.

O exemplo a seguir lista os ids de todas as entidades na cena que possuem um MeshRenderer e Transform. Ele cria um uiText para cada uma. À medida que o conteúdo da cena muda, a lista de entidades de UI também se adapta a cada tick.

arquivo ui.tsx:

arquivo index.ts:

Atualizado