Boa noite amigos e amigas
Segue o link do projeto finalizado;
https://editor.p5js.org/lfavallone88/sketches/kEipYgIl2
abaixo segue os códigos utilizado;
// metricas do projeto
let xBolinha = 300;
let yBolinha = 200;
let diametro = 23;
let raio = diametro /2;
let velocidadeXBolinha = 6;
let velocidadeYBolinha = 6;
// metricas da raquete
let xRaquete = 3;
let yRaquete = 150;
let comprimentoRaquete = 12;
let alturaRaquete = 90;
// metricas da rquete do oponente
let xRaqueteOponente = 585;
let yRaqueteOponente = 150;
let velocidadeYOponente;
// variavel biblioteca
let colidiu = false;
// placar do jogos
let meusPontos = 0;
let pontosOponente = 0;
// sons do jogo
let raquetada;
let trilha;
let ponto;
// chance de erro
let chanceDeErrar =0;
function preload(){
raquetada = loadSound("raquetada.mp3");
trilha = loadSound("trilha.mp3");
ponto = loadSound("ponto.mp3")
}
// cirção do projeto
function setup() {
createCanvas(600, 400);
trilha.loop();
}
function draw() {
background(0);
mostrarbolinha();
velocidadedabolinha();
verificabordas();
mostraraquete();
movimentaraquete();
//verificacolisaoraquete();
colisaobiblioteca(xRaquete, yRaquete);
colisaobiblioteca(xRaqueteOponente, yRaqueteOponente);
raqueteoponete();
movimentaraqueteoponente();
incluiplacar();
marcaponto();
}
// refatoração
function mostrarbolinha(){circle(xBolinha,yBolinha,diametro);
}
function velocidadedabolinha(){
xBolinha += velocidadeXBolinha
yBolinha += velocidadeYBolinha
}
function verificabordas(){
if (xBolinha + raio > width ||xBolinha - raio < 0){
velocidadeXBolinha *= -1;
}
if (yBolinha + raio > height || yBolinha - raio < 0){
velocidadeYBolinha *= -1;
}
}
function mostraraquete(){fill(color(25,25,112));rect(xRaquete, yRaquete, comprimentoRaquete, alturaRaquete)
}
function movimentaraquete(){
if (keyIsDown(UP_ARROW)){yRaquete -= 10}
if (keyIsDown(DOWN_ARROW)){yRaquete += 10}
}
function verificacolisaoraquete(){
if (xBolinha - raio < xRaquete + comprimentoRaquete
&& yBolinha - raio < yRaquete + alturaRaquete
&& yBolinha + raio > yRaquete)
{velocidadeXBolinha *= -1;
}
}
function colisaobiblioteca(x , y){
colidiu = collideRectCircle(x, y, comprimentoRaquete, alturaRaquete, xBolinha, yBolinha, raio);
if (colidiu){velocidadeXBolinha *= -1; raquetada.play();}
}
function raqueteoponete(){fill(color(255,0,0));rect(xRaqueteOponente, yRaqueteOponente, comprimentoRaquete, alturaRaquete)}
function movimentaraqueteoponente(){
velocidadeYOponente = yBolinha - yRaqueteOponente - comprimentoRaquete / 2 - 30;
yRaqueteOponente += velocidadeYOponente + chanceDeErrar
calculaChanceDeErrar();
}
function calculaChanceDeErrar(){
if(pontosOponente >= meusPontos){
chanceDeErrar += 1
if(chanceDeErrar >= 39){ chanceDeErrar = 40}
else{chanceDeErrar -= 1
if (chanceDeErrar <= 35){chanceDeErrar
= 35}
}
}
}
function incluiplacar(){
stroke (255);
textAlign (CENTER);
textSize (16);
fill(color(25,25,112));
rect (150,10,40,20);
fill (255);
text (meusPontos, 170, 26);
fill(color(255,0,0));
rect (450,10,40,20);
fill (255);
text (pontosOponente, 470, 26);
}
function marcaponto(){
if (xBolinha > 587){meusPontos += 1; ponto.play();}
if (xBolinha < 10){pontosOponente += 1; ponto.play();}
}