【uniapp 开发】手绘签名组件

- 代码如下:
<template>
	<view class="content">
		<button type="primary" @tap="doss">点击签名1</button>
		<button type="primary" @tap="doss2">点击签名2</button>
		<view class="imgs">
			<image class="img" :src="img1" mode="widthFix"></image>
			<image class="img" :src="img2" mode="widthFix"></image>
		</view>
		<catSignature canvasId="canvas1"  @close="close" @save="save" :visible="isShow" />
		<catSignature canvasId="canvas2" @close="close2" @save="save2" :visible="isShow2" />
	</view>
</template>
<script>
	import catSignature from "@/components/cat-signature/cat-signature.vue"
	export default {
		components:{catSignature},
		data() {
			return {
				img1:'',
				img2:'',
				isShow:false,
				isShow2:false,
			}
		},
		onLoad() {
		},
		methods: {
			doss(){
				this.isShow = true;
			},
			close(){
				this.isShow = false;
			},
			save(val){
				this.isShow = false;
				this.img1 = val
			},
			doss2(){
				this.isShow2 = true;
			},
			close2(){
				this.isShow2 = false;
			},
			save2(val){
				this.isShow2 = false;
				this.img2 = val
			},
		}
	}
</script>
<style>
	.imgs{width: 500upx;height: 500upx;display: flex;margin: 0 auto;flex-wrap: wrap;}
	.imgs img{width: 100%; height: 100%;}
</style>
- 插件代码:
<template>
	<view v-if="visibleSync" class="cat-signature" :class="{'visible':show}" @touchmove.stop.prevent="moveHandle">
		<view class="mask" @tap="close" />
		<view class="content">
			<canvas class='firstCanvas' :canvas-id="canvasId" @touchmove='move' @touchstart='start($event)' @touchend='end'
			 @touchcancel='cancel' @longtap='tap' disable-scroll='true' @error='error' />
			<view class="btns">
				<view class="btn" @tap="clear">清除</view>
				<view class="btn" @tap="save">保存</view>
			</view>
		</view>
	</view>
</template>
<script>
	var content = null;
	var touchs = [];
	var canvasw = 0;
	var canvash = 0;
	//获取系统信息
	uni.getSystemInfo({
		success: function(res) {
			canvasw = res.windowWidth;
			canvash = canvasw * 9 / 16;
		},
	})
	export default{
		name:'cat-signature',
		props:{
			visible: {
				type: Boolean,
				default: false
			},
			canvasId:{
				type: String,
				default: 'firstCanvas'
			}
		},
		data(){
			return{
				show:false,
				visibleSync: false,
				signImage:'',
				hasDh:false,
			}
		},
		watch:{
			visible(val) {
				this.visibleSync = val;
				this.show = val;
				this.getInfo()
			}
		},
		created(options) {
			this.visibleSync = this.visible
			this.getInfo()
			setTimeout(() => {
				this.show = this.visible;
			}, 100)
		},
		methods:{
			getInfo(){
				//获得Canvas的上下文
				content = uni.createCanvasContext(this.canvasId,this)
				//设置线的颜色
				content.setStrokeStyle("#000")
				//设置线的宽度
				content.setLineWidth(5)
				//设置线两端端点样式更加圆润
				content.setLineCap('round')
				//设置两条线连接处更加圆润
				content.setLineJoin('round')
			},
			//
			close() {
				this.show = false;
				this.hasDh = false;
				this.$emit('close')
			},
			moveHandle(){
			},
			// 画布的触摸移动开始手势响应
			start(e){
				let point = {
					x: e.touches[0].x,
					y: e.touches[0].y,
				}
				touchs.push(point);
				this.hasDh = true
			},
			// 画布的触摸移动手势响应
			move: function(e) {
				let point = {
					x: e.touches[0].x,
					y: e.touches[0].y
				}
				touchs.push(point)
				if (touchs.length >= 2) {
					this.draw(touchs)
				}
			},
			// 画布的触摸移动结束手势响应
			end: function(e) {
				//清空轨迹数组
				for (let i = 0; i < touchs.length; i++) {
					touchs.pop()
				}
			},
			// 画布的触摸取消响应
			cancel: function(e) {
				// console.log("触摸取消" + e)
			},
			// 画布的长按手势响应
			tap: function(e) {
				// console.log("长按手势" + e)
			},
			error: function(e) {
				// console.log("画布触摸错误" + e)
			},
			//绘制
			draw: function(touchs) {
				let point1 = touchs[0]
				let point2 = touchs[1]
				// console.log(JSON.stringify(touchs))
				content.moveTo(point1.x, point1.y)
				content.lineTo(point2.x, point2.y)
				content.stroke()
				content.draw(true);
				touchs.shift()
			},
			//清除操作
			clear: function() {
				//清除画布
				content.clearRect(0, 0, canvasw, canvash)
				content.draw(true)
				// this.close()
				this.hasDh = false;
				this.$emit('clear')
			},
			save(){
				var that = this;
				if(!this.hasDh){
					uni.showToast({title:'请先签字',icon:'none'})
					return;
				}
				uni.showLoading({title:'生成中...',mask:true})
				setTimeout(()=>{
					uni.canvasToTempFilePath({
						canvasId: this.canvasId,
						success: function(res) {
							that.signImage = res.tempFilePath;
							that.$emit('save',res.tempFilePath);
							uni.hideLoading()
							that.hasDh = false;
							that.show = false;
						},
						fail:function(err){
							console.log(err)
							uni.hideLoading()
						}
					},this)
				},100)
			}
		}
	}
</script>
<style lang="scss">
	.cat-signature.visible {
		visibility: visible
	}
	.cat-signature{
		display: block;
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		overflow: hidden;
		z-index: 11;
		height: 100vh;
		visibility: hidden;
		.mask{display: block;opacity: 0;position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: rgba(0, 0, 0, .4);transition: opacity .3s;}
		.content{display: block;position: absolute;top: 0;left: 0;bottom:0;right: 0;margin: auto; width:94%;height: 500upx;background: #fff;border-radius: 8upx;box-shadow: 0px 3px 3px #333;
			// canvas
			.firstCanvas {background-color: #fff;width: 100%;height: 400upx;}
			// canvas
			.btns{padding: 0 15px;height: 100upx;overflow: hidden; position: absolute;bottom: 10upx;left: 0;right: 0;margin: auto;display: flex;justify-content: space-between;
				.btn{width: 40%;text-align: center;font-size: 28upx;height:60upx;line-height: 60upx;background-color: #999;color: #fff;border-radius: 6upx;}
			}
		}
	}
	.visible .mask {
		display: block;
		opacity: 1
	}
</style>
【uniapp 开发】手绘签名组件的更多相关文章
- Blazor组件自做二 : 使用JS隔离制作手写签名组件
		Blazor组件自做二 : 使用JS隔离制作手写签名组件 本文相关参考链接 JavaScript 模块中的 JavaScript 隔离 Viewer.js工程 Blazor组件自做一 : 使用JS隔离 ... 
- Microsoft Tech Summit 2018 课程简述:利用 Windows 新特性开发出更好的手绘视频应用
		概述 Microsoft Tech Summit 2018 微软技术暨生态大会将于10月24日至27日在上海世博中心举行,这也会是国内举办的最后一届 Tech Summit,2019 年开始会以 Mi ... 
- uni-app通过canvas实现手写签名
		分享一个uni-app实现手写签名的方法 具体代码如下: <template> <view > <view class="title">请在下面 ... 
- Blazor组件自做四 : 使用JS隔离封装signature_pad签名组件
		运行截图 演示地址 响应式演示 感谢szimek写的棒棒的signature_pad.js项目, 来源: https://github.com/szimek/signature_pad 正式开始 1. ... 
- uni-app开发微信小程序引入UI组件库(Vant-weapp)步骤
		uni-app开发微信小程序引入UI组件库(Vant-weapp)步骤 这里以vant-weapp为例 uni-app官方文档介绍引入组件的方法 1. 新建相关目录 根目录下创建 wxcomponen ... 
- uni-app开发踩坑记录
		大部分问题是我在h5端看不到而在android.iOS平台上暴露出来的,不包含小程序 1.:class="['defaultStyle', dynamicStyle]" 不支持直接 ... 
- Ionic5手写签名SignaturePad
		测试程序下载:https://hanzhe.lanzous.com/itt47kncw3a 初始化项目 1. 首先新建一个Ionic5的项目: ionic start test-1 blank 2. ... 
- CVPR2020论文解读:手绘草图卷积网络语义分割
		CVPR2020论文解读:手绘草图卷积网络语义分割 Sketch GCN: Semantic Sketch Segmentation with Graph Convolutional Networks ... 
- Android基于mAppWidget实现手绘地图(一)--简介
		http://lemberg.github.io/mappwidget/user_guide.html 最近在看一些导游类应用,发现一些景区的导览图使用的完全是自定义地图,也就是手绘地图.这种小范围使 ... 
随机推荐
- Python   完美诠释"高内聚"概念的 IO 流 API 体系结构
			1. 前言 第一次接触 Python 语言的 IO API 时,是惊艳的.相比较其它语言所提供的 IO 流 API . 无论是站在使用者的角度还是站在底层设计者的角度,都可以称得上无与伦比. 很多人在 ... 
- Dubbo服务框架和spring-cloud架构的优缺点
			Dubbo一.dubbo简介 Dubbo是阿里巴巴公司开源的一个高性能优秀的服务框架,使得应用可通过高性能的RPC实现服务的输出和输入功能,可以和Spring框架无缝集成. Dubbo是一款高性能.轻 ... 
- 有效提升Python代码性能的三个层面
			使用python进入一个熟练的状态之后就会思考提升代码的性能,尤其是python的执行效率还有很大提升空间(委婉的说法).面对提升效率这个话题,python自身提供了很多高性能模块,很多大牛开发出了高 ... 
- 二级py--day3
			二级PY--day3 1.结构化程序设计方法主要原则:自顶向下.逐步求精.模块化.限制使用goto语句 2.三种控制结构:顺序.选择和重复(循环) 3.结构化程序强调:程序的可复用性 4.结构化程序设 ... 
- laravel 解决跨域问题并封装到中间件
			larav 官方手册有详细的步骤 https://learnku.com/articles/6504/laravel-cross-domain-solution 我们在用 laravel 进行开发的时 ... 
- CA周记 2022年的第一课 - Rust
			现代编程语言有很多,在我的编程学习里面有小学阶段的 LOGO , 中学阶段的 Pascal ,也有大学阶段的 C/C++.Java..NET,再到工作的 Objective-C .Swift.Go.K ... 
- tensorflow源码解析系列文章索引
			文章索引 framework解析 resource allocator tensor op node kernel graph device function shape_inference 拾遗 c ... 
- htm5基本学习
			HTML学习 1.HTML概念 1.1.HTML是什么 Hyper Text Markup Language (超文本标记语言)包括:文字.图片.音频.视频.动画等. 1.2.HTML优势 所有浏览器 ... 
- 微信小程序结合原生JS实现电商模板(一)
			前几天遇到一个朋友求助,实现购物车的相关功能,一时心血来潮,想着抽空搭建一个小程序电商平台(虽然网上有很多,但还是自己撸一遍才是王道),所以在工作之余整了一个仓库,今天提交了第一次代码,已经满足了朋友 ... 
- 报错———http://mybatis.org/dtd/mybatis-3-mapper.dtd 报红解决方案
			初次使用mybatis时,下面红线上的地址报红. 解决方法是:将http://mybatis.org/dtd/mybatis-3-mapper.dtd拷贝.添加到下面标记处. 
