Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- nestjs
- GIT
- cookie
- class
- react
- typeORM
- 자료구조
- OCR
- 게임
- Queue
- Sequelize
- Express
- 공룡게임
- JavaScript
- 정렬
- Nest.js
- Python
- mongoose
- nodejs
- dfs
- AWS
- Dinosaur
- MongoDB
- flask
- MySQL
- TypeScript
- Bull
- game
- jest
Archives
- Today
- Total
포시코딩
javascript - 구글 공룡 게임 구현(6) 본문
728x90
여기까지 했으니 목숨과 스코어도 만들어서
게임답게 만들어보자
다시 html 넘어가서 목숨, 점수 항목 추가
<span>목숨: <i id="life">5</i></span>
<span style="margin-left: 10px;">점수: <i id="score">0</i></span>
js 쪽에도 life, score 변수 추가
let life = 5;
let score = 0;
cactus x 좌표가 0 미만이 될때마다 점수가 10점씩 오르게 하고
innerHTML 로 화면에 바로 반영되게 세팅
document.querySelector('#score').innerHTML = score;
충돌시에도 목숨을 1씩 깎으며 반영되게 세팅한다음
충돌감지 함수에 리턴값을 줘서 충돌한 cactus 는 바로 사라지게끔 했다.
function collisionDetection(dino, cactus){
let xValue = cactus.x - ( dino.x + dino.width );
let yValue = cactus.y - ( dino.y + dino.height );
if( xValue < 0 && yValue < 0 ){ // 충돌!
// 충돌 시 실행되는 코드
life--;
document.querySelector('#life').innerHTML = life;
if(life == 0){
alert('게임오버');
gameState = 0;
cancelAnimationFrame(animation);
// ctx.clearRect(0, 0, canvas.width, canvas.height); // 작동이 안되서 새로고침으로 대체
location.reload();
}
return -1;
} else {
return 1;
}
}
cactusArr.forEach((a, i, o)=>{
if(a.x < 0){
o.splice(i, 1);
score += 10;
document.querySelector('#score').innerHTML = score;
} else if(collisionDetection(dino, a) < 0){
o.splice(i, 1);
}
a.x -= 2;
a.draw();
})
나머지 dino 와 cactus 들의 크기, 속도까지 입맛에 맞게 조정하면 다음과 같은 코드가 된다.
let canvas = document.querySelector('#canvas');
let ctx = canvas.getContext('2d'); // context 란 뜻으로 ctx
canvas.width = window.innerWidth - 100;
canvas.height = window.innerHeight - 100;
let dino = {
x: 10,
y: 200,
width: 40,
height: 50,
draw() {
ctx.fillStyle = 'green';
ctx.fillRect(this.x, this.y, this.width, this.height);
}
}
class Cactus {
constructor() {
this.width = 20 + getRandomInt(-3, 4);
this.height = 30 + getRandomInt(-3, 4);
this.x = 500;
this.y = 250 - this.height;
}
draw() {
ctx.fillStyle = 'red';
ctx.fillRect(this.x, this.y, this.width, this.height);
}
}
let timer = 0;
let cactusArr = [];
let gameState = 0; // 0: end, 1: start
let jumpState = 0; // 0: default, 1: jumping
let jumpTimer = 0;
let animation;
let life = 5;
let score = 0;
function frameAction() {
animation = requestAnimationFrame(frameAction);
ctx.clearRect(0, 0, canvas.width, canvas.height);
timer += 1;
if(timer % 120 == 0){
let cactus = new Cactus();
cactusArr.push(cactus);
}
cactusArr.forEach((a, i, o)=>{
if(a.x < 0){
o.splice(i, 1);
score += 10;
document.querySelector('#score').innerHTML = score;
} else if(collisionDetection(dino, a) < 0){
o.splice(i, 1);
}
a.x -= 2;
a.draw();
})
if(jumpState == 1){
jumpTimer++;
dino.y -= 2;
}
if(jumpTimer > 50){
jumpState = 0;
jumpTimer = 0;
}
if(jumpState == 0){
if(dino.y < 200){
dino.y += 2;
}
}
drawLine();
dino.draw();
}
document.addEventListener('keydown', (e)=>{
if(e.code == 'Space'){
if(gameState == 0){
gameState = 1; // 게임실행
frameAction();
document.querySelector('h2').style.display = 'none';
} else if(gameState == 1){ // 게임실행중일때 스페이스누르면
jumpState = 1; // 점프중으로 변경
}
}
})
function collisionDetection(dino, cactus){
let xValue = cactus.x - ( dino.x + dino.width );
let yValue = cactus.y - ( dino.y + dino.height );
if( xValue < 0 && yValue < 0 ){ // 충돌!
// 충돌 시 실행되는 코드
life--;
document.querySelector('#life').innerHTML = life;
if(life == 0){
alert('게임오버');
gameState = 0;
cancelAnimationFrame(animation);
// ctx.clearRect(0, 0, canvas.width, canvas.height); // 작동이 안되서 새로고침으로 대체
location.reload();
}
return -1;
} else {
return 1;
}
}
function getRandomInt(min, max) {
min = Math.ceil(min);
max = Math.floor(max);
return Math.floor(Math.random() * (max - min)) + min; //최댓값은 제외, 최솟값은 포함
}
function drawLine(){
ctx.beginPath();
ctx.moveTo(0, 250);
ctx.lineTo(600, 250);
ctx.stroke();
}
EZ
728x90
'개인프로젝트 > 구글 공룡 게임' 카테고리의 다른 글
javascript - 구글 공룡 게임 구현(7) - 이미지 씌우기 (0) | 2022.06.23 |
---|---|
javascript - 구글 공룡 게임 구현(5) - Collision detection(충돌감지) (0) | 2022.06.22 |
javascript - 구글 공룡 게임 구현(4) (0) | 2022.06.22 |
javascript - 구글 공룡 게임 구현(3) (0) | 2022.06.22 |
javascript - 구글 공룡 게임 구현(2) (0) | 2022.06.22 |