JS通过canvas获取旋转90度后的图片

2024-06-03 23:36

本文主要是介绍JS通过canvas获取旋转90度后的图片,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

部分代码来自这里,若侵权,请联系我!

个人只使用了其中一种方法,已成功:

环境:H5 、vue3、vant4、js,

使用了vant4中的签名组件( van-signature ),设计要求页面是横屏显示,但是由于canvas在组件内部,暂时没办法通过H5 document.getElementById 获取到canvas元素(组件旋转后,canvas的XY轴也需要修改,但是获取不到元素,就没有办法修改)。所以组件旋转放弃, 考虑签名组件生成图片后,再通过canvas旋转图片

代码如下:


<van-signature ref="sign" @submit="onSubmit" @clear="onClear" confirm-button-text=""/><div class="absolute bottom-20 left--6 rotate-90 origin-center flex items-center"><!--<div class="absolute bottom-5 left-5 flex items-center">--><van-button type="primary" @click="clear" round>擦除</van-button><van-button type="primary" @click="submit" round color="#2e99a4">完成并同意</van-button>
</div>
<canvas id="canvas"></canvas>
onSubmit(data) {
// 这里我使用的是vant4 中的签名组件,签名完成后返回值返回的就是base64格式的图片地址this.image = data.image// 获取到图片后使用canvas获取旋转90度后的图片const imgN = new Image()imgN.src = this.image // base64 imageconst canvas = document.getElementById('canvas')const context = canvas.getContext('2d')const cutCoor = {sx: 0,sy: 0,ex: 0,ey: 0,}imgN.onload = () => {const imgW = imgN.widthconst imgH = imgN.heightconst size = imgH//   常量大小 = imgH;canvas.width = size * 2canvas.height = size * 2cutCoor.sx = sizecutCoor.sy = size - imgWcutCoor.ex = size + imgHcutCoor.ey = size + imgWcontext.translate(size, size)context.rotate((Math.PI / 2) * 3)context.drawImage(imgN, 0, 0)const imgData = context.getImageData(cutCoor.sx, cutCoor.sy, cutCoor.ex, cutCoor.ey)canvas.width = imgHcanvas.height = imgWcontext.putImageData(imgData, 0, 0)this.image = canvas.toDataURL('image/png')this.show = true}
},
onClear() {},
clear() {this.$refs.sign.clear()
},
submit() {this.$refs.sign.submit()
},

完整代码

<template><div class="page w-screen h-screen bg-red-200"><div class="absolute top-10 right-10" @click="back"><van-icon name="close" size="24"></van-icon></div><van-signature ref="sign" @submit="onSubmit" @clear="onClear" confirm-button-text=""/><div class="absolute bottom-20 left--6 rotate-90 origin-center flex items-center"><!--<div class="absolute bottom-5 left-5 flex items-center">--><img src="@/assets/image/clear-icon.png" class="w-5 h-5 object-cover mr-4 box-border" alt="" @click="clear"><van-button type="primary" @click="submit" round color="#2e99a4">完成并同意</van-button></div><canvas id="canvas" ref="canvas"></canvas></div>
</template><script>
import { useWindowSize } from '@vant/use'
import HNavBar from '@/components/HNavBar.vue'export default {components: { HNavBar },props: {},data() {return {image: '',}},computed: {},watch: {},beforeMount() {},async activated() {},mounted() {},methods: {onSubmit(data) {this.image = data.image// 获取到图片后使用canvas获取旋转90度后的图片const imgN = new Image()imgN.src = this.image // base64 imageconst canvas = document.getElementById('canvas')const context = canvas.getContext('2d')const cutCoor = {sx: 0,sy: 0,ex: 0,ey: 0,}imgN.onload = () => {const imgW = imgN.widthconst imgH = imgN.heightconst size = imgH//   常量大小 = imgH;canvas.width = size * 2canvas.height = size * 2cutCoor.sx = sizecutCoor.sy = size - imgWcutCoor.ex = size + imgHcutCoor.ey = size + imgWcontext.translate(size, size)context.rotate((Math.PI / 2) * 3)context.drawImage(imgN, 0, 0)const imgData = context.getImageData(cutCoor.sx, cutCoor.sy, cutCoor.ex, cutCoor.ey)canvas.width = imgHcanvas.height = imgWcontext.putImageData(imgData, 0, 0)this.image = canvas.toDataURL('image/png')}},onClear() {},back() {this.$router.back()},clear() {this.$refs.sign.clear()},submit() {this.$refs.sign.submit()},},
}
</script><style lang="scss" scoped>
:deep .van-signature {width: 100%;height: 100%;box-sizing: border-box;
}:deep .van-signature__content {width: 100%;height: 100%;
}:deep .van-signature {padding: 0 !important;
}:deep .van-signature__content canvas {width: 100%;height: 100%;
}
</style>

这篇关于JS通过canvas获取旋转90度后的图片的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1028429

相关文章

Python如何去除图片干扰代码示例

《Python如何去除图片干扰代码示例》图片降噪是一个广泛应用于图像处理的技术,可以提高图像质量和相关应用的效果,:本文主要介绍Python如何去除图片干扰的相关资料,文中通过代码介绍的非常详细,... 目录一、噪声去除1. 高斯噪声(像素值正态分布扰动)2. 椒盐噪声(随机黑白像素点)3. 复杂噪声(如伪

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

SpringBoot服务获取Pod当前IP的两种方案

《SpringBoot服务获取Pod当前IP的两种方案》在Kubernetes集群中,SpringBoot服务获取Pod当前IP的方案主要有两种,通过环境变量注入或通过Java代码动态获取网络接口IP... 目录方案一:通过 Kubernetes Downward API 注入环境变量原理步骤方案二:通过

Python基于微信OCR引擎实现高效图片文字识别

《Python基于微信OCR引擎实现高效图片文字识别》这篇文章主要为大家详细介绍了一款基于微信OCR引擎的图片文字识别桌面应用开发全过程,可以实现从图片拖拽识别到文字提取,感兴趣的小伙伴可以跟随小编一... 目录一、项目概述1.1 开发背景1.2 技术选型1.3 核心优势二、功能详解2.1 核心功能模块2.

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

使用Python实现获取屏幕像素颜色值

《使用Python实现获取屏幕像素颜色值》这篇文章主要为大家详细介绍了如何使用Python实现获取屏幕像素颜色值,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 一、一个小工具,按住F10键,颜色值会跟着显示。完整代码import tkinter as tkimport pyau