返回顶部
首页 > 资讯 > 精选 >JavaScript如何实现涂鸦笔功能
  • 252
分享到

JavaScript如何实现涂鸦笔功能

2023-07-02 11:07:35 252人浏览 安东尼
摘要

今天小编给大家分享一下javascript如何实现涂鸦笔功能的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、html部分、

今天小编给大家分享一下javascript如何实现涂鸦笔功能的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

JavaScript如何实现涂鸦笔功能

1、html部分、CSS部分

1 实现一个画框

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

2 css部分

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

2、js部分

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.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;});

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;    });

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

1 首先创建一个新的路径

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

2 记录一开始点的位置

ctx.moveTo(x,y);

3 路径的终点

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

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

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

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

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

以上就是“JavaScript如何实现涂鸦笔功能”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注编程网精选频道。

--结束END--

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

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

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

猜你喜欢
  • JavaScript如何实现涂鸦笔功能
    今天小编给大家分享一下JavaScript如何实现涂鸦笔功能的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、html部分、...
    99+
    2023-07-02
  • JavaScript实现涂鸦笔功能
    本文实例为大家分享了JavaScript实现涂鸦笔的具体代码,供大家参考,具体内容如下 1、html部分、css部分 1.1 实现一个画框 <canvas id="draw"...
    99+
    2024-04-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涂鸦功能
  • 怎么自定义视图view使用Canvas实现手写板和涂鸦功能
    本文小编为大家详细介绍“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”,内容详细,步骤清晰,细节处理妥当,希望这篇“怎么自定义视图view使用Canvas实现手写板和涂鸦功能”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入...
    99+
    2023-07-05
  • JavaScript如何实现截屏功能
    小编给大家分享一下JavaScript如何实现截屏功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!最近参与了网易炉石盒子的相关...
    99+
    2024-04-02
  • javascript如何实现打印功能
    这篇文章主要介绍“javascript如何实现打印功能”,在日常操作中,相信很多人在javascript如何实现打印功能问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”java...
    99+
    2024-04-02
  • javascript如何实现下载功能
    本篇内容主要讲解“javascript如何实现下载功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript如何实现下载功能”吧!javascript实现下载功能的方法:1、通过a标...
    99+
    2023-07-05
  • JavaScript如何实现全选功能
    本篇内容介绍了“JavaScript如何实现全选功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!实现全选的原理在学习如何实现全选功能之前,...
    99+
    2023-07-06
  • html5如何实现画板画笔功能
    这篇文章主要介绍了html5如何实现画板画笔功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。   实现画板画笔功能,效果如下:   1...
    99+
    2024-04-02
  • javascript如何实现计算器功能
    这篇文章给大家分享的是有关javascript如何实现计算器功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、计算器功能介绍可以实现数据的加(+),减(-),乘(*),除(/),取余运算(%),以及实现数据的...
    99+
    2023-06-25
  • Javascript如何实现下拉刷新功能
    这篇文章将为大家详细讲解有关Javascript如何实现下拉刷新功能,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Html相关代码<!DOCTYPE ht...
    99+
    2024-04-02
  • JavaScript如何实现评论点赞功能
    这篇文章主要为大家展示了“JavaScript如何实现评论点赞功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript如何实现评论点赞功能”这篇文...
    99+
    2024-04-02
  • JavaScript如何实现下拉菜单功能
    这篇文章主要介绍了JavaScript如何实现下拉菜单功能,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体代码如下所示:<!doct...
    99+
    2024-04-02
  • javaScript如何实现复制粘贴功能
    小编给大家分享一下javaScript如何实现复制粘贴功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧! ...
    99+
    2024-04-02
  • JavaScript如何实现答题评分功能
    这篇“JavaScript如何实现答题评分功能”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JavaScript如何实现答题...
    99+
    2023-07-06
  • android:照片涂画功能实现过程及原理详解
    这个功能可以帮你实现,在图片上进行随意的涂抹,可以用于SNS产品。 绘图本身很简单,但是要实现在图片上指定的部分精确(位置,缩放)的绘图,就有点麻烦了。 下面讲讲实现过程及原理...
    99+
    2022-06-06
    Android
  • JavaScript+HTML5如何实现日期比较功能
    这篇文章主要介绍JavaScript+HTML5如何实现日期比较功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!代码:<!DOCTYPE HTML> <...
    99+
    2024-04-02
  • JavaScript中如何实现附件预览功能
    这篇文章给大家分享的是有关JavaScript中如何实现附件预览功能的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。由于公司的EMP影像平台比较繁琐,还需要下载才能够能够进行图片的...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作