V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
爱意满满的作品展示区。
littletong
V2EX  ›  分享创造

为什么有这么多图片压缩工具,还要再做一个?

  •  
  •   littletong · 44 天前 · 3314 次点击
    这是一个创建于 44 天前的主题,其中的信息可能已经有所发展或是发生改变。

    最近频繁使用图片压缩功能,发现目前主流图片压缩工具还是有些不足:

    • TinyPNG 会上传图片,且限制了 5M 大小。压缩后无法对比效果。
    • Squoosh 不支持批量压缩图片,效率太低。且无法压缩到指定 KB 以内。

    所以叒整了一个新的图片压缩工具,算是把几个痛点都解决了:

    1. 隐私安全,不上传图片,压缩速度也成倍提升;
    2. 批量压缩,不限制个数;
    3. 大图片压缩,不限制大小;
    4. 支持指定 KB 压缩;
    5. 支持指定尺寸和压缩质量,图片格式;
    6. 支持压缩后对比效果;
    7. 默认高效的 WebP 格式,透明度+小+质量高,主流浏览器和系统都支持;

    欢迎大家体验并提出改进意见 https://compressimage.cn

    compressimage.cn

    59 条回复    2024-12-17 07:54:07 +08:00
    iMusic
        1
    iMusic  
       44 天前
    第 4 点怎么做到的?
    zqjilove
        2
    zqjilove  
       44 天前
    界面舒服,点个赞
    zqjilove
        3
    zqjilove  
       44 天前
    给个建议,添加到列表里待处理的,无法删除,这个体验不够好。
    miaomiao888
        4
    miaomiao888  
       44 天前   ❤️ 5
    ltaoo1o
        5
    ltaoo1o  
       44 天前
    这类工具核心是压缩算法

    刚刚试了下,一张 280kb 的 PNG 图片,你的压缩率 0 。。。TinyPNG 能压缩到 76KB

    https://image.988589.xyz/api/cfile/AgACAgUAAyEGAASC5r41AAMoZ1AdKZVcixStxWYgMs8oBpLgC8IAAtq9MRsNv4FW6VqTga4eZuIBAAMCAAN5AAM2BA
    ltaoo1o
        6
    ltaoo1o  
       44 天前
    @miaomiao888 笑死
    bugoftime
        7
    bugoftime  
       44 天前
    👍。试了下,保持原格式 png ,80p 质量,变大了好多啊
    ypzhou
        8
    ypzhou  
       44 天前
    @li1218040201 有原图吗 我想试下我的压缩工具
    Outshine
        10
    Outshine  
       44 天前
    页面很清爽干净啊。

    你这 cn 域名放 vercel ?

    不考虑盈利?
    siweipancc
        11
    siweipancc  
       44 天前 via iPhone
    移动端不友好啊
    lizhenda
        12
    lizhenda  
       44 天前
    cn 域名不太好做海外吧
    liu731
        13
    liu731  
       44 天前
    试了一下,建议别叫压缩工具,叫图片格式转换算了
    chutsetien
        14
    chutsetien  
       44 天前
    首先,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
    ```
    givebest
        15
    givebest  
       44 天前
    Mac 上可以试下这个仅 3MB 的 App: https://hp60.com/image2webp/
    chutsetien
        16
    chutsetien  
       44 天前
    @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.
    chutsetien
        17
    chutsetien  
       44 天前
    @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 了。
    vsean
        18
    vsean  
       44 天前
    compressimage + cn 这个域名搭配,不知道该说什么好
    ltaoo1o
        19
    ltaoo1o  
       44 天前
    @chutsetien 贴个文件链接就好了,回复越长消耗铜币数越多的,而且确实太长了。。
    chutsetien
        20
    chutsetien  
       44 天前
    @li1218040201 在我的个人 Wiki 上,因此不太方便贴。我真不是程序员,就是个从 DOS 一路走来的老一代电脑使用者,所以没有把这些放在 GitHub 之类的地方,自己的小站也是自娱自乐,就不献丑了 :)
    icyalala
        21
    icyalala  
       44 天前   ❤️ 1
    我还是推荐一下 https://imageoptim.com/mac
    本地批量压缩,也支持有损和无损,而且会用多种算法压缩最终选择体积最小的
    shyrock
        22
    shyrock  
       44 天前
    op 这不是个网络服务吗?怎么说不上传图片?
    LogicDX342
        23
    LogicDX342  
       44 天前 via Android   ❤️ 1
    vampuke
        24
    vampuke  
       44 天前
    @shyrock #22 在浏览器就压缩了,不用上传到服务器
    anzu
        25
    anzu  
       44 天前
    我在做漫画汉化,有时把 jpg 原图转换成 webp 后,80%质量的 webp 文件大小反而比无损 webp 大几倍。问了 AI 说可能是原图片有大量重复图案导致的。我猜测应该是网点的原因,所以要不要有损压缩还需要自己判断一下。
    chutsetien
        26
    chutsetien  
       44 天前
    @LogicDX342 所以说我真不是程序员哈哈,之前都没听说过这个~谢谢推荐。
    BYDH
        27
    BYDH  
       44 天前
    市面上缺少的是能把每一张图片的有效视觉信息损失自动控制在及格线上的工具,需要做一些算法上的工作和大量的试验
    longsays
        28
    longsays  
       44 天前 via Android
    https://i0.du0.org/i/4sd823.jpg
    这张图片也是越压越大
    kalman03
        29
    kalman03  
       44 天前
    压缩一次有新的释义了
    BYDH
        30
    BYDH  
       44 天前
    @longsays 还真别说,我觉得这张图没法直接压,因为它相较于刚扫描出来的原图,已经压得很极限了,不改变分辨率、不涂抹纹理的情况下把这张图二压到更小的体积,细节的损失绝对是不可接受的。只能说用更先进的编码器去处理尚且无损的原图,或许会比这张更好
    Tiande
        31
    Tiande  
       44 天前   ❤️ 1
    Windows 下推荐 XnConvert ,好用,绝绝子
    hoythan
        32
    hoythan  
       44 天前
    从来不相信有慈善家,你这个项目看起来没法盈利,说明这个工具没法持久。
    mayli
        33
    mayli  
       44 天前
    @BYDH 有的 jpg 80%就是,当然及格是个主管概念,有些人觉得 100%也不及格
    有些人觉得 75%也行。
    微信压缩图片挺狠的,也没挡住它的流行
    BYDH
        34
    BYDH  
       44 天前
    @mayli 问题就在这里了,有的是 q=80 ,那还有的呢?一张满是纹理的图,和一张背景虚化的特写,最合适的质量参数绝对是不一样的,因为纹理一般认为不可舍弃,放大很容易看出端倪,而虚化的背景就无所谓。我认为可以做个算法,去衡量人眼会关注的局部区域(视觉显著性/边缘检测之类)相对于原图的质量损失,让程序算出一个"主观数据",反馈到输入端,用于调整 q 。给用户喂💩是厂商的行为,用户没有必要亏待自己,在算力充裕的情况下,拿时间换无脑但稳定的输出是可行的,至少应该是可选的,然而并没有这样的工具
    mayli
        35
    mayli  
       44 天前
    @BYDH 我觉得是你在民科了,jpg 保留的主要就是人眼主要关注的区域,而且对于压缩后的损失算法也有大量现成的比如 ssni/vmaf 。
    Jpg 的 q 就是质量参数了,你复杂图和简单色块在 q=80 的时候压缩出来的体积明显差很多。
    建议民科不要没事想着做个算法,现有的工具已经足够成熟了,而且除了成熟还有效率和兼容性的权衡。
    你要是觉得有损压缩是吃屎,选择无损图片就好了,png webp av1 都有,就是相对于 jpg 都是小众需求。
    Serino
        36
    Serino  
       44 天前
    我用过多线程批量压缩 webp 质量最好压缩率也超高的是 pingo (带 gui 的是 pinga )
    一般我是
    ./pingo -s4 -webp *.png
    压缩率很高,依然保留了超级多的细节,甚至噪点细节

    其次用过最满意的截图软件是 Linux 下的 Spectacle ,截取成 JPEG XL ,质量默认 90 ,也是图片很小(跟上面 pingo 压缩无损的 png ,注意不是无损压缩,是 -s4 ,质量类似,保持了超级多细节的同时,图片大小让我很满意)
    ch563
        37
    ch563  
       44 天前
    szdev
        38
    szdev  
       44 天前
    TinyPNG 是有绝对的算法门槛的,不要小瞧这个领域,我之前找类似的开源算法,没有能达到 tiny 这么好的效果的
    BYDH
        39
    BYDH  
       44 天前
    @mayli #35 你说的都对,但是没有解决我的问题:用户不知道参数怎么设,jpg 的 80%、webp 的 80%、avif 的 80%,heic 的 80%,是一样的吗?你能确切地回答这个问题吗?显然不是。如果需求是把 10000 张不同的图按各种编码各压一张,要求画质保持在同一水准,即放大到 200%肉眼看不出来,怎么办?期待你能给出建设性的意见
    Xinu
        40
    Xinu  
       44 天前
    推荐 utools 下的图片压缩 嘎嘎好用
    Icecokelulu
        41
    Icecokelulu  
       44 天前
    使用下来的体验:
    优点:
    1. 界面简单,操作流程很舒服。
    2. 原图与压缩对比用户体验感很棒。
    3. 因为本人没有经常压缩图片的需求,但是界面开放出来压缩图片的可调节参数是符合我自己的需求的。

    一些建议:
    1. 浏览器刷新之后会造成选择的图片消失,看能不能浏览器缓存服务存储当前的图片?
    2. 图片列表没有删除图片的操作。
    3. 压缩完成之后,我继续选择图片,已经压缩的图片丢失,可以考虑在界面添加一个已压缩项。
    forty
        42
    forty  
       44 天前
    gif 都不支持?
    avif 都不支持?
    尺寸只有 10 种预设尺寸,自定义都没有?
    还能越压越大了?
    metalvest
        43
    metalvest  
       43 天前
    @hoythan 但 vercel 上的纯前端也没啥成本
    alphaControler
        44
    alphaControler  
       43 天前 via Android
    我比较好奇,你这怎么保持可持续发展?
    mayli
        45
    mayli  
       43 天前
    @BYDH 普通用户,默认即可.
    BYDH
        46
    BYDH  
       43 天前
    @mayli #45 0 分
    hfl1995
        47
    hfl1995  
       43 天前
    压缩带有 HDR 元数据的 jpg ,导出 jpg, HDR 信息会丢失.
    Aixtuz
        48
    Aixtuz  
       43 天前
    Squoosh 那个命令行的方式可以批量的。
    NamelessRain
        49
    NamelessRain  
       43 天前
    @miaomiao888 笑不活了
    Jesmora
        50
    Jesmora  
       43 天前
    ![7cd954ba13c68593e9e33a623bd90d4f.png]( https://ice.frostsky.com/2024/12/06/7cd954ba13c68593e9e33a623bd90d4f.png) 怎么还反向压缩 啊
    Luffy0o
        51
    Luffy0o  
       42 天前
    @ltaoo1o 对,压缩算法才是核心,包括之前腾讯还出过一个叫智图的压缩工具,在某些图片的压缩上也存在问题,会出现摩尔纹。 目前就压缩结果而言,Tiny 的结果是最稳的,压缩效率也很高。
    littletong
        52
    littletong  
    OP
       42 天前
    @iMusic 二分查找
    littletong
        53
    littletong  
    OP
       42 天前
    @zqjilove 感谢支持!
    删除功能尽快加上
    littletong
        54
    littletong  
    OP
       42 天前
    @shyrock 图片仅放在内存,不会上传图片
    littletong
        55
    littletong  
    OP
       42 天前
    @Icecokelulu 感谢非常实用的建议!
    littletong
        56
    littletong  
    OP
       42 天前
    @szdev 核心还是推广 webp 格式,tinypng 压缩算法再好,也和 webp 体积大很多
    littletong
        57
    littletong  
    OP
       42 天前
    @Outshine 可以科普一下为什么 cn 放 vercel 不好盈利吗,还不是很懂
    Outshine
        58
    Outshine  
       42 天前
    @littletong #57 哈哈哈,不是,你别把两句话放一起理解啊。
    hGaHLRyC
        59
    hGaHLRyC  
       32 天前
    webp 的优势就是有的软件还不支持 avif 和 jxl 吧。
    现在 jpegli 出来后 webp 就更尴尬了。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2940 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 07:44 · PVG 15:44 · LAX 23:44 · JFK 02:44
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.