blob: fdfd38eba426ab6584aa3df944012f260a077937 [file] [log] [blame]
cristydcca3fa2010-12-29 21:50:07 +00001
2<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
3 "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
4<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" dir="ltr">
5<head>
6 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
7 <meta name="verify-v1" content="g222frIIxcQTrvDR3NBRUSKP3AnMNoqxOkIniCEkV7U="/>
8 <title>ImageMagick: Magick++, C++ API for ImageMagick</title>
9 <meta http-equiv="Content-Language" content="en-US"/>
10 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
11 <meta http-equiv="Reply-to" content="magick-users@imagemagick.org"/>
12 <meta name="Application-name" content="ImageMagick"/>
13 <meta name="Description" content="ImageMagick is a software suite to create, edit, compose, or convert bitmap images in a variety of formats. Use ImageMagick to scale, rotate, shear, distort and transform images."/>
14 <meta name="Application-url" content="http://www.imagemagick.org"/>
15 <meta name="Generator" content="PHP"/>
16 <meta name="Keywords" content="magick++, c++, api, for, imagemagick, ImageMagick, ImageMagic, MagickCore, MagickWand, PerlMagick, Magick++, RMagick, PythonMagick, JMagick, TclMagick, Image, Magick, Magic, Wand, ImageMagickObject, Swiss, Army, Knife, Image, Processing"/>
17 <meta name="Rating" content="GENERAL"/>
18 <meta name="Robots" content="INDEX, FOLLOW"/>
19 <meta name="Generator" content="ImageMagick Studio LLC"/>
20 <meta name="Author" content="ImageMagick Studio LLC"/>
21 <meta name="Revisit-after" content="2 DAYS"/>
22 <meta name="Resource-type" content="document"/>
23 <meta name="Copyright" content="Copyright (c) 1999-2011 ImageMagick Studio LLC"/>
24 <meta name="Distribution" content="Global"/>
25 <link rel="icon" href="../images/wand.png"/>
26 <link rel="shortcut icon" href="../images/wand.ico" type="images/x-icon"/>
27 <link rel="meta" type="application/rdf+xml" title="ICI" href="http://imagemagick.org/ici.rdf"/>
cristy7a40ba82011-01-08 20:31:18 +000028 <link rel="stylesheet" href="http://www.google.com/cse/style/look/default.css" type="text/css" />
cristydcca3fa2010-12-29 21:50:07 +000029 <style type="text/css" media="all">
30 @import url("../www/magick.css");
31 </style>
32 <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>
cristy361f4662010-12-31 23:02:52 +000033 <script type="text/javascript" src="../fancybox/jquery.fancybox-1.3.4.pack.js"></script>
34 <link rel="stylesheet" type="text/css" href="../fancybox/jquery.fancybox-1.3.4.css" media="screen" />
35 <script type="text/javascript">
36 $(document).ready(function() {
37 $("a[href$=.jpg],a[href$=.png],a[href$=.gif]").fancybox({
38 'transitionIn' : 'elastic',
39 'transitionOut' : 'elastic',
40 'overlayShow' : false,
41 'opacity' : true
42 });
43 });
44 </script>
cristydcca3fa2010-12-29 21:50:07 +000045</head>
46
47<body id="www-imagemagick-org">
48<div class="titlebar">
49<a href="../index.html">
50 <img src="../images/script.png" alt="[ImageMagick]"
51 style="width: 350px; height: 60px; margin: 28px auto; float: left;" /></a>
52<a href="http://www.networkredux.com">
53 <img src="../images/networkredux.png" alt="[sponsor]"
cristy52923442011-01-15 22:54:31 +000054 style="margin-top: 42px; border: 0px; float: left;" /></a>
cristydcca3fa2010-12-29 21:50:07 +000055<a href="http://www.imagemagick.org/discourse-server/">
56 <img src="../images/logo.jpg" alt=""
cristy178edaf2011-01-23 03:42:39 +000057 style="width: 123px; height: 118px; border: 0px; float: right;" /></a>
cristydcca3fa2010-12-29 21:50:07 +000058<a href="../index.html">
59 <img src="../images/sprite.jpg" alt=""
60 style="width: 114px; height: 118px; border: 0px; float: right;" /></a>
61</div>
62
63<div class="westbar">
64
65<div class="menu">
66 <a title="About ImageMagick" href="../index.html">About ImageMagick</a>
67</div>
68<div class="sep"></div>
69<div class="menu">
70 <a title="Binary Releases" href="../www/binary-releases.html">Binary Releases</a>
71</div>
72<div class="sub">
73 <a title="Binary Release: Unix" href="../www/binary-releases.html#unix">Unix</a>
74</div>
75<div class="sub">
76 <a title="Binary Release: MacOS X" href="../www/binary-releases.html#macosx">Mac OS X</a>
77</div>
78<div class="sub">
79 <a title="Binary Release: Windows" href="../www/binary-releases.html#windows">Windows</a>
80</div>
81<div class="sep"></div>
82<div class="menu">
83 <a title="Command-line Tools" href="../www/command-line-tools.html">Command-line Tools</a>
84</div>
85<div class="sub">
86 <a title="Command-line Tools: Processing" href="../www/command-line-processing.html">Processing</a>
87</div>
88<div class="sub">
89 <a title="Command-line Tools: Options" href="../www/command-line-options.html">Options</a>
90</div>
91<div class="sub">
92 <a title="Command-line Tools: Usage" href="http://www.imagemagick.org/Usage/">Usage</a>
93</div>
94<div class="menu">
95 <a title="Program Interfaces" href="../www/api.html">Program Interfaces</a>
96</div>
97<div class="sub">
98 <a title="Program Interface: MagickWand" href="../www/magick-wand.html">MagickWand</a>
99</div>
100<div class="sub">
101 <a title="Program Interface: MagickCore" href="../www/magick-core.html">MagickCore</a>
102</div>
103<div class="sub">
104 <a title="Program Interface: PerlMagick" href="../www/perl-magick.html">PerlMagick</a>
105</div>
106<div class="sub">
107 <a title="Program Interface: Magick++" href="../www/magick++.html">Magick++</a>
108</div>
109<div class="sep"></div>
110<div class="menu">
111 <a title="Install from Source" href="../www/install-source.html">Install from Source</a>
112</div>
113<div class="sub">
114 <a title="Install from Source: Unix" href="../www/install-source.html#unix">Unix</a>
115</div>
116<div class="sub">
117 <a title="Install from Source: Windows" href="../www/install-source.html#windows">Windows</a>
118 </div>
119<div class="menu">
120 <a title="Resources" href="../www/resources.html">Resources</a>
121</div>
122<div class="menu">
123 <a title="Architecture" href="../www/architecture.html">Architecture</a>
124</div>
125<div class="menu">
126 <a title="Download" href="../www/download.html">Download</a>
127</div>
128<div class="sep"></div>
129<div class="menu">
cristy52923442011-01-15 22:54:31 +0000130 <a title="Search" href="../www/search.html">Search</a>
cristydcca3fa2010-12-29 21:50:07 +0000131</div>
132<div class="sep"></div>
133<div class="menu">
134 <a title="Site Map" href="../www/sitemap.html">Site Map</a>
135</div>
136<div class="sub">
137 <a title="Site Map: Links" href="../www/links.html">Links</a>
138</div>
139<div class="sep"></div>
140<div class="menu">
141 <a title="Sponsors" href="../www/sponsors.html">Sponsors:</a>
142
143<div class="sponsbox">
cristy178edaf2011-01-23 03:42:39 +0000144<div class="sponsor">
145 <a title="Sponsor: Druckerei" href="http://www.allesdruck.de">Druckerei</a><!-- 201106010240 -->
146</div>
cristyec6b4752011-01-08 03:16:23 +0000147<div class="sponsor">
cristy52923442011-01-15 22:54:31 +0000148 <a title="Sponsor: Web Hosting" href="http://www.bodhost.com/hosting.shtml">Web Hosting</a><!-- 201104010090 -->
cristydcca3fa2010-12-29 21:50:07 +0000149</div>
150<div class="sponsor">
cristydcca3fa2010-12-29 21:50:07 +0000151 <a title="Sponsor: Image Converter" href="http://www.batchphoto.com">Image Converter</a><!-- 201103010900 Bits Coffee-->
152</div>
153<div class="sponsor">
154 <a title="Sponsor: Flyer drucken" href="http://www.online-druck.biz">Flyer drucken</a><!-- 201109010900 Floeter-->
155</div>
cristyec6b4752011-01-08 03:16:23 +0000156<div class="sponsor">
cristy178edaf2011-01-23 03:42:39 +0000157 <a title="Sponsor: Druckerei" href="http://print24.com/de/">Druckerei</a><!-- 201110010720 -->
158</div>
159<div class="sponsor">
cristyf7964272011-01-30 03:49:12 +0000160 <a title="Sponsor: Fernsehdienst Berlin" href="http://www.atlas-multimedia.de">Fernsehdienst Berlin</a><!-- 2011050100025 atlas.multimedia-->
cristyec6b4752011-01-08 03:16:23 +0000161</div>
cristydcca3fa2010-12-29 21:50:07 +0000162</div>
163</div>
164</div>
165
166<div class="eastbar">
167 <script type="text/javascript">
168 <!--
169 google_ad_client = "pub-3129977114552745";
170 google_ad_slot = "0574824969";
171 google_ad_width = 160;
172 google_ad_height = 600;
173 //-->
174 </script>
175 <script type="text/javascript"
176 src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
177 </script>
178</div>
179
180<div class="main">
181
182<h1>Magick++ C++ API</h1>
183<p class="navigation-index">[<a href="#intro">Introduction to Magick++</a> &bull; <a href="#documentation">Documentation</a> &bull; <a href="#get">Obtaining Magick++</a> &bull; <a href="#install">Installation</a> &bull; <a href="#bugs">Reporting Bugs</a>]</p>
184<div class="doc-section">
185<a id="intro"></a>
186<p>Magick++ is the object-oriented C++ API to the <A HREF="http://www.imagemagick.org/">ImageMagick</A> image-processing library.</p>
187<p>Magick++ supports an object model which is inspired by <A HREF="http://www.imagemagick.org/www/perl-magick.html">PerlMagick</A>.
188Images support implicit reference counting so that copy constructors
189and assignment incur almost no cost. The cost of actually copying an
190image (if necessary) is done just before modification and this copy
191is managed automagically by Magick++. De-referenced copies are
192automagically deleted. The image objects support value (rather than
193pointer) semantics so it is trivial to support multiple generations
194of an image in memory at one time.
195</p>
196<p>Magick++ provides integrated support for the <A HREF="http://www.sgi.com/tech/stl/">Standard
197Template Library</A> (STL) so that the powerful containers available
198(e.g. <A HREF="http://www.sgi.com/tech/stl/Deque.html">deque</A>,
199<A HREF="http://www.sgi.com/tech/stl/Vector.html">vector</A>, <A HREF="http://www.sgi.com/tech/stl/List.html">list</A>,
200and <A HREF="http://www.sgi.com/tech/stl/Map.html">map</A>)&nbsp; can
201be used to write programs similar to those possible with PERL &amp;
202PerlMagick. STL-compatible template versions of ImageMagick's
203list-style operations are provided so that operations may be
204performed on multiple images stored in STL containers.
205</p>
206</div>
207<h2>Documentation</h2>
208<div class="doc-section">
209<a id="documentation"></a>
210<p>Detailed <A HREF="../Magick++/Documentation.html">documentation</A> is
211provided for all Magick++ classes, class methods, and template
cristy361f4662010-12-31 23:02:52 +0000212functions which comprise the API. See a <a href="http://www.imagemagick.org/Magick++/tutorial/Magick++_tutorial.pdf"> Gentle Introduction to Magick++</a> for an introductory tutorial to Magick++. We include the <a href="http://www.imagemagick.org/Magick++/tutorial/Magick++_tutorial.odt" >source</a> if you want to correct, enhance, or expand the tutorial.</p>
cristydcca3fa2010-12-29 21:50:07 +0000213</p>
214</div>
215<h2>Obtaining Magick++</h2>
216<a id="get"></a>
217<div class="doc-section">
218<p>Magick++ is included as part of <A HREF="../www/index.html">ImageMagick</A>
219source releases and may be retrieved via <A HREF="http://www.imagemagick.org/www/download.html">ftp</A>
220or <A HREF="http://www.imagemagick.org/www/subversion.html">Subversion</A>.
221</p>
222</div>
223<h2>Installation</h2>
224<div class="doc-section">
225<a id="install"></a>
226<p>Once you have the Magick++ sources available, follow these detailed
227<A HREF="../Magick++/Install.html">installation instructions</A> for UNIX and
228Windows.
229</p>
230<p>A helper script named <I>Magick++-config</I> is installed
231under Unix which assists with recalling compilation options required
232to compile and link programs which use Magick++. For example, the
233following command will compile and link the source file <I>demo.cpp</I>
234to produce the executable <I>demo</I> (notice that quotes are
235backward quotes):
236</p>
237<pre class="text">
238c++ `Magick++-config --cxxflags --cppflags` -O2 -o demo demo.cpp \
239 `Magick++-config --ldflags --libs`
240</pre>
241<p>Windows users may get started by manually editing a project file
242for one of the Magick++ demo programs.
243</p>
244<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>
245<pre class="text">
246int main( int argc, char ** argv) {
247 InitializeMagick(*argv);
248 ...
249</pre>
250<p>This initialization step is not required under Unix, Linux,
251Cygwin, or any other operating environment that supports the notion
252of <em>installing</em> ImageMagick in a known location.
253</p>
254</div>
255<h2>Reporting Bugs</h2>
256<div class="doc-section">
257<a id="bugs"></a>
258<p>Please report any bugs via the
259<A HREF="http://www.imagemagick.org/discourse-server/viewforum.html?f=3">Magick++ bug tracking forum</A>.
260Questions regarding usage should be directed to
261<A HREF="http://www.imagemagick.org/discourse-server/viewforum.html?f=1">Magick++ discussion forum</A>.
262</p>
263</div>
264
265</div>
266
267<div id="linkbar">
268 <span id="linkbar-west">&nbsp;</span>
269 <span id="linkbar-center">
270 <a href="http://www.imagemagick.org/discourse-server/">Discourse Server</a> &bull;
271 <a href="http://www.imagemagick.org/MagickStudio/scripts/MagickStudio.cgi">Studio</a>
272 </span>
273 <span id="linkbar-east">&nbsp;</span>
274 </div>
275 <div class="footer">
276 <span id="footer-west">&copy; 1999-2011 ImageMagick Studio LLC</span>
277 <span id="footer-east"> <a href="http://www.imagemagick.org/script/contact.php">Contact the Wizards</a></span>
278 </div>
279 <div style="clear: both; margin: 0; width: 100%; "></div>
280 <script type="text/javascript">
281 var _gaq = _gaq || [];
282 _gaq.push(['_setAccount', 'UA-17690367-1']);
283 _gaq.push(['_trackPageview']);
284
285 (function() {
286 var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
287 ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
288 var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
289 })();
290 </script>
291</body>
292</html>