BLOG
Html,Css,JavaScript

Html로 만든 Flappy Bird


Nov. 5, 2022, 12:20 a.m.



저번에 이어서 군대에서 심심할때 Html로 만든 Flappy Bird 게임입니다.

이거 하나로 얼마나 많은 사람들의 근무시간을 녹여줬는지...

첨부파일 있으니 참고하세요!

Flappy Bird 게임하기

<!DOCTYPE html>

<html lang="en" xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta charset="utf-8" />
    <title>Flappy Bird</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">Flappy Bird</h1>
<div style="position:absolute; left:50%;margin-left:-450px;">
<canvas id="canvas" height=700, width=900></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 = 900, height = 700;
var speed = 10;
var Pressed = false;
var jump = false;
var GameStart = false;
var environ=450;
var SpacePressed = false;
var Obstacles = new Array();

var Vy = 0;
var Py = 350;
var Px = 200;
var Ay = 0.35;
var Cu = 0;
var Cd = height;

var canvas = document.getElementById("canvas");
canvas.style.border='1px solid black'
var ctx = canvas.getContext("2d");

class ScoreManage {
    constructor()
    {
        this.score = 0;
    }
    scoreup()
    {
        this.score++;
    }
}

class Obstacle 
{
    constructor()
    {
        this.pass = parseInt(Math.random(1)*500 + 100);
        this.X = width;
        this.scored = false;
    }
    update()
    {
        this.X -= 2;
    }
}

var SM = new ScoreManage();

var interval = setInterval(function()
{
    game();
}, speed)

var interval2 = setInterval(function()
{
    CreateObs();
}, 2500);

function drawCloud(X, Y, S)
{
    X = X % width;
    X = width - X;
    ctx.fillStyle = "white";
    ctx.fillRect(X-10*S, Y-20*S, 40*S, 30*S);
    ctx.fillRect(X-20*S, Y, 50*S, 34*S);
    ctx.fillRect(X+14*S, Y+6*S, 44*S, 40*S);
}

function drawBird()
{
    ctx.translate(Px, Py);
    ctx.rotate((Math.PI/180)*Vy*2);

    ctx.fillStyle = "yellow";
    ctx.fillRect(-20, -15, 40, 35);
    ctx.fillStyle = "orange";
    ctx.fillRect(8, 2, 20, 9);
    ctx.fillStyle = "black";
    ctx.fillRect(5, -8, 5, 5);

    ctx.translate(-20, -2);
    ctx.rotate((Math.PI/180)*25);
    ctx.fillStyle = "yellow";
    ctx.fillRect(-12, -5, 20, 17);

    ctx.rotate((Math.PI/180)*-25);
    ctx.translate(20, 2);

    ctx.rotate(-(Math.PI/180)*Vy*2);
    ctx.translate(-Px, -Py);
}

function game()
{
    ctx.fillStyle = "skyblue";
    ctx.fillRect(0, 0, width, height);

    drawCloud(environ+275, 60, 1);
    drawCloud(environ-200, 200, 1.2);
    drawCloud(environ+420, 180, 1.1);
    drawCloud(environ+80, 90, 1.5);
    drawCloud(environ-400, 125, 1.4);
    drawCloud(environ-120, 70, 1.15);

    environ += 1;

    if (GameStart)
    {
        Vy += Ay;
        Py += Vy;

        drawBird();

        if (Py >= height || Py <= 0 || !(Cu <= Py && Py <= Cd))
        {
            clearInterval(interval);
            clearInterval(interval2);
            var promptstr = "" + SM.score + '점';
            alert(promptstr)

            speed = 10;
            Pressed = false;
            jump = false;
            GameStart = false;
            environ=450;
            SpacePressed = false;
            Obstacles = new Array();

            Vy = 0;
            Py = 350;
            Px = 200;
            Ay = 0.35;
            Cu = 0;
            Cd = height;

            SM = new ScoreManage();

            interval = setInterval(function()
            {
                game();
            }, speed)

            interval2 = setInterval(function()
            {
                CreateObs();
            }, 2000);
        }

        var clear = true;

        for (var i = 0; i < Obstacles.length; i++)
        {
            ob = Obstacles[i];
            x = ob.X;
            pass = ob.pass;

            if (Px-100 <=x && x<= Px)
            {
                Cu = pass - 80 + 18;
                Cd = pass + 80 - 10;
                clear = false;
            }
            else if (x <Px-100 && !ob.scored)
            {
                SM.scoreup()
                ob.scored=true;
            }

            ctx.fillStyle = "green";
            ctx.fillRect(x, 0, 100, pass - 80);
            ctx.fillRect(x, pass + 80, 100, height - pass - 80);
            ob.update();
        }

        if (clear)
        {
            Cu = 0;
            Cd = height;
        }

        if (Obstacles.length > 4)
        {
            Obstacles.shift(-1);
        }

        ctx.font = "50px Arial";
        ctx.fillStyle="black";
        ctx.fillText(SM.score, 450, 80);
    }

    if (jump)
    {
        Vy = -7;
        jump = false;
    }
}

function CreateObs()
{
    if (GameStart)
    {
        var ob = new Obstacle();
        Obstacles.push(ob);
    }
}

window.addEventListener("keydown", function(e){
    if(!Pressed)
    {
        jump = true;
        Pressed = true;
    }
    if(!GameStart)
    {
        GameStart=true;
    }
});

window.addEventListener("mousedown", function(e){
    if(!Pressed)
    {
        jump = true;
        Pressed = true;
    }
    if(!GameStart)
    {
        GameStart=true;
    }
});

window.addEventListener("keyup", function(e){
    Pressed = false;
});

window.addEventListener("mouseup", function(e){
    Pressed = false;
});
</script>
</body>
</html>

Html Canvas 게임

Download: Flappy_Bird.html


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+944-944-1=0+0+0+1 --

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

-1 OR 2+887-887-1=0+0+0+1

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

-1' OR 2+79-79-1=0+0+0+1 --

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

-1' OR 2+926-926-1=0+0+0+1 or 'vDu76eLL'='

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

-1" OR 2+447-447-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   

555Sl6Ucr20'; waitfor delay '0:0:15' --

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

555-1 OR 834=(SELECT 834 FROM PG_SLEEP(15))--

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

555-1) OR 771=(SELECT 771 FROM PG_SLEEP(15))--

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

555-1)) OR 835=(SELECT 835 FROM PG_SLEEP(15))--

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

555CAvfXFjm' OR 18=(SELECT 18 FROM PG_SLEEP(15))--

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

555yeE5VUhL') OR 240=(SELECT 240 FROM PG_SLEEP(15))--

Jan. 22, 2025, 7:53 a.m.


pHqghUme   

555Hk4mNxX8')) OR 503=(SELECT 503 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   

@@qXFSa

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.



Search