Html,Css,JavaScript
Html
Canvas
게임
Download: Pong2P.html
Html로 만든 PONG 게임
Nov. 3, 2022, 11:36 a.m.
저는 군대에서 보급계라 컴퓨터를 만질 일이 많았습니다. 그래서 군생활을 녹이기 위해 여러 방법을 생각해 보다가 다른 해군 어느 부대에서 html로 테트리스를 만들었길래 저도 그 테트리스 코드를 뜯어보며 html canvas를 이용한 게임 제작에 대해서 알게 되었죠.
전역하기까지 한 5개 정도의 게임을 만들었는데 나오기전에 코드를 다 적어왔습니다. 그래서 그것들을 하나하나 올려보려고 합니다.
제일 먼저 PONG 2P 입니다.
.
PONG이라는 아주 전통적인 아케이드 게임이 있죠. 저는 그것을 살짝 변형해서 막대의 가운데 부분을 정확히 맞추게 되면 속도가 빨라지는 시스템을 넣어봤습니다.
.
.
밑에는 코드 전문입니다. 첨부파일로도 올려놨으니 확인해보세요.
아무래도 군대에서 메모장으로 짬짬히 개발을 하다보니까 깔끔한 코드를 짜지는 못했습니다..
<!DOCTYPE html>
<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta charset="utf-8" />
<title>Pong2P</title>
<link href="https://cdn.jsdelivr.net/npm/bootstrap@5.2.2/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-Zenh87qX5JnK2Jl0vWa8Ck2rdkQ2Bzep5IDxbcnCeuOxjzrPF/et3URy9Bv1WTRi" crossorigin="anonymous">
</head>
<body>
<h1 class="text-center">PONG 2P</h1>
<div style="position:absolute; left:50%;margin-left:-600px;">
<canvas id="canvas" height=800, width=1200></canvas>
</div>
<script src="https://cdn.jsdelivr.net/npm/bootstrap@5.2.2/dist/js/bootstrap.bundle.min.js" integrity="sha384-OERcA2EqjJCMA+/3y+gxIOqMEjwtxJY7qPCqsdltbNJuaOe923+mo//f6V8Qbsw3" crossorigin="anonymous"></script>
<script>
var width=1200, height=800;
var GAME = false;
var GAMEOVER = false;
var AREADY = false;
var BREADY = false;
var barw = 100;
var Hw = 20;
var barh = 20;
var barv = 1;
var ballw = 20;
var bard = 50;
var coll = barh;
var BOOSTED = false;
var BoostC = 2.7;
var speed=10;
var key = [];
var APoints = 0;
var BPoints=0;
var Ay = height / 2 - barw /2;
var By = height / 2 - barw/2;
var Av = 0;
var Bv = 0;
var cx = 0.2;
var cy = 0.4;
var Px = width/2;
var Py = height/2;
var Pvx = 5 * dir() * 2;
var Pvy = 6 * dir() * 0.8;
var canvas = document.getElementById("canvas");
canvas.style.border='1px solid black'
var ctx = canvas.getContext("2d");
function dir()
{
a = Math.random(1);
if (a>= 0.5)
{
return 0.5;
}
else
{
return -0.5;
}
}
function reset()
{
GAME = false;
AREADY = false;
BREADY = false;
Pvx = 5 * dir() * 2;
Pvy = 6 * dir() * 0.8;
Ay = height/2 - barw/2;
By = height/2 - barw/2;
Px = width/2;
Py = height/2;
Av = 0;
Bv = 0;
}
function ball()
{
if(BOOSTED)
{
ctx.fillStyle="red";
}
else
{
ctx.fillStyle="white";
}
ctx.fillRect(Px - ballw/2, Py - ballw/2, ballw, ballw);
Px += Pvx;
Py += Pvy;
if(Pvx < 0 && Px < bard + ballw + ballw/2 && Px > bard + ballw + ballw/2 - coll && Ay < Py && Py < Ay + barw)
{
if(BOOSTED)
{
Pvx = Pvx / BoostC;
BOOSTED=false;
}
if(Ay + barw / 2 - Hw /2 < Py && Py < Ay +barw/2 + Hw/2)
{
BOOSTED = true;
Pvx = - BoostC * (Pvx);
Pvy += Av * cy;
}
else
{
Pvx = -1 * (Pvx);
Pvy += Av * cy;
}
}
if (Pvx > 0 && Px + ballw + ballw/2 + bard > width && Px + ballw + ballw/2 + bard < width + coll && By < Py && Py < By + barw)
{
if(BOOSTED)
{
Pvx = Pvx / BoostC;
BOOSTED = false;
}
if (By + barw/2 - Hw/2 < Py && Py < By + barw/2 + Hw/2)
{
BOOSTED = true;
Pvx = -BoostC * Pvx;
Pvy += Bv * cy;
}
else
{
Pvx = -1 * Pvx;
Pvy += Bv * cy;
}
}
if (Py < ballw/2)
{
Pvy = -Pvy;
}
if (Py + ballw/2 > height)
{
Pvy = -Pvy;
}
if(Px < 0)
{
BPoints +=1;
reset();
}
if(Px > width)
{
APoints +=1;
reset();
}
}
function points()
{
ctx.fillStyle="white";
ctx.font="40px Arial";
ctx.fillText(APoints, width/4, 40);
ctx.fillText(BPoints, width * 3 / 4, 40);
}
function game()
{
ctx.fillStyle="black";
ctx.fillRect(0, 0, width, height);
ctx.fillStyle="white";
ctx.fillRect(bard, Ay, barh, barw);
ctx.fillRect(width-barh-bard, By, barh, barw);
ctx.fillStyle="red";
ctx.fillRect(bard, Ay + barw/2 - Hw/2, barh, Hw);
ctx.fillRect(width - barh - bard, By + barw/2 - Hw/2, barh, Hw);
if (GAME)
{
ball();
points();
if(key[83]&&!(Av < 0))
{
Av += barv;
if(Av > 10)
Av = 10;
}
else if (key[87]&&!(Av > 0))
{
Av += -barv;
if(Av < -10)
Av = -10;
}
else
Av = 0;
if(key[40]&&!(Bv < 0))
{
Bv += barv;
if(Bv > 10)
Bv = 10;
}
else if (key[38]&&!(Bv > 0))
{
Bv += -barv;
if(Bv < -10)
Bv = -10;
}
else
Bv = 0;
Ay += Av;
if(Ay < 0)
Ay = 0;
else if (Ay > height - barw)
Ay = height - barw;
By += Bv;
if(By < 0)
By = 0;
else if (By > height - barw)
By = height - barw
if (APoints > 9 || BPoints > 9)
{
if (APoints > BPoints)
{
alert("A SIDE WIN!");
}
else
{
alert("B SIDE WIN!");
}
APoints=0;
BPoints=0;
GAME=false;
}
}
else
{
BOOSTED=false;
points();
ctx.filStyle="white";
ctx.fillRect(Px-ballw/2, Py - ballw/2, ballw, ballw);
ctx.fillStyle = "white";
ctx.font="40px Arial";
if(key[65])
AREADY = true;
if(key[39])
BREADY = true;
if(AREADY&&BREADY)
GAME=true;
if(AREADY)
{
ctx.fillText("READY", width/6, 100);
}
if(BREADY)
{
ctx.fillText("READY", width * 4 / 6, 100);
}
}
}
var interval = setInterval(function()
{
game();
}, speed);
window.addEventListener("keydown", function(e)
{
key[e.keyCode]=true;
});
window.addEventListener("keyup", function(e){
key[e.keyCode]=false;
})
</script>
</body>
</html>
Download: Pong2P.html
Html,Css,JavaScript 의 다른 글 보기
pHqghUme
555
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555
Jan. 22, 2025, 7:53 a.m.
pHqghUme
-1 OR 2+59-59-1=0+0+0+1 --
Jan. 22, 2025, 7:53 a.m.
pHqghUme
-1 OR 2+811-811-1=0+0+0+1
Jan. 22, 2025, 7:53 a.m.
pHqghUme
-1' OR 2+513-513-1=0+0+0+1 --
Jan. 22, 2025, 7:53 a.m.
pHqghUme
-1' OR 2+714-714-1=0+0+0+1 or 'KqiHbgki'='
Jan. 22, 2025, 7:53 a.m.
pHqghUme
-1" OR 2+489-489-1=0+0+0+1 --
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555*if(now()=sysdate(),sleep(15),0)
Jan. 22, 2025, 7:53 a.m.
pHqghUme
5550'XOR(555*if(now()=sysdate(),sleep(15),0))XOR'Z
Jan. 22, 2025, 7:53 a.m.
pHqghUme
5550"XOR(555*if(now()=sysdate(),sleep(15),0))XOR"Z
Jan. 22, 2025, 7:53 a.m.
pHqghUme
(select(0)from(select(sleep(15)))v)/*'+(select(0)from(select(sleep(15)))v)+'"+(select(0)from(select(sleep(15)))v)+"*/
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555-1; waitfor delay '0:0:15' --
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555-1); waitfor delay '0:0:15' --
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555-1 waitfor delay '0:0:15' --
Jan. 22, 2025, 7:53 a.m.
pHqghUme
5551mI4H4ty'; waitfor delay '0:0:15' --
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555-1 OR 873=(SELECT 873 FROM PG_SLEEP(15))--
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555-1) OR 229=(SELECT 229 FROM PG_SLEEP(15))--
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555-1)) OR 872=(SELECT 872 FROM PG_SLEEP(15))--
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555Hp7WRkJO' OR 706=(SELECT 706 FROM PG_SLEEP(15))--
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555ma5A7bD8') OR 386=(SELECT 386 FROM PG_SLEEP(15))--
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555gkYRU02p')) OR 331=(SELECT 331 FROM PG_SLEEP(15))--
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555*DBMS_PIPE.RECEIVE_MESSAGE(CHR(99)||CHR(99)||CHR(99),15)
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555'||DBMS_PIPE.RECEIVE_MESSAGE(CHR(98)||CHR(98)||CHR(98),15)||'
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555'"
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555����%2527%2522\'\"
Jan. 22, 2025, 7:53 a.m.
pHqghUme
@@HDzfj
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555
Jan. 22, 2025, 7:53 a.m.
pHqghUme
555
Jan. 22, 2025, 7:53 a.m.