Avatares NPC

Exibir e controlar avatar NPC

Exiba um avatar como uma entidade em uma cena.

💡 Dica: Experimente a biblioteca NPC Toolkit para uma experiência mais fácil ao lidar com NPCs, especialmente se você precisar interagir por meio de uma árvore de conversa.

Criar um avatar

O snippet a seguir cria um avatar com wearables e body shape aleatórios, e nome "NPC".

const myAvatar = engine.addEntity()
AvatarShape.create(myAvatar)

Transform.create(myAvatar, {
	position: Vector3.create(4, 0.25, 5),
})

Ao passar dados para gerar um AvatarShape, os seguintes campos são obrigatórios:

  • id: (obrigatório) Identificador interno do Avatar

Os seguintes campos opcionais também estão disponíveis:

  • name: Nome a ser exibido acima da cabeça do Avatar. Padrão: "NPC".

  • bodyShape: String para definir qual body shape usar. As opções válidas são 'urn:decentraland:off-chain:base-avatars:BaseMale' e 'urn:decentraland:off-chain:base-avatars:BaseFemale'.

  • wearables: Array com a lista de URNs dos wearables que o avatar está usando no momento. Se os wearables entrarem em conflito (como quando dois deles são chapéus), o último da lista substitui o outro.

  • emotes: Array com a lista de URNs dos emotes NFT que o avatar é capaz de reproduzir

  • eyeColor: Color3 para a cor dos olhos (qualquer cor é válida)

  • skinColor: Color3 para a cor da pele (qualquer cor é válida)

  • hairColor: Color3 para a cor do cabelo (qualquer cor é válida)

  • talking: Se true, exibe um conjunto verde de barras ao lado do nome, como quando os players usam chat de voz in-world.

  • 💡 Dica: Consulte tipos de cor para mais detalhes sobre como definir cores.

Animations

Avatars reproduzem animações idle padrão enquanto estão parados.

Para reproduzir animações no avatar, defina a expressionTriggerId string com o nome da animação que você quer reproduzir.

O expressionTriggerId campo suporta todas as animações padrão, assim como animações personalizadas de um arquivo de cena, e até mesmo URNs de emotes publicados no marketplace.

Animações em Loop

As animações em um AvatarShape são reproduzidas uma vez; se você quiser que o avatar continue em loop com uma animação, você deve criar um system que diga para reproduzir a animação novamente a cada poucos segundos.

Use o expressionTriggerTimestamp para reproduzir o mesmo emote novamente. O valor deste campo é um timestamp lamport, o que significa que não é um valor de tempo, mas sim um índice que aumenta em 1 para cada repetição do emote.

Então, da primeira vez que você reproduzir um emote, você define expressionTriggerTimestamp // desenhar UI 0. Para reproduzir o emote novamente, você deve atualizar esse valor para 1. É assim que o engine sabe que esta é uma nova instrução, e não uma instrução à qual ele já tenha reagido.

O snippet a seguir cria um system que executa o mesmo emote a cada 2 segundos:

💡 Dica: Você precisa conhecer a duração do emote e fazer com que essa seja a duração do system. Se você criar um emote que mantém o avatar parado em uma mesma pose, é recomendável tornar a duração do emote maior do que a do system. Dessa forma, você pode garantir que não haverá artefatos ao finalizar e redefinir a animação.

Copiar wearables do player

O snippet a seguir altera os wearables e outras características de um avatar NPC para corresponder àqueles que o player está usando no momento. Isso pode ser usado em uma cena como um manequim, para exibir um wearable ou emote específico combinado com a roupa atual do player.

Exibir apenas wearables

Use o show_only_wearables campo para exibir apenas os wearables listados de um avatar. O restante do corpo do avatar ficará invisível.

Isso é útil para exibir wearables, por exemplo em uma loja.

💡 Dica: Se um wearable for muito pequeno, tente definir o scale de Transform para um valor maior.

Anexar uma entidade a um NPC

Você pode usar o AvatarAttach recurso para fixar uma entidade a um dos bones de um avatar NPC, por exemplo para que o NPC esteja segurando um objeto na mão. A entidade se moverá junto com o avatar quando ele animar.

Para usar esse recurso, use o id component em qualquer UI entity. Por exemplo, para definir uma entity que não tem nenhum AvatarShape para atribuir um id arbitrário a este avatar e então referencie esse id no AvatarAttach. O id pode ser qualquer string que você quiser.

Saiba mais sobre o AvatarAttach component aqui.

Atualizado