当前位置: 首页 > news >正文

js实现webp转png/jpg

网上保存的图片是webp类型的,但是我把它嵌入flac格式的音频里后导致网页中无法播放
wps要会员,真麻烦。
完整代码:
 

<!DOCTYPE html>  
<html lang="zh-CN">  
<head>  
<meta charset="UTF-8">  
<meta name="viewport" content="width=device-width, initial-scale=1.0">  
<title>WebP to PNG Converter</title>  
<style>  .input-area {  margin-bottom: 10px;  }  .output-area {  margin-top: 10px;  }  
</style>  
</head>  
<body>  <div class="input-area">  <input type="file" id="webp-input" accept=".webp" onchange="javascript:preview()" /><div id="img-preview"></div><button onclick="convertWebp('image/png')">转换成png</button><button onclick="convertWebp('image/jpg')">转换成jpg</button>
</div>  <div class="output-area" id="output-area">  <!-- 下载链接将在这里动态生成 -->  
</div>  <script>  
function preview(){const imgContent = document.getElementById('img-preview');const file = document.getElementById("webp-input").files[0];imgContent.innerHTML = '';const img = document.createElement('img');img.src = URL.createObjectURL(file);imgContent.appendChild(img);img.onload = function() {URL.revokeObjectURL(this.src);}
}
function convertWebp(mimeType) {  const inputElement = document.getElementById('webp-input');  const file = inputElement.files[0];  if (!file) {  alert('Please select a WebP file first.');  return;  }  const reader = new FileReader();  reader.onload = function(event) {  const img = new Image();  img.onload = function() {  const canvas = document.createElement('canvas');  canvas.width = img.width;  canvas.height = img.height;  const ctx = canvas.getContext('2d');  ctx.drawImage(img, 0, 0, img.width, img.height);  const pngUrl = canvas.toDataURL(mimeType);  const link = document.createElement('a');  link.href = pngUrl;if(mimeType === 'image/png'){link.download = 'converted.png';  }else if(mimeType === 'image/jpg'){link.download = 'converted.jpg';}document.getElementById('output-area').appendChild(link);  link.click(); // 触发下载  };  img.src = event.target.result;  };  reader.readAsDataURL(file);  
}  
</script>  </body>  
</html>

相关文章:

js实现webp转png/jpg

网上保存的图片是webp类型的&#xff0c;但是我把它嵌入flac格式的音频里后导致网页中无法播放 wps要会员&#xff0c;真麻烦。 完整代码&#xff1a; <!DOCTYPE html> <html lang"zh-CN"> <head> <meta charset"UTF-8">…...

DVWA -File Upload-通关教程-完结

DVWA -File Upload-通关教程-完结 文章目录 DVWA -File Upload-通关教程-完结页面功能LowMediumHighImpossible 页面功能 此页面的功能为选择某个图片文件点击Upload按钮上传&#xff0c;上传成功后得知文件上传路径为DVWA\hackable\uploads。 Low 源码审计 这段 PHP 代码…...

中介者模式:简化对象间通信的协调者

在面向对象的软件开发中&#xff0c;中介者模式是一种重要的行为型设计模式&#xff0c;用于降低多个对象间通信的复杂性。通过提供一个中心化的对象来处理不同组件之间的交互&#xff0c;中介者模式使得组件间不必显式引用彼此&#xff0c;从而使其松散耦合、更易于维护。本文…...

【Python系列】pydantic版本问题

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...

深度学习-多尺度训练的介绍与应用

一、引言 在当今快速发展的人工智能领域&#xff0c;多尺度训练已经成为了一种至关重要的技术&#xff0c;特别是在处理具有复杂结构和不同尺度特征的数据时。这种技术在许多应用中发挥着关键作用&#xff0c;例如图像识别、自然语言处理和视频分析等。 多尺度训练的定义 多尺…...

详解单文件组件

当你创建 Vue 单文件组件时&#xff0c;通常会包含三个部分&#xff1a;<template>、<script> 和 <style>。这三个部分分别用于定义组件的模板、逻辑和样式。让我更详细地解释一下它们的作用和用法&#xff1a; <template> <template> 标签用于…...

MLeaksFinder报错

1.报错&#xff1a;FBClassStrongLayout.mm 文件&#xff1a;layoutCache[currentClass] ivars; 解决&#xff1a;替换为layoutCache[(id)currentClass] ivars; 2.编译正常但运行时出现crash indirect_symbol_bindings[i] cur->rebinding FBRetainCycleDetector iOS15 …...

【心路历程】初次参加蓝桥杯实况

送给大家一句话&#xff1a; 寂静的光辉平铺的一刻&#xff0c;地上的每一个坎坷都被映照得灿烂。 – 史铁生 《我与地坛》 初次参加蓝桥杯有感 一点小小的震撼难评的做题过程A题 艺术与篮球问题描述解题 B 题 五子棋问题描述解题 C题 训练士兵问题描述解题 D题 团建解题 E题 …...

微信小程序全屏开屏广告

效果图 代码 <template><view><!-- 自定义头部 --><u-navbar title" " :bgColor"bgColor"><view class"u-nav-slot" slot"left"><view class"leftCon"><view class"countDown…...

记录day1

1.早上 ①协同过滤算法 基于物品基于用户分别是如何实现的 相似度的计算方式 基于用户和基于物品的区别 实时性和新物品这里&#xff1a; 实时性指的是用户有新行为&#xff0c;这样基于物品就好&#xff0c;因为用户新行为了&#xff0c;用户矩阵不会变化&#xff0c;用户…...

stm32GPio的开发基础

上拉输入&#xff1a;高电平&#xff08;弱高电平&#xff0c;一般默认&#xff09; 下拉输入&#xff1a;低电平 没有上拉下拉就是处于一个不确定的状态 推挽wan输出&#xff1a;驱动能力比较强&#xff0c;推挽是因为往外推 set就是1&#xff0c;reset就是0 XMX就是封装的…...

DataSource

目录 1、 DataSource 1.1、 * 建立数据库连接的参数对象 1.1.1、 * 数据库url 1.1.2、 * 数据库用户名 1.1.3、 * 数据库密码 1.1.4、 * 数据库驱动名称 <...

Linux防止暴力破解密码脚本

1.认识记录linux记录安全的日志 [roottestpm ~]# cd /var/log/ [roottestpm log]# ls | grep secure secure 2.该日志的内容查看 [roottestpm log]# tail -f secure #表示ssh身份验证失败 Aug 29 23:35:03 testpm sshd[111245]: pam_unix(sshd:auth): authentication fa…...

Unity 遮罩

编辑器版本 2017.2.3f1 学习Unity的三张遮罩方式 1. Mask 遮罩方式 首先&#xff0c;在界面上创建2个Image&#xff0c;一个命名Img_Mask,大小设置 400* 400&#xff0c; 一个命名Img_Show,大小设置500*500。 然后&#xff0c;给 Img_Mask添加Mask,选择Img_Mask,点击Add Com…...

jmeter实验 模拟:从CSV数据到加密请求到解密返回数据再到跨越线程组访问解密后的数据

注意,本实验所说的加密只是模拟加密解密,您需要届时写自己的加解密算法或者引用含有加密算法的相关jar包才行. 思路: 线程组1: 1.从CSV文件读取原始数据 2.将读取到的数据用BeanShell预习处理器进行加密 3.HTTP提取器使用加密后的数据发起请求 4.使用BeanShell后置处理器…...

设计模式——外观(门面)模式10

外观模式&#xff1a;能为系统框架或其他复杂业务流程封装提供一个简单的接口。 例如抽奖过程中 设计模式&#xff0c;一定要敲代码理解 调用1&#xff08;抽奖系统&#xff09; /*** author ggbond* date 2024年04月08日 10:34*/ public class Lottery {public String getId…...

第七周周一人工智能导论预告

第一讲 人工智能概述 1.1 简介 1.2人工智能的概念 1.3 人工智能的发展简史 1.4 人工智能研究的基本内容 第一讲 人工智能概述单元测试 第二讲 一阶谓词逻辑表示法 2.1 命题逻辑 2.2 谓词逻辑 2.3 一阶谓词逻辑知识表示法 第二讲 一阶谓词逻辑知识表示法单元测试 第…...

npm install 的不同选项:--save、--save-dev、-S、-D 的区别

Node.js 的包管理器 npm 提供了一个命令 npm install&#xff0c;用于安装 Node.js 项目所需的依赖包。在使用这个命令时&#xff0c;我们可以通过添加不同的选项来控制依赖包的安装方式。本文将详细介绍这些选项&#xff1a;--save、--save-dev、-S 和 -D 的区别。 1. --save…...

设计模式详解(十四)——策略模式

策略模式简介 策略模式定义 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为型设计模式&#xff0c;它使能在运行时改变对象的行为。策略模式属于对象行为模式&#xff0c;它定义了一系列的算法&#xff0c;并将每一个算法封装起来&#xff0c;使它们可以互相替换…...

【牛客SQL快速入门】SQL基础(二)

一、高级查询 1. 计算函数 AVG AVG()为平均值函数&#xff0c;通过对表中行数计数并计算其列值之和&#xff0c;求得该列的平均值。 AVG() 可用来返回所有列的平均值&#xff0c;也可以用来返回特定列或行的平均值。 Select avg(gpa) From user_profile COUNT COUNT()函数…...

【Matlab】无人机集群通信拓扑优化实现

【Matlab】无人机集群通信拓扑优化实现 一、引言 无人机集群凭借协同作业、冗余容错、全域覆盖等核心优势,在区域侦察、应急搜救、编队巡检、联合打击等场景中实现规模化应用,而**稳定高效的通信拓扑**是集群完成协同任务的核心基础。无人机集群属于动态移动自组织网络,节…...

王道C语言督学营课后习题OJ题解:手把手教你如何高效刷题

王道C语言OJ题解实战指南&#xff1a;从刷题到精通的系统化路径 在编程学习的道路上&#xff0c;OJ&#xff08;Online Judge&#xff09;系统就像一位严格的考官&#xff0c;它能准确检验我们对C语言的理解深度和算法应用能力。很多学习者虽然掌握了基础语法&#xff0c;却在面…...

收藏!小白程序员必看:11个高级RAG策略彻底解决系统效果不佳问题

本文深入探讨了朴素RAG系统效果不佳的原因&#xff0c;并提出了11种先进的RAG策略&#xff0c;包括上下文感知分块、上下文检索、重排序等&#xff0c;详细阐述了如何通过组合这些策略来提升系统准确率。文章还提供了实际应用案例和实施路线图&#xff0c;帮助读者理解和应用这…...

代码知识图谱进阶实战(非常详细),GitNexus公共记忆系统从入门到精通,收藏这一篇就够了!

&#x1f980;在 GitHub 日榜登顶的 GitNexus&#xff0c;表面是一款代码智能引擎&#xff0c;本质上是用图结构沉淀知识、让协作永不失忆的基础设施。它不仅解决了“屎山代码看不懂”的问题&#xff0c;更给我们提供了一套构建可靠公共记忆系统的底层范式。 一、GitNexus 到底…...

六、免Root免Hook,探索Android原生系统层定位修改新实践

1. 为什么需要免Root免Hook的定位修改方案 最近几年&#xff0c;金融类App的风控系统越来越严格&#xff0c;传统的定位修改方法逐渐失效。我做过测试&#xff0c;某银行App能检测出90%的Xposed框架&#xff0c;甚至能识别Magisk的隐藏模式。更麻烦的是&#xff0c;很多社交平…...

translategemma-27b-it实战:本地部署图文翻译模型,轻松制作视频字幕

Translategemma-27b-it实战&#xff1a;本地部署图文翻译模型&#xff0c;轻松制作视频字幕 1. 为什么选择translategemma-27b-it做字幕翻译 视频字幕制作一直是内容创作者面临的挑战。传统方法需要先提取视频中的文字&#xff0c;再使用翻译工具处理&#xff0c;整个过程繁琐…...

KeySim:如何通过3D虚拟设计打造你的梦想键盘?

KeySim&#xff1a;如何通过3D虚拟设计打造你的梦想键盘&#xff1f; 【免费下载链接】keysim design and test virtual 3d keyboards. 项目地址: https://gitcode.com/gh_mirrors/ke/keysim 在键盘爱好者的世界里&#xff0c;每一款键盘都是个性与功能的完美结合&#…...

机载火控雷达资源调度优化:工作模式与功率管理的实战解析

1. 机载火控雷达的战场生存法则 现代空战就像两个蒙着眼睛的拳击手在擂台上对决&#xff0c;谁先摸清对方的位置&#xff0c;谁就能打出致命一击。机载火控雷达就是战机在空战中的"电子眼"&#xff0c;但这个眼睛有个致命弱点——当它盯着对手看的时候&#xff0c;自…...

STM32烟花爆竹仓库环境监测系统设计

基于STM32的烟花爆竹仓库环境监测系统设计 1. 项目概述 1.1 系统架构 本系统采用STM32F103RCT6作为主控制器&#xff0c;构建了一套完整的烟花爆竹仓库环境监测解决方案。系统通过多传感器协同工作&#xff0c;实时采集仓库内的温度、湿度、可燃气体浓度、烟雾浓度及火焰状态…...

解析防护等级IP52、IP67和IP69K

一、IP代码基础结构IP代码&#xff08;Ingress Protection&#xff0c;进入防护&#xff09;是国际标准&#xff08;IEC 60529&#xff09;&#xff0c;用于定义电气设备外壳对固体异物和液体的防护能力。代码格式为&#xff1a;IP [第一位数字] [第二位数字]第一位数字&#x…...