C HTML Makefile Hack C++ XS Other
Failed to load latest commit information.
.github Also mention 'ImageMagick' folder inside issue template. Sep 5, 2017
.travis Fixed export. Jan 28, 2018
Magick++ Added LinearGRAYColorspace to the header. Jul 11, 2018
MagickCore ... Aug 15, 2018
MagickWand ... Aug 5, 2018
PerlMagick ... Aug 15, 2018
api_examples status is unused Feb 28, 2017
coders https://bugs.chromium.org/p/oss-fuzz/issues/detail?id=9879 Aug 15, 2018
config ... May 21, 2018
filters Static scheduling without a chunk size has the lowest performance ove… Mar 18, 2018
images Update documentation Dec 16, 2017
m4 ... Dec 6, 2017
scripts Update copyright years Dec 12, 2015
tests Use memset() rather than ResetMagickMemory() Mar 10, 2018
utilities ... Aug 6, 2018
www ... Jul 26, 2018
.gitignore Removed object file and modified .gitignore Oct 3, 2015
.travis.yml use set -e in the standard travis script and switch to multi-line Jan 16, 2018
AUTHORS.txt Prefer https over http Nov 5, 2016
AppRun Update AppRun Apr 2, 2018
ChangeLog ... Aug 13, 2018
ImageMagick.spec.in ... May 29, 2018
Install-mac.txt ... Aug 28, 2017
Install-unix.txt ... Aug 28, 2017
Install-vms.txt No commit message Jul 1, 2011
Install-windows.txt ... May 26, 2018
LICENSE ... Dec 6, 2017
Magickshr.opt http://www.imagemagick.org/discourse-server/viewtopic.php?f=2&t=28359 Sep 18, 2015
Make.com ... Sep 12, 2017
Makefile.am ... Feb 25, 2018
Makefile.in ImageMagick/ImageMagick6#10 Jun 20, 2018
NEWS.txt No commit message Sep 5, 2009
NOTICE ... Dec 6, 2017
Platforms.txt No commit message Sep 5, 2009
QuickStart.txt Prefer https over http Nov 5, 2016
README.md ... Aug 4, 2018
README.txt ... Aug 4, 2018
aclocal.m4 ... Jan 8, 2018
common.shi.in ... Mar 4, 2018
configure ... Aug 14, 2018
configure.ac ... Aug 14, 2018
gitversion.sh ... Sep 14, 2017
imagemagick.desktop Generate AppImage Nov 12, 2017
index.html ... Jul 8, 2018
magick.sh.in ... Dec 6, 2017
version.sh ... Aug 14, 2018
winpath.sh ... Dec 6, 2017



ImageMagick logo

Use ImageMagick® o create, edit, compose, or convert bitmap images. It can read and write images in a variety of formats (over 200) including PNG, JPEG, GIF, HEIC, TIFF, DPX, EXR, WebP, Postscript, PDF, and SVG. Use ImageMagick to resize, flip, mirror, rotate, distort, shear and transform images, adjust image colors, apply various special effects, or draw text, lines, polygons, ellipses and Bézier curves.

Version *nix Windows
7 Build Status Build status
6 Build Status Build status

What is ImageMagick?

The functionality of ImageMagick is typically utilized from the command line or you can use the features from programs written in your favorite programming language. Choose from these interfaces: G2F (Ada), MagickCore (C), MagickWand (C), ChMagick (Ch), ImageMagickObject (COM+), Magick++ (C++), JMagick (Java), L-Magick (Lisp), NMagick (Neko/haXe), MagickNet (.NET), PascalMagick (Pascal), PerlMagick (Perl), MagickWand for PHP (PHP), IMagick (PHP), PythonMagick (Python), RMagick (Ruby), or TclMagick (Tcl/TK). With a language interface, use ImageMagick to modify or create images dynamically and automagically.

ImageMagick utilizes multiple computational threads to increase performance and can read, process, or write mega-, giga-, or tera-pixel image sizes.

ImageMagick is free software delivered as a ready-to-run binary distribution or as source code that you may use, copy, modify, and distribute in both open and proprietary applications. It is distributed under the Apache 2.0 license.

The ImageMagick development process ensures a stable API and ABI. Before each ImageMagick release, we perform a comprehensive security assessment that includes memory error and thread data race detection to prevent security vulnerabilities.

The current release is the ImageMagick 7.0.8 series. It runs on Linux, Windows, Mac Os X, iOS, Android OS, and others.

The authoritative ImageMagick web site is https://www.imagemagick.org. The authoritative source code repository is https://github.com/ImageMagick. We maintain a source code mirror at https://gitlab.com/ImageMagick.

We continue to maintain the legacy release of ImageMagick, version 6, at https://legacy.imagemagick.org.

Features and Capabilities

Here are just a few examples of what ImageMagick can do:

Examples of ImageMagick Usage, shows how to use ImageMagick from the command-line to accomplish any of these tasks and much more. Also, see Fred's ImageMagick Scripts: a plethora of command-line scripts that perform geometric transforms, blurs, sharpens, edging, noise removal, and color manipulations. With Magick.NET, use ImageMagick without having to install ImageMagick on your server or desktop.


Now that ImageMagick version 7 is released, we continue to maintain the legacy release of ImageMagick, version 6. Learn how ImageMagick version 7 differs from previous versions with our porting guide.

ImageMagick best practices strongly encourages you to configure a security policy that suits your local environment.

As an analog to linear (RGB) and non-linear (sRGB) color colorspaces, as of ImageMagick 7.0.7-17, we introduce the LinearGray colorspace. Gray is non-linear grayscale and LinearGray is linear (e.g. -colorspace linear-gray).

Want more performance from ImageMagick? Try these options:

  • Add more memory to your system, see the pixel cache;
  • Add more cores to your system, see threads of execution support;
  • push large images to a solid-state drive, see large image support.

If these options are prohibitive, you can reduce the quality of the image results. The default build is Q16 HDRI. If you disable HDRI, you use half the memory and instead of predominately floating point operations, you use the typically more efficient integer operations. The tradeoff is reduced precision and you cannot process out of range pixel values (e.g. negative). If you build the Q8 non-HDRI version of ImageMagick, you again reduce the memory requirements in half-- and once again there is a tradeoff, even less precision and no out of range pixel values. For a Q8 non-HDRI build of ImageMagick, use these configure script options: --with-quantum-depth=8 --disable-hdri.