본문 바로가기
JavaScript

[JavaScript] Canvas로 클릭 이벤트를 받아 애니메이션 만들기(+루프)

by teamnova 2023. 8. 22.
728x90

안녕하세요. 지난 시간 canvas를 이용해 원을 이동시켰다면 오늘은 클릭 이벤트를 받아 시작과 정지를 만들고 원이 끝에 도착했을 때 다시 원점으로 돌아가 시작하는 기능을 만들어 보겠습니다.

 

먼저 지난 시간 예제의 링크입니다.

https://stickode.tistory.com/886

 

html 파일 코드 입니다.

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <canvas id="myCanvas" width="400" height="300"></canvas>

    <script>
        const canvas = document.getElementById("myCanvas");
        //그리기객체
        const context = canvas.getContext("2d");
        let move_ev = false;
        // 시작 좌표
        let x = 0;
        let ani;

        // 애니메이션
        function MoveCircle(){
        //캔버스 지우기
        context.clearRect(0, 0, canvas.width, canvas.height);

        // 원 생성
        context.beginPath();
        context.arc(x, 150, 10, 0, Math.PI * 2, false);
        context.fill();

        //x좌표값 추가함으로서 이동시키기
        x += 2;
       
        //x좌표값이 380이 넘어가면 다시 x좌표값을 0으로 만들어 새로 시작하게 하기
        if(x >= 380){
            x = 0;
        }
        ani = requestAnimationFrame(MoveCircle);
        }

        //클릭 시 이벤트
        canvas.addEventListener("click",()=>{
            if(move_ev){
                move_ev = false;
                cancelAnimationFrame(ani);
            }else{
                move_ev = true;
                MoveCircle();
            }
        })
       
         
       
    </script>
</body>
</html>

실행 영상입니다.

클릭시 애니메이션이 시작이 되고 다시 한번 클릭하면 멈춥니다.