小程序实现手写板签名

 更新时间:2022年07月08日 08:03:58   作者:李湘湘  
这篇文章主要为大家详细介绍了小程序实现手写板签名,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

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
}

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

相关文章

  • Javascript迭代、递推、穷举、递归常用算法实例讲解

    Javascript迭代、递推、穷举、递归常用算法实例讲解

    今天小编就为大家分享一篇关于Javascript迭代、递推、穷举、递归常用算法实例讲解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • JavaScript中for与forEach分别如何跳出循环

    JavaScript中for与forEach分别如何跳出循环

    forEach的优势一个是它的回调函数形成了一个作用域,它的curItem和i不会像for循环一样污染全局变量,这篇文章主要给大家介绍了关于JavaScript中for与forEach分别如何跳出循环的相关资料,需要的朋友可以参考下
    2024-01-01
  • JavaScript实现把rgb颜色转换成16进制颜色的方法

    JavaScript实现把rgb颜色转换成16进制颜色的方法

    这篇文章主要介绍了JavaScript实现把rgb颜色转换成16进制颜色的方法,涉及javascript实现数制转换的相关技巧,需要的朋友可以参考下
    2015-06-06
  • JavaScript常用标签和方法总结

    JavaScript常用标签和方法总结

    JavaScript可以被浏览器直接解释执行,它可以更好得减小服务器压力,提高程序运行效率,下面小编通过本篇文章给大家分享JavaScript常用标签和方法,需要的朋友一起来学习吧
    2015-09-09
  • 彻底弄懂 JavaScript 执行机制

    彻底弄懂 JavaScript 执行机制

    不论你是javascript新手还是老鸟,不论是面试求职,还是日常开发工作,我们经常会遇到这样的情况:给定的几行代码,我们需要知道其输出内容和顺序。接下来通过本文给大家分享 JavaScript 执行机制,感兴趣的朋友一起看看吧
    2018-10-10
  • JSQL 基于客户端的成绩统计实现方法

    JSQL 基于客户端的成绩统计实现方法

    JSQL应用案例 基于客户端的成绩统计,下面我把整个example的代码贴出来,欢迎拍砖
    2010-05-05
  • 微信小程序防止多次点击跳转(函数节流)

    微信小程序防止多次点击跳转(函数节流)

    这篇文章主要介绍了微信小程序防止多次点击跳转问题(函数节流),本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • JavaScript生成二维数组的多种方法小结

    JavaScript生成二维数组的多种方法小结

    我经常在面试中问候:你能用 JavaScript 生成一个二维数组吗?这个问题看似简单,实际上却能揭示出面试者对 JavaScript 的熟练程度,天,就让我们一起来探索这个问题背后的答案,揭开生成二维数组的多种秘密,需要的朋友可以参考下
    2024-04-04
  • 如何基于filter实现网站整体变灰功能

    如何基于filter实现网站整体变灰功能

    这篇文章主要介绍了如何基于filter实现网站整体变灰功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-04-04
  • js实现简易计算器功能

    js实现简易计算器功能

    这篇文章主要为大家详细介绍了js实现简易计算器功能,制作能进行加减乘除的计算器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10

最新评论