返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScript实现涂鸦笔功能
  • 596
分享到

JavaScript实现涂鸦笔功能

2024-04-02 19:04:59 596人浏览 八月长安
摘要

本文实例为大家分享了javascript实现涂鸦笔的具体代码,供大家参考,具体内容如下 1、html部分、CSS部分 1.1 实现一个画框 <canvas id="draw"

本文实例为大家分享了javascript实现涂鸦笔的具体代码,供大家参考,具体内容如下

1、html部分、CSS部分

1.1 实现一个画框

<canvas id="draw" width="800" height="800">
    
</canvas>

1.2 css部分

<style>
    html,body{
        margin:0;
    }
    canvas{
        border:1px solid black;
    }
</style>

2、js部分

2.1 先让canvas是个画框,然后处理事件监听

const canvas = document.querySelector("#draw");

canvas.addEventListener("mousedown",(e)=>{
    
});

canvas.addEventListener("mouseup",(e)=>{

});

canvas.addEventListener("mouseover",(e)=>{

});

canvas.addEventListener("mouseleave",(e)=>{

});

2.2 对监听事件进行处理

2.2.1 首先要先设置一个值,确保是鼠标点击后才会实现画图

let drawing = false;
let x = 0, y = 0 ;

canvas.addEventListener("mousedown",(e)=>{
    drawing = true;
    [x,y] = [e.offsetX,e.offsetY];//这个是为了让鼠标点下去之后,要记住点的位置-----记住鼠标开始的点,方便连成线
});

canvas.addEventListener("mouseup",(e)=>{
    drawing = false;
});

canvas.addEventListener("mouseover",(e)=>{
    //判断如果drawing为真,就返回值,console一下
    if(!drawing) return;
    console.log("draw");

});

canvas.addEventListener("mouseleave",(e)=>{
    drawing = false;
});

2.3 实现画笔的粗细变化、画笔颜色的变化

let colorDeg = 0; //为了实现使用hsl(hsl的颜色是角度取值的)的颜色取值
let lineWidth = 50; //画笔粗细的定义
let direction = 1; //方便变大变小,取反值用的

//让上面那些值,赋值给画布ctx的值上
let ctx = canvas.getContext("2d");
ctx.strokeStyle = `hsl(${colorDeg},100%,50%)`;//颜色的值
ctx.lineWidth = lineWidth;//线的粗细
ctx.lineCap = "round"; 
ctx.lineJoin = "round"; 


canvas.addEventListener("mouseover",(e)=>{
    //判断如果drawing为真,就返回值,console一下
    if(!drawing) return;
    console.log("draw");
    
    //颜色操作
    colorDeg = colorDeg < 360 ? colorDeg + 1 : 0 ;
    ctx.strokeStyle = `hsl(${colorDeg},100%,50%)`;
    
    //粗细的更改
    if(lineWidth < 1 || lineWidth > 50){
        direction =  direction * (-1);
    }

    lineWidth += direction;
    ctx.lineWidth = lineWidth;
    
});

2.4 以上仅实现画笔的逻辑变化,我们还需要让画笔显示出来

2.4.1 首先创建一个新的路径

ctx.beginPath();//新路径的起点。

2.4.2 记录一开始点的位置

ctx.moveTo(x,y);

2.4.3 路径的终点

ctx.lineTo(e.offsetX,e.offsetY);

2.4.4 重新定义鼠标按下时的[x,y]的位置

[x,y] = [e.offsetX,e.offsetY];

2.4.5 实现了点的位置获取,需要再来一个函数来连接他们

ctx.stroke();//这是画出线的方法,没有这个方法,画不出线

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

--结束END--

本文标题: JavaScript实现涂鸦笔功能

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

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

猜你喜欢
  • JavaScript实现涂鸦笔功能
    本文实例为大家分享了JavaScript实现涂鸦笔的具体代码,供大家参考,具体内容如下 1、html部分、css部分 1.1 实现一个画框 <canvas id="draw"...
    99+
    2024-04-02
  • JavaScript如何实现涂鸦笔功能
    今天小编给大家分享一下JavaScript如何实现涂鸦笔功能的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、html部分、...
    99+
    2023-07-02
  • Android 使用Path实现涂鸦功能
    今天实现一个涂鸦效果,会分几步实现,这里有一个重要的知识点就是图层,要理解这个,不然你看这篇博客,很迷茫,迷茫的苍茫的天涯是我的爱,先从简单的需求做起,绘制一条线,代码如下: ...
    99+
    2022-06-06
    path Android
  • AndroidStudio实现能在图片上涂鸦程序
    本文实例为大家分享了AndroidStudio实现能在图片上涂鸦的具体代码,供大家参考,具体内容如下 一、内容:设计一个能在图片上涂鸦的程序 二、实现 1. 布局文件activity...
    99+
    2024-04-02
  • 自定义视图view使用Canvas实现手写板和涂鸦功能
    目录预览图一、xml布局二、MainActivity代码三、我们自定义view的类预览图 一、xml布局 <xml version="1.0" encoding="utf-8...
    99+
    2023-05-14
    自定义视图 自定义view 自定义视图使用Canvas Canvas实现手写板 Canvas涂鸦功能
  • Vue怎么实现多点涂鸦效果
    这篇文章主要介绍“Vue怎么实现多点涂鸦效果”,在日常操作中,相信很多人在Vue怎么实现多点涂鸦效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Vue怎么实现多点涂鸦效果”的疑惑有所帮助!接下来,请跟着小编...
    99+
    2023-07-05
  • Android编程实现在Bitmap上涂鸦效果
    本文实例讲述了Android编程实现在Bitmap上涂鸦效果。分享给大家供大家参考,具体如下: 布局文件: <?xml version="1.0" encod...
    99+
    2022-06-06
    bitmap Android
  • Android实现Path平滑的涂鸦效果实例
    前言在最近的一个项目中做了一个涂鸦的效果,手指快速移动,会出现折线,这篇文章记录笔触优化。下面话不多说了,来一起看看详细的介绍吧。优化前优化设计到的类:Paint,PathPath类记录了坐标点集合决定线条轨迹,Paint决定怎么画Pain...
    99+
    2023-05-30
    android path平滑 涂鸦
  • 怎么自定义视图view使用Canvas实现手写板和涂鸦功能
    本文小编为大家详细介绍“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-05
  • 怎么用纯CSS3实现自定义Tooltip边框涂鸦风格
    这篇文章主要介绍“怎么用纯CSS3实现自定义Tooltip边框涂鸦风格”,在日常操作中,相信很多人在怎么用纯CSS3实现自定义Tooltip边框涂鸦风格问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操...
    99+
    2024-04-02
  • Python编程tkinter库Canvas实现涂鸦颜色表及围棋盘示例
    目录tkinter库Canvas操作三个实例实例一:涂鸦运行效果图:其它作图函数:实例二:颜色表运行效果图:实例三:围棋盘运行效果图:tkinter库Canvas操作三个实例 实例一...
    99+
    2024-04-02
  • android:照片涂画功能实现过程及原理详解
    这个功能可以帮你实现,在图片上进行随意的涂抹,可以用于SNS产品。 绘图本身很简单,但是要实现在图片上指定的部分精确(位置,缩放)的绘图,就有点麻烦了。 下面讲讲实现过程及原理...
    99+
    2022-06-06
    Android
  • JavaScript实现时钟功能
    本文实例为大家分享了JavaScript实现时钟功能的具体代码,供大家参考,具体内容如下 1、HTML和CSS部分 1.1 HTML部分 1.1.1先放在一个容器中clock,存放 ...
    99+
    2024-04-02
  • javascript能实现交互功能吗
    随着互联网的发展,越来越多的网站和应用都需要实现交互功能,这些交互功能往往需要使用到JavaScript语言。虽然在Web开发领域中,JavaScript早已成为一个非常流行的编程语言,但是对于一些新手开发者或者没有接触过JavaScrip...
    99+
    2023-05-21
  • html5如何实现画板画笔功能
    这篇文章主要介绍了html5如何实现画板画笔功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。   实现画板画笔功能,效果如下:   1...
    99+
    2024-04-02
  • JavaScript如何实现截屏功能
    小编给大家分享一下JavaScript如何实现截屏功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!最近参与了网易炉石盒子的相关...
    99+
    2024-04-02
  • javascript如何实现打印功能
    这篇文章主要介绍“javascript如何实现打印功能”,在日常操作中,相信很多人在javascript如何实现打印功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java...
    99+
    2024-04-02
  • JavaScript实现更换头像功能
    本文实例为大家分享了JavaScript实现更换头像功能的具体代码,供大家参考,具体内容如下 最主要的是使用jquery的插件 cropper 1、基本使用步骤 1.在 <he...
    99+
    2024-04-02
  • javascript实现查询商品功能
    本文实例为大家分享了javascript实现查询商品功能的具体代码,供大家参考,具体内容如下 这是没有点击查询的主界面图 这是点击名称查询之后 按照价格查询 代码: <...
    99+
    2024-04-02
  • JavaScript实现限时秒杀功能
    本文实例为大家分享了JavaScript实现限时秒杀功能的具体代码,供大家参考,具体内容如下 <!DOCTYPE html> <html> <he...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作