# PicSizer **Repository Path**: tiduszhang/pic-sizer ## Basic Information - **Project Name**: PicSizer - **Description**: 一款支持将图片压缩到指定大小(KB)的批量压缩软件 - **Primary Language**: C# - **License**: GPL-2.0 - **Default Branch**: master - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 32 - **Created**: 2024-07-02 - **Last Updated**: 2025-05-27 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README ## 项目介绍(重构中) 由于目前学业繁重,且Webp格式一直未能找到合适的压缩组件,更新进度会较为缓慢.重构内容请切换至dev分支查看. PicSizer是一款图片批量压缩软件,解决了传统压缩软件只能指定压缩比,而不能指定压缩后的大小的问题. 在网页中,图片需要尽可能占用更少的带宽,盲目使用画质作为唯一标准来压缩图片的后果是大图片压缩后仍然较大,而小图片越压缩越模糊.PicSizer可以在尽可能保证图片质量的情况下,将图片尽可能压缩到指定的大小,例如200KB.对大图片降低画质,对小图片仅转码而不改变画质,可以满足大部分需求. 本软件初衷是用于网页中 JPEG 图片的压缩,设计之初并未想到会被软件园及论坛所推荐,后续将会优化 PNG 和 WEBP 的压缩算法及性能,添加更多图像处理功能,以适应各类不同需求. ## PicSizer的优势 ### 注重效率 - 通过二分查找来计算符合条件的最高画质 - 使用内存流读写的方法来避免文件读写时的低效 - 使用多个线程来充分使用CPU的性能 - 使用CUDA在英伟达GPU上为图形处理加速 ### 使用方便 - 整个程序仅不到 1MB 的体积,没有多余的装饰,专注于实际体验 - 绿色软件,无需安装.运行过程中仅会往临时目录解压两个dll文件,除此之外不会主动创建或修改任何文件,不会尝试后台运行或修改系统设置 - 开门见山,没有花哨的欢迎语等任何弹出式消息,直奔主题 ## 下载与使用 ### 下载地址 项目仍在重构中,此处给出**老版本**下载地址,而非本文档对应的版本. [转到Gitee下载](https://gitee.com/picsizer/pic-sizer/releases) ### 界面截图    ## 格式说明 PicSizer可以读取的格式很多,但是支持的输出格式只有 JPEG, PNG, ICON ,WEBP(仍在完善中) 四个. ## 功能说明 ### 批量增删图片 PicSizer支持每次打开同一目录下的图片或通过拖拽的方式将图片拖入窗体,并将生成的图片保存至指定目录.如果指定的目录不存在,会自动生成;如果目录中已经有文件,则同名文件将会被直接替换而不事先警告. 增加图片时会自动将地址与列表中的地址比对,如果已存在,则会跳过,并在添加完成后提示有几张图片被跳过. 使用 SHIFT 或 CTRL 来辅助多选,使用 Crtl+A 全选列表, Ctrl+R 反选列表,使用 BackSpace 或 Delete 来删除选中项. ### 尺寸修正 PicSizer可以把图片按比例缩放(也可以选择不缩放),甚至破坏原图的比例. 由于Icon图标的特殊性,因此ico图片与其它格式的图片修正方式相互独立,一律采用强制修正 一般情况下,你可以选择以下5种修正方式之一.
修正方式 | 描述 |
---|---|
无修正 | 将图片按照原图尺寸输出. |
不小于限定值 |
在保持宽度和高度不小于给定值的情况下,尽可能按比例缩小图片.例如,给定 400×300 的尺寸,而图片的尺寸为 800×800,则修正后的尺寸为 400×400. 如果图片的宽或高已经小于给定尺寸,则图片不会被修正. |
不大于限定值 |
在保持宽度和高度不大于给定值的情况下,尽可能按比例放大图片.例如,给定 400×300 的尺寸,而图片的尺寸为 100×100,则修正后的尺寸为 300×300. 如果图片的宽或高已经大于给定尺寸,则图片不会被修正. |
强制修正 | 图片会被强制缩放到你指定的尺寸,即使这会破坏图片原有比例. |
居中裁剪 |
严格按照给定的宽度和高度输出图片,多余的部分将被删除,如果图片太大或太小,则会先被缩放到合适的尺寸再裁剪. 例如: 图片的原尺寸为 600×500,而限制尺寸为 1000×1000,则图片会先被放大到 1200×1000,然后再裁剪掉两边. |
![]() 原图(JPEG):224 KB |
![]() 原图(PNG):1.33 MB |
![]() JPEG(压缩强度=80):114 KB |
![]() JPEG(文件大学=50 KB):48.8 KB |
![]() PNG(压缩强度=80):334 KB |
![]() WEBP(压缩强度=80):11.8 KB |
特殊字符串 | 描述 |
---|---|
{index} |
下标. 将会被直接替换为数字序号,起始值可修改,默认为"1". |
{name} |
原文件名(不包含后缀). 如原文件名为"abc.jpg",则"{name}"将会被替换为"abc".如果有同名不同后缀的图片,可能会出现图片被覆盖. |
{ext} |
后缀名. 将会被直接替换为原始文件后缀(不包含点号). |
原始文件名+后缀 | 文件名配置(假设序号为1) | 输出文件名 | 解释 |
---|---|---|---|
abc.jpg | {name}_{index}.png | abc_1.png | 直接替换 |
abc.png.jpg | {name}.png | abc.png.png | 文件名为"abc.png",后缀为".jpg",注意最后的点号才是后缀名 |
abc.jpg | {name}.{ext} | abc.jpg | 用源文件名和原后缀名来替换,因此得到的仍是原文件名.如果压缩的图片中有同名同后缀不在同一文件夹,但输出目录是同一个文件夹,则会导致图片被覆盖. |
abc.jpg | 3.jpg | 3.jpg | 没有使用特殊字符串来替换文件名,因此生成的图片全部是同名的. |