iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >基于html5中canvas做批改作业小插件的示例分析
  • 423
分享到

基于html5中canvas做批改作业小插件的示例分析

2023-06-09 10:06:44 423人浏览 安东尼
摘要

这篇文章给大家分享的是有关基于HTML5中canvas做批改作业小插件的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。需求分析能进行批改,就是相当于画笔能进行画笔的撤回功能能进行全部画笔的清除功能可以转化

这篇文章给大家分享的是有关基于HTML5canvas做批改作业小插件的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

需求分析

  1. 能进行批改,就是相当于画笔

  2. 能进行画笔的撤回功能

  3. 能进行全部画笔的清除功能

  4. 可以转化画笔的颜色

技术上的实现思路

在听到这需求后的第一反应就是用canvas来做,所以我在w3school阅读了 canvas的api .

将图片转到canvas,用到API: drawImage()

2画笔的实现

  • 当按下鼠标(mousedown)记录开始点startX, startY

  • 当移动鼠标的时候(mousemove)就获取当前的鼠标的坐标e.clientX, e.clientY,获取到了当前的坐标后,与上一个点的坐标轴的左边进行连线(lineTo ),这样就能画出了一条横线了

  • 当鼠标松开左键(mouseup)时候,就清除mousemove的函数

清除功能:讲原始的图片再次用drawImage()函数来重置
4.撤回功能:在每次按下鼠标那时候,用getImageData()函数获取当前的图像记录到数组里面,然后按撤回则使用putImageData()函数放在canvas
5.画笔的颜色:在mousemove里面改变strokeStyle笔的颜色

代码实现

移动鼠标画出线条的代码

let self = this;    this.canvasnode = document.createElement('canvas');    let styleString = this.utils.fORMatStyle(CANVAS_STYLE); // CANVAS_STYLE是canvas的样式    this.canvasNode.setAttribute('id','canvas');    // 一定要设置这width 和 height    let ratio = this.imgNode.width / this.imgNode.height, height = this.imgNode.height, width = this.imgNode.width;    let tempWidth , tempHeight;    // 按比例伸缩    if(ratio >= window.innerWidth / window.innerHeight){      if(width > window.innerWidth){        tempWidth = window.innerWidth;        tempHeight = height * window.innerWidth / width;      } else {        tempWidth = width;        tempHeight = height;      }    }else{      if(height > window.innerHeight){        tempWidth = width * window.innerHeight / width;        tempHeight = window.innerHeight;      }else{        tempWidth = width;        tempHeight = height;      }    }    this.canvasNode.height = tempHeight;    this.canvasNode.width = tempWidth;    styleString = Object.assign({'width': tempWidth, 'height': tempHeight}, CANVAS_STYLE);    this.canvasNode.setAttribute('style', styleString);    let ctx = this.canvasNode.getContext('2d'), startX = 0, startY = 0;    let image = new Image() ;    image.setAttribute("crossOrigin",'Anonymous')    // 加时间戳因为这图片的域名没设置跨域https://www.jianshu.com/p/c3aa975923De    image.src = this.imgNode.src + '?t=' + new Date().getTime();     image.height = tempHeight;    image.width = tempWidth;    image.onload = function(){      ctx.drawImage(image, 0, 0, tempWidth, tempHeight);    }    // 鼠标移动事件    let mousemoveFn = function(e) {      ctx.beginPath();      ctx.lineWidth = 3;      ctx.strokeStyle = self.currentColor;      if(startX == e.clientX - self.canvasNode.offsetLeft || startY ===  e.clientY - self.canvasNode.offsetTop  ) return      ctx.moveTo(startX,startY);      ctx.lineTo(e.clientX - self.canvasNode.offsetLeft , e.clientY - self.canvasNode.offsetTop );      ctx.stroke();      startX = e.clientX - self.canvasNode.offsetLeft;      startY = e.clientY - self.canvasNode.offsetTop ; // 37是header的高度    }    // 鼠标按下事件    this.canvasNode.addEventListener("mousedown",function(e){      startX = e.clientX - self.canvasNode.offsetLeft;      startY = e.clientY - self.canvasNode.offsetTop ;      // 如果在mouseup那里记录 则在撤回时候要做多一个步骤      let imageData = ctx.getImageData(0,0, self.canvasNode.width, self.canvasNode.height);      self.imageDataArray.push(imageData); // 这imageDataArray用来记录画笔的笔画      self.canvasNode.addEventListener("mousemove", mousemoveFn, false);    },false);    this.canvasNode.addEventListener('mouseup', function(e){      self.canvasNode.removeEventListener('mousemove', mousemoveFn);    });    this.bgNode.appendChild(this.canvasNode);

遇到的问题

图片的跨域问题   因为这个域名只设置了192.168.6.*的跨域,所以我localhost的域名会报跨域的问题(只对192.168.6.*的跨域是同事告诉我的,不然我还在傻乎乎的查问题)

解决办法:设置Vue.congfig.js文件的dev下的host

图片的按比例伸缩完按保存后图片的尺寸变了   我用toDataURL()方法输出的base64后的图片尺寸变了。原因:在我把图片draw上canvas上时候,用了上面代码的图片那比例伸缩的算法把图片变小了,所以画在canvas上的图片也变小了...

解决办法:(待解决)

总结

  • 第一次接触canvas与图片相结合的功能,让我熟悉了canvas的api

  • 在遇到没做过的功能之前,一定要先定下心来运用你所知道的知识思考下有没可行的方法,找到了突破点就可以做了

  • 在你碰上不熟悉的知识时候,一定要先看api,我这canvas之前不怎么会的,之后我细看了几遍的api,我就可以上手去做功能了,并且在w3school看到的例子让我觉得canvas真的很强大

感谢各位的阅读!关于“基于html5中canvas做批改作业小插件的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

--结束END--

本文标题: 基于html5中canvas做批改作业小插件的示例分析

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

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

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

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

下载Word文档
猜你喜欢
  • 基于html5中canvas做批改作业小插件的示例分析
    这篇文章给大家分享的是有关基于html5中canvas做批改作业小插件的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。需求分析能进行批改,就是相当于画笔能进行画笔的撤回功能能进行全部画笔的清除功能可以转化...
    99+
    2023-06-09
  • canvas中视频遮罩插件的示例分析
    这篇文章将为大家详细讲解有关canvas中视频遮罩插件的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一个长视频可能包含多个遮罩,每个遮罩有特定的显示时间(在此时间外,隐藏该遮罩)。前端实现视频遮...
    99+
    2023-06-09
  • canvas中二维码邀请函生成插件的示例分析
    这篇文章将为大家详细讲解有关canvas中二维码邀请函生成插件的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。效果图:我看见效果后第一反映就是,肯定canvas进...
    99+
    2024-04-02
  • HTML5中canvas基本绘图之绘制阴影效果的示例分析
    小编给大家分享一下HTML5中canvas基本绘图之绘制阴影效果的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!<canvas></ca...
    99+
    2023-06-09
  • 基于jquery日历价格、库存等设置插件的示例分析
    这篇文章将为大家详细讲解有关基于jquery日历价格、库存等设置插件的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。源码地址:https://github.com...
    99+
    2024-04-02
  • 基于红黑树插入操作原理及java实现的示例分析
    这篇文章主要介绍基于红黑树插入操作原理及java实现的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!红黑树是一种二叉平衡查找树,每个结点上有一个存储位来表示结点的颜色,可以是RED或BLACK。红黑树具有以下...
    99+
    2023-05-30
    java
  • 微信小程序中基于slider组件动态修改标签透明度的示例分析
    这篇文章将为大家详细讲解有关微信小程序中基于slider组件动态修改标签透明度的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体如下:1、效果展示2、关键代码i...
    99+
    2024-04-02
  • BAT批处理中文件与文件夹操作的示例分析
    这篇文章将为大家详细讲解有关BAT批处理中文件与文件夹操作的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。批处理中的文件、文件夹操作,xcopy命令的用法。一,建bat文件自动执行复制,删除命令。...
    99+
    2023-06-08
  • bootstrap中datepicker插件默认英文修改为中文的示例分析
    这篇文章主要介绍了bootstrap中datepicker插件默认英文修改为中文的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。da...
    99+
    2024-04-02
  • 基于Vue中点击组件外关闭组件的示例分析
    这篇文章主要为大家展示了“基于Vue中点击组件外关闭组件的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“基于Vue中点击组件外关闭组件的示例分析”这篇文...
    99+
    2024-04-02
  • Flex与.NET互操作中基于WebService数据访问的示例分析
    这篇文章将为大家详细讲解有关Flex与.NET互操作中基于WebService数据访问的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Flex与.NET互操作:基于WebService的数据访问F...
    99+
    2023-06-17
  • 基于MongoDB数据库中数据类型和$type操作符的示例分析
    这篇文章将为大家详细讲解有关基于MongoDB数据库中数据类型和$type操作符的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。前面的话  本文将详细介绍Mong...
    99+
    2024-04-02
  • JS基于设计模式中单例模式实现封装对数据增删改查功能的示例分析
    这篇文章给大家分享的是有关JS基于设计模式中单例模式实现封装对数据增删改查功能的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。单例模式单例模式的核心结构中只包含一个被称为...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作