记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就是横版的签名图片啦
            }
         })
}})

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

相关推荐
Qlittleboy10 分钟前
uniAPP报错:v-for 暂不支持循环数据: (env: Windows,mp,1.06.2307260; lib: 3.12.0)
uni-app
曾帅16810 分钟前
uniapp安卓启动图
android·opencv·uni-app
m0_7408596210 分钟前
解决uniapp折叠面板报错this.collapse.onChange is not a function
uni-app
天府之绝35 分钟前
uniapp 中使用uview表单验证时,自定义扩展的表单,在改变时无法触发表单验证处理;
开发语言·前端·javascript·vue.js·uni-app
2501_9151063244 分钟前
常见 iOS 抓包工具的使用方式与组合思路
android·ios·小程序·https·uni-app·iphone·webview
脾气有点小暴2 小时前
uniapp真机调试无法连接
前端·uni-app
HashTang13 小时前
【AI 编程实战】第 7 篇:登录流程设计 - 多场景、多步骤的优雅实现
前端·uni-app·ai编程
Mr -老鬼1 天前
移动端跨平台适配技术框架:从发展到展望
android·ios·小程序·uni-app
一颗小青松1 天前
uniapp app端显示天气详情
uni-app
Swift社区2 天前
H5 与 ArkTS 通信的完整设计模型
uni-app·harmonyos