1.å¾çå¨çº¿å缩ï¼å¾çå缩å¨çº¿å·¥å
·ï¼
2.开发一款压缩工具(二):使用 pngquant 实现压缩
3.Pic Smaller:在线图像压缩工具源码 基于浏览器本地压缩
4.NodeJS Imagemin
5.基于AI或传统编码方法的压缩g源图像压缩开源算法汇总
å¾çå¨çº¿å缩ï¼å¾çå缩å¨çº¿å·¥å ·ï¼
å¾çå缩å¨å·¥ä½ä¸ç»å¸¸ä¼ç¨å°ï¼ä¾å¦PPTéé¢å¾çç´ æä½ç§¯å¤ªå¤§çè¯ï¼ä¼å¯¼è´PPTæ件太大ï¼æå¼éåº¦å¤ªæ ¢ãåæè ç½ç«çå¾çä½ç§¯å¤ªå¤§ï¼å½±å访é®é度ï¼ç¨æ·ä½éªä¸éï¼æ以就å¾ç»å¾çè¿è¡å缩ä½ç§¯ï¼å¹¶ä¸ä¸ä¼æ失å¾ç太大çè´¨éã
é£ä¹æä»ä¹å¾çåç¼©å·¥å ·å¥½ç¨ï¼ä¸é¢éå¥ç»å¤§å®¶æ¾æ¥äº4款å è´¹å¾çåç¼©å·¥å ·ï¼å ¶ä¸å¼ºçæ¨èè°·æçSquooshå è´¹å¼æºå·¥å ·ã
TinyPNG
TinyPNGä¸ä¸ªèåçå¨çº¿å¾çå缩ç½ç«ï¼å®æ²¡ææä¾å缩çç»ä½ éæ©ï¼ä¼èªå¨æ ¹æ®å¾çè´¨éå¸®ä½ èªå¨éæ©è¾å¥½çå缩çï¼ååºæ¥çå¾çé½ä¸ä¼åºç°ææ¾çæ失质éã
ä¸è¿å è´¹ç¨æ·å¾çéå¶æ大5MBï¼è¶ è¿çè¯å°±éè¦è´ä¹°PROçäºãä¹åéå¥ç»å¤§å®¶å享è¿ç¬¬ä¸æ¹çTinyPNG客æ·ç«¯ï¼å©ç¨å®æ¹çAPIæ¥å£ï¼åªè¦éè¿APIKEY就没ææ大5MBéå¶äºã
注æçæ¯ï¼æ¯ä¸ªAPIæ¯ææå¼ å¾çå è´¹é¢åº¦ï¼å¦æä½ ä¸å¤ç¨çè¯ï¼åæ¢ä¸ªé®ç®±å»ç³è¯·KEY就好äºãå¦å¤å®¢æ·ç«¯æ¯æå缩åç´æ¥æ¿æ¢åå¾çåè½ã
Imagine
Imagineä¸æ¬¾å¼æºå è´¹å®ç¨çå¾çåç¼©å·¥å ·ï¼æ¯æç®å主æµçå¾çæ ¼å¼ï¼å æ¬æWebPãPNGãJPEGï¼åªè¦ææ¾å¾çå°è½¯ä»¶çé¢å³å¯èªå¨å缩ï¼å¹¶å¯ä»¥çå°å缩çï¼æ¯æèªç±è°æ´å缩大å°ã
å缩好çå¾çæ¯ææ¹é导åºï¼å¯ä»¥è¦çæºæ件æè 导åºå°æ°çç®å½éé¢ï¼æ»çæ¥è¯´ç®åæ¹ä¾¿ï¼éåéé度å¾çå缩ç¨æ·ã
å¾å
å¾åä¸æ¬¾å è´¹ç®åæç¨çå¾çå缩软件ï¼è¿æ¯æWindows/macOSåå¹³å°ï¼å®æ¹è¡¨ç¤ºåºäºä¼ç§çå¼æºé¡¹ç®è¿è¡å¼åçä½åï¼æ以å¾åä¹æ¯å è´¹å¼æºçï¼åªä¸è¿æ²¡æå ¬å¼æºç ï¼ä½ éè¦æºç çè¯å¯ä»¥å¨å®æ¹çè¨åé¦ç³è¯·ã
å¾åç®åæ¯æJPGãPNGãGIFãSVGåç§æ常è§çå¾çæ ¼å¼ï¼æä½é常ç®åï¼åªéè¦æå ¥å¾çå°ãå¾åãçé¢åå°±ä¼èªå¨å缩ã
Squoosh
Squooshæ¯ç±GoogleChromeLabsä¹å°±æ¯è°·æåºåçå è´¹å¼æºå¾çåç¼©å·¥å ·ï¼ä½¿ç¨ç®åï¼ææé«çå缩æ¯ãé¤å¤è¿æ¯æç设置é项å æ¬å¾çç宽é«ã纵横æ¯ãè°è²æ¿çåæ°ï¼åæ¶ä¹å¯ä»¥å°å¾çå缩转å为JPGãWebPåPNGçå¤ç§å¾çç±»åã
å 为Squooshæ¯å¼æºé¡¹ç®ï¼å¹¶ä¸æä¾äºAPIçæ¯æï¼ç®åä¹æ人å¶ä½äºç¦»çº¿ç客æ·ç«¯çï¼è¿æ ·å°±å¯ä»¥ç´æ¥æ¬å°ç¨äºï¼æ¯è¾æ¹ä¾¿ã
åè½æ¹é¢åºæ¬ä¸åSquooshå¨çº¿çæ¬ä¸æ ·ï¼å½ç¶å¦æä½ æèªå·±çVPSæå¡å¨ä¹å¯ä»¥èªå·±é¨ç½²æ管项ç®ã
æ»ç»
å¨ä¹åéå¥ä¸ç´ç¨TinyPNGæ¥å缩å¾çï¼å 为ä¸éè¦ä½ å»è®¾ç½®å缩çï¼è½ç¶æ¯ææå缩ï¼ä¸éèç¼åºæ¬ä¸çä¸å¤ªåºè´¨éä¸éãä¸è¿æ¯è¾éº»ç¦ç¹å°±æ¯éè¦ç³è¯·APIæè è´ä¹°PROçã
ç´å°ç¨äºè°·æçSquooshåç°å®å ¨å¯ä»¥ä»£æ¿TinyPNGï¼æ¯æç´æ¥å¯¹æ¯å缩åçææï¼è¿æä¸äºå缩é项åè½ï¼ä¾å¦å辨çãå缩åæ°çï¼å¹¶ä¸å®å®å ¨å ¨å è´¹ï¼æ ä»»ä½éå¶ã
开发一款压缩工具(二):使用 pngquant 实现压缩
使用 pngquant 实现压缩,相较于上篇使用 pillow 库,压缩g源pngquant 能提供更高效的压缩g源压缩效果,文件大小通常能减小高达 %,压缩g源且能保持 alpha 透明度,压缩g源甚至在使用 8 位 PNG 格式时,压缩g源代购产品溯源码相较于 / 位 PNG 文件,压缩g源体积能减小 -%。压缩g源其背后核心算法包括改进的压缩g源中值切割量化和 K-means 颜色校正,使得压缩后的压缩g源颜色差异几乎不可察觉。
将 pngquant 库应用在压缩时,压缩g源首先需要安装相应的压缩g源工具,这涵盖了源码、压缩g源命令行、压缩g源GUI 等多种形式。压缩g源虽然 GUI 工具目前较为复杂,不易使用,但命令行形式通过直接调用命令即可实现 PNG 压缩,操作简便。安装步骤包括下载适合的操作系统版本的安装包,然后在命令行界面输入“pngquant”即可启动使用。电脑硬盘锁源码若希望进一步方便操作,还可配置环境变量,便于后续使用。
在实际操作中,pngquant 提供了多种可选参数来调整压缩效果,以适应不同的需求。例如,“--skip-if-larger”选项可避免压缩后的文件体积大于原始文件,以避免无效操作;“--quality”参数允许设置质量等级,通常建议在不影响视觉效果的前提下适当减小,但降低此值会导致压缩率降低;“--force”选项则允许覆盖已存在的压缩文件,确保压缩过程的一致性;此外,通过“--output”参数指定输出文件名,若希望将输出文件格式设定为 jpg,尽管此操作通常不会使文件变小,但在某些场景下可能有特定需求。
为了更高效地调用 pngquant 命令行工具,可以使用 Python 的 subprocess 模块来封装一个压缩函数。虽然在获取命令行输出时通常不需要此操作,但在实际集成应用中,layer7 源码通过 subprocess 调用 pngquant 命令行,能够实现自动化处理,提升整体流程的效率与灵活性。
Pic Smaller:在线图像压缩工具源码 基于浏览器本地压缩
图小小是Github开源社区上的一款在线图像压缩工具源码,它采用Vite+React技术栈开发,支持JPEG/PNG/WebP/Gif四种格式的压缩。
图小小是一款用户界面直观且提供压缩配置的优秀在线压缩工具。其特色在于使用浏览器本地进行压缩,避免了服务端交互,确保了用户的安全性。
使用图小小非常便捷,无需担心GFW影响,中国用户可直接访问网址pic-smaller.vercel.app或 picsmaller.com来使用它。
图小小是一个纯Vite + React项目,开发前需先熟悉这些技术。项目使用现代浏览器技术,如OffscreenCanvas、WebAssembly和Web Worker,提供高效压缩功能。
如需在本地服务器部署图小小,arm gpu 驱动 源码项目提供了基于Docker的文档和测试通过的Dockerfile脚本。只需在项目根目录按照指引启动Docker应用程序。
部署完成后,通过.0.0.1:可访问项目。若要使项目面向所有人开放,需准备指向本地的域名,并通过nginx等反向代理服务器将请求代理至本地的端口。
NodeJS Imagemin
imagemin是常用的NodeJS压缩库,支持多种插件,包括有损和无损压缩。其用法简单直接,但安装过程中可能出现一些问题,特别是在 CentOS 系统上。
在安装过程中,首先安装imagemin本身,这通常不会出现问题。接着,安装用于压缩PNG的插件imagemin-pngquant时,会遇到依赖底层读写PNG的跨平台库libpng-dev的错误。在CentOS上,qtopia4源码可以使用rpm -qa |grep libpng命令检查该库是否已安装,如果没有,则需要通过yum install libpng-devel进行安装。
安装libpng-dev之后,再次尝试安装imagemin-pngquant,仍会遇到错误“Error: pngquant failed to build, make sure that libpng-dev is installed”。进一步的排查发现,问题可能是由yum安装的libpng-devel版本过低,不兼容pngquant-bin提供的源码版本所导致的。
解决这一问题有两种方法。第一种是升级libpng-devel的版本,但这并非推荐做法,因为这可能会依赖于GLIBC版本,而GLIBC是Linux系统底层API,几乎所有运行库都依赖于它,并且它提供了许多必要的功能实现。这种升级操作可能会导致严重问题。第二种方法是手动安装pngquant(一个使用C语言编写的PNG压缩开源库),在CentOS中,需要先安装epel-release包,然后通过yum安装pngquant。安装完成之后,使用pngquant --version查看版本信息,并在pngquant-bin的安装代码中去除编译安装失败时终止进程的逻辑,发布一个名为pngquant-bin-no-exit的npm包。
接着,对于依赖pngquant-bin-no-exit的插件imagemin-pngquant,同样需要创建一个名为imagemin-pngquant-no-exit的npm包,这样可以避免安装原始的imagemin-pngquant。最后,引入imagemin-pngquant-no-exit进行使用即可。
对于其他imagemin插件安装失败时,同样可以采用上述方法解决,例如用于压缩JPG的imagemin-mozjpeg插件。这些插件通常依赖于特定的C语言编写的压缩库,如mozjpeg,与PNG压缩插件不同。另外,mozjpeg不能通过yum安装,需要下载源代码进行编译安装。编译完成后,可以在/opt/mozjpeg/bin目录下找到对应的二进制可执行文件。
虽然整个安装过程可能没有完全成功,但通过上述步骤,可以确保程序的正常运行。只需对引入的代码稍作修改即可。
基于AI或传统编码方法的图像压缩开源算法汇总
探索图像压缩技术的前沿,融合AI与传统编码策略,我们精选了多项开创性研究成果,旨在提升图像压缩的效率与视觉质量。让我们一同探索这些卓越的算法:Li Mu等人的突破:年CVPR大会上,他们提出了《Learning Convolutional Networks for Content-weighted Image Compression》(论文链接),借助深度学习的自编码器,赋予内容感知,通过优化编码器、解码器和量化器,赋予图像在低比特率下更清晰的边缘和丰富纹理,减少失真。其开源代码可于这里找到,基于Caffe框架。
Conditional Probability Models的革新:Mentzer等人在年的CVPR展示了他们的工作,通过内容模型提升深度图像压缩的性能,论文名为《Conditional Probability Models for Deep Image Compression》(论文链接)。
利用深度神经网络的力量,研究者们正在重新定义压缩标准。例如,Toderici等人在年的CVPR中展示了《Full Resolution Image Compression with Recurrent Neural Networks》,使用RNN构建可变压缩率的系统,无需重新训练(论文链接)。其开源代码可在GitHub找到,基于PyTorch 0.2.0。 创新性的混合GRU和ResNet架构,结合缩放加性框架,如Prakash等人年的工作所示,通过一次重建优化了率-失真曲线(论文链接),在Kodak数据集上,首次超越了JPEG标准。开源代码见这里,基于Tensorflow和CNN。 AI驱动的图像压缩,如Haimeng Zhao和Peiyuan Liao的CAE-ADMM,借助ADMM技术优化隐性比特率,提高了压缩效率与失真性能(论文),对比Balle等人的工作(论文)有所突破。 生成对抗网络(GAN)的优化应用,如.论文,展示了在低比特率下图像压缩的显著改进,开源代码可在GitHub找到,它以简洁的方式实现高图像质量。 深度学习驱动的DSSLIC框架,通过语义分割与K-means算法,提供分层图像压缩的高效解决方案,开源代码在此,适用于对象适应性和图像检索。 传统方法如Lepton,通过二次压缩JPEG,节省存储空间,Dropbox的开源项目链接,适合JPEG格式存储优化。 无损图像格式FLIF,基于MANIAC算法,超越PNG/FFV1/WebP/BPG/JPEG,支持渐进编码,详情可在官方网站查看。 Google的Guetzli,以高效压缩提供高画质JPEG,体积比libjpeg小-%,适用于存储优化(源码)。 这些创新的算法和技术,展示了AI和传统编码方法在图像压缩领域的融合与进步,不仅提升了压缩效率,更为图像的存储和传输提供了前所未有的可能性。