]> granicus.if.org Git - imagemagick/blob - www/api/effect.html
(no commit message)
[imagemagick] / www / api / effect.html
1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" \r
2   "http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">\r
3 <html version="-//W3C//DTD XHTML 1.1//EN"\r
4       xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"\r
5       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"\r
6       xsi:schemaLocation="http://www.w3.org/1999/xhtml\r
7                           http://www.w3.org/MarkUp/SCHEMA/xhtml11.xsd">\r
8 <head>\r
9   <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>\r
10   <meta name="verify-v1" content="g222frIIxcQTrvDR3NBRUSKP3AnMNoqxOkIniCEkV7U="/>\r
11   <title>ImageMagick: MagickCore, C API for ImageMagick: Add an Effect</title>
12   <meta http-equiv="Content-Language" content="en-US"/>
13   <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
14   <meta http-equiv="Reply-to" content="magick-users@imagemagick.org"/>
15   <meta name="Application-name" content="ImageMagick"/>
16   <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."/>
17   <meta name="Application-url" content="http://www.imagemagick.org"/>
18   <meta name="Generator" content="PHP"/>
19   <meta name="Keywords" content="magickcore, c, api, for, imagemagick:, add, an, effect, ImageMagick, ImageMagic, MagickCore, MagickWand, PerlMagick, Magick++, RMagick, PythonMagick, JMagick, TclMagick, Image, Magick, Magic, Wand, ImageMagickObject, Swiss, Army, Knife, Image, Processing"/>
20   <meta name="Rating" content="GENERAL"/>
21   <meta name="Robots" content="INDEX, FOLLOW"/>
22   <meta name="Generator" content="ImageMagick Studio LLC"/>
23   <meta name="Author" content="ImageMagick Studio LLC"/>
24   <meta name="Revisit-after" content="2 DAYS"/>
25   <meta name="Resource-type" content="document"/>
26   <meta name="Copyright" content="Copyright (c) 1999-2011 ImageMagick Studio LLC"/>
27   <meta name="Distribution" content="Global"/>
28   <link rel="icon" href="../../images/wand.png"/>
29   <link rel="shortcut icon" href="../../images/wand.ico"  type="images/x-icon"/>
30   <link rel="meta" type="application/rdf+xml" title="ICI" href="http://imagemagick.org/ici.rdf"/>\r
31   <link rel="stylesheet" href="http://www.google.com/cse/style/look/default.css" type="text/css" />\r
32   <style type="text/css" media="all">\r
33     @import url("../../www/magick.css");\r
34   </style>\r
35   <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>\r
36   <script type="text/javascript" src="../fancybox/jquery.fancybox-1.3.4.pack.js"></script>\r
37   <link rel="stylesheet" type="text/css" href="../fancybox/jquery.fancybox-1.3.4.css" media="screen" />\r
38   <script type="text/javascript">\r
39     $(document).ready(function() {\r
40       $("a[href$=.jpg],a[href$=.png],a[href$=.gif]").fancybox({\r
41         'transitionIn'  : 'elastic',\r
42         'transitionOut' : 'elastic',\r
43         'overlayShow'   : false,\r
44         'opacity'       : true\r
45       });\r
46     });\r
47   </script>\r
48 </head>\r
49 \r
50 <body id="www-imagemagick-org">\r
51 <div class="titlebar">\r
52 <div style="margin: 17px auto; float: left;">\r
53   <script type="text/javascript">\r
54   <!--\r
55     google_ad_client = "pub-3129977114552745";\r
56     google_ad_slot = "5439289906";\r
57     google_ad_width = 728;\r
58     google_ad_height = 90;\r
59   //-->\r
60   </script>\r
61   <script type="text/javascript"\r
62     src="http://pagead2.googlesyndication.com/pagead/show_ads.js">\r
63   </script>\r
64 </div>\r
65 <a href="http://www.imagemagick.org/discourse-server/">\r
66   <img src="../../images/logo.jpg"\r
67   alt="ImageMagick Logo"\r
68   style="width: 123px; height: 118px; border: 0px; float: right;" /></a>\r
69 <a href="../../index.html">\r
70   <img src="../../images/sprite.jpg"\r
71   alt="ImageMagick Sprite"\r
72   style="width: 114px; height: 118px; border: 0px; float: right;" /></a>\r
73 </div>\r
74 \r
75 <div class="westbar">\r
76 \r
77 <div class="menu">
78   <a title="About ImageMagick" href="../../index.html">About ImageMagick</a>
79 </div>
80 <div class="sep"></div>\r
81 <div class="menu">
82   <a title="Binary Releases" href="../../www/binary-releases.html">Binary Releases</a>
83 </div>
84 <div class="sub">
85     <a title="Binary Release: Unix" href="../../www/binary-releases.html#unix">Unix</a>
86 </div>
87 <div class="sub">
88     <a title="Binary Release: MacOS X" href="../../www/binary-releases.html#macosx">Mac OS X</a>
89 </div>
90 <div class="sub">
91     <a title="Binary Release: iPhone" href="../../www/binary-releases.html#iPhone">iPhone</a>
92 </div>
93 <div class="sub">
94     <a title="Binary Release: Windows" href="../../www/binary-releases.html#windows">Windows</a>
95 </div>
96 <div class="sep"></div>\r
97 <div class="menu">
98   <a title="Command-line Tools" href="../../www/command-line-tools.html">Command-line Tools</a>
99 </div>
100 <div class="sub">
101     <a title="Command-line Tools: Processing" href="../../www/command-line-processing.html">Processing</a>
102 </div>
103 <div class="sub">
104     <a title="Command-line Tools: Options" href="../../www/command-line-options.html">Options</a>
105 </div>
106 <div class="sub">
107     <a title="Command-line Tools: Usage" href="http://www.imagemagick.org/Usage/">Usage</a>
108 </div>
109 <div class="menu">
110   <a title="Program Interfaces" href="../../www/api.html">Program Interfaces</a>
111 </div>
112 <div class="sub">
113     <a title="Program Interface: MagickWand" href="../../www/magick-wand.html">MagickWand</a>
114 </div>
115 <div class="sub">
116     <a title="Program Interface: MagickCore" href="../../www/magick-core.html">MagickCore</a>
117 </div>
118 <div class="sub">
119     <a title="Program Interface: PerlMagick" href="../../www/perl-magick.html">PerlMagick</a>
120 </div>
121 <div class="sub">
122     <a title="Program Interface: Magick++" href="../../www/magick++.html">Magick++</a>
123 </div>
124 <div class="sep"></div>\r
125 <div  class="menu">
126    <a title="Install from Source" href="../../www/install-source.html">Install from Source</a>
127 </div>
128 <div class="sub">
129     <a title="Install from Source: Unix" href="../../www/install-source.html#unix">Unix</a>
130 </div>
131 <div class="sub">
132     <a title="Install from Source: Windows" href="../../www/install-source.html#windows">Windows</a>
133  </div>
134 <div class="menu">
135   <a title="Resources" href="../../www/resources.html">Resources</a>
136 </div>
137 <div class="menu">
138   <a title="Architecture" href="../../www/architecture.html">Architecture</a>
139 </div>
140 <div class="menu">
141   <a title="Download" href="../../www/download.html">Download</a>
142 </div>
143 <div class="sep"></div>\r
144 <div class="menu">
145   <a title="Search" href="../../www/search.html">Search</a>
146 </div>
147 <div class="sep"></div>\r
148 <div class="menu">
149   <a title="Site Map" href="../../www/sitemap.html">Site Map</a>
150 </div>
151 <div  class="sub">
152   <a title="Site Map: Links" href="../../www/links.html">Links</a>
153 </div>
154 <div class="sep"></div>\r
155 <div  class="menu">
156   <a title="Sponsors" href="../../www/sponsors.html">Sponsors:</a>
157
158 <a href="http://www.networkredux.com">
159   <img src="../../images/networkredux.png" alt="[sponsor]"
160   style="margin-top: 4px; margin-left: 4px; border: 0px; float: left;" /></a>
161 <div class="sponsbox">
162 <div  class="sponsor">
163   <a title="Sponsor: Druckerei" href="http://www.allesdruck.de">Druckerei</a><!-- 201303011500 r.leo -->
164 </div>
165 <div  class="sponsor">
166   <a title="Sponsor: Hotel München" href="http://www.messehotel-erb-muenchen.de">Hotel München</a><!-- 201111010450 cerb -->
167 </div>
168 <div  class="sponsor">
169   <a title="Sponsor: Website Hosting" href="http://www.hostreviewgeeks.com">Website Hosting</a><!-- 201106010090 alexanian media -->
170 </div>
171 <div  class="sponsor">
172   <a title="Sponsor: Best Web Hosting" href="http://webhostinggeeks.com">Best Web Hosting</a><!-- 201110010720 -->
173 </div>
174 <div  class="sponsor">
175   <a title="Sponsor: Web Hosting Ratings" href="http://webhostingrating.com">Web Hosting Ratings</a><!-- 201110010720 -->
176 </div>
177 <div  class="sponsor">
178   <a title="Sponsor: Flyer drucken" href="http://www.online-druck.biz">Flyer drucken</a><!-- 201109010900 Floeter-->
179 </div>
180 <div class="sponsor">
181   <a title="Sponsor: Web Hosting" href="http://www.bodhost.com/hosting.shtml">Web Hosting</a><!-- 201104010090 -->
182 </div>
183 <div  class="sponsor">
184   <a title="Sponsor: Druckerei" href="http://print24.com/de/">Druckerei</a><!-- 201110010720 -->
185 </div>
186 <div  class="sponsor">
187    <a title="Sponsor: Webdesign" href="http://www.renehornig.com/">Webdesign</a><!-- 20111001000240 -->
188 </div>
189 </div>
190 </div>
191 </div>\r
192 \r
193 <div class="eastbar">\r
194 \r
195 </div>\r
196 \r
197 <div class="main">\r
198 \r
199 <h1>Module effect Methods</h1>
200 <p class="navigation-index">[<a href="#AdaptiveBlurImage">AdaptiveBlurImage</a> &bull; <a href="#AdaptiveSharpenImage">AdaptiveSharpenImage</a> &bull; <a href="#BlurImage">BlurImage</a> &bull; <a href="#ConvolveImage">ConvolveImage</a> &bull; <a href="#DespeckleImage">DespeckleImage</a> &bull; <a href="#EdgeImage">EdgeImage</a> &bull; <a href="#EmbossImage">EmbossImage</a> &bull; <a href="#FilterImage">FilterImage</a> &bull; <a href="#GaussianBlurImage">GaussianBlurImage</a> &bull; <a href="#MotionBlurImage">MotionBlurImage</a> &bull; <a href="#PreviewImage">PreviewImage</a> &bull; <a href="#RadialBlurImage">RadialBlurImage</a> &bull; <a href="#SelectiveBlurImage">SelectiveBlurImage</a> &bull; <a href="#ShadeImage">ShadeImage</a> &bull; <a href="#SharpenImage">SharpenImage</a> &bull; <a href="#SpreadImage">SpreadImage</a> &bull; <a href="#StatisticImage">StatisticImage</a> &bull; <a href="#UnsharpMaskImage">UnsharpMaskImage</a>]</p>
201
202 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="AdaptiveBlurImage">AdaptiveBlurImage</a></h2>
203 <div class="doc-section">
204
205 <p>AdaptiveBlurImage() adaptively blurs the image by blurring less intensely near image edges and more intensely far from edges.  We blur the image with a Gaussian operator of the given radius and standard deviation (sigma).  For reasonable results, radius should be larger than sigma.  Use a radius of 0 and AdaptiveBlurImage() selects a suitable radius for you.</p>
206
207 <p>The format of the AdaptiveBlurImage method is:</p>
208
209 <pre class="code">
210   Image *AdaptiveBlurImage(const Image *image,const double radius,
211     const double sigma,ExceptionInfo *exception)
212   Image *AdaptiveBlurImageChannel(const Image *image,
213     const ChannelType channel,double radius,const double sigma,
214     ExceptionInfo *exception)
215 </pre>
216
217 <p>A description of each parameter follows:</p>
218
219 <h5>image</h5>
220 <p>the image.</p>
221
222 <h5>channel</h5>
223 <p>the channel type.</p>
224
225 <h5>radius</h5>
226 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
227
228 <h5>sigma</h5>
229 <p>the standard deviation of the Laplacian, in pixels.</p>
230
231 <h5>exception</h5>
232 <p>return any errors or warnings in this structure.</p>
233
234  </div>
235 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="AdaptiveSharpenImage">AdaptiveSharpenImage</a></h2>
236 <div class="doc-section">
237
238 <p>AdaptiveSharpenImage() adaptively sharpens the image by sharpening more intensely near image edges and less intensely far from edges. We sharpen the image with a Gaussian operator of the given radius and standard deviation (sigma).  For reasonable results, radius should be larger than sigma.  Use a radius of 0 and AdaptiveSharpenImage() selects a suitable radius for you.</p>
239
240 <p>The format of the AdaptiveSharpenImage method is:</p>
241
242 <pre class="code">
243   Image *AdaptiveSharpenImage(const Image *image,const double radius,
244     const double sigma,ExceptionInfo *exception)
245   Image *AdaptiveSharpenImageChannel(const Image *image,
246     const ChannelType channel,double radius,const double sigma,
247     ExceptionInfo *exception)
248 </pre>
249
250 <p>A description of each parameter follows:</p>
251
252 <h5>image</h5>
253 <p>the image.</p>
254
255 <h5>channel</h5>
256 <p>the channel type.</p>
257
258 <h5>radius</h5>
259 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
260
261 <h5>sigma</h5>
262 <p>the standard deviation of the Laplacian, in pixels.</p>
263
264 <h5>exception</h5>
265 <p>return any errors or warnings in this structure.</p>
266
267  </div>
268 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="BlurImage">BlurImage</a></h2>
269 <div class="doc-section">
270
271 <p>BlurImage() blurs an image.  We convolve the image with a Gaussian operator of the given radius and standard deviation (sigma).  For reasonable results, the radius should be larger than sigma.  Use a radius of 0 and BlurImage() selects a suitable radius for you.</p>
272
273 <p>BlurImage() differs from GaussianBlurImage() in that it uses a separable kernel which is faster but mathematically equivalent to the non-separable kernel.</p>
274
275 <p>The format of the BlurImage method is:</p>
276
277 <pre class="code">
278   Image *BlurImage(const Image *image,const double radius,
279     const double sigma,ExceptionInfo *exception)
280   Image *BlurImageChannel(const Image *image,const ChannelType channel,
281     const double radius,const double sigma,ExceptionInfo *exception)
282 </pre>
283
284 <p>A description of each parameter follows:</p>
285
286 <h5>image</h5>
287 <p>the image.</p>
288
289 <h5>channel</h5>
290 <p>the channel type.</p>
291
292 <h5>radius</h5>
293 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
294
295 <h5>sigma</h5>
296 <p>the standard deviation of the Gaussian, in pixels.</p>
297
298 <h5>exception</h5>
299 <p>return any errors or warnings in this structure.</p>
300
301  </div>
302 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="ConvolveImage">ConvolveImage</a></h2>
303 <div class="doc-section">
304
305 <p>ConvolveImage() applies a custom convolution kernel to the image.</p>
306
307 <p>The format of the ConvolveImage method is:</p>
308
309 <pre class="code">
310   Image *ConvolveImage(const Image *image,const size_t order,
311     const double *kernel,ExceptionInfo *exception)
312   Image *ConvolveImageChannel(const Image *image,const ChannelType channel,
313     const size_t order,const double *kernel,ExceptionInfo *exception)
314 </pre>
315
316 <p>A description of each parameter follows:</p>
317
318 <h5>image</h5>
319 <p>the image.</p>
320
321 <h5>channel</h5>
322 <p>the channel type.</p>
323
324 <h5>order</h5>
325 <p>the number of columns and rows in the filter kernel.</p>
326
327 <h5>kernel</h5>
328 <p>An array of double representing the convolution kernel.</p>
329
330 <h5>exception</h5>
331 <p>return any errors or warnings in this structure.</p>
332
333  </div>
334 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="DespeckleImage">DespeckleImage</a></h2>
335 <div class="doc-section">
336
337 <p>DespeckleImage() reduces the speckle noise in an image while perserving the edges of the original image.</p>
338
339 <p>The format of the DespeckleImage method is:</p>
340
341 <pre class="code">
342   Image *DespeckleImage(const Image *image,ExceptionInfo *exception)
343 </pre>
344
345 <p>A description of each parameter follows:</p>
346
347 <h5>image</h5>
348 <p>the image.</p>
349
350 <h5>exception</h5>
351 <p>return any errors or warnings in this structure.</p>
352
353  </div>
354 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="EdgeImage">EdgeImage</a></h2>
355 <div class="doc-section">
356
357 <p>EdgeImage() finds edges in an image.  Radius defines the radius of the convolution filter.  Use a radius of 0 and EdgeImage() selects a suitable radius for you.</p>
358
359 <p>The format of the EdgeImage method is:</p>
360
361 <pre class="code">
362   Image *EdgeImage(const Image *image,const double radius,
363     ExceptionInfo *exception)
364 </pre>
365
366 <p>A description of each parameter follows:</p>
367
368 <h5>image</h5>
369 <p>the image.</p>
370
371 <h5>radius</h5>
372 <p>the radius of the pixel neighborhood.</p>
373
374 <h5>exception</h5>
375 <p>return any errors or warnings in this structure.</p>
376
377  </div>
378 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="EmbossImage">EmbossImage</a></h2>
379 <div class="doc-section">
380
381 <p>EmbossImage() returns a grayscale image with a three-dimensional effect. We convolve the image with a Gaussian operator of the given radius and standard deviation (sigma).  For reasonable results, radius should be larger than sigma.  Use a radius of 0 and Emboss() selects a suitable radius for you.</p>
382
383 <p>The format of the EmbossImage method is:</p>
384
385 <pre class="code">
386   Image *EmbossImage(const Image *image,const double radius,
387     const double sigma,ExceptionInfo *exception)
388 </pre>
389
390 <p>A description of each parameter follows:</p>
391
392 <h5>image</h5>
393 <p>the image.</p>
394
395 <h5>radius</h5>
396 <p>the radius of the pixel neighborhood.</p>
397
398 <h5>sigma</h5>
399 <p>the standard deviation of the Gaussian, in pixels.</p>
400
401 <h5>exception</h5>
402 <p>return any errors or warnings in this structure.</p>
403
404  </div>
405 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="FilterImage">FilterImage</a></h2>
406 <div class="doc-section">
407
408 <p>FilterImage() applies a custom convolution kernel to the image.</p>
409
410 <p>The format of the FilterImage method is:</p>
411
412 <pre class="code">
413   Image *FilterImage(const Image *image,const KernelInfo *kernel,
414     ExceptionInfo *exception)
415   Image *FilterImageChannel(const Image *image,const ChannelType channel,
416     const KernelInfo *kernel,ExceptionInfo *exception)
417 </pre>
418
419 <p>A description of each parameter follows:</p>
420
421 <h5>image</h5>
422 <p>the image.</p>
423
424 <h5>channel</h5>
425 <p>the channel type.</p>
426
427 <h5>kernel</h5>
428 <p>the filtering kernel.</p>
429
430 <h5>exception</h5>
431 <p>return any errors or warnings in this structure.</p>
432
433  </div>
434 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="GaussianBlurImage">GaussianBlurImage</a></h2>
435 <div class="doc-section">
436
437 <p>GaussianBlurImage() blurs an image.  We convolve the image with a Gaussian operator of the given radius and standard deviation (sigma). For reasonable results, the radius should be larger than sigma.  Use a radius of 0 and GaussianBlurImage() selects a suitable radius for you</p>
438
439 <p>The format of the GaussianBlurImage method is:</p>
440
441 <pre class="code">
442   Image *GaussianBlurImage(const Image *image,onst double radius,
443     const double sigma,ExceptionInfo *exception)
444   Image *GaussianBlurImageChannel(const Image *image,
445     const ChannelType channel,const double radius,const double sigma,
446     ExceptionInfo *exception)
447 </pre>
448
449 <p>A description of each parameter follows:</p>
450
451 <h5>image</h5>
452 <p>the image.</p>
453
454 <h5>channel</h5>
455 <p>the channel type.</p>
456
457 <h5>radius</h5>
458 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
459
460 <h5>sigma</h5>
461 <p>the standard deviation of the Gaussian, in pixels.</p>
462
463 <h5>exception</h5>
464 <p>return any errors or warnings in this structure.</p>
465
466  </div>
467 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="MotionBlurImage">MotionBlurImage</a></h2>
468 <div class="doc-section">
469
470 <p>MotionBlurImage() simulates motion blur.  We convolve the image with a Gaussian operator of the given radius and standard deviation (sigma). For reasonable results, radius should be larger than sigma.  Use a radius of 0 and MotionBlurImage() selects a suitable radius for you. Angle gives the angle of the blurring motion.</p>
471
472 <p>Andrew Protano contributed this effect.</p>
473
474 <p>The format of the MotionBlurImage method is:</p>
475
476 <pre class="code">
477       Image *MotionBlurImage(const Image *image,const double radius,
478   const double sigma,const double angle,ExceptionInfo *exception)
479       Image *MotionBlurImageChannel(const Image *image,const ChannelType channel,
480   const double radius,const double sigma,const double angle,
481   ExceptionInfo *exception)
482 </pre>
483
484 <p>A description of each parameter follows:</p>
485
486 <h5>image</h5>
487 <p>the image.</p>
488
489 <h5>channel</h5>
490 <p>the channel type.</p>
491
492 <h5>radius</h5>
493 <p>the radius of the Gaussian, in pixels, not counting the center</p>
494 <h5>radius</h5>
495 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
496
497 <h5>sigma</h5>
498 <p>the standard deviation of the Gaussian, in pixels.</p>
499
500 <h5>angle</h5>
501 <p>Apply the effect along this angle.</p>
502
503 <h5>exception</h5>
504 <p>return any errors or warnings in this structure.</p>
505
506  </div>
507 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="PreviewImage">PreviewImage</a></h2>
508 <div class="doc-section">
509
510 <p>PreviewImage() tiles 9 thumbnails of the specified image with an image processing operation applied with varying parameters.  This may be helpful pin-pointing an appropriate parameter for a particular image processing operation.</p>
511
512 <p>The format of the PreviewImages method is:</p>
513
514 <pre class="code">
515   Image *PreviewImages(const Image *image,const PreviewType preview,
516     ExceptionInfo *exception)
517 </pre>
518
519 <p>A description of each parameter follows:</p>
520
521 <h5>image</h5>
522 <p>the image.</p>
523
524 <h5>preview</h5>
525 <p>the image processing operation.</p>
526
527 <h5>exception</h5>
528 <p>return any errors or warnings in this structure.</p>
529
530  </div>
531 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="RadialBlurImage">RadialBlurImage</a></h2>
532 <div class="doc-section">
533
534 <p>RadialBlurImage() applies a radial blur to the image.</p>
535
536 <p>Andrew Protano contributed this effect.</p>
537
538 <p>The format of the RadialBlurImage method is:</p>
539
540 <pre class="code">
541       Image *RadialBlurImage(const Image *image,const double angle,
542   ExceptionInfo *exception)
543       Image *RadialBlurImageChannel(const Image *image,const ChannelType channel,
544   const double angle,ExceptionInfo *exception)
545 </pre>
546
547 <p>A description of each parameter follows:</p>
548
549 <h5>image</h5>
550 <p>the image.</p>
551
552 <h5>channel</h5>
553 <p>the channel type.</p>
554
555 <h5>angle</h5>
556 <p>the angle of the radial blur.</p>
557
558 <h5>exception</h5>
559 <p>return any errors or warnings in this structure.</p>
560
561  </div>
562 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="SelectiveBlurImage">SelectiveBlurImage</a></h2>
563 <div class="doc-section">
564
565 <p>SelectiveBlurImage() selectively blur pixels within a contrast threshold. It is similar to the unsharpen mask that sharpens everything with contrast above a certain threshold.</p>
566
567 <p>The format of the SelectiveBlurImage method is:</p>
568
569 <pre class="code">
570   Image *SelectiveBlurImage(const Image *image,const double radius,
571     const double sigma,const double threshold,ExceptionInfo *exception)
572   Image *SelectiveBlurImageChannel(const Image *image,
573     const ChannelType channel,const double radius,const double sigma,
574     const double threshold,ExceptionInfo *exception)
575 </pre>
576
577 <p>A description of each parameter follows:</p>
578
579 <h5>image</h5>
580 <p>the image.</p>
581
582 <h5>channel</h5>
583 <p>the channel type.</p>
584
585 <h5>radius</h5>
586 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
587
588 <h5>sigma</h5>
589 <p>the standard deviation of the Gaussian, in pixels.</p>
590
591 <h5>threshold</h5>
592 <p>only pixels within this contrast threshold are included in the blur operation.</p>
593
594 <h5>exception</h5>
595 <p>return any errors or warnings in this structure.</p>
596
597  </div>
598 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="ShadeImage">ShadeImage</a></h2>
599 <div class="doc-section">
600
601 <p>ShadeImage() shines a distant light on an image to create a three-dimensional effect. You control the positioning of the light with azimuth and elevation; azimuth is measured in degrees off the x axis and elevation is measured in pixels above the Z axis.</p>
602
603 <p>The format of the ShadeImage method is:</p>
604
605 <pre class="code">
606   Image *ShadeImage(const Image *image,const MagickBooleanType gray,
607     const double azimuth,const double elevation,ExceptionInfo *exception)
608 </pre>
609
610 <p>A description of each parameter follows:</p>
611
612 <h5>image</h5>
613 <p>the image.</p>
614
615 <h5>gray</h5>
616 <p>A value other than zero shades the intensity of each pixel.</p>
617
618 <h5>azimuth, elevation</h5>
619 <p>Define the light source direction.</p>
620
621 <h5>exception</h5>
622 <p>return any errors or warnings in this structure.</p>
623
624  </div>
625 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="SharpenImage">SharpenImage</a></h2>
626 <div class="doc-section">
627
628 <p>SharpenImage() sharpens the image.  We convolve the image with a Gaussian operator of the given radius and standard deviation (sigma).  For reasonable results, radius should be larger than sigma.  Use a radius of 0 and SharpenImage() selects a suitable radius for you.</p>
629
630 <p>Using a separable kernel would be faster, but the negative weights cancel out on the corners of the kernel producing often undesirable ringing in the filtered result; this can be avoided by using a 2D gaussian shaped image sharpening kernel instead.</p>
631
632 <p>The format of the SharpenImage method is:</p>
633
634 <pre class="code">
635       Image *SharpenImage(const Image *image,const double radius,
636   const double sigma,ExceptionInfo *exception)
637       Image *SharpenImageChannel(const Image *image,const ChannelType channel,
638   const double radius,const double sigma,ExceptionInfo *exception)
639 </pre>
640
641 <p>A description of each parameter follows:</p>
642
643 <h5>image</h5>
644 <p>the image.</p>
645
646 <h5>channel</h5>
647 <p>the channel type.</p>
648
649 <h5>radius</h5>
650 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
651
652 <h5>sigma</h5>
653 <p>the standard deviation of the Laplacian, in pixels.</p>
654
655 <h5>exception</h5>
656 <p>return any errors or warnings in this structure.</p>
657
658  </div>
659 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="SpreadImage">SpreadImage</a></h2>
660 <div class="doc-section">
661
662 <p>SpreadImage() is a special effects method that randomly displaces each pixel in a block defined by the radius parameter.</p>
663
664 <p>The format of the SpreadImage method is:</p>
665
666 <pre class="code">
667   Image *SpreadImage(const Image *image,const double radius,
668     ExceptionInfo *exception)
669 </pre>
670
671 <p>A description of each parameter follows:</p>
672
673 <h5>image</h5>
674 <p>the image.</p>
675
676 <h5>radius</h5>
677 <p>Choose a random pixel in a neighborhood of this extent.</p>
678
679 <h5>exception</h5>
680 <p>return any errors or warnings in this structure.</p>
681
682  </div>
683 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="StatisticImage">StatisticImage</a></h2>
684 <div class="doc-section">
685
686 <p>StatisticImage() makes each pixel the min / max / median / mode / etc. of the neighborhood of the specified width and height.</p>
687
688 <p>The format of the StatisticImage method is:</p>
689
690 <pre class="code">
691   Image *StatisticImage(const Image *image,const StatisticType type,
692     const size_t width,const size_t height,ExceptionInfo *exception)
693   Image *StatisticImageChannel(const Image *image,
694     const ChannelType channel,const StatisticType type,
695     const size_t width,const size_t height,ExceptionInfo *exception)
696 </pre>
697
698 <p>A description of each parameter follows:</p>
699
700 <h5>image</h5>
701 <p>the image.</p>
702
703 <h5>channel</h5>
704 <p>the image channel.</p>
705
706 <h5>type</h5>
707 <p>the statistic type (median, mode, etc.).</p>
708
709 <h5>width</h5>
710 <p>the width of the pixel neighborhood.</p>
711
712 <h5>height</h5>
713 <p>the height of the pixel neighborhood.</p>
714
715 <h5>exception</h5>
716 <p>return any errors or warnings in this structure.</p>
717
718  </div>
719 <h2><a href="http://www.imagemagick.org/api/MagickCore/effect_8c.html" id="UnsharpMaskImage">UnsharpMaskImage</a></h2>
720 <div class="doc-section">
721
722 <p>UnsharpMaskImage() sharpens one or more image channels.  We convolve the image with a Gaussian operator of the given radius and standard deviation (sigma).  For reasonable results, radius should be larger than sigma.  Use a radius of 0 and UnsharpMaskImage() selects a suitable radius for you.</p>
723
724 <p>The format of the UnsharpMaskImage method is:</p>
725
726 <pre class="code">
727       Image *UnsharpMaskImage(const Image *image,const double radius,
728   const double sigma,const double amount,const double threshold,
729   ExceptionInfo *exception)
730       Image *UnsharpMaskImageChannel(const Image *image,
731   const ChannelType channel,const double radius,const double sigma,
732   const double amount,const double threshold,ExceptionInfo *exception)
733 </pre>
734
735 <p>A description of each parameter follows:</p>
736
737 <h5>image</h5>
738 <p>the image.</p>
739
740 <h5>channel</h5>
741 <p>the channel type.</p>
742
743 <h5>radius</h5>
744 <p>the radius of the Gaussian, in pixels, not counting the center pixel.</p>
745
746 <h5>sigma</h5>
747 <p>the standard deviation of the Gaussian, in pixels.</p>
748
749 <h5>amount</h5>
750 <p>the percentage of the difference between the original and the blur image that is added back into the original.</p>
751
752 <h5>threshold</h5>
753 <p>the threshold in pixels needed to apply the diffence amount.</p>
754
755 <h5>exception</h5>
756 <p>return any errors or warnings in this structure.</p>
757
758  </div>
759 \r
760 </div>\r
761 \r
762 <div id="linkbar">\r
763     <span id="linkbar-west">&nbsp;</span>\r
764     <span id="linkbar-center">\r
765       <a href="http://www.imagemagick.org/discourse-server/">Discourse Server</a> &bull;\r
766       <a href="http://www.imagemagick.org/MagickStudio/scripts/MagickStudio.cgi">Studio</a>\r
767     </span>\r
768     <span id="linkbar-east">&nbsp;</span>\r
769   </div>\r
770   <div class="footer">\r
771     <span id="footer-west">&copy; 1999-2011 ImageMagick Studio LLC</span>\r
772     <span id="footer-east"> <a href="../http://www.imagemagick.org/script/contact.php">Contact the Wizards</a></span>\r
773   </div>\r
774   <div style="clear: both; margin: 0; width: 100%; "></div>\r
775   <script type="text/javascript">\r
776     var _gaq = _gaq || [];\r
777     _gaq.push(['_setAccount', 'UA-17690367-1']);\r
778     _gaq.push(['_trackPageview']);\r
779 \r
780     (function() {\r
781       var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;\r
782       ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';\r
783       var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);\r
784     })();\r
785   </script>\r
786 </body>\r
787 </html>\r