Merge branch 'main' of ssh://gitlab.fdmci.hva.nl/propedeuse-hbo-ict/onderwijs/2023-2024/out-a-se-ti/blok-2/cuujooceevii61
This commit is contained in:
47
web/game.js
47
web/game.js
@@ -3,6 +3,12 @@
|
||||
const width = 1260;
|
||||
const height = 620;
|
||||
|
||||
// Menu variables
|
||||
let letters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ'.split('');
|
||||
let currentIndex = 0;
|
||||
let name = '';
|
||||
let pressed = false;
|
||||
|
||||
// Player variables
|
||||
const playerSize = 10;
|
||||
let radius = playerSize / 2;
|
||||
@@ -11,7 +17,7 @@ let playerPosY = 300;
|
||||
let playerSpeed = 4;
|
||||
let booleanArray = window.booleanArray;
|
||||
let lives = 1;
|
||||
|
||||
let isDead = false;
|
||||
let bossPosX = width / 2;
|
||||
let bossPosY = 100;
|
||||
let shotSpeed = 12;
|
||||
@@ -69,16 +75,24 @@ function score() {
|
||||
time += 3 / framerate;
|
||||
}
|
||||
|
||||
function life() {
|
||||
textAlign(CENTER);
|
||||
function gameOver() {
|
||||
if (lives == 0) {
|
||||
//game over screen
|
||||
isDead = true;
|
||||
push();
|
||||
fill(255, 0, 0);
|
||||
textSize(40);
|
||||
textAlign(CENTER);
|
||||
text("Game Over", width / 2, height / 2);
|
||||
text("Game Over", width / 2, height / 2 - 80);
|
||||
pop();
|
||||
push();
|
||||
fill(255,255,255)
|
||||
textSize(32);
|
||||
text(letters[currentIndex], width / 2, height / 2);
|
||||
pop();
|
||||
|
||||
if (key == ' ') {
|
||||
//reset all the variables so the game can be played again
|
||||
lives = 1;
|
||||
time = 0;
|
||||
bounceX = bossPosX;
|
||||
@@ -90,18 +104,20 @@ function life() {
|
||||
shot = false;
|
||||
chosen = false;
|
||||
finalPhase = false;
|
||||
isDead = false;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
function movementCheck() {
|
||||
//check if the player has moved
|
||||
if (playerPosX != initialPlayerPosX || playerPosY != initialPlayerPosY) {
|
||||
hasMoved = true;
|
||||
}
|
||||
}
|
||||
|
||||
async function keyPressed() {
|
||||
if (!isDead) {
|
||||
if (keyIsDown(LEFT_ARROW) && playerPosX > 0 + radius) {
|
||||
playerPosX -= playerSpeed;
|
||||
}
|
||||
@@ -115,6 +131,21 @@ async function keyPressed() {
|
||||
playerPosY += playerSpeed;
|
||||
}
|
||||
}
|
||||
if (isDead) {
|
||||
if (keyCode === UP_ARROW) {
|
||||
currentIndex = (currentIndex + 1) % letters.length;
|
||||
}
|
||||
if (keyCode === DOWN_ARROW) {
|
||||
currentIndex = (currentIndex - 1 + letters.length) % letters.length;
|
||||
}
|
||||
if (keyCode === ENTER) {
|
||||
name += letters[currentIndex];
|
||||
console.log(name);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
function wait(waitTime) {
|
||||
return new Promise(resolve => {
|
||||
setTimeout(() => {
|
||||
@@ -124,10 +155,9 @@ function wait(waitTime) {
|
||||
}
|
||||
|
||||
async function Movementloop() {
|
||||
//get info from controller and use it to move the player
|
||||
window.addEventListener('booleanArrayUpdated', function (event) {
|
||||
// event.detail contains the booleanArray
|
||||
let booleanArray = event.detail;
|
||||
// Use booleanArray here...
|
||||
|
||||
if (booleanArray[1]) {
|
||||
playerPosX += playerSpeed;
|
||||
@@ -147,7 +177,7 @@ async function Movementloop() {
|
||||
// the function draw() is called every frame
|
||||
function draw() {
|
||||
keyPressed();
|
||||
life();
|
||||
gameOver();
|
||||
phase();
|
||||
// draw background
|
||||
//myBullet.draw();
|
||||
@@ -159,6 +189,7 @@ function draw() {
|
||||
if (homescreenOn == false) {
|
||||
game();
|
||||
}
|
||||
keyDown();
|
||||
}
|
||||
|
||||
async function randPatern() {
|
||||
|
Reference in New Issue
Block a user