// 将图片转换为 PNG 格式 const convertImageToPng = (file: File): Promise<File> => { return new Promise((resolve, reject) => { const reader = new FileReader() reader.onload = (e) => { const img = new window.Image() img.onload = () => { // 创建 canvas const canvas = document.createElement('canvas') canvas.width = img.width canvas.height = img.height // 绘制图片到 canvas const ctx = canvas.getContext('2d') if (!ctx) { reject(new Error('无法获取 canvas context')) return } ctx.drawImage(img, 0, 0) // 转换为 PNG blob canvas.toBlob( (blob) => { if (!blob) { reject(new Error('图片转换失败')) return } // 创建新的 File 对象 const pngFile = new File( [blob], file.name.replace(/\.[^.]+$/, '.png'), { type: 'image/png', } ) resolve(pngFile) }, 'image/png', 1.0 ) } img.onerror = () => reject(new Error('图片加载失败')) img.src = e.target?.result as string } reader.onerror = () => reject(new Error('文件读取失败')) reader.readAsDataURL(file) }) } // 上传图片到七牛云 const handleImageUpload = async (e: React.ChangeEvent<HTMLInputElement>) => { const files = e.target.files if (!files || files.length === 0 || !qiniuToken) return const file = files[0] try { // 将图片转换为 PNG 格式 const pngFile = await convertImageToPng(file) const formData = new FormData() const key = `ai/mjBaseImg/${Date.now()}_${pngFile.name}` formData.append('file', pngFile) formData.append('token', qiniuToken) formData.append('key', key) const response = await fetch('https://upload-z1.qiniup.com', { method: 'POST', body: formData, }) const result = await response.json() if (result.code === 200) { const imageUrl = `https://static.xutongbao.top/${result.data.key}` setUploadedImages((prev) => [...prev, imageUrl]) } } catch (error) { console.error('上传失败:', error) } // 清空 input,允许重复选择同一文件 e.target.value = '' }js上传图片前改变图片的格式为png
张小明
前端开发工程师
【动态多目标优化】进化动态约束多目标优化测试集DCP1-DCP9的TruePF研究附Matlab代码
✅作者简介:热爱科研的Matlab仿真开发者,擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。🍎 往期回顾关注个人主页:Matlab科研工作室🍊个人信条:格物致知,完整Matlab代码及仿真咨询…
Spring AI Alibaba与 Agent Scope到底选哪个?
文章目录 引言概念纠正目前的两大发展方向Workflow模式(工作流)运行机制后端视角类比适用场景 Agentic 模式 (智能体 / 自主模式)运行机制:Loop (循环)后端视角类比适用场景 AgentScope java 和 Spring AI Alibaba的区别总结 引言 Spring AI Alibaba 和 Agent Scop…
导师推荐!10款AI论文写作软件测评:本科生毕业论文必备工具
导师推荐!10款AI论文写作软件测评:本科生毕业论文必备工具 2026年AI论文写作工具测评:为何需要这份榜单? 随着人工智能技术的快速发展,越来越多的本科生开始借助AI工具提升论文写作效率。然而,面对市场上琳…
ssm473的阳光养老院管理系统
目录阳光养老院管理系统摘要开发技术源码文档获取/同行可拿货,招校园代理 :文章底部获取博主联系方式!阳光养老院管理系统摘要 阳光养老院管理系统基于SSM(SpringSpringMVCMyBatis)框架开发,旨在为养老机构提供高效、…
uv 与 pip:Python 包与依赖管理工具对比
当谈到 Python 的包管理工具时,开发者常常要在 uv 和 pip 之间做出选择。 如果你看重开箱即用、广泛的兼容性和成熟的生态系统,pip 依然是稳妥之选;而如果你更关注安装速度、环境可复现性、干净的卸载行为,或者希望为新项目建立高…
如何选择适合跨境电商的全球代理IP?
在跨境电商运营中,代理IP已经成为保障业务顺利运行的重要工具。无论是进行多账号管理、广告投放,还是接触地区限制,都离不开代理IP的帮助。然而,面对市场上种类繁多的代理IP,如何挑选最合适自己的产品呢?下…