blob: dff5b9b2ad4ad106b4c8d9e1de9a1ff81a22f605 [file] [log] [blame]
cristyba1758d2011-06-03 01:29:12 +00001
2<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
3 "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
4<html version="-//W3C//DTD XHTML 1.1//EN"
5 xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"
6 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
7 xsi:schemaLocation="http://www.w3.org/1999/xhtml
8 http://www.w3.org/MarkUp/SCHEMA/xhtml11.xsd">
9<head>
10 <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
11 <meta name="verify-v1" content="g222frIIxcQTrvDR3NBRUSKP3AnMNoqxOkIniCEkV7U="/>
12 <title>ImageMagick: Porting to ImageMagick Version 7</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."/>
18 <meta name="Application-url" content="http://www.imagemagick.org"/>
19 <meta name="Generator" content="PHP"/>
20 <meta name="Keywords" content="porting, to, imagemagick, version, 7, ImageMagick, ImageMagic, MagickCore, MagickWand, PerlMagick, Magick++, RMagick, PythonMagick, JMagick, TclMagick, Image, Magick, Magic, Wand, ImageMagickObject, Swiss, Army, Knife, Image, Processing"/>
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-2011 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="meta" type="application/rdf+xml" title="ICI" href="http://imagemagick.org/ici.rdf"/>
32 <link rel="stylesheet" href="http://www.google.com/cse/style/look/default.css" type="text/css" />
33 <style type="text/css" media="all">
34 @import url("../www/magick.css");
35 </style>
36 <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>
37 <script type="text/javascript" src="../fancybox/jquery.fancybox-1.3.4.pack.js"></script>
38 <link rel="stylesheet" type="text/css" href="../fancybox/jquery.fancybox-1.3.4.css" media="screen" />
39 <script type="text/javascript">
40 $(document).ready(function() {
41 $("a[href$=.jpg],a[href$=.png],a[href$=.gif]").fancybox({
42 'transitionIn' : 'elastic',
43 'transitionOut' : 'elastic',
44 'overlayShow' : false,
45 'opacity' : true
46 });
47 });
48 </script>
49</head>
50
51<body id="www-imagemagick-org">
52<div class="titlebar">
53<div style="margin: 17px auto; float: left;">
54 <script type="text/javascript">
55 <!--
56 google_ad_client = "pub-3129977114552745";
57 google_ad_slot = "5439289906";
58 google_ad_width = 728;
59 google_ad_height = 90;
60 //-->
61 </script>
62 <script type="text/javascript"
63 src="http://pagead2.googlesyndication.com/pagead/show_ads.js">
64 </script>
65</div>
66<a href="http://www.imagemagick.org/discourse-server/">
67 <img src="../images/logo.jpg"
68 alt="ImageMagick Logo"
69 style="width: 123px; height: 118px; border: 0px; float: right;" /></a>
70<a href="../index.html">
71 <img src="../images/sprite.jpg"
72 alt="ImageMagick Sprite"
73 style="width: 114px; height: 118px; border: 0px; float: right;" /></a>
74</div>
75
76<div class="westbar">
77
78<div class="menu">
79 <a title="About ImageMagick" href="../index.html">About ImageMagick</a>
80</div>
81<div class="sep"></div>
82<div class="menu">
83 <a title="Binary Releases" href="../www/binary-releases.html">Binary Releases</a>
84</div>
85<div class="sub">
86 <a title="Binary Release: Unix" href="../www/binary-releases.html#unix">Unix</a>
87</div>
88<div class="sub">
89 <a title="Binary Release: MacOS X" href="../www/binary-releases.html#macosx">Mac OS X</a>
90</div>
91<div class="sub">
92 <a title="Binary Release: iPhone" href="../www/binary-releases.html#iPhone">iPhone</a>
93</div>
94<div class="sub">
95 <a title="Binary Release: Windows" href="../www/binary-releases.html#windows">Windows</a>
96</div>
97<div class="sep"></div>
98<div class="menu">
99 <a title="Command-line Tools" href="../www/command-line-tools.html">Command-line Tools</a>
100</div>
101<div class="sub">
102 <a title="Command-line Tools: Processing" href="../www/command-line-processing.html">Processing</a>
103</div>
104<div class="sub">
105 <a title="Command-line Tools: Options" href="../www/command-line-options.html">Options</a>
106</div>
107<div class="sub">
108 <a title="Command-line Tools: Usage" href="http://www.imagemagick.org/Usage/">Usage</a>
109</div>
110<div class="menu">
111 <a title="Program Interfaces" href="../www/api.html">Program Interfaces</a>
112</div>
113<div class="sub">
114 <a title="Program Interface: MagickWand" href="../www/magick-wand.html">MagickWand</a>
115</div>
116<div class="sub">
117 <a title="Program Interface: MagickCore" href="../www/magick-core.html">MagickCore</a>
118</div>
119<div class="sub">
120 <a title="Program Interface: PerlMagick" href="../www/perl-magick.html">PerlMagick</a>
121</div>
122<div class="sub">
123 <a title="Program Interface: Magick++" href="../www/magick++.html">Magick++</a>
124</div>
125<div class="sep"></div>
126<div class="menu">
127 <a title="Install from Source" href="../www/install-source.html">Install from Source</a>
128</div>
129<div class="sub">
130 <a title="Install from Source: Unix" href="../www/install-source.html#unix">Unix</a>
131</div>
132<div class="sub">
133 <a title="Install from Source: Windows" href="../www/install-source.html#windows">Windows</a>
134 </div>
135<div class="menu">
136 <a title="Resources" href="../www/resources.html">Resources</a>
137</div>
138<div class="menu">
139 <a title="Architecture" href="../www/architecture.html">Architecture</a>
140</div>
141<div class="menu">
142 <a title="Download" href="../www/download.html">Download</a>
143</div>
144<div class="sep"></div>
145<div class="menu">
146 <a title="Search" href="../www/search.html">Search</a>
147</div>
148<div class="sep"></div>
149<div class="menu">
150 <a title="Site Map" href="../www/sitemap.html">Site Map</a>
151</div>
152<div class="sub">
153 <a title="Site Map: Links" href="../www/links.html">Links</a>
154</div>
155<div class="sep"></div>
156<div class="menu">
157 <a rel="follow" title="Sponsors" href="../www/sponsors.html">Sponsors:</a>
158
159<a href="http://www.networkredux.com">
160 <img src="../images/networkredux.png" alt="[sponsor]"
161 style="margin-top: 4px; margin-left: 4px; border: 0px; float: left;" /></a>
162<div class="sponsbox">
163<div class="sponsor">
164 <a rel="follow" title="Sponsor: Web Hosting Deals" href="http://www.webhostingdeals.org">Web Hosting Deals</a><!-- 201111010270 chee.hoa darin -->
165</div>
166<div class="sponsor">
167 <a rel="follow" title="Sponsor: Web Hosting Reviews" href="http://www.webhostingsecretrevealed.com">Web Hosting Secret Revealed</a><!-- 201204010540 iamchee jerry -->
168</div>
169<div class="sponsor">
170 <a rel="follow" title="Sponsor: Druckerei" href="http://print24.com/de/">Druckerei</a><!-- 201110010720 -->
171</div>
172<div class="sponsor">
173 <a rel="follow" title="Sponsor: Web Hosting Break" href="http://www.webhostingbreak.com">Web Hosting Break</a><!-- 201109010090 ian@ian-m... -->
174</div>
175<div class="sponsor">
176 <a rel="follow" title="Sponsor: Druckerei" href="http://www.allesdruck.de">Druckerei</a><!-- 201303011500 r.leo -->
177</div>
178<div class="sponsor">
179 <a rel="follow" title="Sponsor: Website Hosting" href="http://www.hostreviewgeeks.com">Website Hosting</a><!-- 201110010090 alexanian media -->
180</div>
181<div class="sponsor">
182 <a rel="follow" title="Sponsor: Hotel München" href="http://www.messehotel-erb-muenchen.de">Hotel München</a><!-- 201111010450 cerb -->
183</div>
184<div class="sponsor">
185 <a rel="follow" title="Sponsor: Best Web Hosting" href="http://webhostinggeeks.com">Best Web Hosting</a><!-- 201110010720 -->
186</div>
187<div class="sponsor">
188 <a rel="follow" title="Sponsor: Flyer drucken" href="http://www.online-druck.biz">Flyer drucken</a><!-- 201109010900 Floeter-->
189</div>
190<div class="sponsor">
191 <a rel="follow" title="Sponsor: Web Hosting Reviews" href="http://www.webhostingmasters.com">Web Hosting Reviews</a><!-- 201107011500 affliatelabel -->
192</div>
193<div class="sponsor">
194 <a rel="follow" title="Sponsor: Web Hosting Ratings" href="http://webhostingrating.com">Web Hosting Ratings</a><!-- 201110010720 -->
195</div>
196<div class="sponsor">
197 <a rel="follow" title="Sponsor: Fototapete" href=" http://www.allesdruck.de/Fototapete-Tapetendruck,category,8830.html">Fototapete</a><!-- 20110701000080 a-o.de -->
198</div>
199</div>
200</div>
201</div>
202
203<div class="eastbar">
204
205</div>
206
207<div class="main">
208
209<p class="navigation-index">[<a href="#headers">Header Files</a> &bull; <a href="#channels">Pixel Channels</a> &bull; <a href="#alpha">Alpha</a> &bull; <a href="#depecate">Deprecated Features Removed</a> &bull; <a href="#summary">Version 7 Change Summary</a> ]</p>
210
211<h1>ImageMagick Version 7 Porting Guide</h1>
212
213<p>ImageMagick was originally designed to display RGB images to an X Windows server. Over time we extended support to RGBA images and then to the CMYK and CMYKA image format. With ImageMagick version 7, we extend support to arbitrary colorspaces with an arbitrary number of pixel channels.
214
215<h2><a id="headers"></a>Header Files</h2>
216<div class="doc-section">
217<p>Prior versions of ImageMagick (4-6) references the ImageMagick header files as <kbd>magick/</kbd> and <kbd>wand/</kbd>. ImageMagick 7 instead uses <kbd>MagickCore/</kbd> and <kbd>MagickWand/</kbd> respectively. For example,</p>
218<pre class="code">
219#include &lt;MagickCore/MagickCore.h>
220#include &lt;MagickWand/MagickWand.h>
221</pre>
222</div>
223
224<h2><a id="channels"></a>Pixel Channels</h2>
225<div class="doc-section">
226<p>Prior versions of ImageMagick (4-6), supports 4 to 5 pixel channels (RGBA or CMYKA). The first 4 channels are accessed with the PixelPacket data structure. The structure includes 4 members of type Quantum (typically 16-bits) of red, green, blue, and opacity. The black channel or colormap indexes are supported by a separate method and structure, IndexPacket. As an example, here is a code snippet from ImageMagick version 6 that negates image pixels:</p>
227
228<pre class="code">
229 for (y=0; y &lt; (ssize_t) image->rows; y++)
230 {
231 register IndexPacket
232 *indexes;
233
234 register PixelPacket
235 *q;
236
237 q=GetCacheViewAuthenticPixels(image_view,0,y,image->columns,1,exception);
238 if (q == (PixelPacket *) NULL)
239 {
240 status=MagickFalse;
241 continue;
242 }
243 indexes=GetCacheViewAuthenticIndexQueue(image_view);
244 for (x=0; x &lt; (ssize_t) image->columns; x++)
245 {
246 if ((channels & RedChannel) != 0)
247 q->red=(Quantum) QuantumRange-q->red;
248 if ((channels & GreenChannel) != 0)
249 q->green=(Quantum) QuantumRange-q->green;
250 if ((channels & BlueChannel) != 0)
251 q->blue=(Quantum) QuantumRange-q->blue;
252 if ((channels & OpacityChannel) != 0)
253 q->opacity=(Quantum) QuantumRange-q->opacity;
254 if (((channels & IndexChannel) != 0) &&
255 (image->colorspace == CMYKColorspace))
256 indexes[x]=(IndexPacket) QuantumRange-indexes[x];
257 q++;
258 }
259 if (SyncCacheViewAuthenticPixels(image_view,exception) == MagickFalse)
260 status=MagickFalse;
261 }
262</pre>
263
264<p>ImageMagick version 7 supports any number of channels from 1 to 100 (and beyond) and simplifies access with a single method that returns an array of channels of type Quantum. Source code that compiles against prior versions of ImageMagick will require refactoring to work with ImageMagick version 7. We illustrate with an example. Let's refactor the version 6 code snippet from above so it works with the ImageMagick version 7 API:</p>
265
266<pre class="code">
267 for (y=0; y &lt; (ssize_t) image->rows; y++)
268 {
269 register Quantum
270 *q;
271
272 q=GetCacheViewAuthenticPixels(image_view,0,y,image->columns,1,exception);
273 if (q == (Quantum *) NULL)
274 {
275 status=MagickFalse;
276 continue;
277 }
278 for (x=0; x &lt; (ssize_t) image->columns; x++)
279 for (channel=0; channel &lt; GetCacheViewChannels(image_view); channel++)
280 {
281 if ((channels & (1 &lt;&lt; channel)) != 0)
282 *q=(Quantum) QuantumRange-(*q);
283 q++;
284 }
285 if (SyncCacheViewAuthenticPixels(image_view,exception) == MagickFalse)
286 status=MagickFalse;
287 }
288</pre>
289
290<p>In addition to supporting any number of channels, version 7 simplifies working with channels and provides opportunity for compiler optimiziations that were previously not possible. Our benchmarking shows version 7 has increased performance for virtually all image operations.</p>
291</div>
292
293<h2><a id="alpha"></a>Alpha</h2>
294<div class="doc-section">
295<p>We support alpha now, previously opacity. With alpha, a value of 0 means that the pixel does not have any coverage information and is transparent; i.e. there was no color contribution from any geometry because the geometry did not overlap this pixel. A value of QuantumRange means that the pixel is opaque because the geometry completely overlapped the pixel.</p>
296<p>In version 7, the PixelPacket structure member alpha has replaced the previous opacity member.</p>
297</div>
298
299<h2><a id="deprecate"></a>Deprecated Features Removed</h2>
300<div class="doc-section">
301<p>All deprecated features from ImageMagick version 1-6 are removed in version 7. These include the <kbd>Magick-config<kbd> and <kbd>Wand-config<kbd> configuration utilities. Instead use:</p>
302
303<pre class="code">
304 MagickCore-config
305 MagickWand-config
306</pre>
307
308<p>In addition, all deprecated <a href="http://magick.imagemagick.org/api/deprecate.html">MagickCore</a> and <a href="http://magick.imagemagick.org/api/magick-deprecate.html">MagickWand</a> methods are no longer available in version 7.</p>
309</div>
310<h2><a id="summary"></a>Version 7 Change Summary</h2>
311<div class="doc-section">
312<p>Changes from ImageMagick version 1-6 to version 7 are summarized here:</p>
313<h5>Pixels</h5>
314<dl>
315<li>Pixels are no longer addressed with PixelPacket structure members (e.g. red, green, blue, opacity) but as an array of channels (e.g. p[RedPixelComponent]).</li>
316<li>Use convenience macros to access pixel components (e.g. GetRedPixelComponent(p), SetRedPixelComponent(q,red)).</li>
317<li>The black channel for the CMYK colorspace is no longer stored in the index channel, previously accessed with GetAuthenticIndexQueue() and GetCacheViewAuthenticIndexQueue((). Instead its now a pixel channel and accessed with the convenience pixel macros GetBlackPixelComponent(p) and SetBlackPixelComponent(q).</li>
318<li>Use the index channel to address colormapped indexes. It no longer hosts the black channel for CMYK and CMYKA images.</li>
319</dl>
320<h5>Alpha</h5>
321<dl>
322<li>We support alpha rather than opacity (0 transparent; QuantumRange opaque).</li>
323<li>The PixelPacket structure member alpha has replaced the previous opacity member.</li>
324</dl>
325<h5>Deprecated Methods</h5>
326<dl>
327<li>All MagickCore and MagickWand deprecated methods are removed and no longer available in ImageMagick version 7.</li>
328</dl>
329</div>
330
331</div>
332
333<div id="linkbar">
334 <span id="linkbar-west">&nbsp;</span>
335 <span id="linkbar-center">
336 <a href="http://www.imagemagick.org/discourse-server/">Discourse Server</a> &bull;
337 <a href="http://www.imagemagick.org/MagickStudio/scripts/MagickStudio.cgi">Studio</a>
338 </span>
339 <span id="linkbar-east">&nbsp;</span>
340 </div>
341 <div class="footer">
342 <span id="footer-west">&copy; 1999-2011 ImageMagick Studio LLC</span>
343 <span id="footer-east"> <a href="http://www.imagemagick.org/script/contact.php">Contact the Wizards</a></span>
344 </div>
345 <div style="clear: both; margin: 0; width: 100%; "></div>
346 <script type="text/javascript">
347 var _gaq = _gaq || [];
348 _gaq.push(['_setAccount', 'UA-17690367-1']);
349 _gaq.push(['_trackPageview']);
350
351 (function() {
352 var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
353 ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
354 var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
355 })();
356 </script>
357</body>
358</html>