1
resposta

Alguém me ajuda !

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();
    }
}
1 resposta

*Necessário adicionar uma function em conjunto cm variável let *