Skip to content

Commit

Permalink
Add files via upload
Browse files Browse the repository at this point in the history
  • Loading branch information
davidmagnotti authored Mar 4, 2024
1 parent d2f3d29 commit d712342
Showing 1 changed file with 166 additions and 55 deletions.
221 changes: 166 additions & 55 deletions cardodge.html
Original file line number Diff line number Diff line change
Expand Up @@ -26,7 +26,7 @@
let boostTimer = 0;
let redCars = [];
let blueCar;
let carSpriteSheet = "";
let carSpriteSheet = "";
let score = 0;
let highScore = 0;
let spritesheet;
Expand All @@ -43,18 +43,46 @@
sourceSize: { w: 32, h: 32 },
spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 }
},
blueCar2: {
frame: { x: 32, y:0, w:32, h:32 },
sourceSize: { w: 32, h: 32 },
spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 }
},
redCar1: {
frame: { x: 64, y:0, w:32, h:32 },
sourceSize: { w: 32, h: 32 },
spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 }
},
pinkCar: {
frame: { x: 0, y:32, w:32, h:32 },
sourceSize: { w: 32, h: 32 },
spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 }
},
boost1: {
frame: { x: 32, y:32, w:32, h:32 },
sourceSize: { w: 32, h: 32 },
spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 }
},
boost2: {
frame: { x: 64, y:32, w:32, h:32 },
sourceSize: { w: 32, h: 32 },
spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 }
},
boost3: {
frame: { x: 0, y:64, w:32, h:32 },
sourceSize: { w: 32, h: 32 },
spriteSourceSize: { x: 0, y: 0, w: 32, h: 32 }
},
},
meta: {
scale: 1
},
animations: {
blueCar: ['blueCar1'],
redCar: ['redCar1']
redCar: ['redCar1'],
blueCarBoost: ['blueCar1', 'pinkCar'],
redCarHiding: ['redCar1', 'pinkCar'],
boost: ['boost1', 'boost2', 'boost3', 'boost2', 'boost1']
}
}

Expand All @@ -67,7 +95,7 @@
}

function click(e) {
if (e.clientX < 640 && e.clientY < 480)
if (e.clientX < 400 && e.clientY < 480)
{
lastTouch = {x: e.clientX, y: e.clientY};
}
Expand All @@ -79,7 +107,7 @@
document.onkeydown = keydown;
document.onkeyup = keyup;

app = new PIXI.Application({width: 640, height: 580});
app = new PIXI.Application({width: 400, height: 540});
document.body.appendChild(app.view);

app.renderer.background.color = 0xaaaaaa;
Expand All @@ -95,54 +123,80 @@

// spawn the player
blueCar = new PIXI.AnimatedSprite(spritesheet.animations.blueCar);
blueCar.position = {x:10, y:10};
blueCar.position = {x:200, y:200};
app.stage.addChild(blueCar);

// display a score and high score
app.stage.addChild(scoreDisplay);
scoreDisplay.y = 500;
app.stage.addChild(highScoreDisplay);
app.stage.addChild(scoreDisplay);

highScoreDisplay.y = 500;
highScoreDisplay.x = 400;
highScoreDisplay.x = 240;
app.stage.addChild(highScoreDisplay);

// add the main game loop
app.ticker.add((t) => loop(t));
}

function loop(t)
{
scoreDisplay.text = "Score: " + score;

// chance of spawning in a boost, only if one isn't already there
if (!isBoostAvailable && Math.floor(Math.random() * 100) == 1 && boostTimer == 0)
{
let rx = Math.floor(Math.random() * 500) + 10;
let rx = Math.floor(Math.random() * 350) + 10;
let ry = Math.floor(Math.random() * 480) + 10;

boost = new PIXI.AnimatedSprite(spritesheet.animations.boost);
boost.animationSpeed = 0.2;
boost.play();
boost.x = rx;
boost.y = ry;

boostPosition = {x: rx, y: ry};
boost = new PIXI.Graphics();
boost.beginFill(0xFF0000);
boost.lineStyle(2, 0xFFCC00);
boost.drawRect(rx, ry, 30, 30);

app.stage.addChild(boost);

isBoostAvailable = true;
score += 1;
}

// if there's a boost, check if we picked it up
if (isBoostAvailable)
{
if (blueCar.x > boostPosition.x - 30 && blueCar.x < boostPosition.x + 30 &&
blueCar.y > boostPosition.y - 30 && blueCar.y < boostPosition.y + 30)
{
boostTimer = 500;
score += 1;
isBoostAvailable = false;
app.stage.removeChild(boost);

// remove the non-boosted player and add boosted
let pos = blueCar.position ;
app.stage.removeChild(blueCar);
blueCar = new PIXI.AnimatedSprite(spritesheet.animations.blueCarBoost);
blueCar.animationSpeed = 0.1;
blueCar.play();
blueCar.position = pos;
app.stage.addChild(blueCar);
}
}

let movementSpeed = 2;
if (boostTimer > 0)
{
boostTimer -= 1;
movementSpeed += 3;
movementSpeed += 1;

// If the boostTimer hits 0 after this decrement, stop the animation
if (boostTimer == 0)
{
let pos = blueCar.position;
app.stage.removeChild(blueCar);
blueCar = new PIXI.AnimatedSprite(spritesheet.animations.blueCar);
blueCar.position = pos;
app.stage.addChild(blueCar);
}
}

// conduct movement based off arrow presses
Expand Down Expand Up @@ -200,32 +254,57 @@
lastTouch = null;
}

if (redCars.length < score + 1)

if (blueCar.x < 20)
{
blueCar.x = 20;
}
else if (blueCar.x > 350)
{
blueCar.x = 350;
}

if (blueCar.y < 20)
{
blueCar.y = 20;
}
else if (blueCar.y > 460)
{
blueCar.y = 460;
}

let increaseOnce = false;
while (redCars.length < score + 1 && boostTimer == 0)
{
if (!increaseOnce)
{
increaseOnce = true;
score += 1;
}
let newRedCar = new PIXI.AnimatedSprite(spritesheet.animations.redCar);
let x = Math.floor(Math.random() * 640);
let y = Math.floor(Math.random() * 520);
if (blueCar.x > x && blueCar.x < x + 40)
let x = Math.floor(Math.random() * 300);
let y = Math.floor(Math.random() * 300);

let r = Math.floor(Math.random() * 4);
if (r == 1)
{
if (Math.random() < 0.5)
{
x -= 75;
}
else
{
x += 75;
}
x = Math.random() * 300;
y = 0;
}
if (blueCar.y > y && blueCar.y < y + 40)
else if (r == 2)
{
if (Math.random() < 0.5)
{
y -= 75;
}
else
{
y += 75;
}
x = Math.random() * 300;
y = 600;
}
else if (r == 3)
{
x = 400;
y = Math.random() * 400;
}
else
{
x = 0;
y = Math.random() * 400;
}

newRedCar.position.x = x;
Expand All @@ -237,44 +316,77 @@
let gameOver = false;
for (const redCar of redCars)
{
let offset = 1;
if (boostTimer > 0)
{
offset = -2;
}
redCar.pivot.set(16);
if (redCar.x > blueCar.x && redCar.x - blueCar.x > 3)
{
redCar.rotation = 4.7;
redCar.x -= Math.floor(Math.random() * 2) + 1;
redCar.x -= Math.floor(Math.random() * 2) + offset;
}
else if (redCar.y > blueCar.y && redCar.y - blueCar.y > 3)
{
redCar.rotation = 0;
redCar.y -= Math.floor(Math.random() * 2) + 1;
redCar.y -= Math.floor(Math.random() * 2) + offset;
}
else if (redCar.x < blueCar.x && blueCar.x - redCar.x > 3)
{
redCar.x += Math.floor(Math.random() * 2) + 1;
redCar.x += Math.floor(Math.random() * 2) + offset;
redCar.rotation = 1.6;
}
else if (redCar.y < blueCar.y && blueCar.y - redCar.y > 3)
{
redCar.y += Math.floor(Math.random() * 2) + 1;
redCar.y += Math.floor(Math.random() * 2) + offset;
redCar.rotation = 3.1;
}
// if red car runs into blue car, it's game over
if ((blueCar.x >= redCar.x - 5 && blueCar.x <= redCar.x + 35) &&
(blueCar.y >= redCar.y - 5 && blueCar.y <= redCar.y + 35))

// boundary check (necessary if car is 'running away' from player
// while player is boosted)
if (redCar.x < 20)
{
blueCar.x = Math.floor(Math.random() * 300);
blueCar.y = Math.floor(Math.random() * 300);
redCar.x = 20;
}
else if (redCar.x > 350)
{
redCar.x = 350;
}

if (score > highScore)
if (redCar.y < 20)
{
redCar.y = 20;
}
else if (redCar.y > 460)
{
redCar.y = 460;
}

// if red car runs into blue car, it's game over - unless player is boosted
if ((blueCar.x >= redCar.x - 5 && blueCar.x <= redCar.x + 20) &&
(blueCar.y >= redCar.y - 5 && blueCar.y <= redCar.y + 20))
{
if (boostTimer > 0)
{
highScore = score;
highScoreDisplay.text = "High Score: " + highScore;
app.stage.removeChild(redCar);
redCars.splice(redCars.indexOf(redCar), 1);
}
else
{
blueCar.x = Math.floor(Math.random() * 300);
blueCar.y = Math.floor(Math.random() * 300);

if (score > highScore)
{
highScore = score;
highScoreDisplay.text = "High Score: " + highScore;
}
lastTouch = null;
score = 0;
gameOver = true;
break;
}
lastTouch = null;
score = 0;
gameOver = true;
break;
}
}
if (gameOver)
Expand All @@ -285,7 +397,6 @@
}
redCars = [];
}
scoreDisplay.text = "Score: " + score;
}
</script>
<body onload="init()">
Expand Down

0 comments on commit d712342

Please sign in to comment.