Vue使用sign-canvas实现在线手写签名的实例

目录
  • 更新日志
  • 安装
  • 全局方式
  • 局部方式

效果图:

sign-canvas 一个基于 canvas 开发,封装于 Vue 组件的通用手写签名板(电子签名板),支持 pc 端和移动端。

更新日志

v1.1.4 功能更新:增加全屏手写方案,可以通过 options.isFullScreen,和 options.isFullCover 属性控制,全屏模式下 canvasWidth 和 canvasHeight 属性设置无效,感谢网友 AFelicity”的建议与反馈。

v1.1.3 功能更新:增加高倍屏下,绘制会模糊的适配方案,可以通过 options.isDpr 属性进行开启或者关闭,感谢网友“Wong-Harry”的建议与反馈。

安装

npm install --save sign-canvas

全局方式

main.js:

import SignCanvas from "sign-canvas";
Vue.use(SignCanvas);

局部方式

//局部注册 模板中引入

import SignCanvas from "sign-canvas";
components: {
    SignCanvas;
}

 完整代码: 

<template>
  <div class="sign">
    <sign-canvas
      class="sign-canvas"
      ref="SignCanvas"
      :options="options"
      v-model="value"
    />
    <div class="btnList" ref="btnList">
      <van-button type="danger" v-throttle size="small" @click="clearSignImg">清空</van-button>
      <van-button type="primary" v-throttle size="small" class="ml30 mr30" @click="saveSignImg">保存</van-button>
      <van-button type="primary" v-throttle size="small" @click="back">返回</van-button>
    </div>
  </div>
</template>
<script>
//接口引入
import { signShipmentsContract } from "../../api/userMG";
export default {
  name: "signDialog",
  //props: {
    //组件传递的值
    //visible: {
      //type: Boolean,
      //default: false,
    //},
    //图片信息Base64
    //src: {
      //type: String,
      //default: null,
    //},
  //},
  data() {
    return {
      value: null,
      //配置
      options: {
        lastWriteSpeed: 1, //书写速度 [Number] 可选
        lastWriteWidth: 2, //下笔的宽度 [Number] 可选
        lineCap: "round", //线条的边缘类型 [butt]平直的边缘 [round]圆形线帽 [square]	正方形线帽
        lineJoin: "round", //线条交汇时边角的类型  [bevel]创建斜角 [round]创建圆角 [miter]创建尖角。
        canvasWidth: "750", //canvas宽高 [Number] 可选
        canvasHeight: "500", //高度  [Number] 可选
        isShowBorder: false, //是否显示边框 [可选]
        bgColor: "#fcc", //背景色 [String] 可选
        borderWidth: 1, // 网格线宽度  [Number] 可选
        borderColor: "#ff787f", //网格颜色  [String] 可选
        writeWidth: 5, //基础轨迹宽度  [Number] 可选
        maxWriteWidth: 30, // 写字模式最大线宽  [Number] 可选
        minWriteWidth: 5, // 写字模式最小线宽  [Number] 可选
        writeColor: "#101010", // 轨迹颜色  [String] 可选
        isSign: true, //签名模式 [Boolean] 默认为非签名模式,有线框, 当设置为true的时候没有任何线框
        imgType: "png", //下载的图片格式  [String] 可选为 jpeg  canvas本是透明背景的
      },
    };
  },
  created() {
  },
  mounted() {
    let windowHeight = document.documentElement.clientHeight;
    let btnList = this.$refs.btnList.offsetHeight;
    let windowWidth = document.documentElement.clientWidth;
    this.options.canvasWidth = windowWidth;
    this.options.canvasHeight = windowHeight - btnList;
    // console.log(this.$refs.SignCanvas.saveAsImg(),"this.$refs.SignCanvas.saveAsImg()")
  },
  methods: {
    //清除画板
    clearSignImg() {
      this.$refs.SignCanvas.canvasClear();
    },
    // 保存图片
    saveSignImg() {
      console.log(this.value, "value");
      if (this.value == null) {
        this.$toast.fail("请先签名");
      } else {
        this.$dialog
          .confirm({
            title: "签名确认",
            message: "请先确认签名是否正确,一旦签名成功,无法撤销",
          })
          .then(() => {
            console.log(1);
            const img = this.$refs.SignCanvas.saveAsImg();
            this.signShipmentsContractFun(img);
          })
          .catch(() => {
            console.log(2);
            this.$toast.fail({
              message: "签名取消,请重新签名",
              onClose: () => {
                this.$refs.SignCanvas.canvasClear();
              },
            });
          });
      }
    },
    //下载图片/
    // downloadSignImg() {
    //   this.$refs.SignCanvas.downloadSignImg();
    // },
    back() {
      this.$router.back(-1);
    },
    // 签名
    signShipmentsContractFun(img) {
      let params = {
        contractId: this.$route.query.contractId,
        carrierContractPicture: img,
        contractInfoDto: JSON.parse(this.$route.query.contractList),
      };
      signShipmentsContract(params)
        .then((res) => {
          console.log(res, "签名");
          if (res.code == 200) {
            this.$toast.success({
              message: "保存成功",
              onClose: () => {
                this.$router.back(-1);
              },
            });
          } else {
            this.$toast.fail(res.msg);
          }
        })
        .catch((error) => {});
    },
  },
};
</script>
<style lang="scss" scoped>
.btnList {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 30px 0;
  display: flex;
  justify-content: center;
}
.sign-canvas {
  display: block;
  margin: 0 auto;
  background: #F1F1F1 !important;
  border-radius: 8px;
}
</style>

到此这篇关于Vue使用sign-canvas实现在线手写签名的文章就介绍到这了,更多相关vue在线手写签名内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 使用vue实现手写签名功能

     个人实现截图: 安装: npm install vue-esign --save 使用: 1.在main.js中引入 import vueEsign from 'vue-esign' Vue.use(vueEsign) 2.在页面中引用 <vue-esign ref="esign" :width="800" :height="300" :isCrop="isCrop" :lineWidth="lineWidt

  • 基于canvas实现手写签名(vue)

    最近一直在研究canvas的东西,正好之前对手写签名这块有点兴趣.就自己基于vue写了一个简易的手写签名demo. 其中原理比较简单,先生成一个canvas画布,并对canvas进行touchstart和touchmove事件进行监听.当监听touchstart事件被触发时,我们开始触发canvas里的beginPath事件并且设置moveTo原始点.当监听touchmove事件则去不断去触发lineTo事件,最后stroke(). demo里还有清除签名和保存签名的功能,分别对应了clearR

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

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

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

    本文实例为大家分享了vue+canvas实现移动端手写签名的具体代码,供大家参考,具体内容如下 <template> <div class="sign"> <div class="header"> <i class="el-icon-arrow-left backImg" @click="goBack"></i> <span class="title&

  • Vue使用sign-canvas实现在线手写签名的实例

    目录 更新日志 安装 全局方式 局部方式 效果图: sign-canvas 一个基于 canvas 开发,封装于 Vue 组件的通用手写签名板(电子签名板),支持 pc 端和移动端. 更新日志 v1.1.4 功能更新:增加全屏手写方案,可以通过 options.isFullScreen,和 options.isFullCover 属性控制,全屏模式下 canvasWidth 和 canvasHeight 属性设置无效,感谢网友 AFelicity”的建议与反馈. v1.1.3 功能更新:增加高倍

  • 微信小程序canvas实现手写签名

    本文实例为大家分享了微信小程序canvas实现手写签名的具体代码,供大家参考,具体内容如下 很多时候,程序中需要用到签名的功能,附上源码(微信小程序) .wxml <view class="canvasBox">       <view class="canvasTitle">请签名:</view>       <view class="canvasContent">         <vie

  • Vue源码学习记录之手写vm.$mount方法

    目录 一.概述 二.使用方式 三.完整版vm.$mount的实现原理 四.只包含运行时版本的vm.$mount的实现原理 这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 一.概述 在我们开发中,经常要用到Vue.extend创建出Vue的子类来构造函数,通过new 得到子类的实例,然后通过$mount挂载到节点,如代码: <div id="mount-point"></div> <!-- 创建构造器 --> var Profile =

  • 微信小程序实现手写签名(签字版)

    本文实例为大家分享了微信小程序实现手写签名的具体代码,供大家参考,具体内容如下 公司近期有个需要用户签名的功能,就用小程序canvas写了个 wxml <view class="sign">   <view class="paper">     <canvas class="handWriting" disable-scroll="true" bindtouchstart="touchs

  • Android实现手写签名

    本文实例为大家分享了Android手写签名的实现方法,产品要求用户可以在app上签协议..所以得弄个手写签名版,参考了一些资料自己写了个PaintView去继承View,实现签名功能. package com.****.*****.widget; import android.content.Context; import android.graphics.Bitmap; import android.graphics.Canvas; import android.graphics.Color;

  • Android实现屏幕手写签名

    Android屏幕手写签名的原理就是把手机屏幕当作画板,把用户手指当作画笔,手指在屏幕上在屏幕上划来划去,屏幕就会显示手指的移动轨迹,就像画笔在画板上写字一样.实现手写签名需要结合绘图的路径工具Path,在有按下动作时调用Path对象的moveTo方法,将路径起始点移动到触摸点:在有移动操作时调用Path对象的quadTo方法,将记录本次触摸点与上次触摸点之间的路径:在有移动操作与提起动作时调用Canvas对象的drawPath方法,将本次触摸绘制在画布上. layout/activity_si

随机推荐