文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Vue怎么使用sign-canvas实现在线手写签名

2023-06-30 14:59

关注

这篇文章主要讲解了“Vue怎么使用sign-canvas实现在线手写签名”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Vue怎么使用sign-canvas实现在线手写签名”吧!

效果图:

Vue怎么使用sign-canvas实现在线手写签名

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

Vue怎么使用sign-canvas实现在线手写签名

Vue怎么使用sign-canvas实现在线手写签名

Vue怎么使用sign-canvas实现在线手写签名

 完整代码: 

<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怎么使用sign-canvas实现在线手写签名这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯