diff options
author | Carlos Alan <88628271+surykt@users.noreply.github.com> | 2021-11-07 09:54:11 -0300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-07 09:54:11 -0300 |
commit | 830621df7f8fff0b157cb5fa3551c4fe75f8e9d8 (patch) | |
tree | 1d503486bd1b39a2f3cb84277b04c4f58e351a02 /files/pt-br/learn/javascript | |
parent | 7bc6744472098eaaea483f07b30c93460ab34f5f (diff) | |
download | translated-content-830621df7f8fff0b157cb5fa3551c4fe75f8e9d8.tar.gz translated-content-830621df7f8fff0b157cb5fa3551c4fe75f8e9d8.tar.bz2 translated-content-830621df7f8fff0b157cb5fa3551c4fe75f8e9d8.zip |
Improve Object building practice page in pt-br (#2748)
Diffstat (limited to 'files/pt-br/learn/javascript')
-rw-r--r-- | files/pt-br/learn/javascript/objects/object_building_practice/index.html | 46 |
1 files changed, 23 insertions, 23 deletions
diff --git a/files/pt-br/learn/javascript/objects/object_building_practice/index.html b/files/pt-br/learn/javascript/objects/object_building_practice/index.html index 070fd6206f..d1ce18c866 100644 --- a/files/pt-br/learn/javascript/objects/object_building_practice/index.html +++ b/files/pt-br/learn/javascript/objects/object_building_practice/index.html @@ -13,11 +13,11 @@ original_slug: Aprender/JavaScript/Objetos/Object_building_practice <table class="learn-box standard-table"> <tbody> <tr> - <th scope="row">Prerequisites:</th> + <th scope="row">Pré-requisitos:</th> <td>Conhecimentos básicos de informática, conhecimento básico de HTML e CSS, familiaridade com o básico de JavaScript (veja <a href="/en-US/docs/Learn/JavaScript/First_steps">First steps</a> e <a href="/en-US/docs/Learn/JavaScript/Building_blocks">Building blocks</a>) e o básico de OOJS (veja <a href="/en-US/docs/Learn/JavaScript/Object-oriented/Introduction">Introduction to objects</a>).</td> </tr> <tr> - <th scope="row">Objective:</th> + <th scope="row">Objetivo:</th> <td>Adiquirir alguma prática no uso de objetos e técnicas de orientação a objetos num contexto real.</td> </tr> </tbody> @@ -180,31 +180,32 @@ testBall.draw()</pre> <p>Agora vamos tornar isso divertido. Vamos começar a adicionar bolas à tela e a animá-las.</p> <ol> - <li>Primeiro, precisamos de um lugar para armazenar todas as nossas bolas. O array a seguir fará esse trabalho — adicione-o ao final do seu código agora: - <pre class="brush: js">let balls = [];</pre> + <li>Primeiro, precisamos de criar um lugar para armazenar todas as nossas bolas e então preenche-lo. O código a seguir fará esse trabalho — adicione-o ao final do seu código agora: + <pre class="brush: js">let balls = []; + +while (balls.length < 25) { + let size = random(10,20); + let ball = new Ball( + // ball position always drawn at least one ball width + // away from the edge of the canvas, to avoid drawing errors + random(0 + size,width - size), + random(0 + size,height - size), + random(-7,7), + random(-7,7), + 'rgb(' + random(0,255) + ',' + random(0,255) + ',' + random(0,255) +')', + size + ); + + balls.push(ball); +}</pre> - <p>Todos os programas que animam as coisas geralmente envolvem um loop de animação, que serve para atualizar as informações no programa e renderizar a visualização resultante em cada quadro da animação; esta é a base para a maioria dos jogos e outros programas.</p> + <p>O laço <code>while</code> cria uma nova instância da nossa <code>Ball()</code> usando valores aleatórios gerados com nossa função <code>random()</code>, então a função <code>push()</code> coloca ela no final do nosso array de bolas, mas somente enquanto o número de bolas no array é menor que 25. Então quando nos tivermos 25 bolas na tela mais nenhuma bola aparece. Você pode tentar variar o número em <code>balls.length < 25</code> para obter mais ou menos bolas na tela. Dependendo de quanto poder de processamento seu computador/navegador tiver, especificar várias milhares de bolas pode diminuir bastante a velocidade da animação!</p> </li> <li>Adicione o seguinte ao final do seu código agora: <pre class="brush: js">function loop() { ctx.fillStyle = 'rgba(0, 0, 0, 0.25)'; ctx.fillRect(0, 0, width, height); - while (balls.length < 25) { - let size = random(10,20); - let ball = new Ball( - // ball position always drawn at least one ball width - // away from the edge of the canvas, to avoid drawing errors - random(0 + size,width - size), - random(0 + size,height - size), - random(-7,7), - random(-7,7), - 'rgb(' + random(0,255) + ',' + random(0,255) + ',' + random(0,255) +')', - size - ); - balls.push(ball); - } - for (let i = 0; i < balls.length; i++) { balls[i].draw(); balls[i].update(); @@ -213,12 +214,11 @@ testBall.draw()</pre> requestAnimationFrame(loop); }</pre> - <p>Nossa função <code>loop()</code> faz o seguinte:</p> + <p>Todos os programas que animam as coisas geralmente envolvem um loop de animação, que serve para atualizar as informações no programa e renderizar a visualização resultante em cada quadro da animação; esta é a base para a maioria dos jogos e outros programas. Nossa função <code>loop()</code> faz o seguinte:</p> <ul> <li>Define a cor de preenchimento da tela como preto semitransparente e desenha um retângulo com a cor em toda a largura e altura da tela, usando <code>fillRect()</code> (os quatro parâmetros fornecem uma coordenada de início e uma largura e altura para o retângulo desenhado ). Isso serve para encobrir o desenho do quadro anterior antes que o próximo seja desenhado. Se você não fizer isso, você verá apenas longas cobras se movimentando ao redor da tela, em vez de mover as bolas! A cor do preenchimento é definida como semitransparente, <code>rgba(0,0,0,0.25)</code>, para permitir que os poucos quadros anteriores brilhem levemente, produzindo as pequenas trilhas atrás das bolas à medida que elas se movem. Se você mudou 0,25 para 1, você não vai mais vê-los. Tente variar esse número para ver o efeito que ele tem.</li> - <li>Cria uma nova instância de nossa <code>Ball()</code> usando valores aleatórios gerados com a nossa função <code>random()</code> então <code>push()</code>para o final de nosso array de bolas, mas somente enquanto o número de bolas no array é menor que 25. Então quando temos 25 bolas na tela, não aparecem mais bolas. Você pode tentar variar o número em<code>balls.length < 25</code> para obter mais ou menos bolas na tela. Dependendo de quanto poder de processamento seu computador / navegador possui, especificar vários milhares de bolas pode retardar bastante a animação!</li> - <li>Faz um loop em todas as <code>balls</code> no array de bolas e executa a função <code>draw()</code> e <code>update()</code> de cada bola para desenhar cada uma delas na tela, depois faz as atualizações necessárias para a posição e a velocidade no tempo para o próximo quadro.</li> + <li>Percorre todas as bolas no array <code>balls</code> e executa a função <code>draw()</code> e <code>update()</code> de cada bola para desenhar cada uma delas na tela, depois faz as atualizações necessárias para a posição e a velocidade a tempo para o próximo quadro.</li> <li>Executa a função novamente usando o método <code>requestAnimationFrame()</code> — quando esse método é executado constantemente e passa o mesmo nome de função, ele executará essa função um número definido de vezes por segundo para criar uma animação suave. Isso geralmente é feito de forma recursiva — o que significa que a função está chamando a si mesma toda vez que é executada, portanto, ela será executada repetidas vezes.</li> </ul> </li> |