Eu não compreendo esta lógica do professor e muito menos porque no meu código ela não funciona... A margem de erro do oponente parece não funcionar pois ele não erra nunca, temos que criar uma forma de dar a posição errada da bolinha certo ? Por que o meu oponente não erra ?
//variáveis da raquete
let xRaquete = 10;
let yRaquete = 150;
let raqueteComprimento = 5;
let raqueteAltura = 70;
//variaveis o oponete
let xRaqueteOponente = 585;
let yRaqueteOponente = 150;
let velocidadeYOponente;
let chanceDeErrar = 0;
//Aparencia da boliha (variaveis da boliha)
let xBolinha = 300;
let yBolinha = 200;
let diametro = 15;
//variaveis da velocidade
let velocidadeXBolinha = 6;
let velocidadeYBolinha = 6;
//variavel que ajuda no criterio de colisão da bolinha
let raio = diametro/2;
let colidiu = false;
//placar do jogo
let meuPlacar = 0;
let oponentePlacar = 0;
function draw() {
background(0);
mostraBolinha();
movimentaBolinha();
verificaColisaoBorda();
mostraRaquete(xRaquete,yRaquete);
movimentaMinhaRaquete();
//verificaColisaoRaquete();
verificaColisaoRaqueteBiblioteca(xRaquete,yRaquete);
mostraRaquete(xRaqueteOponente, yRaqueteOponente);
movimentaRaqueteOponente();
verificaColisaoRaqueteBiblioteca(xRaqueteOponente,yRaqueteOponente);
mostraPlacar();
marcarPonto();
}
//sons do jogo
let raquetada;
let ponto;
let trilha;
function preload(){
trilha = loadSound("trilha.mp3");
ponto = loadSound("ponto.mp3");
raquetada = loadSound("raquetada.mp3");
}
function setup() {
createCanvas(600, 400);
trilha.loop();
}
function mostraRaquete(x,y) {
rect(x, y, raqueteComprimento, raqueteAltura);
}
function movimentaMinhaRaquete() {
if (keyIsDown(UP_ARROW)) {
yRaquete -= 10;
}
if (keyIsDown(DOWN_ARROW)) {
yRaquete += 10;
}
}
function verificaColisaoRaquete() {
if (xBolinha - raio < xRaquete + raqueteComprimento
&& yBolinha - raio < yRaquete + raqueteAltura
&& yBolinha + raio > yRaquete) {
velocidadeXBolinha *= -1;
}
}
function mostraBolinha() {
circle(xBolinha, yBolinha, diametro)
}
//velocidade Bolinha
function movimentaBolinha() {
xBolinha += velocidadeXBolinha;
yBolinha += velocidadeYBolinha;
}
function verificaColisaoBorda() {
if (xBolinha + raio > width || xBolinha - raio < 0) {
velocidadeXBolinha *= -1;
}
if (yBolinha + raio > height || yBolinha - raio < 0) {
velocidadeYBolinha *= -1;
}
}
function verificaColisaoRaqueteBiblioteca(x,y) {
colidiu = collideRectCircle(x,y,raqueteComprimento,raqueteAltura,xBolinha,yBolinha,raio);
if (colidiu) {
velocidadeXBolinha *= -1;
raquetada.play();
}
}
function calculaChanceDeErrar() {
if (oponentePlacar >= meuPlacar) {
chanceDeErrar += 1
if (chanceDeErrar >= 39){
chanceDeErrar = 40
}
} else {
chanceDeErrar -= 1
if (chanceDeErrar <= 35){
chanceDeErrar = 35
}
}
}
function movimentaRaqueteOponente() {
velocidadeYOponente = yBolinha - yRaqueteOponente - raqueteComprimento / 2 - 50;
yRaqueteOponente += velocidadeYOponente + chanceDeErrar;
calculaChanceDeErrar();
}
function mostraPlacar(){
stroke(255);
textAlign(CENTER);
textSize(16);
fill(color(255,140,0));
rect(150,10,40,20)
fill(255);
text(meuPlacar, 170, 26);
fill(color(255,140,0));
rect(450,10,40,20)
fill(255);
text(oponentePlacar, 470,26);
}
function marcarPonto() {
if (xBolinha > 590) {
meuPlacar += 1;
ponto.play();
}
if (xBolinha < 10) {
oponentePlacar += 1;
ponto.play();
}
}