小程序实现手写板签名

本文实例为大家分享了小程序实现手写板签名的具体代码,供大家参考,具体内容如下

1.wxss代码

page {
    background: #F8F8F8;
}
/* 签名 */
.qianming {
    background: #fff;
    padding: 20rpx 30rpx;
    font-size: 32rpx;
    color: #333;
    padding-bottom: 0;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 92%;
    height: 47%;
}

.qianming .clear {
    font-size: 26rpx;
    color: #669AF2;
}

.flex-def {
    display: flex;
}

.flex-one {
    flex: 1;
}

.flex-cCenter {
    align-items: center;
}

/* 底部按钮 */
.bottom_btn {
    font-size: 32rpx;
    color: #fff;
    padding: 30rpx 0;
    background: #fff;
    width: 100%;
}

.bottom_btn view {
    width: 100%;
    background: #FF083C;
    border-radius: 40rpx;
    height: 80rpx;
    line-height: 80rpx;
    text-align: center;
}

/*隐藏滚动条*/
::-webkit-scrollbar {
    width: 0;
    height: 0;
    color: transparent;
    display: none;
}

2.wxml代码

<view class="qianming">
    <view class="qianming_top flex-def flex-cCenter" wx:if="{{is_sign==1}}">
        <view class="flex-one">签名</view>
        <view class="clear" bindtap="clear">清空</view>
    </view>
    <view class="canvas">
        <canvas style="width: 100%;height: 360rpx;border: 1px #eee solid;background-color: #fff;border-radius: 16rpx;margin-top: 20rpx;" canvas-id="firstCanvas" id='firstCanvas' bindtouchstart="bindtouchstart" bindtouchmove="bindtouchmove"></canvas>
    </view>
    <view class="bottom_btn">
        <view class="skin-bg-{{theme}}" bindtap='export'>我已知悉并同意</view>
    </view>
</view>

3.js代码

data: {
        context: null,
        imgUrl: "",
        index:0,//用来判断是否签名
    },
    /**记录开始点 */
    bindtouchstart: function (e) {
        this.data.context.moveTo(e.changedTouches[0].x, e.changedTouches[0].y)
        // 记录已经开始签名
        this.setData({
            index:1
        })
    },
    /**记录移动点,刷新绘制 */
    bindtouchmove: function (e) {
        this.data.context.lineTo(e.changedTouches[0].x, e.changedTouches[0].y);
        this.data.context.stroke();
        this.data.context.draw(true);
        this.data.context.moveTo(e.changedTouches[0].x, e.changedTouches[0].y);
        // 记录已经开始签名
        this.setData({
            index:1
        })
    },
    /**清空画布 */
    clear: function () {
        this.data.context.draw();
        this.setData({
            index:0
        })
    },
    /**导出图片 点击确定按钮*/
    export: function () {
        const that = this;
        
            if (that.data.index==0) {
                wx.showToast({
                    title: '请阅读并签名',
                    icon: 'none',
                    duration: 2000
                })
                return
                }
            that.data.context.draw(true,
                wx.canvasToTempFilePath({
                    x: 0,
                    y: 0,
                    fileType: 'png',
                    canvasId: 'firstCanvas',
                    success(res) {
                        that.upload_image(res.tempFilePath)
                    },
                    fail() {
                        wx.showToast({
                            title: '签名失败',
                            icon: 'none',
                            duration: 2000
                        })
                    }
                })
            )
        }

        
    },
    // 将图片保存到服务器
    upload_image(imgurl) {
        var that = this;
    },

4.注意json文件必须加这个参数为true,否则签名时晃动

{
"disableScroll": true
}

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

(0)

相关推荐

  • 微信小程序实现横屏和竖屏签名功能

    本文实例为大家分享了微信小程序实现横屏和竖屏签名的具体代码,供大家参考,具体内容如下 wxml <view class="container">   <canvas canvas-id="firstCanvas" id="firstCanvas" bindtouchstart="bindtouchstart" bindtouchmove="bindtouchmove"></ca

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

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

  • 微信小程序实现手写板

    本文实例为大家分享了微信小程序实现手写板的具体代码,供大家参考,具体内容如下 <!-- wxml --> <view class="hxt-flex-column">         <view class="hxt-flex" style="font-size: 30rpx;padding: 30rpx;">           <view>             <text wx:if=

  • 微信小程序实现电子签名

    本文实例为大家分享了微信小程序实现电子签名的具体代码,供大家参考,具体内容如下 <view class="sign-contain"> <view class="signName"> <canvas id="canvas" canvas-id="canvas" class="{{ sysType === 'iOS' ? 'canvas' : 'canvas bg000'}}"

  • 微信小程序实现电子签名功能

    本文实例为大家分享了微信小程序实现电子签名的具体代码,供大家参考,具体内容如下 // XXXX.wxml <view class="signName"> <canvas class="canvas" id="canvas" canvas-id="canvas" disable-scroll="true" bindtouchstart="canvasStart" bind

  • 微信小程序实现电子签名并导出图片

    本文实例为大家分享了微信小程序做电子签名,并导出图片的具体代码,供大家参考,具体内容如下 wxml: <canvas class="canvas" id="canvas" canvas-id="canvas" disable-scroll="true" bindtouchstart="canvasStart" bindtouchmove="canvasMove" bindtouch

  • 微信小程序canvas实现签名功能

    在微信小程序项目中,开发模块涉及到手写签名功能,微信小程序canvas闪亮登场 前言 微信小程序canvas实现签名功能 核心内容简介: (1)签名实现,开始,移动,结束 (2)重写 (3)完成 (4)上传 一.微信小程序canvas实现签名功能 效果演示: (1)签名实现 (2)重写 (3)完成 完成后将图片展示在相应的位置 (4)根据业务需求,可以将图片上传到后台,在需要的地方展示 二.上代码 1.全部演示 wxml <!--pages/canvas-test/canvas-test.wxm

  • 微信小程序实现手写签名的示例代码

    目录 1.效果图 2.相关代码 canvas代码 js相关 在微信小程序上实现手写签名,获取canvascontext新版本和旧版本有点坑,新版本在获取canvas后如果页面有滑动,则签名坐标出现异常(在微信开发者工具上会出现2022-2-17),但是在真机上即使滑动也不会出现异常,为了防止出现问题,暂时使用旧版本获取canvascontext 1.效果图 2.相关代码 canvas代码 新版2d canvas <canvas id="canvas" class="ca

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

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

  • 小程序实现手写板签名

    本文实例为大家分享了小程序实现手写板签名的具体代码,供大家参考,具体内容如下 1.wxss代码 page {     background: #F8F8F8; } /* 签名 */ .qianming {     background: #fff;     padding: 20rpx 30rpx;     font-size: 32rpx;     color: #333;     padding-bottom: 0;     position: fixed;     bottom: 0;  

  • java遇到微信小程序 "支付验证签名失败" 问题解决

    最近在做一个微信小程序项目做到微信支付的时候遇到的一些问题! 详细步骤: 开发前准备(必须) 小程序标识(appid):wx4d4838ebec29b8** 商户号(mch_id):15508070** 商户密钥(key) :wHtQckdfiRBVF7ceGTcSWEEORt6C0D** 我们用微信官方提供的SDK开发 :https://pay.weixin.qq.com/wiki/doc/api/native.php?chapter=11_1 下载 SDK完成后 : 开始写我们的程 进入微信

  • 微信小程序微信登录的实现方法详解(JAVA后台)

    目录 1. 前提 2. 开发流程 2.1 小程序端 2.2 Java后端接口 总结 官方文档:https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html 本文主要记录小程序实现微信登陆功能,后端为Java开发. 在开发之前我们先看一下官方提供的时序图,了解一下我们的大致开发流程: 大致了解流程之后,我们便可以着手开发了. 1. 前提 一个可以测试的微信小程序 此微信小程序的APPID和APP

  • python3爬虫之设计签名小程序

    本文实例为大家分享了python3设计签名小程序的具体代码,供大家参考,具体内容如下 首先,上一下要做的效果图: 先是这样一个丑陋的界面(我尽力了的真的!) 然后随便输入名字 然后点击按钮会显示出对应的个性签名: 这个是怎么实现的呢? 其实这个是将一个签名网站http://www.uustv.com/的内容爬下来显示了而已: 源代码如下: from tkinter import * import requests from tkinter import messagebox import re

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

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

随机推荐