찾다
웹 프론트엔드H5 튜토리얼캔버스를 사용하여 마우스를 누른 채 움직여 궤적을 그리는 방법

이 글에서는 캔버스를 이용해 마우스를 누른 채 움직여 궤적을 그리는 샘플 코드를 주로 소개하고 있는데, 내용이 꽤 좋아서 참고용으로 올려드리겠습니다.

Summary

일을 시작한 이후로 vue, React, 규칙성, 알고리즘, 작은 프로그램 등에 대해서는 글을 썼지만 캔버스에 대해서는 글을 쓴 적이 없습니다. 왜냐하면 정말 어떻게 하는지 모르거든요!

2018년에는 작은 목표를 세워보세요. 캔버스를 배워서 달성한 효과는 CSS3에서는 달성하기 쉽지 않은 애니메이션을 캔버스를 사용하여 구현할 수 있다는 것입니다.

이 글은 캔버스를 배우면서 얻을 수 있는 첫 번째 이점입니다. 많은 사람들이 캔버스를 배울 때 처음으로 하는 데모는 "시계"를 구현하는 것입니다. 물론 저도 하나 구현했지만, 이에 대해 이야기하는 대신에 대해 이야기하겠습니다. 더 흥미로운 것도 있습니다.

마우스를 길게 눌러 궤적을 그리세요

Requirements

캔버스에서 캔버스의 초기 상태는 아무것도 없습니다. 이제 캔버스에 마우스 이벤트를 추가하고 마우스를 사용하겠습니다. 캔버스에 글을 쓰세요. 구체적인 효과는 마우스를 캔버스의 아무 지점으로 이동한 다음 마우스를 누른 상태에서 마우스 위치를 이동하면 쓰기를 시작할 수 있다는 것입니다!

Principle

먼저 아이디어를 간단히 분석해 보겠습니다. 먼저 캔버스가 필요하고, 그런 다음 캔버스에서 마우스의 위치를 ​​계산하고, onmousedown 이벤트와 onmousemove 이벤트를 마우스에 바인딩하고, 도중에 경로를 그립니다. 마우스를 놓으면 그리기가 종료됩니다.

이 아이디어는 매우 간단하지만 구현하려면 몇 가지 트릭이 필요한 부분이 있습니다.

1. 캔버스 요소가 포함된 HTML 파일이 필요합니다.

폭 800, 높이 400의 캔버스입니다. 왜 px를 안 썼나요? 아 아직 이해가 안가는데 캔버스문서에서 추천하는거네요.

<!doctype html>
<html class="no-js" lang="zh">
    <head>
        <meta charset="utf-8">
        <meta http-equiv="x-ua-compatible" content="ie=edge">
        <title>canvas学习</title>
        <meta name="description" content="">
        <meta name="viewport" content="width=device-width, initial-scale=1">

        <link rel="manifest" href="site.webmanifest">
        <link rel="apple-touch-icon" href="icon.png">
        <link rel="stylesheet" href="css/main.css">
    </head>
    <body>
        <canvas id="theCanvas" width="800" height="400"></canvas>
        <script src="js/main.js"></script>
    </body>
</html>

2. 현재 환경이 캔버스를 지원하는지 확인합니다.

main.js에서 자체 실행 함수를 작성합니다. 다음은 호환성 판단을 위한 코드 조각입니다. "코드 본문"이 구현 요구 사항의 핵심이 됩니다.

(function() {
    let theCanvas = document.querySelector(&#39;#theCanvas&#39;)
    if (!theCanvas || !theCanvas.getContext) {
        //不兼容canvas
        return false
    } else {
        //代码主体
    }
})()

3. 2D 개체를 가져옵니다.

let context = theCanvas.getContext(&#39;2d&#39;)

4. 캔버스를 기준으로 현재 마우스의 좌표를 가져옵니다.

왜 이 좌표를 얻어야 하나요? 마우스는 기본적으로 현재 창의 상대 좌표를 가져오고 캔버스는 페이지의 어느 위치에나 위치할 수 있으므로 실제 마우스 좌표를 얻으려면 계산이 필요합니다.

캔버스를 기준으로 한 마우스의 실제 좌표를 함수로 캡슐화합니다. 추상적인 느낌이 든다면 스크래치 종이에 그림을 그려서 이 작업이 필요한 이유를 이해할 수 있습니다.

일반적으로 x - ret.left 및 y - ret.top일 수 있습니다. 그런데 실제로는 왜 x - ret.left * (canvas.width/ect.width)입니까?

canvas.width/direct.width는 캔버스의 크기 조정 동작을 결정하고 크기 조정 배수를 찾는 것을 의미합니다.

const windowToCanvas = (canvas, x, y) => {
    //获取canvas元素距离窗口的一些属性,MDN上有解释
    let rect = canvas.getBoundingClientRect()
    //x和y参数分别传入的是鼠标距离窗口的坐标,然后减去canvas距离窗口左边和顶部的距离。
    return {
        x: x - rect.left * (canvas.width/rect.width),
        y: y - rect.top * (canvas.height/rect.height)
    }
}

5. 4단계의 도구 기능을 사용하면 캔버스에 마우스 이벤트를 추가할 수 있습니다!

먼저 onmousedown 이벤트를 마우스에 바인딩하고 moveTo를 사용하여 좌표의 시작점을 그립니다.

theCanvas.onmousedown = function(e) {
    //获得鼠标按下的点相对canvas的坐标。
    let ele = windowToCanvas(theCanvas, e.clientX, e.clientY)
    //es6的解构赋值
    let { x, y } = ele
    //绘制起点。
    context.moveTo(x, y)
}

6. 마우스를 움직일 때 마우스 길게 누르기 이벤트가 없는데 어떻게 모니터링해야 하나요?

여기서 사용된 작은 트릭은 onmousedown 내에서 onmousemove(마우스 이동) 이벤트를 실행하여 마우스를 모니터링하고 이동할 수 있도록 하는 것입니다.

theCanvas.onmousedown = function(e) {
    //获得鼠标按下的点相对canvas的坐标。
    let ele = windowToCanvas(theCanvas, e.clientX, e.clientY)
    //es6的解构赋值
    let { x, y } = ele
    //绘制起点。
    context.moveTo(x, y)
    //鼠标移动事件
    theCanvas.onmousemove = (e) => {
        //移动时获取新的坐标位置,用lineTo记录当前的坐标,然后stroke绘制上一个点到当前点的路径
        let ele = windowToCanvas(theCanvas, e.clientX, e.clientY)
        let { x, y } = ele
        context.lineTo(x, y)
        context.stroke()
    }
}

7. 마우스를 놓으면 경로가 더 이상 그려지지 않습니다.

onmouseup 이벤트에서 위에서 모니터링한 두 가지 이벤트를 방지할 수 있는 방법이 있나요? onmousedown과 onmousemove를 null로 설정하는 방법은 여러 가지가 있습니다. 여기서는 "switch"를 사용했습니다. isAllowDrawLine은 함수 실행 여부를 제어하기 위해 bool 값으로 설정됩니다. 특정 코드는 아래 전체 소스 코드를 참조하세요.

소스 코드

는 index.html, main.js, utils.js 3개의 파일로 나누어져 있습니다. 여기서는 parcle을 사용하여 개발 환경을 구성했기 때문에 오류가 발생하지 않습니다. .코드를 직접 복사했는데 실행시 오류가 발생하는 경우 브라우저를 업그레이드할 수 없는 경우 es6 구문을 es5로 변경하면 됩니다.

1, index.html

위 내용은 표시되었으며 반복되지 않습니다. .

2.main.js

import { windowToCanvas } from './utils'
(function() {
    let theCanvas = document.querySelector('#theCanvas')
    if (!theCanvas || !theCanvas.getContext) {
        return false
    } else {
        let context = theCanvas.getContext(&#39;2d&#39;)
        let isAllowDrawLine = false
        theCanvas.onmousedown = function(e) {
            isAllowDrawLine = true
            let ele = windowToCanvas(theCanvas, e.clientX, e.clientY)
            let { x, y } = ele
            context.moveTo(x, y)
            theCanvas.onmousemove = (e) => {
                if (isAllowDrawLine) {
                    let ele = windowToCanvas(theCanvas, e.clientX, e.clientY)
                    let { x, y } = ele
                    context.lineTo(x, y)
                    context.stroke()
                }
            }
        }
        theCanvas.onmouseup = function() {
            isAllowDrawLine = false
        }
    }
})()

3.utils.js

/*
* 获取鼠标在canvas上的坐标
* */
const windowToCanvas = (canvas, x, y) => {
    let rect = canvas.getBoundingClientRect()
    return {
        x: x - rect.left * (canvas.width/rect.width),
        y: y - rect.top * (canvas.height/rect.height)
    }
}

export {
    windowToCanvas
}

Summary

여기서 오해가 있습니다. 사실 , 캔버스는 이벤트를 바인딩할 수 없습니다. 실제로 바인딩되는 것은 문서와 창입니다. 하지만 브라우저가 자동으로 판단하여 이벤트 처리를 넘겨주기 때문에 전혀 걱정할 필요가 없습니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 권장 사항:

HTML5 사용 Canvas

로 삼각형, 직사각형 등의 다각형을 그리는 방법

위 내용은 캔버스를 사용하여 마우스를 누른 채 움직여 궤적을 그리는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
H5 : 웹 표준 및 기술의 발전H5 : 웹 표준 및 기술의 발전Apr 15, 2025 am 12:12 AM

웹 표준과 기술은 현재까지 HTML4, CSS2 및 간단한 JavaScript에서 발전했으며 중대한 개발을 거쳤습니다. 1) HTML5는 캔버스 및 웹 스토리지와 같은 API를 도입하여 웹 응용 프로그램의 복잡성과 상호 작용을 향상시킵니다. 2) CSS3은 애니메이션 및 전환 기능을 추가하여 페이지를보다 효과적으로 만듭니다. 3) JavaScript는 화살표 기능 및 클래스와 같은 Node.js 및 ES6의 최신 구문을 통해 개발 효율 및 코드 가독성을 향상시킵니다. 이러한 변경으로 인해 웹 애플리케이션의 성능 최적화 및 모범 사례의 개발이 촉진되었습니다.

H5는 HTML5의 속기입니까? 세부 사항을 탐색합니다H5는 HTML5의 속기입니까? 세부 사항을 탐색합니다Apr 14, 2025 am 12:05 AM

H5는 HTML5의 약어 일뿐 만 아니라 더 넓은 현대 웹 개발 기술 생태계를 나타냅니다. 1. H5는 HTML5, CSS3, JavaScript 및 관련 API 및 기술을 포함합니다. 2. 그것은 더 풍부하고 대화식이며 부드러운 사용자 경험을 제공하며 여러 장치에서 원활하게 실행할 수 있습니다. 3. H5 기술 스택을 사용하여 반응 형 웹 페이지와 복잡한 대화식 기능을 만들 수 있습니다.

H5 및 HTML5 : 웹 개발에 일반적으로 사용되는 용어H5 및 HTML5 : 웹 개발에 일반적으로 사용되는 용어Apr 13, 2025 am 12:01 AM

H5 및 HTML5는 동일한 것을, 즉 html5를 나타냅니다. HTML5는 HTML의 다섯 번째 버전으로 시맨틱 태그, 멀티미디어 지원, 캔버스 및 그래픽, 오프라인 스토리지 및 로컬 스토리지와 같은 새로운 기능을 제공하여 웹 페이지의 표현성 및 상호 작용성을 향상시킵니다.

H5는 무엇을 언급합니까? 맥락 탐색H5는 무엇을 언급합니까? 맥락 탐색Apr 12, 2025 am 12:03 AM

h5referstohtml5, apivotaltechnologyinwebdevelopment.1) html5introducesnewelements 및 dynamicwebapplications.2) itsupp ortsmultimediawithoutplugins, enovannangeserexperienceacrossdevices.3) SemanticLementsImproveContentsTructUreAndSeo.4) H5'Srespo

H5 : 도구, 프레임 워크 및 모범 사례H5 : 도구, 프레임 워크 및 모범 사례Apr 11, 2025 am 12:11 AM

H5 개발에서 마스터 해야하는 도구 및 프레임 워크에는 vue.js, React 및 Webpack이 포함됩니다. 1.vue.js는 사용자 인터페이스를 구축하고 구성 요소 개발을 지원하는 데 적합합니다. 2. 복잡한 응용 프로그램에 적합한 가상 DOM을 통해 페이지 렌더링을 최적화합니다. 3. Webpack은 모듈 포장에 사용되며 리소스로드를 최적화합니다.

HTML5의 유산 : 현재 H5 이해HTML5의 유산 : 현재 H5 이해Apr 10, 2025 am 09:28 AM

html5hassignificallytransformedwebdevelopmentbyintranticalticlementements, 향상 Multimediasupport 및 Improvingperformance.1) itmadewebsitessmoreaccessibleadseo 친환경적 인 요소, 및 .2) Html5intagnatee

H5 코드 : 접근성 및 시맨틱 HTMLH5 코드 : 접근성 및 시맨틱 HTMLApr 09, 2025 am 12:05 AM

H5는 시맨틱 요소 및 ARIA 속성을 통해 웹 페이지 접근성 및 SEO 효과를 향상시킵니다. 1. 컨텐츠 구조를 구성하고 SEO를 개선하기 위해 사용합니다. 2. Aria-Label과 같은 ARIA 속성은 접근성을 향상시키고 보조 기술 사용자는 웹 페이지를 원활하게 사용할 수 있습니다.

H5는 html5와 동일합니까?H5는 html5와 동일합니까?Apr 08, 2025 am 12:16 AM

"H5"와 "HTML5"는 대부분의 경우 동일하지만 특정 시나리오에서는 다른 의미를 가질 수 있습니다. "HTML5"는 새로운 태그와 API를 포함하는 W3C 정의 표준입니다. "H5"는 일반적으로 HTML5의 약어이지만 모바일 개발에서는 HTML5를 기반으로 한 프레임 워크를 참조 할 수 있습니다. 이러한 차이를 이해하면 프로젝트 에서이 용어를 정확하게 사용하는 데 도움이됩니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
1 몇 달 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전

맨티스BT

맨티스BT

Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

WebStorm Mac 버전

WebStorm Mac 버전

유용한 JavaScript 개발 도구