【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

相关文章

Vue中动态权限到按钮的完整实现方案详解

《Vue中动态权限到按钮的完整实现方案详解》这篇文章主要为大家详细介绍了Vue如何在现有方案的基础上加入对路由的增、删、改、查权限控制,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、数据库设计扩展1.1 修改路由表(routes)1.2 修改角色与路由权限表(role_routes)二、后端接口设计

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

Qt实现发送HTTP请求的示例详解

《Qt实现发送HTTP请求的示例详解》这篇文章主要为大家详细介绍了如何通过Qt实现发送HTTP请求,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、添加network模块2、包含改头文件3、创建网络访问管理器4、创建接口5、创建网络请求对象6、创建一个回复对

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

Gin框架中的GET和POST表单处理的实现

《Gin框架中的GET和POST表单处理的实现》Gin框架提供了简单而强大的机制来处理GET和POST表单提交的数据,通过c.Query、c.PostForm、c.Bind和c.Request.For... 目录一、GET表单处理二、POST表单处理1. 使用c.PostForm获取表单字段:2. 绑定到结

springMVC返回Http响应的实现

《springMVC返回Http响应的实现》本文主要介绍了在SpringBoot中使用@Controller、@ResponseBody和@RestController注解进行HTTP响应返回的方法,... 目录一、返回页面二、@Controller和@ResponseBody与RestController

nginx中重定向的实现

《nginx中重定向的实现》本文主要介绍了Nginx中location匹配和rewrite重定向的规则与应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下... 目录一、location1、 location匹配2、 location匹配的分类2.1 精确匹配2