iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >怎么在JavaScript中使用canvas实现一个画板和签字板功能
  • 827
分享到

怎么在JavaScript中使用canvas实现一个画板和签字板功能

2023-06-06 12:06:32 827人浏览 安东尼
摘要

怎么在javascript中使用canvas实现一个画板和签字板功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。<!DOCTYPE html><

怎么在javascript中使用canvas实现一个画板和签字板功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

<!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="canvas"></canvas> <script> let c = document.getElementById('canvas'); c.width = window.innerWidth; c.height = window.innerHeight; let ctx = c.getContext('2d'); // draw one black board ctx.fillStyle = "black"; ctx.fillRect(0,0,600,300); // 按下标记 let onoff = false,  oldx = -10,  oldy = -10; // 设置颜色 let linecolor = "white"; // 设置线宽 let linw = 4; // 添加鼠标事件 // 按下 c.addEventListener('mousedown', event => {  onoff = true;  // 位置 - 10是为了矫正位置,把绘图放在鼠标指针的顶端  oldx = event.pageX - 10;  oldy = event.pageY - 10; },false); // 移动 c.addEventListener('mousemove', event => {  if(onoff == true){  let newx = event.pageX - 10,   newy = event.pageY - 10;  // 绘图  ctx.beginPath();  ctx.moveTo(oldx,oldy);  ctx.lineTo(newx,newy);  ctx.strokeStyle = linecolor;  ctx.lineWidth = linw;  ctx.lineCap = "round";  ctx.stroke();  // 每次移动都要更新坐标位置  oldx = newx,  oldy = newy;  } }, true); // 弹起 c.addEventListener('mouseup', ()=> {  onoff = false; },false); </script></body></html>

结果展示

怎么在JavaScript中使用canvas实现一个画板和签字板功能

代码讲解

思路

鼠标按下,开始描画。鼠标按下事件。
2、鼠标弹起,结束描画。鼠标弹起事件。
3、鼠标按下移动,路径画线。鼠标移动事件。

代码讲解

整体思路:按下鼠标,触发移动的开关,移动后开始记录线条(用移动后的坐标-移动前的坐标,然后绘线),每次移动都会更新旧坐标。松开鼠标后,释放移动开关。

只有在鼠标按下,才会触发移动绘图的效果,所以需要增加一个状态判断。
2、因为鼠标指针和实际位置有一个偏移量,所以在坐标定位的时候,需要增加pagex-10从而使坐标位于指针的尖端处。
3、每次移动都要更新坐标位置,用小段的线段来模拟不规则的线。

封装模块

<canvas id="canvas"></canvas><script> class Board{ constructor(canvasName = 'canvas', data = new Map([  ["onoff", false],  ["oldx", -10],  ["oldy", -10],  ["fillStyle", "black"],  ["lineColor", "white"],  ["lineWidth", 4],  ["lineCap", "round"],  ["canvasWidth", window.innerWidth],  ["canvasHeight", window.innerHeight] ])){  // this.data = data;  this.c = document.getElementById(canvasName);  this.ctx = this.c.getContext('2d');  this.onoff = data.get("onoff");  this.oldx = data.get("oldx");  this.oldy = data.get("oldy");  this.lineColor = data.get("lineColor");  this.lineWidth = data.get("lineWidth");  this.lineCap = data.get("lineCap");  this.c.width = data.get("canvasWidth");  this.c.height = data.get("canvasHeight");  this.ctx.fillStyle = data.get("fillStyle");  this.ctx.fillRect(0,0,600,300); } eventOperation(){  // 添加鼠标事件  // 按下  this.c.addEventListener('mousedown', event => {  this.onoff = true;  // 位置 - 10是为了矫正位置,把绘图放在鼠标指针的顶端  this.oldx = event.pageX - 10;  this.oldy = event.pageY - 10;  },false);  // 移动  this.c.addEventListener('mousemove', event => {  if(this.onoff == true){   let newx = event.pageX - 10,   newy = event.pageY - 10;   // 绘图   this.ctx.beginPath();   this.ctx.moveTo(this.oldx,this.oldy);   this.ctx.lineTo(newx,newy);   this.ctx.strokeStyle = this.lineColor;   this.ctx.lineWidth = this.lineWidth;   this.ctx.lineCap = this.lineCap;      this.ctx.stroke();   // 每次移动都要更新坐标位置   this.oldx = newx,   this.oldy = newy;  }  }, true);  // 弹起  this.c.addEventListener('mouseup', ()=> {  this.onoff = false;  },false); } } let board = new Board(); board.eventOperation();</script>

关于怎么在JavaScript中使用canvas实现一个画板和签字板功能问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注编程网精选频道了解更多相关知识。

--结束END--

本文标题: 怎么在JavaScript中使用canvas实现一个画板和签字板功能

本文链接: https://www.lsjlt.com/news/246932.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么在JavaScript中使用canvas实现一个画板和签字板功能
    怎么在JavaScript中使用canvas实现一个画板和签字板功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。<!DOCTYPE html><...
    99+
    2023-06-06
  • 使用socket.io 和canvas怎么实现一个共享画板功能
    这期内容当中小编将会给大家带来有关使用socket.io 和canvas怎么实现一个共享画板功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。git clone <reposit...
    99+
    2023-06-09
  • 使用canvas怎么实现一个像素画板
    本篇文章给大家分享的是有关使用canvas怎么实现一个像素画板,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。Pixel = function (o...
    99+
    2023-06-09
  • 利用Java怎么实现一个画板功能
    今天就跟大家聊聊有关利用Java怎么实现一个画板功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。基本的思路是这样的:画板实现大致分三部分:一是画板界面的实现,二是画板的监听以及画图...
    99+
    2023-05-31
    java ava
  • 怎么在JavaScript中使用Canvas自定义画板
    本篇文章为大家展示了怎么在JavaScript中使用Canvas自定义画板,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。<!DOCTYPE HTML><html>&...
    99+
    2023-06-09
  • 使用canvas怎么实现一个在线签名功能
    这期内容当中小编将会给大家带来有关使用canvas怎么实现一个在线签名功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。什么是 Canvas?Canvas 是 HTML5 新增的元素,用于在网页上绘制图形...
    99+
    2023-06-09
  • Android开发中项目实现一个画板功能
    这期内容当中小编将会给大家带来有关Android开发中项目实现一个画板功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。效果图如下XML布局代码<RelativeLayout xmlns:andro...
    99+
    2023-05-31
    android roi
  • 怎么在Html5中实现一个剪切板功能
    这期内容当中小编将会给大家带来有关怎么在Html5中实现一个剪切板功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。1.不带input输入框的原生js方法这种情况适用于复制非输入框中的文本到剪切板&nbs...
    99+
    2023-06-09
  • 使用C#怎么实现一个简易画图板
    本篇文章为大家展示了使用C#怎么实现一个简易画图板,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。定义公共变量用于多个窗体之间共同使用数据public class TempData...
    99+
    2023-06-14
  • 怎么在Java中利用JScrollPane实现一个面板滚动功能
    这篇文章将为大家详细讲解有关怎么在Java中利用JScrollPane实现一个面板滚动功能,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。       ...
    99+
    2023-05-31
    java jscrollpane ava
  • 怎么在springboot中利用thymeleaf模板实现一个paginate分页功能
    今天就跟大家聊聊有关怎么在springboot中利用thymeleaf模板实现一个paginate分页功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。pom.xml 加入 ...
    99+
    2023-05-31
    springboot thymeleaf paginate
  • Java语言怎么实现一个简单的画图板的功能呢
    要实现一个简单的画图板,可以使用Java的图形库(如Swing或JavaFX)来创建图形界面,并使用鼠标事件和绘图功能来实现画图功能...
    99+
    2023-08-18
    Java
  • 怎么用JavaScript实现一个模板引擎
    这篇文章给大家分享的是有关怎么用JavaScript实现一个模板引擎的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。功能分析一个模板引擎,在我看来,就是由两块核心功能组成,一个是用...
    99+
    2024-04-02
  • 使用canvas怎么实现一个拼图功能
    使用canvas怎么实现一个拼图功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。实现的思路其实挺简单的,主要是通过服务端获取图片链接,图片宽度,图片高度,然后...
    99+
    2023-06-09
  • 使用canvas怎么实现一个滤镜功能
    使用canvas怎么实现一个滤镜功能?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。1 了解 canvas?1.1 什么是 canvas?这个 HTML 元素是为...
    99+
    2023-06-09
  • 怎么在JavaScript中利用canvas实现一个圆形流水动画
    这篇文章将为大家详细讲解有关怎么在JavaScript中利用canvas实现一个圆形流水动画,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。JavaScript的特点1.JavaScript主...
    99+
    2023-06-14
  • 怎么在H5中使用canvas实现一个动态图形功能
    怎么在H5中使用canvas实现一个动态图形功能?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。什么是动画?我们在绘制动画之前必须要弄清楚什么是动画,一个动画最起码需要哪些基...
    99+
    2023-06-09
  • 怎么自定义视图view使用Canvas实现手写板和涂鸦功能
    本文小编为大家详细介绍“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-05
  • 怎么在html5中利用canvas实现一个弹幕功能
    本篇文章为大家展示了怎么在html5中利用canvas实现一个弹幕功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。(function () {   ...
    99+
    2023-06-09
  • 怎么在Java中使用JavaScript实现一个字符串计算器功能
    本篇文章为大家展示了怎么在Java中使用JavaScript实现一个字符串计算器功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。代码如下:package scc;import ...
    99+
    2023-05-30
    java javascript 字符串
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作