PNG图片压缩-UPNG.js参数说明及示例

UPNG.js是一个非常轻量且高效的库,用于处理PNG图像。它可以编码和解码PNG图片,同时支持压缩和解压缩功能。特别适合在前端项目中处理图像,尤其是在需要优化图像大小而不牺牲质量时。

UPNG.encode()函数是UPNG.js中用于将图像数据编码成PNG格式的函数,参数如下:

UPNG.encode(imgs, w, h, cnum, dels, forbidPlte)

imgs:图像数据。它是一个Uint8Array数组的数组,其中每个Uint8Array代表一个图像帧的RGBA像素数据。

w(width):生成的PNG图像的宽度(以像素为单位)。

h(height):生成的PNG图像的高度(以像素为单位)。

cnum:颜色数量。这个参数决定了输出PNG的颜色深度。比如,将其设置为256会生成8位颜色的PNG图像。特别地,设置为0会让UPNG.js自动选择最优的颜色数量。

dels:帧延时数组,仅当imgs包含多个帧以生成动画PNG时有效。每个元素代表对应帧的延时时间(以毫秒为单位)。

forbidPlte(可选):这是一个布尔值参数,当设置为true时,会禁止生成带有调色板(palette)的PNG。调色板PNG通常用于压缩图像大小而不是质量,但不是所有场景都需要或希望使用调色板。

 

  • 低颜色复杂度:如果你的图像具有很少的颜色(例如图标、简单图形、拥有大块单色区域的图片),则使用较低的cnum值(比如16、64或128)可能是合适的。这样可以减小文件大小,同时保持质量。
  • 高颜色复杂度:对于颜色渐变丰富、细节复杂的照片,低cnum值可能导致质量明显下降。对于这类图片,较高的cnum值或者自动选择(cnum=0)更合适。
  • 网页用途:对于网页用途,你可能希望图像尽可能小以加快页面加载速度。开始可以尝试中等cnum值(如256),根据结果调整或考虑自动选择。
  • 打印或高质量展示:当图像质量是首要考虑时,应优先考虑较高的cnum值,甚至自动选择,以尽可能保留原图的质量和细节。

 

当cnum设置为0时,UPNG.js试图自动确定最佳颜色数以平衡大小和质量,但这并不总能得到最小文件大小。因为自动选择可能会倾向于保留更多的颜色以保证质量,而这有时会导致文件大小的增加,尤其是对于本来就有很多颜色的图片。

 

cnum(颜色数量)的取值范围是从0到32767。具体取值范围如下:

  • 0:自动选择颜色数量,UPNG.js将尝试自动确定最佳的颜色数量以平衡文件大小和图像质量。
  • 1 - 255:指定一个固定的颜色数量。较小的值会产生更小的文件大小,但可能会降低图像质量。
  • 256 - 32767:当cnum大于255时,UPNG.js将尝试最小化文件大小,同时保持足够高的图像质量。

 

示例:

function handlePNG(file) {

  const reader = new FileReader();

  reader.onload = function (e) {

      try {

          const arrayBuffer = e.target.result;

          const decodedImg = UPNG.decode(arrayBuffer); // 解码

          const rgba = UPNG.toRGBA8(decodedImg); // 转换为RGBA数组,每个帧一个元素

          // 压缩和重编码图像,颜色值可根据实际需求调整

          const compressedArrayBuffer = UPNG.encode(rgba, decodedImg.width, decodedImg.height, 0);

          // 处理压缩后的图像

          // 例如,将其转换为Blob,然后URL.createObjectURL可以用于显示图片:

          const blob = new Blob([compressedArrayBuffer], {type: 'image/png'});

          const imageUrl = URL.createObjectURL(blob);

          console.log(imageUrl); // 用于显示或下载图片等

      } catch (error) {

          console.error("处理PNG文件时出错: ", error);

      }

  };

  reader.onerror = function (error) {

      console.error("读取文件时出错: ", error);

  };

  reader.readAsArrayBuffer(file);

}

体验参考:

 简单设计EasyDesign-免费在线设计工具图片处理工具icon-default.png?t=N7T8https://jiandan.link/#/imagetools?index=0&com=ImageCompress

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/402554.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

第三十九天| 62.不同路径、63. 不同路径 II

Leetcode 62.不同路径 题目链接:62 不同路径 题干:一个机器人位于一个 m x n 网格的左上角 (起始点在下图中标记为 “Start” )。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角(在下图中标记为 “…

Android进阶(二十九) 走近 IntentFilter

文章目录 一、什么是IntentFilter ?二、IntentFilter 如何过滤隐式意图?2.1 动作测试2.2 类别测试2.3 数据测试 一、什么是IntentFilter ? 如果一个 Intent 请求在一片数据上执行一个动作, Android 如何知道哪个应用程序&#xf…

三维测量技术及应用

接触式测量(Contact Measurement): 坐标测量机(CMM, Coordinate Measuring Machine):通过探针直接接触物体表面获取三维坐标数据。优点是精度高,但速度慢,对软质材料测量效果不佳&am…

JavaScript 设计模式之享元模式

享元 将一部分共用的方法提取出来作为公用的模块 const Car {getName: function () {return this.name},getPrice: function (price) {return price * 30} }const BMW function (name, price) {this.name namethis.price price } BMW.prototype Car const bmw new BMW(…

【嵌入式学习】IO进程线程day02.22

一、思维导图 二、习题 1> 将互斥机制的代码实现 #include <myhead.h>//定义一个全局变量 char str[128]"我是一个全局字符串数组"; //1、创建一个互斥锁变量 pthread_mutex_t mutex;//线程1 void *pth1(void *arg) {//上锁pthread_mutex_lock(&mutex…

Azuki NFT 概览与数据分析

作者&#xff1a;stellafootprint.network 编译&#xff1a;cicifootprint.network 数据源&#xff1a;Azuki NFT Collection Dashboard Azuki NFT 将动漫艺术与实用性相结合&#xff0c;培育了一个充满活力的 Web3 社区。 这个 NFT 项目会在 2024 年崛起吗&#xff1f; …

keepalived双活互备模式测试

文章目录 环境准备部署安装keepavlived配置启动测试模拟Nginx宕机重新启动问题分析 环境准备 测试一下keepalived的双主模式&#xff0c;所谓双主模式就是两个keepavlied节点各持有一个/组虚IP&#xff0c;默认情况下&#xff0c;二者互为主备&#xff0c;同时对外提供服务&am…

运维07:堡垒机

什么是跳板机 跳板机就是一台服务器而已&#xff0c;运维人员在使用管理服务器的时候&#xff0c;必须先连接上跳板机&#xff0c;然后才能去操控内网中的服务器&#xff0c;才能登录到目标设备上进行维护和操作 开发小张 ---> 登录跳板机 ---> 再登录开发服务器 测试…

[AI]部署安装有道QanyThing

前提条件&#xff1a; 1、win10系统更新到最新的版本&#xff0c;系统版本最好为专业版本 winver 查看系统版本&#xff0c;内部版本要大于19045 2、CPU开启虚拟化 3、开启虚拟化功能&#xff0c;1、2、3每步完成后均需要重启电脑&#xff1b; 注&#xff1a;windows 虚拟…

C++模板->模板的概念、函数模板基本语法、函数模板注意事项、普通函数与函数模板区别、普通函数与函数模板调用规则、模板的局限性

#include<iostream> using namespace std; //交换两个整型函数 void swapInt(int& a, int& b) { int temp a; a b; b temp; } //交换两个浮点型函数 void swapDouble(double& a, double& b) { double temp a; a b; b te…

Unity Meta XR SDK 快捷配置开发工具【Building Block/Quick Action/OVRCameraRigInteraction】

文章目录 &#x1f4d5;教程说明&#x1f4d5;Building Block&#x1f4d5;Quick Action&#x1f4d5;OVRCameraRigInteraction 此教程相关的详细教案&#xff0c;文档&#xff0c;思维导图和工程文件会放入 Spatial XR 社区。这是一个高质量 XR 社区&#xff0c;博主目前在内…

计算机网络Day02--物理层(一)

计算机网络Day02–物理层 物理层基本概念 物理层考虑的是怎么才能在连接各种计算机的传输媒体上传输比特流&#xff0c;而不是具体的传输媒体 作用&#xff1a;尽可能屏蔽掉不同传输媒体和通信手段的差异 用于物流层的协议也称为物流层规程 主要作用&#xff1a;解决计算机…

基于SpringBoot + Layui的社区物业管理系统

项目介绍 社区物业管理系统是基于java编程语言&#xff0c;springboot框架&#xff0c;idea工具&#xff0c;mysql数据库进行开发&#xff0c;本系统分为业主和管理员两个角色&#xff0c;业主可以登陆系统&#xff0c;查看车位费用信息&#xff0c;查看物业费用信息&#xff0…

yml配置文件中常见的配置及含义

1.数据库连接的相关配置 项目名称:datasource:driver-class-name: com.mysql.cj.jdbc.Driverhost: localhostport: 3306database: 数据库名username: 用户名password: 密码 springboot配置文件,用于配置数据库源连接信息 数据库驱动类型为com.mysql.cj.jdbc.Driver,这是数据…

linux逻辑卷/dev/mapper/centos-root扩容增加空间

centos7中/dev/mapper/centos-root扩容 问题文件系统根目录&#xff0c;/dev/mapper/centos-root空间满了&#xff0c;导致k8s不停重启 1.查看磁盘情况 df -h #查看最大占用目录 du -h -x --max-depth12.查看磁盘信息 fdisk -l3.查看磁盘分区层级 lsblk4.新建分区 在/dev…

面试答疑03

1、登录鉴权怎么做的&#xff1f;为什么采用jwt的方式&#xff1f;有什么好处&#xff1f; Java登录鉴权常见的实现方式包括**CookieSession、HTTP Basic Authentication、ServletJDBC**等。 在Java的Web应用中&#xff0c;登录鉴权是确认用户身份的关键环节。一个常用的传统…

补环境框架过某物

声明: 本文章中所有内容仅供学习交流使用&#xff0c;不用于其他任何目的&#xff0c;不提供完整代码&#xff0c;抓包内容、敏感网址、数据接口等均已做脱敏处理&#xff0c;严禁用于商业用途和非法用途&#xff0c;否则由此产生的一切后果均与作者无关&#xff01;wx a15018…

2024年最火副业揭示:抖音小店无货源,我每小时收入高达2000

大家好&#xff0c;我是电商花花。 昨天刷到一条网友的帖子&#xff0c;“没有副业根本活不下去”&#xff0c;说的心里一紧。 细细品味&#xff0c;说的还真的挺对&#xff0c;大多数人都只是只有一个收入渠道&#xff0c;那就是上班&#xff0c;上班才会有收入&#xff0c;…

Typescript初体验

Typescript Typescript 官网地址: https://www.typescriptlang.org/zh/ 使用 nvm 来管理 node 版本: https://github.com/nvm-sh/nvm 装 Typescript: npm install -g typescript使用 tsc 全局命令&#xff1a; // 查看 tsc 版本 tsc -v // 编译 ts 文件 tsc fileName.ts1.…

外包干了三年,技术算是废了。。。

先说一下自己的个人情况&#xff0c;大专生&#xff0c;17年通过校招进入湖南某软件公司&#xff0c;干了接近5年的手工测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了五年的手工…