首页
学习
活动
专区
工具
TVP
发布

JS 图片压缩

前言 说起图片压缩,大家想到的或者平时用到的很多工具都可以实现,例如,客户类的有图片压缩工具 PPDuck3, JS 实现类的有插件 compression.js ,亦或是在线处理类的 OSS 上传,...文件上传后,在访问文件时中也有图片压缩配置选项,不过,能不能自己撸一套 JS 实现的图片压缩代码呢?...压缩思路 涉及到 JS图片压缩,我的想法是需要用到 Canvas 的绘图能力,通过调整图片的分辨率或者绘图质量来达到图片压缩的效果,实现思路如下: 获取上传 Input 中的图片对象 File 将图片转换成...base64 格式 base64 编码的图片通过 Canvas 转换压缩,这里会用到的 Canvas 的 drawImage 以及 toDataURL 这两个 Api,一个调节图片的分辨率的,一个是调节图片压缩质量并且输出的...,后续会有详细介绍 转换后的图片生成对应的新图片,然后输出 优缺点介绍 不过 Canvas 压缩的方式也有着自己的优缺点: 优点:实现简单,参数可以配置化,自定义图片的尺寸,指定区域裁剪等等。

25.3K21

详解 JS 压缩图片

作者 | wuwhs https://segmentfault.com/a/1190000023486410 公司的移动业务需要在用户上传图片是由前端压缩图片大小,再上传到服务器,这样可以减少移动端上行流量...插播一下,本文案例已整理成插件,已上传 npm ,可通过 npm install js-image-compressor -D 安装使用,可以从 github 下载。...JavaScript 操作压缩图片原理不难,已有成熟 API,然而在实际输出压缩后结果却总有意外,有些图片竟会越压缩越大,加之终端(手机)类型众多,有些手机压缩图片甚至变黑。 ?...; 这个图片文件可以被缓存或保存到本地,由用户代理自行决定。...将改进版图片压缩整理成插件,已上传 npm ,可通过 npm install js-image-compressor -D 安装使用,可以从 github 下载。 整理匆忙,如有问题欢迎大家指正,完~

12.5K31
您找到你想要的搜索结果了吗?
是的
没有找到

移动图片上传旋转、压缩的解决方案

Orientation 这个参数并不是所有图片都有的,不过手机拍出来的图片是带有这个参数的。...想要获取 Orientation 参数,可以通过 exif.js 库来操作。exif.js 功能很多,体积也很大,未压缩之前足足有 30k,这对手机页面加载来说是非常大影响的。...压缩 手机拍出来的照片太大,而且使用 base64 编码的照片会比原照片大,那么上传的时候进行压缩就非常有必要的。...因此第一步需要先对上传照片的宽高做限制,判断宽度或高度是否超出哪个范围,则等比压缩其宽高。...第二个参数为压缩质量,在指定图片格式为 image/jpeg 或 image/webp的情况下,可以从 0 到 1 的区间内选择图片的质量。

4.7K60

移动图片上传旋转、压缩的解决方案

Orientation 这个参数并不是所有图片都有的,不过手机拍出来的图片是带有这个参数的。...想要获取 Orientation 参数,可以通过 exif.js 库来操作。exif.js 功能很多,体积也很大,未压缩之前足足有 30k,这对手机页面加载来说是非常大影响的。...压缩 手机拍出来的照片太大,而且使用 base64 编码的照片会比原照片大,那么上传的时候进行压缩就非常有必要的。...因此第一步需要先对上传照片的宽高做限制,判断宽度或高度是否超出哪个范围,则等比压缩其宽高。...第二个参数为压缩质量,在指定图片格式为 image/jpeg 或 image/webp的情况下,可以从 0 到 1 的区间内选择图片的质量。

2.8K20

Nginx网络压缩 CSS压缩 图片压缩 JSON压缩

一、序言 使用Nginx作为web应用服务时,会代理如下常见文件:js、css、JSON、图片等,本文提供基于Nginx内置的压缩技术,提供网络请求响应速度的解决方案。...二、网络压缩 此部分所有的压缩内容在浏览器都会还原,特别需要指出的是图片图片在网络间是压缩状态传输的,到达浏览器后是会被还原的。...技术实现依托gzip压缩,仅仅在服务器与客户网络传输时对静态资源进程压缩,文件的大小在压缩前与还原后保持不变。...(一)Web资源 1、静态资源 前端项目中js/css文件越来越大,对其执行压缩处理越来越有必要。...图片压缩分为两类:一是等比压缩;二是固定宽高压缩。根据应用场景的不同也分为两类:一是固定参数;二是动态参数。 此部分图片压缩后到达浏览器不会被还原。

5.1K41

图片压缩原理

前言 说起图片压缩,大家想到的或者平时用到的很多工具都可以实现,例如,客户类的有图片压缩工具 PPDuck3, JS 实现类的有插件 compression.js ,亦或是在线处理类的 OSS 上传,...文件上传后,在访问文件时中也有图片压缩配置选项,不过,能不能自己撸一套 JS 实现的图片压缩代码呢?...压缩思路 涉及到 JS图片压缩,我的想法是需要用到 Canvas 的绘图能力,通过调整图片的分辨率或者绘图质量来达到图片压缩的效果,实现思路如下: 获取上传 Input 中的图片对象 File 将图片转换成...base64 格式 base64 编码的图片通过 Canvas 转换压缩,这里会用到的 Canvas 的 drawImage 以及 toDataURL 这两个 Api,一个调节图片的分辨率的,一个是调节图片压缩质量并且输出的...,后续会有详细介绍 转换后的图片生成对应的新图片,然后输出 优缺点介绍 不过 Canvas 压缩的方式也有着自己的优缺点: 优点:实现简单,参数可以配置化,自定义图片的尺寸,指定区域裁剪等等。

4.6K31

java 图片压缩

使用开源工具:thumbnailator 从jpg、jpeg、png(3.44MB)压缩到440kb也非常清晰,可自动设置压缩程度(0-1),目前压缩成为jpg的比较理想,压缩后为png并不能减少多少...,可能是由于png是属于无损压缩 1、截止2022-5-18最新版本为0.4.17 使用方便 size(width,height):图片宽高比。...forceSize:压缩至指定图片尺寸(例如:横400高300) scale:指定图片的大小,值在0到1之间,1f就是原图大小,0.5就是原图的一半大小,这里的大小是指图片的长宽。...遇到的问题 可能会出现OOM内存溢出的现象 ,需要调整-Xss大小 java启动命令nohup java -jar -Xmx6000m XXX.jar >/dev/null 2>&1 /** * 压缩图片...log.error("关闭输出流失败{}", e.getMessage()); } } catch (IOException e) { log.error("压缩图片处理失败

9.8K10

实践 | 移动图片上传旋转、压缩的解决方案

想要获取 Orientation 参数,可以通过 exif.js 库来操作。exif.js 功能很多,体积也很大,未压缩之前足足有 30k,这对手机页面加载来说是非常大影响的。...exif.js 获取 Orientation : file 则是 input 文件表单上传的文件。...压缩 手机拍出来的照片太大,而且使用 base64 编码的照片会比原照片大,那么上传的时候进行压缩就非常有必要的。...因此第一步需要先对上传照片的宽高做限制,判断宽度或高度是否超出哪个范围,则等比压缩其宽高。 第二步就通过 canvas.toDataURL() 方法来压缩照片质量。...第二个参数为压缩质量,在指定图片格式为 image/jpeg 或 image/webp的情况下,可以从 0 到 1 的区间内选择图片的质量。

2K20

【Android 内存优化】图片文件压缩 ( Android 原生 API 提供的图片压缩功能能 | 图片质量压缩 | 图片尺寸压缩 )

文章目录 一、 图片压缩 二、 图片文件压缩类型 三、 Android 原生 API 提供的质量压缩 四、 Android 原生 API 提供的尺寸压缩 一、 图片压缩 ---- 图片压缩 : ① 文件压缩...: 图片的文件压缩 , 一张图片可以经过压缩 , 占用更少的磁盘或网络空间 ; ② 文件压缩应用场景 : 网络传输图片 : 上传图片至服务器 , 为了 节省占用的带宽资源 , 将图片文件进行压缩 ;...保存图片 : 保存图片到设备的 SD 卡 , 为了 节省磁盘资源 , 将图片文件进行压缩 ; ③ 内存压缩 : 与文件压缩相对应的是内存压缩 , 在 内存中如何使用更少的内存显示出想要显示的图片 ; 在之后的博客中会详细介绍...; 二、 图片文件压缩类型 ---- 图片文件压缩类型 : ① 质量压缩 : 压缩清晰度 : 将图片的清晰度降低 , 一些画面的细节被模糊掉了 , 这些细节尽量不要让肉眼观察出来 ; 有损压缩 : 压缩后有信息损失..., 0-100 ; 0 压缩到极限最小 , 100 压缩时最高质量 , PNG 图片是无损图片格式 , 其质量不能被降低 , 会忽略该参数 ; OutputStream stream 参数 : 写出被压缩图片的输出流

4.2K20

Android-图片压缩-2行搞定图片压缩【2019】

图片压缩的方法有很多,这两天向同学学了一种方法,刚觉非常行之有效,与大家分享。...---- 图片压缩的作用: 当我们上传图片到数据库时,如果是头像图片,那么在客户显示出来一般是缩略图,这时大图是没有用的,又浪费加载时间 ---- 图片压缩的方法 /* 压缩路径下的文件 */ private...; } return pic; } ---- 使用解析 bitmap=Bitmap.createScaledBitmap(bitmap, 400, 400, false); 这段代码将图片大小压缩到...newBitmap = BitmapFactory.decodeStream(new ByteArrayInputStream(baos.toByteArray()), null, null); 这段将图片质量减少到原来的一半...---- 最后返回的File 为图片在内存中的暂存地址,自动释放,不用手动删除

1.6K10

Picdiet 在线图片压缩 极速压缩 80%图片质量不变

随着网站发布图片越来越多,图片压缩优化而不失真成了一个很重要的事情。前面介绍过 tinypng 和 Optimizilla 这两种在线图片压缩网站,今天再来说一个Picdiet 在线图片压缩。...官方号称其独特且强悍的 JavaScript 算法,能极速压缩 80%的图片大小,而不损害其质量。让我们来试试吧。...相关文章:Optimizilla 在线图片压缩优化 自由调整图片压缩比例 TinyPNG 和 WordPress 图片压缩 Picdiet 的优点是无图像尺寸限制、无图像数量限制、无文件大小限制。...3、从下面可以看到图片压缩前后的效果对比,中间的滚动条可以跟随鼠标滑动,一个蛮有意思的互动响应。压缩前 2.47M,压缩后 664K,压缩比 74%也是蛮高了。而通过图片效果也看不出质量有明显下降。...,压缩比例也是自动调节的,你如果用过另外两个图片压缩网站有什么心得体会,希望能分享出来大家知道。

3.8K10
领券