最近频繁使用图片压缩功能,发现目前主流图片压缩工具还是有些不足:
所以叒整了一个新的图片压缩工具,算是把几个痛点都解决了:
欢迎大家体验并提出改进意见 https://compressimage.cn
1
iMusic 8 天前
第 4 点怎么做到的?
|
2
zqjilove 8 天前
界面舒服,点个赞
|
3
zqjilove 8 天前
给个建议,添加到列表里待处理的,无法删除,这个体验不够好。
|
4
miaomiao888 8 天前 5
|
5
ltaoo1o 8 天前
这类工具核心是压缩算法
刚刚试了下,一张 280kb 的 PNG 图片,你的压缩率 0 。。。TinyPNG 能压缩到 76KB https://image.988589.xyz/api/cfile/AgACAgUAAyEGAASC5r41AAMoZ1AdKZVcixStxWYgMs8oBpLgC8IAAtq9MRsNv4FW6VqTga4eZuIBAAMCAAN5AAM2BA |
6
ltaoo1o 8 天前
@miaomiao888 笑死
|
7
bugoftime 8 天前
👍。试了下,保持原格式 png ,80p 质量,变大了好多啊
|
8
ypzhou 8 天前
@li1218040201 有原图吗 我想试下我的压缩工具
|
9
ltaoo1o 8 天前 2
|
10
Outshine 8 天前
页面很清爽干净啊。
你这 cn 域名放 vercel ? 不考虑盈利? |
11
siweipancc 8 天前 via iPhone
移动端不友好啊
|
12
lizhenda 8 天前
cn 域名不太好做海外吧
|
13
liu731 8 天前
试了一下,建议别叫压缩工具,叫图片格式转换算了
|
14
chutsetien 8 天前
首先,webp 的画质非常差,用 cwebp -mt -q 100 -m 6 -sharp_yuv -af -alpha_filter best -sns 0 压出来的 webp 都会与原图有放大后能够看到的明显区别,毕竟是 VP8 打底,最高水准也就那样了。当然,确实,体积小。
目前建议 jpegli. jpegli 的 q 90 感觉和上面那个各项打满的 q 100 的质量差不多。当然要求高一些的话可以往 q 95+ 走。 我有个自用的 batch 档,也是做转换和切割图片的——我不是 programmer, 真不是,而且 batch 纯自用,因此各种不足之处还请见谅了。不知道 V 站怎么贴,就试试看 markdown 了。 ``` @echo off chcp 65001 setlocal enabledelayedexpansion set "a=" set "i=" set "fn=" set "bn=" set "on=" set "gn=" set "np=" set "op=" set "cm=" set "sm=" set "hg=" set "jq=" set "wq=" set "sl=" set "sp=" set "ss=" set "sx=" set "sy=" set "cr1=" set "cr2=" set "cx1=" set "cx2=" set "sf1=" set "sf2=" set "cmb=" set "smb=" set "vfb=" set "cpf=" set "spf=" set "jpg=" set "png=" set "wbp=" set "sns=" :a if "%~1"=="" goto p set "a=%~1" if "!a:~0,1!"=="-" ( if "!a!"=="-op" (set "np=%~2" & shift) if "!a!"=="-on" (set "gn=%~2" & set "hg=1" & shift) if "!a!"=="-ob" (set "bn=%~2" & shift) if "!a!"=="-p" (set "png=1") if "!a!"=="-wpq" (set "wbp=1" & set "sns=80" & set "wq=80") if "!a!"=="-wlq" (set "wbp=1" & set "sns=50" & set "wq=85") if "!a!"=="-wmq" (set "wbp=1" & set "sns=20" & set "wq=90") if "!a!"=="-w" (set "wbp=1" & set "sns=0" & set "wq=95") if "!a!"=="-whq" (set "wbp=1" & set "sns=0" & set "wq=99") if "!a!"=="-jpq" (set "jpg=1" & set "jq=80") if "!a!"=="-jlq" (set "jpg=1" & set "jq=85") if "!a!"=="-jmq" (set "jpg=1" & set "jq=90") if "!a!"=="-j" (set "jpg=1" & set "jq=95") if "!a!"=="-jhq" (set "jpg=1" & set "jq=99") if "!a!"=="-rg" (set "cm=rg" & set "cpf=rgr") if "!a!"=="-cx" (set "cm=cx" & set "cx1=%~2" & set "cx2=%~3" & set "cpf=wth!cx1!t!cx2!" & shift & shift) if "!a!"=="-cr" (set "cm=cr" & set "cr1=%~2" & set "cr2=%~3" & set "cpf=lts!cr1!t!cr2!" & shift & shift) if "!a!"=="-gy" (set "cm=gy" & set "cpf=grv") if "!a!"=="-gx" (set "cm=gx" & set "cpf=grh") if "!a!"=="-gr" (set "cm=gr" & set "cpf=gr") if "!a!"=="-sq" (set "cm=sq" & set "cpf=sq") if "!a!"=="-up" (set "sm=up" & set "sp=%~2" & set "spf=!sp!pc" & shift) if "!a!"=="-uf" (set "sm=uf" & set "sf1=%~2" & set "sf2=%~3" & set "spf=!sf1!d!sf2!" & shift & shift) if "!a!"=="-uy" (set "sm=uy" & set "sy=%~2" & set "spf=x!sy!" & shift) if "!a!"=="-ux" (set "sm=ux" & set "sx=%~2" & set "spf=!sx!x" & shift) if "!a!"=="-us" (set "sm=us" & set "ss=%~2" & set "spf=s!ss!" & shift) if "!a!"=="-ul" (set "sm=ul" & set "sl=%~2" & set "spf=l!sl!" & shift) if "!a!"=="-sp" (set "sm=sp" & set "sp=%~2" & set "spf=!sp!pc" & shift) if "!a!"=="-sf" (set "sm=sf" & set "sf1=%~2" & set "sf2=%~3" & set "spf=!sf1!d!sf2!" & shift & shift) if "!a!"=="-sy" (set "sm=sy" & set "sy=%~2" & set "spf=x!sy!" & shift) if "!a!"=="-sx" (set "sm=sx" & set "sx=%~2" & set "spf=!sx!x" & shift) if "!a!"=="-ss" (set "sm=ss" & set "ss=%~2" & set "spf=s!ss!" & shift) if "!a!"=="-sl" (set "sm=sl" & set "sl=%~2" & set "spf=l!sl!" & shift) ) else ( if not defined i set "i=%~1" for %%f in ("!i!") do set "op=%%~dpf" & set "on=%%~nf" ) shift goto a :p if "!np!"=="" set "np=!op!" if not "!np:~-1!"=="\" set "np=!np!\" if not exist "!np!" md "!np!" if "!bn!"=="" set "bn=!on!" if defined cpf set "cpf=-!cpf!" if defined spf set "spf=-!spf!" if "!gn!"=="" set "gn=!bn!!cpf!!spf!" if defined cm ( if "!cm!"=="cx" set "cmb=crop='floor(if(gte(iw/ih,!cx1!/!cx2!),ih*!cx1!/!cx2!,iw)/2)*2:floor(if(gte(iw/ih,!cx1!/!cx2!),ih,iw*!cx2!/!cx1!)/2)*2'" if "!cm!"=="cr" set "cmb=crop='floor(if(gte(iw,ih),min(iw,ih*(!cr1!/!cr2!)),min(iw,ih*(!cr2!/!cr1!)))/2)*2:floor(if(gte(iw,ih),min(ih,iw*(!cr2!/!cr1!)),min(ih,iw*(!cr1!/!cr2!)))/2)*2'" if "!cm!"=="rg" set "cmb=crop='floor(if(gte(iw,ih),min(iw,ih*(17711/28657)),min(iw,ih*(28657/17711)))/2)*2:floor(if(gte(iw,ih),min(ih,iw*(28657/17711)),min(ih,iw*(17711/28657)))/2)*2'" if "!cm!"=="gy" set "cmb=crop='floor(if(gte(iw/ih,17711/28657),ih*17711/28657,iw)/2)*2:floor(if(gte(iw/ih,17711/28657),ih,iw*28657/17711)/2)*2'" if "!cm!"=="gx" set "cmb=crop='floor(if(gte(iw/ih,28657/17711),ih*28657/17711,iw)/2)*2:floor(if(gte(iw/ih,28657/17711),ih,iw*17711/28657)/2)*2'" if "!cm!"=="gr" set "cmb=crop='floor(if(gte(iw,ih),min(iw,ih*(28657/17711)),min(iw,ih*(17711/28657)))/2)*2:floor(if(gte(iw,ih),min(ih,iw*(17711/28657)),min(ih,iw*(28657/17711)))/2)*2'" if "!cm!"=="sq" set "cmb=crop='floor(min(iw,ih)/2)*2:floor(min(iw,ih)/2)*2'" ) if defined sm ( if "!sm!"=="sp" set "smb=scale='if(lte(!sp!,100),floor(iw*!sp!/100),iw):if(lte(!sp!,100),floor(ih*!sp!/100),ih)'" if "!sm!"=="sf" set "smb=scale='if(lte(iw*!sf1!/!sf2!,iw),floor(iw*!sf1!/!sf2!),iw):if(lte(ih*!sf1!/!sf2!,ih),floor(ih*!sf1!/!sf2!),ih)'" if "!sm!"=="sy" set "smb=scale='-2:if(lte(!sy!,ih),!sy!,ih)'" if "!sm!"=="sx" set "smb=scale='if(lte(!sx!,iw),!sx!,iw):-2'" if "!sm!"=="ss" set "smb=scale='if(lt(iw,ih),min(!ss!,iw),-2):if(gte(iw,ih),min(!ss!,ih),-2)'" if "!sm!"=="sl" set "smb=scale='if(gte(iw,ih),min(!sl!,iw),-2):if(lt(iw,ih),min(!sl!,ih),-2)'" if "!sm!"=="up" set "smb=scale='floor(iw*!sp!/100):floor(ih*!sp!/100)'" if "!sm!"=="uf" set "smb=scale='floor(iw*!sf1!/!sf2!):floor(ih*!sf1!/!sf2!)'" if "!sm!"=="uy" set "smb=scale=-2:!sy!" if "!sm!"=="ux" set "smb=scale=!sx!:-2" if "!sm!"=="us" set "smb=scale='if(lt(iw,ih),!ss!,-2):if(gte(iw,ih),!ss!,-2)'" if "!sm!"=="ul" set "smb=scale='if(gte(iw,ih),!sl!,-2):if(lt(iw,ih),!sl!,-2)'" ) if defined cm if not defined sm (set "vfb=!cmb!") if not defined cm if defined sm (set "vfb=!smb!") if defined cm if defined sm (set "vfb=!cmb!,!smb!") if not defined vfb ( ffmpeg -i "!i!" -vframes:v 1 -update true -compression_level 0 "!op!!on!_intermediateagzk3kXe8nDr.png" -y ) else ( ffmpeg -i "!i!" -vframes:v 1 -update true -compression_level 0 -vf "!vfb!" -sws_flags lanczos+accurate_rnd+full_chroma_inp+full_chroma_int "!op!!on!_intermediateagzk3kXe8nDr.png" -y ) if "!jpg!"=="1" ( cjpegli -q !jq! --chroma_subsampling=444 "!op!!on!_intermediateagzk3kXe8nDr.png" "!op!!on!_intermediateagzk3kXe8nDr.jpg" exiftool -overwrite_original -all= "!op!!on!_intermediateagzk3kXe8nDr.jpg" if "!hg!"=="1" ( move /y "!op!!on!_intermediateagzk3kXe8nDr.jpg" "!np!!gn!.jpg" ) else ( move /y "!op!!on!_intermediateagzk3kXe8nDr.jpg" "!np!!gn!-q!jq!.jpg" ) ) if "!wbp!"=="1" ( cwebp -mt -q !wq! -m 6 -sharp_yuv -af -alpha_filter best -sns !sns! "!op!!on!_intermediateagzk3kXe8nDr.png" -o "!op!!on!_intermediateagzk3kXe8nDr.webp" exiftool -overwrite_original -all= "!op!!on!_intermediateagzk3kXe8nDr.webp" if "!hg!"=="1" ( move /y "!op!!on!_intermediateagzk3kXe8nDr.webp" "!np!!gn!.webp" ) else ( move /y "!op!!on!_intermediateagzk3kXe8nDr.webp" "!np!!gn!-q!wq!.webp" ) ) if "!png!"=="1" ( optipng -o7 -zm1-9 "!op!!on!_intermediateagzk3kXe8nDr.png" exiftool -overwrite_original -all= "!op!!on!_intermediateagzk3kXe8nDr.png" move /y "!op!!on!_intermediateagzk3kXe8nDr.png" "!np!!gn!.png" ) else ( del /q "!op!!on!_intermediateagzk3kXe8nDr.png" ) endlocal ``` |
15
givebest 8 天前
Mac 上可以试下这个仅 3MB 的 App: https://hp60.com/image2webp/
|
16
chutsetien 8 天前
@chutsetien 顺附自写的该 batch 档的用法解释:
A tiny little Windows Batch script used for the cropping, scaling, and format conversion of images. It requires the following software to be properly set up in %PATH% (here in my case is C:\_c\): ffmpeg; libwebp; optipng; and exiftool. Understanding ‘orientation-adaptive’ and ‘orientation-irrelevant’ As the script is used for the cropping and scaling of images, it would require the clarification of two concepts: ‘orientation-adaptive’ and ‘orientation-irrelevant’. The former, as its name indicates, takes the image’s orientation into account. This can be easily understood in the context of scaling, as we often do need to scale an image by its ‘long edge’ or ‘short edge’, regardless of whether it is the width or the height. It might get a little bit confusing when it comes to cropping. In cropping, by saying ‘orientation-adaptive’, it means that when given a ratio, the long edge always takes the first number, while the short edge takes the second. For example, if we have a horizontal image (which means its width is greater than its height), and we want to crop it to 4:3 orientation-adaptively, then the long edge, the width, will take the ‘4’ while the short edge, the height, will take the ‘3’. And when done, it would indeed be an image of 4:3. But if we have a vertical image (which means the height is the longer edge), and we still want to orientation-adaptively crop it to 4:3, then the height of the image, now the long edge, shall take the ‘4’, while the width of the image will take the ‘3’, and the final result we get is actually an image of 3:4. What makes the ‘orientation-adaptive cropping’ more confusing is that it can be used to crop ‘against’ the image’s orientation by setting a ratio smaller than 1, in that it can force the long edge to take the smaller number in the ratio to become the new short edge while the original short edge can take the larger number and becomes the new long edge. The ‘orientation-irrelevant’ scaling or cropping is much easier to understand—as its name indicates, it does not take the image’s orientation into account, only focusing on scaling or cropping based on the width and height, regardless of which one is longer. Cropping switches The script accepts switches used for cropping in an order of precedence as follows—if more than one switch is detected in one operation, a switch with a higher rank surpasses the lower ones: -sq: crops the image to a 1:1 square; -gr: orientation-adaptively crops the image to the golden ratio; -gx: orientation-irrelevantly crops the image to the golden ratio by setting its width as the long edge; -gy: orientation-irrelevantly crops the image to the golden ratio by setting its height as the long edge; -cr x y: orientation-adaptively crops the image to a set ratio of x:y, where the long edge of the image takes the x, and the short edge takes the y; -cx x y: orientation-irrelevantly crops the image to a set ratio of x:y, where the width of the image takes the x, and the height takes the y; and -rg: performs a ‘reversed’ orientation-adaptive golden ratio cropping, where the long edge of the image takes the smaller number of the golden ratio, and the short edge takes the larger (not very useful actually, and that’s why it gets the lowest precedence). Scaling switches The script accepts switches used for scaling in an order of precedence as follows—if more than one switch is detected in one operation, a switch with a higher rank surpasses the lower ones: -sl x: proportionally scales the image by setting its long edge to x; -ss x: proportionally scales the image by setting its short edge to x; -sx x: proportionally scales the image by setting its width to x; -sy x: proportionally scales the image by setting its height to x; -sf x y: proportionally scales the image by a given fraction of x/y; and -sp x: proportionally scales the image by a given percentage x (‘%’ is not needed when giving the percentage number). The script, by default, prohibits upscaling, unless the user explicitly orders the script to do so by changing the first letter of these scaling switches to ‘u’ (-ul, -us, -ux, etc). I strongly dissuade anyone who intends to use this script to upscale any image, for that image upscaling simply shall not be done in this way as it needs much more complicated algorithms and should be done with dedicated manual tuning. Output file format and quality switches The script accepts switches -p, -j, and -w to indicate an output of a .png image, a .jpg image, or a .webp image. These switches can be used simultaneously to output more than one image. For -j and -w, there are four quality suffixes, hq (‘highest quality’), mq (‘medium quality’), lq (‘low quality’), and pq (‘poor quality’), each representing a fixed quality parameter (or a group of fixed quality-related parameters in the case of -w), that can be used by immediately appending to the letter j or q, with no spaces in between, to form a five-tier image quality levels (together with the two default ones of no sticking letters, the -j and -w, which are both ranked second best in the hierarchy) for the user to choose. And by knowing me, you can rest assured that even by using -jpq or -wpq, the output will still be acceptable. But since I use ffmpeg to encode JPEG files—which uses mjpeg as its encoder—the output files will then always be added with a ‘dash’ label in the names, indicating that they are intended for quick sharing uses, and are not expected to be used in serious scenarios. If -p is detected, then the output .png file will be compressed by optipng with maximum tries, which means it will take a considerably long period of time if the image is large. Lastly, all of the output files will be cleaned of EXIF information in the end. Designating output filename and path By default, the output file or files will be saved in the same location as the input file, using the original filename as the basename with text labels of the process or processes being done to it and of the image quality parameter appended in the end. And yet the output filename and path are designatable with the switches listed below: -op "path\to\the\designated location\": if used, the output files will then be exported to the designated location; -ob new_basename: if used, then the given string will surpass the file’s original name and be used as the designated basename—the text labels for processed and image quality will still be appended to the given basename; and -on "new filename": if used, then the given string will be used as the full filename of the output file, with no more appendings. Since one operation of the script can produce more than one file in different formats, strings given after -ob and -on shall not contain a file extension, as it will be added automatically according to the output format. |
17
chutsetien 8 天前
@chutsetien 虽然知道可能没什么人看,但是加注一下:
> But since I use ffmpeg to encode JPEG files—which uses mjpeg as its encoder—the output files will then always be added with a ‘dash’ label in the names, indicating that they are intended for quick sharing uses, and are not expected to be used in serious scenarios. 这句是老版本里的,现在的这个脚本用的是 cjpegli, 不是 ffmpeg 的 mjpeg 了。 |
18
vsean 8 天前
compressimage + cn 这个域名搭配,不知道该说什么好
|
19
ltaoo1o 8 天前
@chutsetien 贴个文件链接就好了,回复越长消耗铜币数越多的,而且确实太长了。。
|
20
chutsetien 8 天前
@li1218040201 在我的个人 Wiki 上,因此不太方便贴。我真不是程序员,就是个从 DOS 一路走来的老一代电脑使用者,所以没有把这些放在 GitHub 之类的地方,自己的小站也是自娱自乐,就不献丑了 :)
|
21
icyalala 8 天前 1
我还是推荐一下 https://imageoptim.com/mac
本地批量压缩,也支持有损和无损,而且会用多种算法压缩最终选择体积最小的 |
22
shyrock 8 天前
op 这不是个网络服务吗?怎么说不上传图片?
|
23
LogicDX342 8 天前 via Android 1
@chutsetien #20 可以试试 https://pastebin.com/
|
25
anzu 8 天前
我在做漫画汉化,有时把 jpg 原图转换成 webp 后,80%质量的 webp 文件大小反而比无损 webp 大几倍。问了 AI 说可能是原图片有大量重复图案导致的。我猜测应该是网点的原因,所以要不要有损压缩还需要自己判断一下。
|
26
chutsetien 8 天前
@LogicDX342 所以说我真不是程序员哈哈,之前都没听说过这个~谢谢推荐。
|
27
BYDH 8 天前
市面上缺少的是能把每一张图片的有效视觉信息损失自动控制在及格线上的工具,需要做一些算法上的工作和大量的试验
|
28
longsays 8 天前 via Android
https://i0.du0.org/i/4sd823.jpg
这张图片也是越压越大 |
29
kalman03 8 天前
压缩一次有新的释义了
|
30
BYDH 8 天前
@longsays 还真别说,我觉得这张图没法直接压,因为它相较于刚扫描出来的原图,已经压得很极限了,不改变分辨率、不涂抹纹理的情况下把这张图二压到更小的体积,细节的损失绝对是不可接受的。只能说用更先进的编码器去处理尚且无损的原图,或许会比这张更好
|
31
Tiande 8 天前 1
Windows 下推荐 XnConvert ,好用,绝绝子
|
32
hoythan 8 天前
从来不相信有慈善家,你这个项目看起来没法盈利,说明这个工具没法持久。
|
34
BYDH 8 天前
@mayli 问题就在这里了,有的是 q=80 ,那还有的呢?一张满是纹理的图,和一张背景虚化的特写,最合适的质量参数绝对是不一样的,因为纹理一般认为不可舍弃,放大很容易看出端倪,而虚化的背景就无所谓。我认为可以做个算法,去衡量人眼会关注的局部区域(视觉显著性/边缘检测之类)相对于原图的质量损失,让程序算出一个"主观数据",反馈到输入端,用于调整 q 。给用户喂💩是厂商的行为,用户没有必要亏待自己,在算力充裕的情况下,拿时间换无脑但稳定的输出是可行的,至少应该是可选的,然而并没有这样的工具
|
35
mayli 8 天前
@BYDH 我觉得是你在民科了,jpg 保留的主要就是人眼主要关注的区域,而且对于压缩后的损失算法也有大量现成的比如 ssni/vmaf 。
Jpg 的 q 就是质量参数了,你复杂图和简单色块在 q=80 的时候压缩出来的体积明显差很多。 建议民科不要没事想着做个算法,现有的工具已经足够成熟了,而且除了成熟还有效率和兼容性的权衡。 你要是觉得有损压缩是吃屎,选择无损图片就好了,png webp av1 都有,就是相对于 jpg 都是小众需求。 |
36
Serino 8 天前
我用过多线程批量压缩 webp 质量最好压缩率也超高的是 pingo (带 gui 的是 pinga )
一般我是 ./pingo -s4 -webp *.png 压缩率很高,依然保留了超级多的细节,甚至噪点细节 其次用过最满意的截图软件是 Linux 下的 Spectacle ,截取成 JPEG XL ,质量默认 90 ,也是图片很小(跟上面 pingo 压缩无损的 png ,注意不是无损压缩,是 -s4 ,质量类似,保持了超级多细节的同时,图片大小让我很满意) |
37
ch563 8 天前
|
38
szdev 7 天前
TinyPNG 是有绝对的算法门槛的,不要小瞧这个领域,我之前找类似的开源算法,没有能达到 tiny 这么好的效果的
|
39
BYDH 7 天前
@mayli #35 你说的都对,但是没有解决我的问题:用户不知道参数怎么设,jpg 的 80%、webp 的 80%、avif 的 80%,heic 的 80%,是一样的吗?你能确切地回答这个问题吗?显然不是。如果需求是把 10000 张不同的图按各种编码各压一张,要求画质保持在同一水准,即放大到 200%肉眼看不出来,怎么办?期待你能给出建设性的意见
|
40
Xinu 7 天前
推荐 utools 下的图片压缩 嘎嘎好用
|
41
Icecokelulu 7 天前
使用下来的体验:
优点: 1. 界面简单,操作流程很舒服。 2. 原图与压缩对比用户体验感很棒。 3. 因为本人没有经常压缩图片的需求,但是界面开放出来压缩图片的可调节参数是符合我自己的需求的。 一些建议: 1. 浏览器刷新之后会造成选择的图片消失,看能不能浏览器缓存服务存储当前的图片? 2. 图片列表没有删除图片的操作。 3. 压缩完成之后,我继续选择图片,已经压缩的图片丢失,可以考虑在界面添加一个已压缩项。 |
42
forty 7 天前
gif 都不支持?
avif 都不支持? 尺寸只有 10 种预设尺寸,自定义都没有? 还能越压越大了? |
44
alphaControler 7 天前 via Android
我比较好奇,你这怎么保持可持续发展?
|
47
hfl1995 7 天前
压缩带有 HDR 元数据的 jpg ,导出 jpg, HDR 信息会丢失.
|
48
Aixtuz 7 天前
Squoosh 那个命令行的方式可以批量的。
|
49
NamelessRain 7 天前
@miaomiao888 笑不活了
|
50
Jesmora 6 天前
![7cd954ba13c68593e9e33a623bd90d4f.png]( https://ice.frostsky.com/2024/12/06/7cd954ba13c68593e9e33a623bd90d4f.png) 怎么还反向压缩 啊
|
51
Luffy0o 6 天前
@ltaoo1o 对,压缩算法才是核心,包括之前腾讯还出过一个叫智图的压缩工具,在某些图片的压缩上也存在问题,会出现摩尔纹。 目前就压缩结果而言,Tiny 的结果是最稳的,压缩效率也很高。
|
52
littletong OP @iMusic 二分查找
|
53
littletong OP @zqjilove 感谢支持!
删除功能尽快加上 |
54
littletong OP @shyrock 图片仅放在内存,不会上传图片
|
55
littletong OP @Icecokelulu 感谢非常实用的建议!
|
56
littletong OP @szdev 核心还是推广 webp 格式,tinypng 压缩算法再好,也和 webp 体积大很多
|
57
littletong OP @Outshine 可以科普一下为什么 cn 放 vercel 不好盈利吗,还不是很懂
|
58
Outshine 6 天前
@littletong #57 哈哈哈,不是,你别把两句话放一起理解啊。
|