2024-11-08 16:18:15 +08:00
|
|
|
|
<template>
|
2024-11-12 17:23:52 +08:00
|
|
|
|
<!-- 签字功能 -->
|
|
|
|
|
<view catchtouchmove="true">
|
|
|
|
|
<view class="sign-box">
|
|
|
|
|
<view class="fixedIcon" @click.stop="changeDirection">
|
|
|
|
|
<image style="height: 100rpx; width: 100rpx" :src="icon"></image>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<canvas class="mycanvas" :style="{ height: height + 'px' }" canvas-id="mycanvas" @touchstart="touchstart" @touchmove="touchmove" @touchend="touchend"></canvas>
|
|
|
|
|
<canvas canvas-id="camCacnvs" :style="{ height: width + 'px' }" class="canvsborder"></canvas>
|
|
|
|
|
|
|
|
|
|
<view :class="direction ? 'sigh_btns_true' : 'sigh_btns_false'">
|
|
|
|
|
<nut-button :class="direction ? 'sigh_btns' : 'sigh_btns_noRotate'" style="height: 60rpx" shape="square" type="info" @click="handleCancel"> 取消 </nut-button>
|
|
|
|
|
<nut-button :class="direction ? 'sigh_btns' : 'sigh_btns_noRotate'" style="height: 60rpx" shape="square" type="info" @click="handleReset"> 重写 </nut-button>
|
|
|
|
|
<nut-button :class="direction ? 'sigh_btns' : 'sigh_btns_noRotate'" style="height: 60rpx" shape="square" type="info" @click="handleConfirm"> 确认 </nut-button>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
2024-11-08 16:18:15 +08:00
|
|
|
|
</template>
|
2024-11-12 17:23:52 +08:00
|
|
|
|
|
|
|
|
|
<script setup>
|
|
|
|
|
import './signature.scss'
|
|
|
|
|
import Taro, { useLoad, useUnload } from '@tarojs/taro'
|
|
|
|
|
import { ref, onMounted, watch, computed } from 'vue'
|
|
|
|
|
import icon from '@/assets/images/rotate1.png'
|
|
|
|
|
const _index = ref(0)
|
2024-11-08 16:18:15 +08:00
|
|
|
|
import { useDailyStore } from '@/store/daily'
|
|
|
|
|
const store = useDailyStore()
|
2024-11-12 17:23:52 +08:00
|
|
|
|
const direction = computed(() => store.getDirection)
|
|
|
|
|
const direction1 = computed(() => store.getDirection1)
|
|
|
|
|
const direction2 = computed(() => store.getDirection2)
|
2024-11-08 16:18:15 +08:00
|
|
|
|
|
2024-11-12 17:23:52 +08:00
|
|
|
|
const width = ref(0)
|
|
|
|
|
const height = ref(300)
|
|
|
|
|
const points = ref([]) // 画笔路径点集合
|
|
|
|
|
const tempPoint = ref([]) // 当前签名路径
|
|
|
|
|
let that
|
|
|
|
|
let id
|
|
|
|
|
let type
|
2024-11-08 16:18:15 +08:00
|
|
|
|
useLoad((options) => {
|
|
|
|
|
_index.value = Number(options.index)
|
2024-11-12 17:23:52 +08:00
|
|
|
|
Taro.setNavigationBarTitle({
|
|
|
|
|
title: options.name,
|
2024-11-08 16:18:15 +08:00
|
|
|
|
})
|
2024-11-12 17:23:52 +08:00
|
|
|
|
// if (_index.value === 1) {
|
|
|
|
|
// store.changeDirection__(direction1.value)
|
|
|
|
|
// } else {
|
|
|
|
|
// store.changeDirection__(direction2.value)
|
|
|
|
|
// }
|
|
|
|
|
})
|
|
|
|
|
const ctx = ref(null)
|
|
|
|
|
onMounted(() => {
|
|
|
|
|
that = this
|
|
|
|
|
const { windowWidth, windowHeight } = Taro.getSystemInfoSync()
|
|
|
|
|
width.value = windowWidth
|
|
|
|
|
height.value = windowHeight * 0.98 // 控制画板的宽高
|
|
|
|
|
|
|
|
|
|
// 创建绘图上下文
|
|
|
|
|
ctx.value = Taro.createCanvasContext('mycanvas', this)
|
|
|
|
|
ctx.value.lineWidth = 2
|
|
|
|
|
ctx.value.lineCap = 'round'
|
|
|
|
|
ctx.value.lineJoin = 'round'
|
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
const touchstart = (e) => {
|
|
|
|
|
const startX = e.changedTouches[0].x
|
|
|
|
|
const startY = e.changedTouches[0].y
|
|
|
|
|
points.value.push({ X: startX, Y: startY })
|
|
|
|
|
ctx.value.beginPath()
|
2024-11-08 16:18:15 +08:00
|
|
|
|
}
|
2024-11-12 17:23:52 +08:00
|
|
|
|
|
|
|
|
|
const touchmove = (e) => {
|
|
|
|
|
const moveX = e.changedTouches[0].x
|
|
|
|
|
const moveY = e.changedTouches[0].y
|
|
|
|
|
points.value.push({ X: moveX, Y: moveY })
|
|
|
|
|
if (points.value.length >= 2) {
|
|
|
|
|
draw()
|
2024-11-08 16:18:15 +08:00
|
|
|
|
}
|
2024-11-12 17:23:52 +08:00
|
|
|
|
tempPoint.value.push({ X: moveX, Y: moveY })
|
2024-11-08 16:18:15 +08:00
|
|
|
|
}
|
2024-11-12 17:23:52 +08:00
|
|
|
|
|
|
|
|
|
const touchend = () => {
|
|
|
|
|
points.value = []
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const draw = () => {
|
|
|
|
|
const point1 = points.value[0]
|
|
|
|
|
const point2 = points.value[1]
|
|
|
|
|
points.value.shift()
|
|
|
|
|
ctx.value.moveTo(point1.X, point1.Y)
|
|
|
|
|
ctx.value.lineTo(point2.X, point2.Y)
|
|
|
|
|
ctx.value.stroke()
|
|
|
|
|
ctx.value.draw(true)
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const handleCancel = () => {
|
|
|
|
|
Taro.navigateBack({ delta: 1 })
|
2024-11-08 16:18:15 +08:00
|
|
|
|
}
|
2024-11-12 17:23:52 +08:00
|
|
|
|
|
|
|
|
|
const handleReset = () => {
|
|
|
|
|
ctx.value.clearRect(0, 0, width.value, height.value)
|
|
|
|
|
ctx.value.draw(true)
|
|
|
|
|
tempPoint.value = []
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
const handleConfirm = () => {
|
|
|
|
|
if (tempPoint.value.length === 0) {
|
|
|
|
|
Taro.showToast({ title: '请先签名', icon: 'none', duration: 2000 })
|
|
|
|
|
return
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
Taro.canvasToTempFilePath({
|
|
|
|
|
canvasId: 'mycanvas',
|
|
|
|
|
success: (res) => {
|
|
|
|
|
console.log('canvasToTempFilePath______________', res)
|
|
|
|
|
|
|
|
|
|
const tempPath = res.tempFilePath
|
|
|
|
|
const ctx = Taro.createCanvasContext('camCacnvs', that)
|
|
|
|
|
|
|
|
|
|
// 调整缩放比例,例如压缩到 50%
|
|
|
|
|
const targetWidth = width.value * 0.5
|
|
|
|
|
const targetHeight = height.value * 0.5
|
|
|
|
|
|
|
|
|
|
ctx.translate(0, targetWidth)
|
|
|
|
|
ctx.rotate((-90 * Math.PI) / 180)
|
|
|
|
|
ctx.drawImage(tempPath, 0, 0, targetWidth, targetHeight)
|
|
|
|
|
ctx.draw(false, () => {
|
|
|
|
|
Taro.canvasToTempFilePath({
|
|
|
|
|
canvasId: 'camCacnvs',
|
|
|
|
|
width: targetWidth,
|
|
|
|
|
height: targetHeight,
|
|
|
|
|
success: (compressedRes) => {
|
|
|
|
|
Taro.getFileSystemManager().readFile({
|
|
|
|
|
filePath: compressedRes.tempFilePath,
|
|
|
|
|
encoding: 'base64',
|
|
|
|
|
success: (res) => {
|
|
|
|
|
const base64Image = 'data:image/jpeg;base64,' + res.data
|
|
|
|
|
|
|
|
|
|
console.log('base64Image_________________________', base64Image)
|
|
|
|
|
|
|
|
|
|
if (_index.value === 1) {
|
|
|
|
|
store.change_base64_1(base64Image)
|
|
|
|
|
Taro.navigateBack({ delta: 1 })
|
|
|
|
|
} else {
|
|
|
|
|
store.change_base64_2(base64Image)
|
|
|
|
|
Taro.navigateBack({ delta: 1 })
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
})
|
|
|
|
|
},
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* @direction false 竖屏,true 横屏
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
// const direction = ref(true)
|
|
|
|
|
const changeDirection = () => {
|
|
|
|
|
// direction.value = !direction.value
|
|
|
|
|
store.changeDirection()
|
|
|
|
|
Taro.vibrateShort({ type: 'medium' }).then()
|
|
|
|
|
}
|
|
|
|
|
useUnload(() => {
|
|
|
|
|
if (_index.value === 1) {
|
|
|
|
|
store.changeDirection1(direction.value)
|
|
|
|
|
} else {
|
|
|
|
|
store.changeDirection2(direction.value)
|
|
|
|
|
}
|
|
|
|
|
})
|
2024-11-08 16:18:15 +08:00
|
|
|
|
</script>
|