记uni-app移动端签名图片竖版转横版

前景提示:公司uni-app移动端项目流程中有签名环节,形式是整个页面在手机横版显示,完成后转成base64图片保存

页面be like👇

问题:因为是手机横版签名,但是相对视觉还是竖着的,所以最后生成的签名图片是竖着保存的

be like👇

解决思路:再加一个横版canvas隐藏,签名生成图片后,用生成的图片在横版canvas上绘制一遍再生成签名图片

html 复制代码
<canvas :disable-scroll="true" :style="{width: h +'px',height: w +'px'}" canvas-id="tranCacnvs"></canvas>
js 复制代码
// canvas签名转为图片链接
uni.canvasToTempFilePath({
    canvasId: 'handWriting',
    fileType: 'png',
    quality: 1, //图片质量
    success(res) {
        const ctx = uni.createCanvasContext('tranCacnvs', this);
        ctx.translate(h / 2, w / 2); // 修改原点坐标(这里是以中心为坐标原点)
        ctx.rotate((-90 * Math.PI) / 180); // 逆时针旋转90度
        ctx.translate(-w / 2, -h / 2); // 修改原点坐标(这里是已左上角为坐标原点)
        ctx.drawImage(res.tempFilePath, 0, 0, w, h)
        ctx.draw();					
        uni.canvasToTempFilePath({
            canvasId: 'tranCacnvs',
            fileType: 'png',
            quality: 1, //图片质量
            success(data) {
                // 这里返回的data.tempFilePath就是横版的签名图片啦
            }
         })
}})

注意点:旋转的中心点和绘制的起点要注意,我这边是操作前都重置了成我习惯的中心点和原始点了,也可以用其他的逻辑,比如修改图片绘制的参数等

相关推荐
小徐_23331 天前
uni-app vue3 也能使用 Echarts?Wot Starter 是这样做的!
前端·uni-app·echarts
iOS阿玮1 天前
永远不要站在用户的对立面,挑战大众的公知。
uni-app·app·apple
xw51 天前
uni-app中v-if使用”异常”
前端·uni-app
!win !1 天前
uni-app中v-if使用”异常”
前端·uni-app
2501_915918411 天前
iOS 上架全流程指南 iOS 应用发布步骤、App Store 上架流程、uni-app 打包上传 ipa 与审核实战经验分享
android·ios·小程序·uni-app·cocoa·iphone·webview
00后程序员张1 天前
iOS App 混淆与加固对比 源码混淆与ipa文件混淆的区别、iOS代码保护与应用安全场景最佳实践
android·安全·ios·小程序·uni-app·iphone·webview
00后程序员张2 天前
详细解析苹果iOS应用上架到App Store的完整步骤与指南
android·ios·小程序·https·uni-app·iphone·webview
海绵宝宝不喜欢侬2 天前
uniapp-微信小程序分享功能-onShareAppMessage
微信小程序·小程序·uni-app
2501_915106322 天前
Xcode 上传 ipa 全流程详解 App Store 上架流程、uni-app 生成 ipa 文件上传与审核指南
android·macos·ios·小程序·uni-app·iphone·xcode
xkxnq2 天前
Uniapp崩溃监控体系构建:内存泄漏三维定位法(堆栈/资源/线程)
uni-app