Useful Imagemagick Commands
It’s such a nifty and powerful tool, there’s so much you can do with it.
Subscribe to our awesome Newsletter.
Imagemagick is one of those tools that’s there on literally every developers computer. It’s such a nifty and powerful tool, there’s so much you can do with it.
Imagemagick is a suite of command line tools that can edit, create and convert various image formats. Here’s a few commands I use regularly.
Combine two images together
1
| convert +append a.png b.png c.png |
This takes a.png and b.png and combines them horizontally to createc.png. For best results, make sure both the images are of same or comparable ratios.
To combine them vertically,
1
| convert -append a.png b.png c.png |
You can even combine images of different types (like a PNG and a JPG)!
Resizing images
1
| convert a.png -resize 100x100 a_100.png |
Easily resize images by providing the width and height values. If you attempt to resize your images to a larger ratio, they will often loose quality and appear pixelated. Resize always seeks to preserve your aspect ratio even if given vales do not comply.
Blurring images
1
| convert a.png -blur 0x2 a_blur_2.png |
Add blur effects to your images quickly with this. The first value controls the radius of your blur, while the second value controls the strength. As a quick rule of the thumb, increase the second value to increase the blurriness.
Converting Videos to GIFs
1
| convert -quiet -delay 1 a.avi a.gif |
I’ll admit it, I’ve used this far more times that anything else here. Who doesn’t love a bit of Reddit karma?
Making your white PNGs transparent
1
| convert a.png -fuzz 10% -transparent white a_transparent.png |
I’ve used this a million times. If you ever convert a JPG image to a PNG, you’ll notice the whites aren’t transparent, which ultimately ruins the purpose of a PNG. Use this command to make the white parts of your PNG transparent. The fuzz parameter is to smoothen out the conversion. Use a smaller value to keep the conversion closer to true white, or a larger value to allow more variation from white to become transparent.
Grayscale your images
1
| convert a.jpg -type Grayscale a_gray.jpg |
That’s it! Simple as pie.
Square out your uneven images by adding white padding
1
| convert -define png:size=513x294 a.png -thumbnail '200x200>' -gravity center -crop 120x120+0+0\! -background white -flatten a_thumb.png |
Define the size of the PNG you’re converting in the png:size=wxh block. Here, w is the width and h is the height of the image. In the **-thumbnail **block, define the resultant thumbnail dimensions.
That’s it for now! I’ll keep updating this post as and when I find more useful commands.