2022-11-20 21:17:25 +01:00
---
title: Optimizing PNG images
2023-11-18 23:01:27 +01:00
aliases: /posts/2020-01-20-optimizing-png-images
2022-11-20 21:17:25 +01:00
summary: >
A quick notice about three very handy tools to optimize PNG images on
the command line. They work on linux and macOS. Use jpegtran for JPG
images.
categories: [computerstuff]
2024-09-29 01:48:06 +02:00
tags: [zsh-shell, fish-shell]
2022-11-20 21:17:25 +01:00
date: 2020-01-20T20:34:20+01:00
2024-09-29 01:48:06 +02:00
lastmod: 2024-09-28T23:48:06+0000
2022-11-20 21:17:25 +01:00
---
## Optimizing a bunch of images in a directory
I found these commands here coincidentally on a
[pull request ](https://github.com/xianmin/hugo-theme-jane/pull/266 ) at Github.
I found them quite handy :+1:
2024-09-29 01:48:06 +02:00
```console
2022-11-20 21:17:25 +01:00
$ find . -type f -name "*.png" -print0 | xargs -0 -I {} optipng -nb -nc "{}"
$ find . -type f -name "*.png" -print0 | xargs -0 -I {} advpng -z4 "{}"
$ find . -type f -name "*.png" -print0 | xargs -0 -I {} pngcrush -rem gAMA -rem alla -rem cHRM -rem iCCP -rem sRGB -rem time -ow "{}"
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
## Quickly optimizing only one image
I've set up a function in my `.zaliases` file for this to be done on a single
image aswell:
2024-09-29 01:48:06 +02:00
```zsh
2022-11-20 21:17:25 +01:00
function opti() {
optipng -nb -nc "$*";
advpng -z4 "$*";
pngcrush -rem gAMA -rem alla -rem cHRM -rem iCCP -rem sRGB -rem time -ow "$*";
}
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
To run all three commands on a single image I just call it like that:
2024-09-29 01:48:06 +02:00
```console
2022-11-20 21:17:25 +01:00
$ opti image.png
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
That's all the magic it needs.
## Use jpegtran for JPG images
2024-09-29 01:48:06 +02:00
```console
2022-11-20 21:17:25 +01:00
$ jpegtran -copy none -optimize -progressive -outfile output.jpg input.jpg
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
## Install these tools on your system
On debian or ubuntu
2024-09-29 01:48:06 +02:00
```console
2022-11-20 21:17:25 +01:00
$ sudo apt-get install optipng pngcrush advancecomp
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
2022-12-09 23:25:34 +01:00
On Arch based distros using pamac
2022-11-20 21:17:25 +01:00
2024-09-29 01:48:06 +02:00
```console
2022-12-09 23:25:34 +01:00
$ sudo pamac install optipng pngcrush advancecomp
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
2022-12-09 23:25:34 +01:00
(advancecomp is in AUR)
2022-11-20 21:17:25 +01:00
On macOS
2024-09-29 01:48:06 +02:00
```console
2022-11-20 21:17:25 +01:00
$ sudo port install optipng pngcrush advancecomp
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
or if you use homebrew
2024-09-29 01:48:06 +02:00
```console
2022-11-20 21:17:25 +01:00
$ brew install optipng pngcrush advancecomp
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
You may know other package managers commands, but I only use these.
## An example
### By filesize
The files taken from the snapshot tool on my macbook.
2024-09-29 01:48:06 +02:00
```plain
2022-11-20 21:17:25 +01:00
33K 00_locales.png
61K 01_control-software.png
157K 02_mmdvmhost.png
184K 03_general.png
187K 04_dmrconfig.png
69K 05_exp_mmdvmhost-dmrnetwork.png
212K 06_exp_dmrgw-dmrnetwork1.png
236K 07_exp_dmrgw-dmrnetwork2.png
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
Three to four minutes later (all three commands):
2024-09-29 01:48:06 +02:00
```plain
2022-11-20 21:17:25 +01:00
17K 00_locales.png
33K 01_control-software.png
81K 02_mmdvmhost.png
98K 03_general.png
97K 04_dmrconfig.png
32K 05_exp_mmdvmhost-dmrnetwork.png
127K 06_exp_dmrgw-dmrnetwork1.png
144K 07_exp_dmrgw-dmrnetwork2.png
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
### By view
2024-09-29 01:48:06 +02:00
```plain
2022-11-20 21:17:25 +01:00
25K opti_01.png
13K opti_02.png
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
![Original image ](opti_01.png "This is the unmodified image: `opti_01.png`" ) ![Optimized image ](opti_02.png "And this is the optimized image: `opti_02.png`" )
Do you see much difference?
## Using this with the **fish** shell
I added this to my fishs configuration (when I used fish for a while).
2024-09-29 01:48:06 +02:00
```fish
2022-11-20 21:17:25 +01:00
# file: "~/.config/fish/functions/opti.fish"
function opti --description "Optimizes .png files"
# Author: Dominic, OE7DRT < dominic @ oe7drt . com >
# 2021-04-17
set -e missing
for program in optipng advpng pngcrush
if \! command -v $program > /dev/null
set -a missing $program
continue
end
end
if test -n "$missing"
echo "Could not find executables: $missing"
return 1
end
if test -z $argv[1]
echo "usage: opti < files... > "
return 1
end
set count (count $argv)
for i in (seq 1 $count)
if test ! -f $argv[$i]
echo "Could not read file $argv[$i]..."
continue
end
optipng -nb -nc "$argv[$i]";
advpng -z4 "$argv[$i]";
pngcrush -rem gAMA -rem alla -rem cHRM -rem iCCP -rem sRGB -rem time -ow "$argv[$i]";
end
end
2024-09-29 01:48:06 +02:00
```
2022-11-20 21:17:25 +01:00
And I made one for the jpeg version too:
2024-09-29 01:48:06 +02:00
```fish
2022-11-20 21:17:25 +01:00
# file: "~/.config/fish/functions/jopti.fish"
function jopti --description "Optimizes .jpg files"
# Author: Dominic, OE7DRT < dominic @ oe7drt . com >
# 2021-08-07
set -e missing
for program in jpegtran
if \! command -v $program > /dev/null
set -a missing $program
continue
end
end
if test -n "$missing"
echo "Could not find executables: $missing"
return 1
end
if test -z $argv[1]
echo "usage: jopti < files... > "
return 1
end
set count (count $argv)
for i in (seq 1 $count)
if test ! -f $argv[$i]
echo "Could not read file $argv[$i]..."
continue
end
jpegtran -copy none -optimize -progressive -outfile "$argv[$i]" "$argv[$i]"
end
end
2024-09-29 01:48:06 +02:00
```