1 2 3 4 5<!doctype html> 6<html lang="en"> 7<head> 8 <meta charset="utf-8" /> 9 <meta name="viewport" content="width=device-width, initial-scale=1" /> 10 <title>ImageMagick - Magick++, C++ API</title> 11 <meta name="application-name" content="ImageMagick" /> 12 <meta name="description" content="Use ImageMagick® to create, edit, compose, and convert digital images. Resize an image, crop it, change its shades and colors, add captions, and more." /> 13 <meta name="application-url" content="https://imagemagick.org" /> 14 <meta name="generator" content="PHP" /> 15 <meta name="keywords" content="magick++, c++, api, image processing software" /> 16 <meta name="rating" content="GENERAL" /> 17 <meta name="robots" content="INDEX, FOLLOW" /> 18 <meta name="generator" content="ImageMagick Studio LLC" /> 19 <meta name="author" content="ImageMagick Studio LLC" /> 20 <meta name="revisit-after" content="2 DAYS" /> 21 <meta name="resource-type" content="document" /> 22 <meta name="copyright" content="Copyright (c) 1999-2020 ImageMagick Studio LLC" /> 23 <meta name="distribution" content="Global" /> 24 <meta name="magick-serial" content="P131-S030410-R485315270133-P82224-A6668-G1245-1" /> 25 <meta property='og:url' content='../' /> 26 <meta property='og:title' content='ImageMagick' /> 27 <meta property='og:image' content='../images/logo.png' /> 28 <meta property='og:type' content='website' /> 29 <meta property='og:site_name' content='ImageMagick' /> 30 <meta property='og:description' content="Create, Edit, Compose, or Convert Digital Images" /> 31 <meta name="google-site-verification" content="_bMOCDpkx9ZAzBwb2kF3PRHbfUUdFj2uO8Jd1AXArz4" /> 32 <link href="magick++.html" rel="canonical" /> 33 <link href="../images/wand.png" rel="icon" /> 34 <link href="../images/wand.ico" rel="shortcut icon" /> 35 <link href="assets/magick.css" rel="stylesheet" /> 36</head> 37<body> 38 <nav class="navbar navbar-expand-md navbar-dark bg-dark fixed-top"> 39 <div class="container-fluid"> 40 <a class="navbar-brand" href="../"><img class="d-block" id="icon" alt="ImageMagick" width="32" height="32" src="../images/wand.ico"/></a> 41 <button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#magick-navbars" aria-controls="magick-navbars" aria-expanded="false" aria-label="Toggle navigation"> 42 <span class="navbar-toggler-icon"></span> 43 </button> 44 45 <div class="collapse navbar-collapse" id="magick-navbars"> 46 <ul class="navbar-nav me-auto mb-2 mb-md-0"> 47 <li class="nav-item"> 48 <a class="nav-link " href="../www/index.html">Home</a> 49 </li> 50 <li class="nav-item"> 51 <a class="nav-link " href="../www/download.html">Download</a> 52 </li> 53 <li class="nav-item"> 54 <a class="nav-link " href="../www/command-line-tools.html">Tools</a> 55 </li> 56 <li class="nav-item"> 57 <a class="nav-link " href="../www/command-line-processing.html">CLI</a> 58 </li> 59 <li class="nav-item"> 60 <a class="nav-link " href="../www/develop.html">Develop</a> 61 </li> 62 <li class="nav-item"> 63 <a class="nav-link" target="_blank" href="https://github.com/ImageMagick/ImageMagick/discussions">Community</a> 64 </li> 65 <li class="nav-item"> 66 <iframe src="https://github.com/sponsors/ImageMagick/button" title="Sponsor ImageMagick" height="35" width="107" style="border: 0;"></iframe> 67 </li> 68 </ul> 69 <form class="d-flex form-inline" action="search.html"> 70 <input class="form-control me-2" type="text" name="q" placeholder="Search" aria-label="Search"> 71 <button class="btn btn-outline-success" type="submit" name="sa">Search</button> 72 </form> 73 </div> 74 </div> 75 </nav> 76 77 <div class="container"> 78 <script async="async" src="https://localhost/pagead/js/adsbygoogle.js"></script> 79 <ins class="adsbygoogle" 80 style="display:block" 81 data-ad-client="ca-pub-3129977114552745" 82 data-ad-slot="6345125851" 83 data-full-width-responsive="true" 84 data-ad-format="horizontal"></ins> 85 <script> 86 (adsbygoogle = window.adsbygoogle || []).push({}); 87 </script> 88 89 </div> 90 91 <main class="container"> 92 <div class="magick-template"> 93<div class="magick-header"> 94<p class="text-center"><a href="magick++.html#documentation">Documentation</a> • <a href="magick++.html#get">Obtaining Magick++</a> • <a href="magick++.html#install">Installation</a> • <a href="magick++.html#bugs">Reporting Bugs</a></p> 95 96<a class="anchor" id="intro"></a> 97<p class="lead magick-description"><a href="api/Magick++/index.html">Magick++ API</a> is the object-oriented C++ API to the <a href="../">ImageMagick</a> image-processing library.</p> 98<p>Magick++ supports an object model which is inspired by <a href="perl-magick.html">PerlMagick</a>. 99Images support implicit reference counting so that copy constructors 100and assignment incur almost no cost. The cost of actually copying an 101image (if necessary) is done just before modification and this copy 102is managed automagically by Magick++. De-referenced copies are 103automagically deleted. The image objects support value (rather than 104pointer) semantics so it is trivial to support multiple generations 105of an image in memory at one time. 106</p> 107<p>Magick++ provides integrated support for the <a href="http://www.sgi.com/tech/stl/">Standard 108Template Library</a> (STL) so that the powerful containers available 109(e.g. <a href="http://www.sgi.com/tech/stl/Deque.html">deque</a>, 110<a href="http://www.sgi.com/tech/stl/Vector.html">vector</a>, <a href="http://www.sgi.com/tech/stl/List.html">list</a>, 111and <a href="http://www.sgi.com/tech/stl/Map.html">map</a>) can 112be used to write programs similar to those possible with PERL & 113PerlMagick. STL-compatible template versions of ImageMagick's 114list-style operations are provided so that operations may be 115performed on multiple images stored in STL containers. 116</p> 117<h2>Documentation</h2> 118<a class="anchor" id="documentation"></a> 119<p>Detailed <a href="api/magick++-classes.html">documentation</a> is 120provided for all Magick++ classes, class methods, and template 121functions which comprise the API. See a <a href="../Magick++/tutorial/Magick++_tutorial.pdf"> Gentle Introduction to Magick++</a> for an introductory tutorial to Magick++. We include the <a href="../Magick++/tutorial/Magick++_tutorial.odt" >source</a> if you want to correct, enhance, or expand the tutorial.</p> 122<h2>Obtaining Magick++</h2> 123<a class="anchor" id="get"></a> 124<p>Magick++ is included as part of <a href="../index.html">ImageMagick</a> 125source releases and may be retrieved via <a href="../www/download.html">HTTP</a> 126or <a href="https://github.com/ImageMagick/ImageMagick/tree/main/Magick%2B%2B">GitHub</a>. 127</p> 128<h2>Installation</h2> 129<a class="anchor" id="install"></a> 130<p>Once you have the Magick++ sources available, follow these detailed 131<a href="../Magick++/Install.html">installation instructions</a> for UNIX and 132Windows. 133</p> 134<h2>Usage</h2> 135<p>A helper script named <code>Magick++-config</code> is installed 136under Unix which assists with recalling compilation options required 137to compile and link programs which use Magick++. For example, the 138following command compiles and links the source file <code>demo.cpp</code> 139to produce the executable <code>demo</code> (notice that quotes are 140backward quotes): 141</p> 142<pre class="highlight"><code>c++ `Magick++-config --cxxflags --cppflags` -O2 -o demo demo.cpp \ 143 `Magick++-config --ldflags --libs` 144</code></pre> 145<p>Set the <code>PKG_CONFIG_PATH</code> environment variable if ImageMagick is not in your default system path:</p> 146 147<pre class="highlight"><code>export PKG_CONFIG_PATH=/usr/local/lib/pkgconfig 148</code></pre> 149 150<p>Windows users may get started by manually editing a project file 151for one of the Magick++ demo programs. 152</p> 153<p>Note, under Windows (and possibly the Mac) it may be necessary to initialize the ImageMagick library prior to using the Magick++ library. This initialization is performed by passing the path to the ImageMagick DLLs (assumed to be in the same directory as your program) to the InitializeMagick() function call. This is commonly performed by providing the path to your program (argv[0]) as shown in the following example: </p> 154<pre class="highlight"><code>int main( int argc, char ** argv) { 155 InitializeMagick(*argv); 156 ... 157</code></pre> 158<p>This initialization step is not required under Unix, Linux, 159Cygwin, or any other operating environment that supports the notion 160of <var>installing</var> ImageMagick in a known location. </p> 161<p>Here is a example program that utilizes the Magick++ API to get you started, <a href="https://imagemagick.org/source/magick++.cpp">magick++.cpp</a>. It reads an image, crops it, and writes it to disk in the PNG image format.</p> 162 163<pre class="pre-scrollable highlight"><code> 164#include <Magick++.h> 165#include <iostream> 166 167using namespace std; 168using namespace Magick; 169 170int main(int argc,char **argv) 171{ 172 InitializeMagick(*argv); 173 174 // Construct the image object. Seperating image construction from the 175 // the read operation ensures that a failure to read the image file 176 // doesn't render the image object useless. 177 Image image; 178 try { 179 // Read a file into image object 180 image.read( "logo:" ); 181 182 // Crop the image to specified size (width, height, xOffset, yOffset) 183 image.crop( Geometry(100,100, 100, 100) ); 184 185 // Write the image to a file 186 image.write( "logo.png" ); 187 } 188 catch( Exception &error_ ) 189 { 190 cout << "Caught exception: " << error_.what() << endl; 191 return 1; 192 } 193 return 0; 194} 195</code></pre> 196<h2>Reporting Bugs</h2> 197<a class="anchor" id="bugs"></a> 198<p>Questions regarding usage should be directed to or to report any bugs go to 199<a href="https://github.com/ImageMagick/ImageMagick/discussions">Magick++ community forum</a>. 200</p> 201</div> 202 </div> 203 </main><!-- /.container --> 204 <footer class="magick-footer"> 205 <div class="container-fluid"> 206 <a href="../www/security-policy.html">Security</a> • 207 <a href="../www/news.html">News</a> 208 209 <a href="magick++.html#"><img class="d-inline" id="wand" alt="And Now a Touch of Magick" width="16" height="16" src="../images/wand.ico"/></a> 210 211 <a href="../www/links.html">Related</a> • 212 <a href="../www/sitemap.html">Sitemap</a> 213 <br/> 214 <a href="../www/support.html">Sponsor</a> • 215 <a href="../www/cite.html">Cite</a> • 216 <a href="http://pgp.mit.edu/pks/lookup?op=get&search=0x89AB63D48277377A">Public Key</a> • 217 <a href="../www/https://imagemagick.org/script/contact.php">Contact Us</a> 218 <br/> 219 <a href="https://github.com/imagemagick/imagemagick" target="_blank" rel="noopener" aria-label="GitHub"><svg xmlns="http://www.w3.org/2000/svg" class="navbar-nav-svg" viewBox="0 0 512 499.36" width="2%" height="2%" role="img" focusable="false"><title>GitHub</title><path fill="currentColor" fill-rule="evenodd" d="M256 0C114.64 0 0 114.61 0 256c0 113.09 73.34 209 175.08 242.9 12.8 2.35 17.47-5.56 17.47-12.34 0-6.08-.22-22.18-.35-43.54-71.2 15.49-86.2-34.34-86.2-34.34-11.64-29.57-28.42-37.45-28.42-37.45-23.27-15.84 1.73-15.55 1.73-15.55 25.69 1.81 39.21 26.38 39.21 26.38 22.84 39.12 59.92 27.82 74.5 21.27 2.33-16.54 8.94-27.82 16.25-34.22-56.84-6.43-116.6-28.43-116.6-126.49 0-27.95 10-50.8 26.35-68.69-2.63-6.48-11.42-32.5 2.51-67.75 0 0 21.49-6.88 70.4 26.24a242.65 242.65 0 0 1 128.18 0c48.87-33.13 70.33-26.24 70.33-26.24 14 35.25 5.18 61.27 2.55 67.75 16.41 17.9 26.31 40.75 26.31 68.69 0 98.35-59.85 120-116.88 126.32 9.19 7.9 17.38 23.53 17.38 47.41 0 34.22-.31 61.83-.31 70.23 0 6.85 4.61 14.81 17.6 12.31C438.72 464.97 512 369.08 512 256.02 512 114.62 397.37 0 256 0z"/></svg></a> • 220 <a href="https://twitter.com/imagemagick" target="_blank" rel="noopener" aria-label="Twitter"><svg xmlns="http://www.w3.org/2000/svg" class="navbar-nav-svg" viewBox="0 0 512 416.32" width="2%" height="2%" role="img" focusable="false"><title>Twitter</title><path fill="currentColor" d="M160.83 416.32c193.2 0 298.92-160.22 298.92-298.92 0-4.51 0-9-.2-13.52A214 214 0 0 0 512 49.38a212.93 212.93 0 0 1-60.44 16.6 105.7 105.7 0 0 0 46.3-58.19 209 209 0 0 1-66.79 25.37 105.09 105.09 0 0 0-181.73 71.91 116.12 116.12 0 0 0 2.66 24c-87.28-4.3-164.73-46.3-216.56-109.82A105.48 105.48 0 0 0 68 159.6a106.27 106.27 0 0 1-47.53-13.11v1.43a105.28 105.28 0 0 0 84.21 103.06 105.67 105.67 0 0 1-47.33 1.84 105.06 105.06 0 0 0 98.14 72.94A210.72 210.72 0 0 1 25 370.84a202.17 202.17 0 0 1-25-1.43 298.85 298.85 0 0 0 160.83 46.92"/></svg></a> 221 <br/> 222 <small>© 1999-2021 ImageMagick Studio LLC</small> 223 </div> 224 </footer> 225 226 <!-- Javascript assets --> 227 <script src="assets/magick.js" ></script> 228 </body> 229</html> 230<!-- Magick Cache 13th February 2021 14:08 -->