JS实现canvas简单小画板功能


Posted in Javascript onJune 23, 2020

本文实例为大家分享了JS实现canvas简单小画板的具体代码,供大家参考,具体内容如下

JS实现canvas简单小画板功能

Html部分:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <link rel="stylesheet" href="./index.css" rel="external nofollow" >
  <title>Document</title>
</head>
<body>
  <div class="container">
    <canvas id="cavs" width="700" height="330"></canvas>
    <ul>
      <li> <input type="color" id="color"> </li>
      <li> <input type="button" id="cleanBoard" value="清屏"></li>
      <li> <input type="button" id="eraser" value="橡皮"></li>
      <li> <input type="button" id="rescind" value=撤销></li>
      <li> <input type="button" id="save" value=保存></li>
      <li><input type="range" id="lineRuler" min="1" max="20"> </li>
    </ul>
  </div>
  <script src="./index.js"></script>
</body>
</html>

CSS部分:

*{
  margin: 0;
  padding: 0;
  list-style: none;
}
.container{
  margin: 30px;
}
#cavs{
  border: 1px solid red;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.6);
  border-radius: 10px;
}
.container ul{
  margin-top: 20px;
  width: 700px;
  text-align: center;
}
.container ul li{
  display: inline-block;
  margin-left: 35px;
}
.container ul li input{
  padding: 6px 15px;
  border-radius: 10px;
  border: none;
  outline: none;
  cursor: pointer;
  transition: box-shadow 0.3s cubic-bezier(0.6, -0.28, 0.735, 0.045);
}
.container ul li input:hover{
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.6);
}

JS部分:

var drawingBoard = {
  cavs: document.getElementById('cavs'),
  ctx: document.getElementById('cavs').getContext('2d'),
  ul_node: document.getElementsByTagName('ul')[0],
  colorBoard: document.getElementById('color'),
  lineRuler: document.getElementById('lineRuler'),
  imgArr: [],//存放图片
  init: function () {
    this.ctx.lineCap = 'round';
    this.ctx.lineJoin = 'round';
    this.drawing();//开始画画
    this.btnsFnAll();
  },
  drawing: function () {
    var self = this;
    var left = this.cavs.offsetLeft;
    this.cavs.onmousedown = function (e) {
      var e_x = e.pageX;//鼠标在画布上的x点
      var e_y = e.pageY;
      self.ctx.beginPath();//开始绘制
      self.ctx.moveTo(e_x - left, e_y - left);//落笔点,开始点
      var imgData = self.ctx.getImageData(0, 0, self.cavs.offsetWidth, self.cavs.offsetHeight);
      self.imgArr.push(imgData)
      document.onmousemove = function (e) {
        self.ctx.lineTo(e.pageX - left, e.pageY - left);//落笔点,开始点
        self.ctx.stroke();
      }
      document.onmouseup = function () {
        document.onmousemove = null;
        self.ctx.closePath();//闭合当前的路径 结束绘制
      }
      this.onpointerleave = function () {
        document.onmousemove = null;
      }
    }
  },
  btnsFnAll: function () {
    var self = this;
    this.ul_node.addEventListener('click', function (e) {
      console.log(e.target.id);
      switch (e.target.id) {
        case 'cleanBoard'://清屏
          self.ctx.clearRect(0, 0, self.cavs.offsetWidth, self.cavs.offsetHeight)
          break;
        case 'eraser'://橡皮
          self.ctx.strokeStyle = "#ffffff";
          break;
        case 'save'://保存
          let url = self.cavs.toDataURL('image/jpg');
          let a = document.createElement('a');
          document.body.appendChild(a);
          a.href = url;
          a.download = '草稿纸';
          a.target = '_blank';
          a.click()
          break;
        case 'rescind'://撤销
          console.log(self.imgArr)
          if (self.imgArr.length > 0) {
            self.ctx.putImageData(self.imgArr.pop(), 0, 0)
          }
          break;
      }
    });
    this.colorBoard.onchange = function () {
      self.ctx.strokeStyle = this.value;
    };
    this.lineRuler.onchange = function () {
      self.ctx.lineWidth = this.value
    }
  }
}
drawingBoard.init();

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
自动完成JS类(纯JS, Ajax模式)
Mar 12 Javascript
JQuery打造PHP的AJAX表单提交实例
Nov 03 Javascript
Javascript(AJAX)解析XML的代码(兼容FIREFOX/IE)
Jul 11 Javascript
基于jQuery捕获超链接事件进行局部刷新代码
May 10 Javascript
onclick与listeners的执行先后问题详细解剖
Jan 07 Javascript
父元素与子iframe相互获取变量和元素对象的具体实现
Oct 15 Javascript
js/jquery获取文本框输入焦点的方法
Mar 04 Javascript
javascript实现input file上传图片预览效果
Dec 31 Javascript
jQuery中的each()详细介绍(推荐)
May 25 Javascript
深入理解node.js http模块
Jan 24 Javascript
深入理解es6块级作用域的使用
Mar 28 Javascript
基于element-ui封装可搜索的懒加载tree组件的实现
May 22 Javascript
javascript+Canvas实现画板功能
Jun 23 #Javascript
vue.js实现照片放大功能
Jun 23 #Javascript
vue实现点击按钮切换背景颜色的示例代码
Jun 23 #Javascript
vue.js实现双击放大预览功能
Jun 23 #Javascript
vue实现分页的三种效果
Jun 23 #Javascript
微信小程序清空输入框信息与实现屏幕往上滚动的示例代码
Jun 23 #Javascript
weui上传多图片,压缩,base64编码的示例代码
Jun 22 #Javascript
You might like
php创建基本身份认证站点的方法详解
2013/06/08 PHP
php根据操作系统转换文件名大小写的方法
2014/02/24 PHP
PHP简单实现记录网站访问量功能示例
2018/06/06 PHP
小型js框架veryide.librar源代码
2009/03/05 Javascript
JavaScript 精粹读书笔记(1,2)
2010/02/07 Javascript
js实现jquery的offset()方法实例
2015/01/10 Javascript
JavaScript中toString()方法的使用详解
2015/06/05 Javascript
深入理解JavaScript编程中的同步与异步机制
2015/06/24 Javascript
基于javascript实现样式清新图片轮播特效
2016/03/30 Javascript
JS判断输入字符串长度实例代码(汉字算两个字符,字母数字算一个)
2016/08/02 Javascript
JavaScript与JQUERY获取元素的宽、高和位置
2017/02/26 Javascript
react-native之ART绘图方法详解
2017/08/08 Javascript
Vue仿今日头条实例详解
2018/02/06 Javascript
Angular5.0 子组件通过service传递值给父组件的方法
2018/07/13 Javascript
手把手教你使用TypeScript开发Node.js应用
2019/05/06 Javascript
JQuery实现简单的复选框树形结构图示例【附源码下载】
2019/07/16 jQuery
Vue源码分析之Vue实例初始化详解
2019/08/25 Javascript
Vue封装Axios请求和拦截器的步骤
2020/09/16 Javascript
原生JavaScript实现换肤
2021/02/19 Javascript
Python类的定义、继承及类对象使用方法简明教程
2015/05/08 Python
Python 转义字符详细介绍
2017/03/21 Python
Python3 queue队列模块详细介绍
2018/01/05 Python
python logging日志模块以及多进程日志详解
2018/04/18 Python
对python的文件内注释 help注释方法
2018/05/23 Python
Python常见MongoDB数据库操作实例总结
2018/07/24 Python
Python3.9又更新了:dict内置新功能
2020/02/28 Python
Spartoo西班牙官网:法国时尚购物网站
2018/03/27 全球购物
2014年应届大学生自我评价
2014/01/09 职场文书
关于工资低的辞职信
2014/01/14 职场文书
护士上岗前培训自我鉴定
2014/04/20 职场文书
本科毕业生自荐信
2014/06/02 职场文书
学校交通安全责任书
2014/08/25 职场文书
模范教师事迹材料
2014/12/16 职场文书
老乡会致辞
2015/07/28 职场文书
浅谈Python中的函数(def)及参数传递操作
2021/05/25 Python
在Java中Collection的一些常用方法总结
2021/06/13 Java/Android