]> granicus.if.org Git - imagemagick/blob - www/magick++.html
(no commit message)
[imagemagick] / www / magick++.html
1 \r
2 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" \r
3   "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">\r
4 <html version="-//W3C//DTD XHTML 1.1//EN"\r
5       xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"\r
6       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"\r
7       xsi:schemaLocation="http://www.w3.org/1999/xhtml\r
8                           http://www.w3.org/MarkUp/SCHEMA/xhtml11.xsd">\r
9 <head>\r
10   <meta http-equiv="content-type" content="text/html; charset=UTF-8"/>\r
11   <meta name="google-site-verification" content="MxsMq6bdLOx0KSuz1MY6yG9ZTIJ7_7DVRfl5NCAT5Yg"/>\r
12   <title>ImageMagick: Magick++, C++ API for ImageMagick</title>
13   <meta http-equiv="content-language" content="en-US"/>
14   <meta http-equiv="content-type" content="text/html; charset=utf-8"/>
15   <meta http-equiv="reply-to" content="magick-users@imagemagick.org"/>
16   <meta name="application-name" content="ImageMagick"/>
17   <meta name="description" content="Use ImageMagick to convert, edit, or compose bitmap images in a variety of formats.  In addition resize, rotate, shear, distort and transform images automagically."/>
18   <meta name="application-url" content="http://www.imagemagick.org"/>
19   <meta name="generator" content="PHP"/>
20   <meta name="keywords" content="magick++, c++, api, for, imagemagick, ImageMagick, PerlMagick, image processing, OpenMP, software development library, image, photo, software, Magick++, MagickWand"/>
21   <meta name="rating" content="GENERAL"/>
22   <meta name="robots" content="INDEX, FOLLOW"/>
23   <meta name="generator" content="ImageMagick Studio LLC"/>
24   <meta name="author" content="ImageMagick Studio LLC"/>
25   <meta name="revisit-after" content="2 DAYS"/>
26   <meta name="resource-type" content="document"/>
27   <meta name="copyright" content="Copyright (c) 1999-2012 ImageMagick Studio LLC"/>
28   <meta name="distribution" content="Global"/>
29   <link rel="icon" href="../images/wand.png"/>
30   <link rel="shortcut icon" href="../images/wand.ico"  type="images/x-icon"/>
31   <link rel="canonical" href="http://www.imagemagick.org" />\r
32   <link rel="meta" type="application/rdf+xml" title="ICI" href="http://imagemagick.org/ici.rdf"/>\r
33   <!-- Add jQuery library -->\r
34   <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7/jquery.min.js"></script>\r
35   \r
36   <!-- Optionaly include easing and/or mousewheel plugins -->\r
37   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/jquery.easing-1.3.pack.js"></script>\r
38   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/jquery.mousewheel-3.0.6.pack.js"></script>\r
39   \r
40   <!-- Add fancyBox -->\r
41   <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/jquery.fancybox.css?v=2.0.4" type="text/css" media="screen" />\r
42   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/jquery.fancybox.pack.js?v=2.0.4"></script>\r
43   \r
44   <!-- Optionaly include button and/or thumbnail helpers -->\r
45   <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-buttons.css?v=2.0.4" type="text/css" media="screen" />\r
46   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-buttons.js?v=2.0.4"></script>\r
47   \r
48   <link rel="stylesheet" href="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-thumbs.css?v=2.0.4" type="text/css" media="screen" />\r
49   <script type="text/javascript" src="http://www.imagemagick.org/fancybox/helpers/jquery.fancybox-thumbs.js?v=2.0.4"></script>\r
50   <script type="text/javascript">\r
51         $(document).ready(function() {\r
52                 $(".fancybox").fancybox();\r
53         });\r
54   </script>\r
55   <!-- ImageMagick style -->\r
56   <link rel="stylesheet" href="http://www.google.com/cse/style/look/default.css" type="text/css" />\r
57   <style type="text/css" media="all">\r
58     @import url("../www/magick.css");\r
59   </style>\r
60 </head>\r
61 \r
62 <body id="www-imagemagick-org">\r
63 <div class="titlebar">\r
64 <div style="margin: 17px auto; float: left;">\r
65   <script type="text/javascript">\r
66   <!--\r
67     google_ad_client = "pub-3129977114552745";\r
68     google_ad_slot = "5439289906";\r
69     google_ad_width = 728;\r
70     google_ad_height = 90;\r
71   //-->\r
72   </script>\r
73   <script type="text/javascript"\r
74     src="http://pagead2.googlesyndication.com/pagead/show_ads.js">\r
75   </script>\r
76 </div>\r
77 <a href="../discourse-server">\r
78   <img src="../images/logo.jpg"\r
79   alt="ImageMagick Logo"\r
80   style="width: 123px; height: 118px; border: 0px; float: right;" /></a>\r
81 <a href="../index.html">\r
82   <img src="../images/sprite.jpg"\r
83   alt="ImageMagick Sprite"\r
84   style="width: 114px; height: 118px; border: 0px; float: right;" /></a>\r
85 </div>\r
86 \r
87 <div class="westbar">\r
88 \r
89 <div class="menu">
90   <a title="About ImageMagick" href="../index.html">About ImageMagick</a>
91 </div>
92 <div class="menu">
93   <a title="Binary Releases" href="binary-releases.html">Binary Releases</a>
94 </div>
95 <div class="sub">
96     <a title="Binary Release: Unix" href="binary-releases.html#unix">Unix</a>
97 </div>
98 <div class="sub">
99     <a title="Binary Release: MacOS X" href="binary-releases.html#macosx">Mac OS X</a>
100 </div>
101 <div class="sub">
102     <a title="Binary Release: iOS" href="binary-releases.html#iOS">iOS</a>
103 </div>
104 <div class="sub">
105     <a title="Binary Release: Windows" href="binary-releases.html#windows">Windows</a>
106 </div>
107 <div class="sep"></div>\r
108 <div class="menu">
109   <a title="Command-line Tools" href="command-line-tools.html">Command-line Tools</a>
110 </div>
111 <div class="sub">
112     <a title="Command-line Tools: Processing" href="command-line-processing.html">Processing</a>
113 </div>
114 <div class="sub">
115     <a title="Command-line Tools: Options" href="command-line-options.html">Options</a>
116 </div>
117 <div class="sub">
118     <a title="Command-line Tools: Usage" href="http://www.imagemagick.org/Usage/">Usage</a>
119 </div>
120 <div class="menu">
121   <a title="Program Interfaces" href="api.html">Program Interfaces</a>
122 </div>
123 <div class="sub">
124     <a title="Program Interface: MagickWand" href="magick-wand.html">MagickWand</a>
125 </div>
126 <div class="sub">
127     <a title="Program Interface: MagickCore" href="magick-core.html">MagickCore</a>
128 </div>
129 <div class="sub">
130     <a title="Program Interface: PerlMagick" href="perl-magick.html">PerlMagick</a>
131 </div>
132 <div class="sub">
133     <a title="Program Interface: Magick++" href="magick++.html">Magick++</a>
134 </div>
135 <div class="sep"></div>\r
136 <div  class="menu">
137    <a title="Install from Source" href="install-source.html">Install from Source</a>
138 </div>
139 <div class="sub">
140     <a title="Install from Source: Unix" href="install-source.html#unix">Unix</a>
141 </div>
142 <div class="sub">
143     <a title="Install from Source: Windows" href="install-source.html#windows">Windows</a>
144  </div>
145 <div class="menu">
146   <a title="Resources" href="resources.html">Resources</a>
147 </div>
148 <div class="menu">
149   <a title="Architecture" href="architecture.html">Architecture</a>
150 </div>
151 <div class="menu">
152   <a title="Download" href="download.html">Download</a>
153 </div>
154 <div class="sep"></div>\r
155 <div class="menu">
156   <a title="Search" href="search.html">Search</a>
157 </div>
158 <div class="sep"></div>\r
159 <div class="menu">
160   <a title="Site Map" href="sitemap.html">Site Map</a>
161 </div>
162 <div  class="sub">
163   <a title="Site Map: Links" href="links.html">Links</a>
164 </div>
165 <div class="sep"></div>\r
166 <div class="menu">
167   <a rel="follow" title="Sponsors" href="sponsors.html">Sponsors:</a>
168
169   <a href="http://www.networkredux.com"> <img src="../images/networkredux.png" width="140" height="31" alt="[sponsor]" style="margin-top: 4px; margin-left: 4px; border: 0px; float: left;" /></a>
170   <a href="http://www.dinodirect.com/ipads-tablets/"> <img src="../images/dino-direct.jpg" width="140" height="90" alt="[sponsor]" style="margin-top: 4px; margin-left: 4px; border: 0px; float: left;" /></a><!-- 201208010120 mickey@163... -->
171 <div class="sponsbox">
172 <div class="sponsor">
173   <a rel="follow" title="Sponsor: The Fastest &amp; Easiest Way to Find Images" href="http://www.graphicsfactory.com">The Fastest &amp; Easiest Way to Find Images</a><!-- 201210010270 graphicsfac... -->
174 </div>
175 <div class="sponsor">
176   <a rel="follow" title="Sponsor: VPS" href="http://www.interdominios.com/vps">VPS</a><!-- 201209010090 barsh@inter... -->
177 </div>
178 <div class="sponsor">
179   <a rel="follow" title="Werbebanner Werbeplane" href="http://www.allesbanner.de">Werbebanner Werbeplane</a><!-- 201212010450 info@druck... -->
180 </div>
181 <div class="sponsor">
182   <a rel="follow" title="Entertainment News &amp; Photos" href="http://www.zimbio.com">Entertainment News &amp; Photos</a><!-- 201211010540 bd@zimb... -->
183 </div>
184 <div class="sponsor">
185   <a rel="follow" title="Sponsor: LED24" href="http://led24.de/">LED24</a><!-- 201207010270 info@led24... -->
186 </div>
187 <div class="sponsor">
188   <a rel="follow" title="Sponsor: Best Website Hosting" href="http://www.top-cheap-web-hosting.com">Best Website Hosting</a><!-- 201304010090 eunge.liu-->
189 </div>
190 <div class="sponsor">
191   <a rel="follow" title="Android Tablet" href="http://www.dinodirect.com/ipads-tablets/">Android Tablet</a><!-- 201208010120 mickey@163... -->
192 </div>
193 <div class="sponsor">
194   <a rel="follow" title="Sponsor: Web Site Hosting" href="http://webhostinggeeks.com">Web Site Hosting</a><!-- 201302010900 funds@enmob... -->
195 </div>
196 <div class="sponsor">
197    <a rel="follow" title="Sponsor: Premium Quality Stock Photos" href="http://www.f1online.pro/en/">Premium Quality Stock Photos</a><!-- 2012080100540 ... -->
198 </div>
199 <div class="sponsor">
200    <a rel="follow" title="Sponsor: Druckerei" href="http://print24.com/de/">Druckerei</a><!-- 2012070100250 ... -->
201 </div>
202 <div class="sponsor">
203   <a rel="follow" title="Sponsor: Managed Server" href="http://www.robhost.de">Managed Server</a><!-- 201210010720 klikics... -->
204 </div>
205 <div class="sponsor">
206   <a rel="follow" title="Sponsor: Druckerei" href="http://www.allesdruck.de">Druckerei</a><!-- 201303011500 r.leo -->
207 </div>
208 <div class="sponsor">
209    <a rel="follow" title="Sponsor: Names List" href="http://www.listofnames.info">Names List</a><!-- 2012110100180 grimshrat@busyb-->
210 </div>
211 <div class="sponsor">
212    <a rel="follow" title="Sponsor: Web Hosting" href="http://www.hostucan.com">Web Hosting</a><!-- 2012120100150 racent marketing@webhosting...-->
213 </div>
214 </div>
215 </div>
216 </div>\r
217 \r
218 <div class="eastbar">\r
219   <div class="g-plusone" id="gplusone"></div>\r
220   <script type="text/javascript">\r
221     window.___gcfg = {\r
222       lang: 'en-US'\r
223     };\r
224 \r
225     (function() {\r
226       var po = document.createElement('script');\r
227       po.type = 'text/javascript'; po.async = true;\r
228       po.src = 'https://apis.google.com/js/plusone.js';\r
229       var script = document.getElementsByTagName('script')[0];\r
230       script.parentNode.insertBefore(po, script);\r
231     })();\r
232     var gplusone = document.getElementById("gplusone");\r
233     gplusone.setAttribute("data-size","medium");\r
234     gplusone.setAttribute("data-count","false");\r
235   </script>\r
236 </div>\r
237 \r
238 <div class="main">\r
239 \r
240 <h1>Magick++ C++ API</h1>
241 <p class="navigation-index">[<a href="magick++.html#intro">Introduction to Magick++</a> &bull; <a href="magick++.html#documentation">Documentation</a> &bull; <a href="magick++.html#get">Obtaining Magick++</a> &bull; <a href="magick++.html#install">Installation</a> &bull; <a href="magick++.html#bugs">Reporting Bugs</a>]</p>
242 <div class="doc-section">
243 <a id="intro"></a>
244 <p>Magick++ is the object-oriented C++ API to the <a href="http://www.imagemagick.org/">ImageMagick</a> image-processing library.</p>
245 <p>Magick++ supports an object model which is inspired by <a href="perl-magick.html">PerlMagick</a>.
246 Images support implicit reference counting so that copy constructors
247 and assignment incur almost no cost. The cost of actually copying an
248 image (if necessary) is done just before modification and this copy
249 is managed automagically by Magick++. De-referenced copies are
250 automagically deleted. The image objects support value (rather than
251 pointer) semantics so it is trivial to support multiple generations
252 of an image in memory at one time. 
253 </p>
254 <p>Magick++ provides integrated support for the <a href="http://www.sgi.com/tech/stl/">Standard
255 Template Library</a> (STL) so that the powerful containers available
256 (e.g. <a href="http://www.sgi.com/tech/stl/Deque.html">deque</a>,
257 <a href="http://www.sgi.com/tech/stl/Vector.html">vector</a>, <a href="http://www.sgi.com/tech/stl/List.html">list</a>,
258 and <a href="http://www.sgi.com/tech/stl/Map.html">map</a>)&nbsp; can
259 be used to write programs similar to those possible with PERL &amp;
260 PerlMagick. STL-compatible template versions of ImageMagick's
261 list-style operations are provided so that operations may be
262 performed on multiple images stored in STL containers. 
263 </p>
264 </div>
265 <h2>Documentation</h2>
266 <div class="doc-section">
267 <a id="documentation"></a>
268 <p>Detailed <a href="../www/Magick++/Documentation.html">documentation</a> is
269 provided for all Magick++ classes, class methods, and template
270 functions 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>
271 </div>
272 <h2>Obtaining Magick++</h2>
273 <a id="get"></a>
274 <div class="doc-section">
275 <p>Magick++ is included as part of <a href="../index.html">ImageMagick</a>
276 source releases and may be retrieved via <a href="download.html">ftp</a>
277 or <a href="subversion.html">Subversion</a>.
278 </p>
279 </div>
280 <h2>Installation</h2>
281 <div class="doc-section">
282 <a id="install"></a>
283 <p>Once you have the Magick++ sources available, follow these detailed
284 <a href="../www/Magick++/Install.html">installation instructions</a> for UNIX and
285 Windows. 
286 </p>
287 </div>
288 <h2>Usage</h2>
289 <div class="doc-section">
290 <p>A helper script named <kbd>Magick++-config</kbd> is installed
291 under Unix which assists with recalling compilation options required
292 to compile and link programs which use Magick++. For example, the
293 following command will compile and link the source file <kbd>demo.cpp</kbd>
294 to produce the executable <kbd>demo</kbd> (notice that quotes are
295 backward quotes): 
296 </p>
297 <pre class="text">
298 c++ `Magick++-config --cxxflags --cppflags` -O2 -o demo demo.cpp \
299   `Magick++-config --ldflags --libs`
300 </pre>
301 <p>Windows users may get started by manually editing a project file
302 for one of the Magick++ demo programs. 
303 </p>
304 <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>
305 <pre class="text">
306 int main( int argc, char ** argv) {
307   InitializeMagick(*argv);
308   ...
309 </pre>
310 <p>This initialization step is not required under Unix, Linux,
311 Cygwin, or any other operating environment that supports the notion
312 of <em>installing</em> ImageMagick in a known location. 
313 </p>
314 </div>
315 <h2>Reporting Bugs</h2>
316 <div class="doc-section">
317 <a id="bugs"></a>
318 <p>Questions regarding usage should be directed to or to report any bugs go to
319 <a href="http://www.imagemagick.org/discourse-server/viewforum.php?f=23">Magick++ bug tracking forum</a>.
320 </p>
321 </div>
322 \r
323 </div>\r
324 \r
325 <div id="linkbar">\r
326     <span id="linkbar-west">&nbsp;</span>\r
327     <span id="linkbar-center">\r
328       <a href="../discourse-server">Discourse Server</a> &bull;\r
329       <a href="http://www.imagemagick.org/MagickStudio/scripts/MagickStudio.cgi">Studio</a>\r
330     </span>\r
331     <span id="linkbar-east">&nbsp;</span>\r
332   </div>\r
333   <div class="footer">\r
334     <span id="footer-west">&copy; 1999-2012 ImageMagick Studio LLC</span>\r
335     <span id="footer-east"> <a href="contact.html">Contact the Wizards</a></span>\r
336   </div>\r
337   <div style="clear: both; margin: 0; width: 100%; "></div>\r
338   <script type="text/javascript">\r
339     var _gaq = _gaq || [];\r
340     _gaq.push(['_setAccount', 'UA-17690367-1']);\r
341     _gaq.push(['_trackPageview']);\r
342 \r
343     (function() {\r
344       var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;\r
345       ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';\r
346       var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);\r
347     })();\r
348   </script>\r
349 </body>\r
350 </html>\r