【canvas】实现画布橡皮擦功能、并解决擦除不连贯问题;

2024-02-09 13:20

本文主要是介绍【canvas】实现画布橡皮擦功能、并解决擦除不连贯问题;,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 简单介绍橡皮擦功能思路,代码demo自己看看就好了,一点都不复杂:

  1. 确认橡皮擦大小,可动态设置;
  2. 鼠标按下记录点击的坐标,然后根据设置的橡皮擦大小画一个圆,最后清除该圆形区域坐标范围的颜色信息;然后创建鼠标移动事件;
  3. 按下后鼠标移动过程中对移动的轨迹坐标进行清除颜色信息。
  4. 移动过程中,为了解决鼠标移动事件响应是有时间间隔的,导致正常情况下鼠标快速移动时出现橡皮擦擦除颜色不连贯的问题,为此需要每次擦除需记录上个坐标点,然后对当前坐标点连起来,连起来的范围就是要擦除的坐标范围;
  5. 鼠标松开销毁移动事件;
  6. 没有6了兄弟,功能就是这么简单;
<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><style>* {box-sizing: border-box;margin: 0;padding: 0;}#c {position: absolute;width: 800px;height: 600px;top: 0;left: 0;border: 1px solid black;}#background {font-size: 40px;width: 800px;height: 600px;user-select: none;overflow: hidden;}</style></head><body><div id="background">这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图,这是底图</div><canvas id="c" width="800" height="600"></canvas><div><button id="hehe">爱尔奎特</button></div><script>const eraserWidth = 30;var ctx = c.getContext("2d");ctx.fillStyle = "#336699";ctx.fillRect(0, 0, c.width, c.height);ctx.globalCompositeOperation = "destination-out";let beginP = { x: 0, y: 0 };c.onmousedown = function (e) {beginP.x = e.offsetX;beginP.y = e.offsetY;ctx.beginPath();ctx.arc(beginP.x, beginP.y, eraserWidth / 2, 0, Math.PI * 2);ctx.fill();ctx.closePath();c.onmousemove = function (e) {var tx = e.offsetX;var ty = e.offsetY;ctx.beginPath();ctx.lineJoin = ctx.lineCap = "round";ctx.lineWidth = eraserWidth;ctx.moveTo(beginP.x, beginP.y);ctx.lineTo(tx, ty);ctx.closePath();ctx.stroke();beginP.x = tx;beginP.y = ty;};};c.onmouseup = function () {c.onmousemove = "null";};</script></body>
</html>

这篇关于【canvas】实现画布橡皮擦功能、并解决擦除不连贯问题;的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/694336

相关文章

Nginx 配置跨域的实现及常见问题解决

《Nginx配置跨域的实现及常见问题解决》本文主要介绍了Nginx配置跨域的实现及常见问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来... 目录1. 跨域1.1 同源策略1.2 跨域资源共享(CORS)2. Nginx 配置跨域的场景2.1

Python中提取文件名扩展名的多种方法实现

《Python中提取文件名扩展名的多种方法实现》在Python编程中,经常会遇到需要从文件名中提取扩展名的场景,Python提供了多种方法来实现这一功能,不同方法适用于不同的场景和需求,包括os.pa... 目录技术背景实现步骤方法一:使用os.path.splitext方法二:使用pathlib模块方法三

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

PostgreSQL中MVCC 机制的实现

《PostgreSQL中MVCC机制的实现》本文主要介绍了PostgreSQL中MVCC机制的实现,通过多版本数据存储、快照隔离和事务ID管理实现高并发读写,具有一定的参考价值,感兴趣的可以了解一下... 目录一 MVCC 基本原理python1.1 MVCC 核心概念1.2 与传统锁机制对比二 Postg

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

qt5cored.dll报错怎么解决? 电脑qt5cored.dll文件丢失修复技巧

《qt5cored.dll报错怎么解决?电脑qt5cored.dll文件丢失修复技巧》在进行软件安装或运行程序时,有时会遇到由于找不到qt5core.dll,无法继续执行代码,这个问题可能是由于该文... 遇到qt5cored.dll文件错误时,可能会导致基于 Qt 开发的应用程序无法正常运行或启动。这种错

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri