VUE使用canvas实现签名组件

本文实例为大家分享了VUE使用canvas实现签名组件的具体代码,供大家参考,具体内容如下

效果如下:

<template>
  <div class="sign">
    <div class="content">
      <canvas id="canvas" :width="width" :height="height"/>
    </div>
    <div class="btn">
      <button @click="clearCanvas()">清除</button>
      <button @click="save()">保存</button>
    </div>
  </div>
</template>
 
<script>
export default {
  name: 'App',
  data () {
    return {
    };
  },
  props: {
    // 画布宽度
    width: {
      type: Number,
      default: window.innerWidth
    },
    // 画布高度
    height: {
      type: Number,
      default: 500
    },
    // 笔触半径
    radius: {
      type: Number,
      default: 10
    },
    // 笔触颜色
    color: {
      type: String,
      default: '#000'
    },
    // 画布填充背景
    fillStyle: {
      type: String,
      default: '#ccc'
    }
  },
  created () {
  },
  mounted () {
    this.int();
  },
  methods: {
    // 绘制涂擦效果圆形
    // @param { integer } 圆心的x坐标
    // @param { integer } 圆心的y坐标
    // @param { integer } 圆心半径
    // @param { string } 填充的颜色
    fillCircle (ctx, x, y, radius, fillColor) {
      ctx.fillStyle = fillColor || this.color;
      ctx.beginPath();
      ctx.moveTo(x, y);
      ctx.arc(x, y, radius, 0, Math.PI * 2, false); // 标准画圆
      ctx.fill();
    },
    // 保存图片
    save (name = '签名图片') {
      let imgBase64 = this.canvas.toDataURL('image/png'); // 获取截图base64, 1表示质量(无损压缩)
      let a = document.createElement('a');
      a.download = name + '.png'; // 必须要设置download属性才能够直接下载base64图片
      a.href = imgBase64;
      a.click(); // 触发点击,起到下载效果
    },
    // 清除画布
    clearCanvas () {
      let canvas = this.canvas;
      canvas.getContext('2d').fillStyle = this.fillStyle;
      canvas.getContext('2d').fillRect(0, 0, this.width, this.height);
    },
    // 数据初始化
    int () {
      this.canvas = document.querySelector('#canvas');
      let ctx = this.canvas.getContext('2d');
      let move = false; // 按下标识
      ctx.fillStyle = this.fillStyle;
      ctx.fillRect(0, 0, this.width, this.height);
      // 事件兼容PC 移动端
      let eventStart = 'ontouchstart' in document ? 'touchstart' : 'mousedown';
      let eventMove = 'ontouchmove' in document ? 'touchmove' : 'mousemove';
      let eventEnd = 'ontouchend' in document ? 'touchend' : 'mouseup';
      this.canvas.addEventListener(eventStart, (e) => {
        console.log(e);
        let sx = e.touches ? e.touches[0].pageX : e.pageX;
        let sy = e.touches ? e.touches[0].pageY : e.pageY;
        move = true;
        this.fillCircle(ctx, sx, sy, this.radius);
      }, false);
      this.canvas.addEventListener(eventMove, (e) => {
        let sx = e.touches ? e.touches[0].pageX : e.pageX;
        let sy = e.touches ? e.touches[0].pageY : e.pageY;
        move && this.fillCircle(ctx, sx, sy, this.radius);
      }, false);
      this.canvas.addEventListener(eventEnd, (e) => {
        move = false;
      }, false);
    }
  }
};
</script>
<style lang="less" scoped>
.sign{
  .btn {
    padding:10px;
    button {
      height: 50px;
      width:100%;
      margin-bottom:10px;
      font-size: 20px;
    }
  }
}
</style>

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

(0)

相关推荐

  • Vue+Canvas绘图使用的讲解

    目录 Vue使用Canvas绘图 1.前言 2.实现原理 Vue使用Canvas的小demo 顺便总结一波 Vue使用Canvas绘图 1.前言 图片储存在后台中,根据图片的地址,在vue页面中,查看图片,并根据坐标标注指定区域. 由于浏览器的机制,使用window.location.href下载图片时,并不会保存到本地,会在浏览器打开. 2.实现原理 2.1 绘制画布 <el-dialog     title="查看图片"     :visible.sync="dia

  • Vue3+Canvas实现简易的贪吃蛇游戏

    目录 前言 规则 思路 流程图 代码实现 技术栈 基本变量定义 初始化 食物绘制 蛇头/蛇身绘制 碰撞算法.边界条件 积分计算.暂停,继续等功能 后记 前言 贪吃蛇作为一个经典的小游戏,是很多人儿时的记忆,当时的掌机.诺基亚手机里面都有它的身影,随着时间流逝,当年的我们已经变成大人模样,玩着王者,吃鸡等大型游戏:贪吃蛇这种小游戏已经吊不起我们的兴趣了,不过如果你是一名程序员,那还是建议实现一下,毕竟作为 leetcode 353 算法题你总不想在面试的时候遇到它却不会吧. 本文让我们来复刻一下这

  • Vue+Canvas制作简易的水印添加器小工具

    目录 前言 效果展示 实现功能 实现思路 总结 前言 随着搬运工的逐渐增加,原创作者的利益收到了极大的影响.所以给图片或视频加上水印显得极其重要,他可以有效的维护原创作者的版权防止盗版.本文分享一个由canvas和vue.js制作的图片水印添加器. 效果展示 实现功能 自定义水印的文字及颜色,水印的位置,旋转角度,大小,透明度,是否重复显示,以及选择为重复时可以选择文字之间的水平间距和垂直间距,在设置为合适的图片时点击下载按钮即可下载得到完成图.如果觉得效果不好也可以点击重置按钮瞬间清屏.同时还

  • Vue+canvas实现视频截图功能

    开发过程中遇到一个实际问题,上传的视频需要提供视频封面(视频封面必填).封面可以自己制作并上传,但是这样需要脱离网站,用其他方式制作封面,使用体验并不友好,因此第一个想到的方案是:上传视频时,若人员未上传封面,自动截取视频第一帧作为封面,但是这样会出现一种情况:视频第一帧是黑色,导致封面为黑色.因此考虑视频上传后,在播放中由人员自行截取画面作为视频封面. 简单效果如图: 前端代码如下: <template>   <div>     <video src="https

  • vue项目中canvas实现截图功能

    本文实例为大家分享了vue项目中canvas实现截图功能的具体代码,供大家参考,具体内容如下 实现效果: 整理一下最近在vue项目中做的一个截图功能(只能够截取图片),即用鼠标在画布上进行框选截取. 思路大概如下:做一个弹窗,打开弹窗的时候传入要截的图,接下来在这个窗口里面,点击截图按钮,开始截图,点击取消按钮,取消截图. 窗口里面的html主要是三个部分,一个是可截图区域,一个是截取图片的回显,一个是操作按钮(截图按钮和取消截图按钮). 部分html: <!--截图区域--> <div

  • Vue Canvas实现电子签名

    最近再做移动端电子签名,Vue+Canvas实现,移动端.PC端均可,也可以从github下载 . 我在做这个功能的时候参考了 这个代码,但是在移动端光标与实际划线有偏移,我在我的代码中修正了这个问题. 代码 <template>       <section class="signature">           <div class="signatureBox">               <div class=&q

  • VUE使用canvas实现签名组件

    本文实例为大家分享了VUE使用canvas实现签名组件的具体代码,供大家参考,具体内容如下 效果如下: <template>   <div class="sign">     <div class="content">       <canvas id="canvas" :width="width" :height="height"/>     </di

  • 基于vue+canvas的excel-like组件实例详解

    a vue component,基于vue的表格组件,主要解决大数据量的表格渲染性能问题,使用canvas绘制表格,同时支持类似excel的批量选中,复制黏贴删除,实时编辑等功能. vue-grid-canvas Install NPM / Yarn Install the package: npm install vue-canvas-grid --save Then import it in your project import Vue from 'vue' import Grid fro

  • vue使用canvas实现移动端手写签名

    基于vue使用canvas实现移动端手写签名! 之前自己开发有这么一个需求,需要实现手写签名,然后以图片的形式保存生成图片的base64数据流 .自己在网上找了一堆,都不是很完美.然后参考网上的加自己的优化和修改做了一版.希望有需要的朋友可以拿来直接用. HTML部分: <template> <div class="hello" > <div>请输入您的签名7:</div> <canvas id="canvas"

  • 基于cropper.js封装vue实现在线图片裁剪组件功能

    效果图如下所示, github:demo下载 cropper.js github:cropper.js 官网(demo) cropper.js 安装 npm或bower安装 npm install cropper # or bower install cropper clone下载:下载地址 git clone https://github.com/fengyuanchen/cropper.git 引用cropper.js 主要引用cropper.js跟cropper.css两个文件 <scri

  • vue 使用 canvas 实现手写电子签名

    功能 兼容 PC 和 Mobile: 画布自适应屏幕大小变化(窗口缩放.屏幕旋转时画布无需重置,自动校正坐标偏移): 自定义画布尺寸(导出图尺寸),画笔粗细.颜色,画布背景色: 支持裁剪 (针对需求:有的签字需要裁剪掉四周空白). 导出图片格式为 base64 : 示例demo 安装 npm install vue-esign --save 使用 main.js 中引入 import vueEsign from 'vue-esign' Vue.use(vueEsign) 页面中使用 必须设置 r

  • 微信小程序实现简单手写签名组件的方法实例

    目录 背景: 需求: 效果 一.思路 二.实现 1. 页面与样式 2. 初始化 3. 点击时 4. 签名时 三.总结 背景: 在做项目过程中,需要在微信小程序中实现手写签名组件.在网上找了微信小程序手写签名实现,但是都是不太理想.在实际运用中,会因为实时计算较多的贝塞尔曲线而产生卡顿.效果不理想.所以退一步,不需要笔锋以及笔迹模拟效果.只需要简单的手写签名实现. 需求: 可以实现用户在微信小程序上手写签名. 需要组件化. 效果 一.思路 在微信小程序中,我们使用canvas组件实现.将用户的输入

  • Vue使用Canvas生成随机大小且不重叠圆

    目录 canvas 相关文档 效果图展示 案例完整代码 父组件代码 子组件代码 总结 canvas 相关文档 Canvas Api CANVAS速查简表 效果图展示 第一张是 随机颜色随机大小聚合 在一起效果 第二张是 随机背景图片随机大小分散 效果(这里我使用的图片都一样所以没展现出不同图片) 案例完整代码 本实例是用 vue 来实现的,其他方法和 vue 类似,改为对应的语法即可实现效果. 案例用到了 vue 父子组件传值 父组件代码 <template> <div id="

  • 基于Vue.js的表格分页组件

    一.Vue.js简介 1.Vue的主要特点: (1) 简洁 (2) 轻量 (3)快速 (4) 数据驱动 (5) 模块友好 (6) 组件化 (1) 简洁 下面看一段Angular的实现双向绑定的代码 // html <body ng-app="myApp"> <div ng-controller="myCtrl"> <p>{{ note }}</p> <input type="text" ng-

  • vue的props实现子组件随父组件一起变化

    本文实例为大家分享了vue的props实现父组件变化子组件一起变化,供大家参考,具体内容如下 类似于用 v-bind 绑定 HTML 特性到一个表达式,也可以用 v-bind 绑定动态 Props 到父组件的数据.每当父组件的数据变化时,也会传导给子组件: <div> <input v-model="parentMsg"> <br> <child v-bind:my-message="parentMsg"></c

  • 基于Vue的文字跑马灯组件(npm 组件包)

    一.前言 总结下最近工作上在移动端实现的一个跑马灯效果,最终效果如下: 印象中好像HTML标签的'marquee'的直接可以实现这个效果,不过 HTML标准中已经废弃了'marquee'标签 既然HTML标准已经废弃了这个标签,现在工作上用的是Vue,所以想着能不能自己也发布一个基于Vue的文字跑马灯组件包,这样别人可以通过npm install ...就可以用,想想还有点激动,于是开始我的第一个npm组件之旅! 二.用npm发布一个包 有点惭愧,之前通过npm install ...安装pac

随机推荐