Todos nós já quisemos fazer modelos 3D em algum momento, e embora pareça ser complicado, não é! Neste workshop, usaremos uma biblioteca JavaScript simples chamada Zdog que nos permitirá fazer tudo o que quisermos em questão de minutos.
Ao final deste workshop, você poderá fazer modelos em 3D como estes:
Aqui está uma demonstração ao vivo do que vamos fazer, você também pode encontrar o código final lá.
Configurando
Este workshop requer um conhecimento básico das seguintes linguagens: HTML & JS. Mas não se preocupe se você ficar preso em algum ponto do workshop, tudo é explicado da melhor maneira para que você possa entender!
Para este workshop usaremos o Repl.it, clique aqui para criar um ambiente de programação adequado para este workshop.
Parte do HTML
Muito bem, vamos começar! Primeiro, queremos criar dentro da tag <body>
um <canvas>
no qual, o modelo 3D que vamos criar será renderizado. Depois, coloque uma classe; sinta-se à vontade para nomeá-la como quiser... Eu vou nomeá-la como modelo
.
<canvas class="modelo"></canvas>
Agora temos que colocar o seguinte código dentro da tag <body>
, este código nos permite usar a biblioteca Zdog sem ter que baixá-la. Saiba mais sobre a CDN aqui.
<script src="https://unpkg.com/zdog@1/dist/zdog.dist.min.js"></script>
Seu código HTML deve estar assim agora:
<body>
<canvas class="modelo"></canvas>
<script src="https://unpkg.com/zdog@1/dist/zdog.dist.min.js"></script>
<script src="script.js"></script>
</body>
Nota: é muito importante manter essa ordem para ter certeza que tudo funciona perfeitamente
Parte do JavaScript
Agora que temos nosso arquivo HTML pronto, temos que trabalhar em nosso arquivo JavaScript.
Configurando o canvas
Vamos começar com a parte divertida. Primeiro, vamos criar a variável principal e vamos dar-lhe um nome, eu vou nomeá-la como "ws".
const ws = new Zdog.Illustration({
element: '.modelo',
resize: 'fullscreen',
})
Vamos explicar isso:
- Illustration -> é a classe de nível superior que lida com o elemento
<canvas>
, armazenando todas as formas na cena, e exibindo essas formas noelement
(elemento). - element -> usado para indicar o elemento para ser renderizado com a tag
<canvas>
. - resize -> é usado para modificar o tamanho em que o modelo será renderizado, neste caso, o modelo 3D será renderizado em toda a tela. Se você quiser, você pode remover este elemento.
Neste momento, ainda não aparece nada, então vamos criar nosso primeiro modelo 3D.
Criando o modelo
Agora, vamos criar uma forma, para este worskop quero fazer um simples cubo, mas você pode criar o que quiser. Aqui está uma lista de formas que você pode criar com a Zdog.
Note: Cada forma tem suas próprias propriedades ou elementos, você pode verificar a lista completa aqui.
Vamos adicionar o seguinte código ao nosso arquivo JS:
new Zdog.Box({
addTo: ws,
width: 100,
height: 100,
depth: 100,
stroke: false,
leftFace: '#da0',
rightFace: '#e62',
topFace: '#ed0',
bottomFace: '#636',
})
Explicação:
-
Box
(Caixa) é uma classe de forma, você pode substituí-la pela forma que você deseja usar... -
Fizemos o modelo 3D (cubo) uma criança da Ilustração principal da Zdog (ws) usando o elemento addTo. Este elemento deve estar lá, caso contrário o modelo 3D não será renderizado.
-
Os elementos de
width
(largura),height
(altura) edepth
(profundidade) podem esticar ou encolher a forma de sua caixa:- Width: Define a largura do cubo
- Height: Define a altura do cubo
- Depth: Define a profundidade do cubo. Se o valor for 0, o cubo se renderizará como um quadrado 2d; portanto, certifique-se de dar-lhe um valor.
-
O elemento
stroke
(contorno) cria uma borda ao modelo 3D, ele funciona como uma camada externa que você pode usar para dar ao seu modelo 3D um aspecto arredondado. Brinque com ele! -
Os elementos leftFace, rightFace, topFace e bottomFace dão cor a cada face (esquerda, direita, topo, baixo) do modelo 3D, tente usar cores diferentes para cada face, para que você possa apreciar muito melhor as animações que faz.
Renderizando
Agora que criamos nosso modelo 3D, vamos renderizá-lo. Use a seguinte linha de código para renderizar o cubo que acabamos de criar.
ws.updateRenderGraph()
Este código atualiza e renderiza nossa ilustração da Zdog que foi declarada na primeira variável, portanto, certifique-se de escrever o nome corretamente.
Agora vamos clicar no botão Run para ver o que acontece...
Parabéns, você acabou de fazer seu primeiro modelo 3D... Sim, talvez não seja o que você estava esperando. Vamos consertar isso animando-o.
Animando o modelo
Adicione o seguinte código ao nosso arquivo JS:
function animaModelo() {
ws.rotate.y += 0.01
ws.rotate.x += 0.01
ws.updateRenderGraph()
requestAnimationFrame(animaModelo)
}
animaModelo()
Explicação:
-
Acabamos de criar uma função que fará o modelo 3D girar, você pode nomear esta função como você quiser.
-
O
rotate.x
e orotate.y
definem a velocidade de rotação do modelo:- O cubo se moverá para cima e para baixo, dependendo do valor dado (- ou +, respectivamente)
- O cubo se moverá para a direita e para a esquerda, dependendo do valor dado (- ou +, respectivamente)
-
O
ws.updateRenderGraph()
atualiza e renderiza sua ilustração Zdog que foi declarada na primeira variável, certifique-se de escrever o nome corretamente. -
requestAnimationFrame(animaModelo)
é como um loop, basicamente ele faz o modelo girar cada vez que frames são criados. -
animaModelo()
chama a função.
Agora você pode clicar em run novamente!
Incrível, não é?
Formas múltiplas
Se você quiser tentar fazer modelos mais complexos, você precisará usar múltiplas formas, aqui estão alguns exemplos do que você pode criar:
Fazer múltiplas formas é muito fácil, é tão simples quanto juntar múltiplas formas até conseguir o que você quer. A parte mais difícil disto é colocar tudo onde deve estar, podemos fazer isto usando a propriedade: "translate". Vamos ver como funciona!
Eu quero tentar fazer o logotipo do Hack Club, mas você pode fazer o que quiser! Clique aqui para ver o código final.
Primeiro, vamos alterar a classe do nosso canvas no arquivo index.html
de modelo
para hackclub
.
...
<canvas class="hackclub"></canvas>
...
E adicionar uma cor de fundo para nosso projeto no arquivo style.css
.
.hackclub {
background: #FDB;
}
Após isso, vamos voltar para o arquivo script.js
e alterar o element
selecionado pelo Zdog de .modelo
para .hackclub
e adicionar a propriedade dragRotate
com o valor definido para true
para podermos rodar nossa criação.
const ws = new Zdog.Illustration({
element: '.hackclub',
resize: 'fullscreen',
dragRotate: true
})
Depois, vamos alterar as características do nosso cubo para ele se transformar em um quadrado vermelho:
new Zdog.Box({
addTo: ws,
width: 100,
height: 100,
color: '#ec3750',
stroke: 20,
translate: { z: -18 },
})
- Como visto anteriormente, a propriedade
addTo
coloca a forma feita dentro da Ilustração principal da Zdog. - Utilizamos as propriedades de
width
(largura) eheight
(altura) para fazer um quadrado perfeito, não lhe deidepth
(profundidade) porque não foi necessário. - O quadrado inteiro terá a mesma cor (vermelho), então podemos usar a propriedade da cor para dar à forma inteira uma única cor ao invés de atribuir uma cor a cada face.
- Como mencionado anteriormente, a propriedade
stroke
(contorno) ajuda a forma a parecer um pouco arredondada. - A propriedade
translate
move o quadrado -18 dentro do eixo z. Você pode interpretar isto como se estivesse dando a uma forma uma profundidade, então a forma é movida para trás.
Ao executarmos estas poucas linhas, conseguiremos isto:
Ficou perfeito! Agora vamos criar a letra h, para isso vamos precisar de mais 3 caixas:
new Zdog.Box({
addTo: ws,
depth: 20,
width: 20,
height: 80,
color: '#fff',
translate: { z: 18, x: -20 },
})
- Desta vez, a forma é movida para frente... Assim, criamos um espaço entre o quadrado vermelho e esta nova forma.
- A forma é movida para a esquerda dentro do eixo x
new Zdog.Box({
addTo: ws,
depth: 20,
width: 20,
height: 40,
color: '#fff',
translate: { z: 18, y: 20, x: 20 },
})
- Desta vez, criamos uma nova caixa, mas bem menor.
- Nós a movemos para a direita dentro do eixo x e um pouco para baixo dentro do eixo y.
new Zdog.Box({
addTo: ws,
depth: 20,
width: 40,
height: 20,
color: '#fff',
translate: { z: 18, x: 10 },
})
Nesta último, tudo o que tivemos que fazer foi mover a caixa para a direita dentro do eixo x, para que ela se misture com a caixa da direita.
Agora, vamos atualizar a animação com algumas propriedades simples:
function animaModelo() {
ws.rotate.y += 0.01
ws.updateRenderGraph()
requestAnimationFrame(animaModelo)
}
animaModelo()
Esse é o resultado final:
Hackeando
Parabéns! Você acabou de aprender o básico da Zdog, sinta-se à vontade para dar uma olhada nos recursos abaixo para melhorar seus conhecimentos...
Outros exemplos
Confira estes modelos 3D legais feitos por outras pessoas:
Recursos
Agora que você terminou de construir este maravilhoso projeto, compartilhe sua bela criação com outras pessoas! Lembre-se, é só mandar a URL do seu projeto!