From e19d255caf21ba115bffeb7c1a33fdefd069caed Mon Sep 17 00:00:00 2001 From: Cristy Date: Sat, 27 Apr 2019 20:03:27 -0400 Subject: [PATCH] Update IM docs --- images/wizard.jpg | Bin 23367 -> 23358 bytes index.html | 72 +-- www/ImageMagickObject.html | 50 +- www/advanced-unix-installation.html | 55 ++- www/advanced-windows-installation.html | 41 +- www/animate.html | 44 +- www/api.html | 2 +- www/api/Image++.html | 8 +- www/api/animate.html | 8 +- www/api/annotate.html | 53 +- www/api/attribute.html | 53 +- www/api/blob.html | 8 +- www/api/cache-view.html | 57 ++- www/api/cache.html | 638 +++++++++++++++++-------- www/api/channel.html | 53 +- www/api/cipher.html | 8 +- www/api/color.html | 55 ++- www/api/colormap.html | 55 ++- www/api/colorspace.html | 55 ++- www/api/compare.html | 8 +- www/api/composite.html | 53 +- www/api/constitute.html | 57 ++- www/api/decorate.html | 51 +- www/api/deprecate.html | 8 +- www/api/display.html | 8 +- www/api/distort.html | 55 ++- www/api/draw.html | 55 ++- www/api/drawing-wand.html | 53 +- www/api/effect.html | 57 ++- www/api/enhance.html | 53 +- www/api/exception.html | 8 +- www/api/feature.html | 55 ++- www/api/fourier.html | 8 +- www/api/fx.html | 57 ++- www/api/histogram.html | 55 ++- www/api/image-view.html | 57 ++- www/api/image.html | 51 +- www/api/layer.html | 57 ++- www/api/list.html | 8 +- www/api/magick++-classes.html | 8 +- www/api/magick-deprecate.html | 56 ++- www/api/magick-image.html | 445 +++++++++++++++-- www/api/magick-property.html | 77 ++- www/api/magick-wand.html | 53 +- www/api/magick.html | 53 +- www/api/memory.html | 8 +- www/api/mime.html | 8 +- www/api/module.html | 8 +- www/api/mogrify.html | 53 +- www/api/monitor.html | 8 +- www/api/montage.html | 234 +++++++-- www/api/morphology.html | 57 ++- www/api/paint.html | 51 +- www/api/pixel-iterator.html | 53 +- www/api/pixel-wand.html | 53 +- www/api/profile.html | 53 +- www/api/property.html | 51 +- www/api/quantize.html | 623 ++++++++++++++++-------- www/api/registry.html | 8 +- www/api/resize.html | 50 +- www/api/resource.html | 53 +- www/api/segment.html | 57 ++- www/api/shear.html | 51 +- www/api/signature.html | 8 +- www/api/statistic.html | 53 +- www/api/stream.html | 52 +- www/api/transform.html | 55 ++- www/api/version.html | 8 +- www/api/wand-view.html | 53 +- www/architecture.html | 59 ++- www/binary-releases.html | 2 +- www/changelog.html | 153 +++++- www/cipher.html | 42 +- www/clahe.html | 137 ++++++ www/color-management.html | 52 +- www/color.html | 4 +- www/command-line-options.html | 4 +- www/command-line-processing.html | 67 +-- www/command-line-tools.html | 43 +- www/compare.html | 44 +- www/compose.html | 4 +- www/composite.html | 44 +- www/conjure.html | 48 +- www/connected-components.html | 42 +- www/contact.html | 29 +- www/convert.html | 511 ++++++++++---------- www/develop.html | 48 +- www/display.html | 207 ++++---- www/distribute-pixel-cache.html | 42 +- www/download.html | 137 +++--- www/escape.html | 42 +- www/examples.html | 43 +- www/exception.html | 41 +- www/export.html | 41 +- www/formats.html | 131 ++--- www/fx.html | 42 +- www/gradient.html | 31 +- www/high-dynamic-range.html | 29 +- www/history.html | 41 +- www/identify.html | 48 +- www/import.html | 155 +++--- www/index.html | 99 ++-- www/install-source.html | 50 +- www/jp2.html | 28 +- www/license.html | 43 +- www/links.html | 33 +- www/magick++.html | 48 +- www/magick-core.html | 42 +- www/magick-script.html | 44 +- www/magick-vector-graphics.html | 28 +- www/magick-wand.html | 41 +- www/magick.html | 45 +- www/miff.html | 30 +- www/mirror.html | 45 +- www/mogrify.html | 505 +++++++++---------- www/montage.html | 229 ++++----- www/motion-picture.html | 31 +- www/opencl.html | 42 +- www/openmp.html | 44 +- www/perl-magick.html | 132 ++--- www/porting.html | 49 +- www/quantize.html | 4 +- www/resources.html | 33 +- www/search.html | 41 +- www/security-policy.html | 30 +- www/sitemap.html | 95 ++-- www/stream.html | 42 +- www/support.html | 32 +- www/webp.html | 35 +- 129 files changed, 5426 insertions(+), 3386 deletions(-) diff --git a/images/wizard.jpg b/images/wizard.jpg index 0e64cca4a9bfb6000e03d18cc516368f67119682..5b9529c5d8c7b60e245c05c9d52b744ecc569c48 100644 GIT binary patch delta 21734 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 CDNLvU diff --git a/index.html b/index.html index b2936a067..0d01507ff 100644 --- a/index.html +++ b/index.html @@ -7,9 +7,9 @@ - Convert, Edit, Or Compose Bitmap Images @ ImageMagick + ImageMagick - Convert, Edit, or Compose Bitmap Images - + @@ -22,8 +22,14 @@ + + + + + + - + @@ -38,7 +44,7 @@
- Use ImageMagick® to create, edit, compose, or convert bitmap images. It can read and write images in a variety of formats (over 200) including PNG, JPEG, GIF, HEIC, TIFF, DPX, EXR, WebP, Postscript, PDF, and SVG. Use ImageMagick to resize, flip, mirror, rotate, distort, shear and transform images, adjust image colors, apply various special effects, or draw text, lines, polygons, ellipses and Bézier curves.

-

The functionality of ImageMagick is typically utilized from the command-line or you can use the features from programs written in your favorite language. Choose from these interfaces: G2F (Ada), MagickCore (C), MagickWand (C), ChMagick (Ch), ImageMagickObject (COM+), Magick++ (C++), JMagick (Java), JuliaIO (Julia), L-Magick (Lisp), Lua (LuaJIT), NMagick (Neko/haXe), Magick.NET (.NET), PascalMagick (Pascal), PerlMagick (Perl), MagickWand for PHP (PHP), IMagick (PHP), PythonMagick (Python), magick (R), RMagick (Ruby), or TclMagick (Tcl/TK). With a language interface, use ImageMagick to modify or create images dynamically and automagically.

-

ImageMagick utilizes multiple computational threads to increase performance and can read, process, or write mega-, giga-, or tera-pixel image sizes.

ImageMagick is free software delivered as a ready-to-run binary distribution or as source code that you may use, copy, modify, and distribute in both open and proprietary applications. It is distributed under a derived Apache 2.0 license.

-

The ImageMagick development process ensures a stable API and ABI. Before each ImageMagick release, we perform a comprehensive security assessment that includes memory error, thread data race detection, and continuous fuzzing to help prevent security vulnerabilities.

- -

The current release is ImageMagick 7.0.8-23. It runs on Linux, Windows, Mac Os X, iOS, Android OS, and others.

+

ImageMagick utilizes multiple computational threads to increase performance and can read, process, or write mega-, giga-, or tera-pixel image sizes.

-

The authoritative ImageMagick web site is https://imagemagick.org. The authoritative source code repository is https://github.com/ImageMagick. We maintain a source code mirror at https://gitlab.com/ImageMagick.

+

The current release is ImageMagick 7.0.8-42. It runs on Linux, Windows, Mac Os X, iOS, Android OS, and others.

-

We continue to maintain the legacy release of ImageMagick, version 6, at https://legacy.imagemagick.org.

+

The authoritative ImageMagick web site is https://imagemagick.org. The authoritative source code repository is https://github.com/ImageMagick. We maintain a source code mirror at https://gitlab.com/ImageMagick. We continue to maintain the legacy release of ImageMagick, version 6, at https://legacy.imagemagick.org.

Features and Capabilities

-

Here are just a few examples of what ImageMagick can do for you:

+

Here are just a few examples of what ImageMagick can do for you:

@@ -107,7 +109,7 @@ Use ImageMagickColor management + @@ -119,11 +121,11 @@ Use ImageMagickComposite + - + @@ -139,7 +141,7 @@ Use ImageMagickDFT. - + @@ -147,7 +149,7 @@ Use ImageMagickEncipher or decipher an image + @@ -160,14 +162,18 @@ Use ImageMagickHeterogeneous distributed processing - + - + + + + + @@ -175,7 +181,7 @@ Use ImageMagickImage identification + @@ -216,7 +222,7 @@ Use ImageMagickThreads of execution support - + @@ -233,14 +239,16 @@ Use ImageMagickExamples of ImageMagick Usage shows how to use ImageMagick from the command-line to accomplish any of these tasks and much more. Also, see Fred's ImageMagick Scripts: a plethora of command-line scripts that perform geometric transforms, blurs, sharpens, edging, noise removal, and color manipulations. With Magick.NET, use ImageMagick without having to install ImageMagick on your server or desktop.

+

Examples of ImageMagick Usage shows how to use ImageMagick from the command-line to accomplish any of these tasks and much more. Also, see Fred's ImageMagick Scripts: a plethora of command-line scripts that perform geometric transforms, blurs, sharpens, edging, noise removal, and color manipulations. With Magick.NET, use ImageMagick without having to install ImageMagick on your server or desktop.

News

-

Now that ImageMagick version 7 is released, we continue to maintain the legacy release of ImageMagick, version 6, at https://legacy.imagemagick.org. Learn how ImageMagick version 7 differs from previous versions with our porting guide.

+

Now that ImageMagick version 7 is released, we continue to maintain the legacy release of ImageMagick, version 6, at https://legacy.imagemagick.org. Learn how ImageMagick version 7 differs from previous versions with our porting guide.

ImageMagick best practices strongly encourages you to configure a security policy that suits your local environment.

+

The ImageMagick development process ensures a stable API and ABI. Before each ImageMagick release, we perform a comprehensive security assessment that includes memory error, thread data race detection, and continuous fuzzing to help prevent security vulnerabilities.

+

As an analog to linear (RGB) and non-linear (sRGB) color colorspaces, as of ImageMagick 7.0.7-17, we introduce the LinearGray colorspace. Gray is non-linear grayscale and LinearGray is linear (e.g. -colorspace linear-gray).

Want more performance from ImageMagick? Try these options:

@@ -259,15 +267,16 @@ Use ImageMagick

Security • - Architecture • + Architecture + + And Now a Touch of Magick + Related • Sitemap - - And Now a Touch of Magick - - Public Key • +
Donate • - Contact Us + Public Key • + Contact Us
© 1999-2019 ImageMagick Studio LLC

@@ -277,3 +286,4 @@ Use ImageMagick<\/script>') + \ No newline at end of file diff --git a/www/ImageMagickObject.html b/www/ImageMagickObject.html index 145dcac7a..22a4d89f0 100644 --- a/www/ImageMagickObject.html +++ b/www/ImageMagickObject.html @@ -7,9 +7,9 @@ - Install the ImageMagickObject COM+ Component @ ImageMagick + ImageMagick - Install the ImageMagickObject COM+ Component - + @@ -22,6 +22,12 @@ + + + + + + @@ -31,7 +37,7 @@
Color management accurate color management with color profiles or in lieu of-- built-in gamma compression or expansion as demanded by the colorspace.
Composite overlap one image over another.
Connected component labelingConnected component labeling uniquely label connected regions in an image.
Distributed pixel cacheDistributed pixel cache offload intermediate pixel storage to one or more remote servers.
Encipher or decipher an image convert ordinary images into unintelligible gibberish and back again.
certain algorithms are OpenCL-enabled to take advantage of speed-ups offered by executing in concert across heterogeneous platforms consisting of CPUs, GPUs, and other processors.certain algorithms are OpenCL-enabled to take advantage of speed-ups offered by executing in concert across heterogeneous platforms consisting of CPUs, GPUs, and other processors.
High dynamic-range images accurately represent the wide range of intensity levels found in real scenes ranging from the brightest direct sunlight to the deepest darkest shadows.
Image calculatorHistogram EqualizationUse adaptive histogram equalization to improve contrast in images.
Image calculator apply a mathematical expression to an image or image channels.
Image identification describe the format and attributes of an image.
ImageMagick is thread safe and most internal algorithms execute in parallel to take advantage of speed-ups offered by multicore processor chips.ImageMagick is thread safe and most internal algorithms execute in parallel to take advantage of speed-ups offered by multicore processor chips.
Transform
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Animationcreate a GIF animation sequence from a group of images.
Color managementaccurate color management with color profiles or in lieu of-- built-in gamma compression or expansion as demanded by the colorspace.
Command-line processingutilize ImageMagick from the command-line.
Complex text layoutbidirectional text support and shaping.
Compositeoverlap one image over another.
Connected component labelinguniquely label connected regions in an image.
Decorateadd a border or frame to an image.
Delineate image featuresCanny edge detection, Hough lines.
Discrete Fourier transformimplements the forward and inverse DFT.
Distributed pixel cacheoffload intermediate pixel storage to one or more remote servers.
Drawadd shapes or text to an image.
Encipher or decipher an imageconvert ordinary images into unintelligible gibberish and back again.
Format conversionconvert an image from one format to another (e.g. PNG to JPEG).
Generalized pixel distortioncorrect for, or induce image distortions including perspective.
Heterogeneous distributed processingcertain algorithms are OpenCL-enabled to take advantage of speed-ups offered by executing in concert across heterogeneous platforms consisting of CPUs, GPUs, and other processors.
High dynamic-range imagesaccurately represent the wide range of intensity levels found in real scenes ranging from the brightest direct sunlight to the deepest darkest shadows.
Image calculatorapply a mathematical expression to an image or image channels.
Image gradientscreate a gradual blend of two colors whose shape is horizontal, vertical, circular, or elliptical.
Image identificationdescribe the format and attributes of an image.
ImageMagick on the iPhoneconvert, edit, or compose images on your iOS device such as the iPhone or iPad.
Large image supportread, process, or write mega-, giga-, or tera-pixel image sizes.
Montagejuxtapose image thumbnails on an image canvas.
Morphology of shapesextract features, describe shapes, and recognize patterns in images.
Motion picture supportread and write the common image formats used in digital film work.
Noise and color reductionKuwahara Filter, mean-shift.
Perceptual hashmap visually identical images to the same or similar hash-- useful in image retrieval, authentication, indexing, or copy detection as well as digital watermarking.
Special effectsblur, sharpen, threshold, or tint an image.
Text & commentsinsert descriptive or artistic text in an image.
Threads of execution supportImageMagick is thread safe and most internal algorithms execute in parallel to take advantage of speed-ups offered by multicore processor chips.
Transformresize, rotate, deskew, crop, flip or trim an image.
Transparencyrender portions of an image invisible.
Virtual pixel supportconvenient access to pixels outside the image boundaries.
-
+

AcquirePixelCacheNexusAcquirePixelCachePixelsGetAuthenticMetacontentGetAuthenticPixelQueueGetAuthenticPixelsGetOneAuthenticPixelGetOneVirtualPixelGetOneVirtualPixelInfoGetVirtualMetacontentGetVirtualPixelQueueGetVirtualPixelsQueueAuthenticPixelsSetPixelCacheVirtualMethodSyncAuthenticPixels

+ +

AcquirePixelCacheNexus

+ +

AcquirePixelCacheNexus() allocates the NexusInfo structure.

+ +

The format of the AcquirePixelCacheNexus method is:

+ +
+NexusInfo **AcquirePixelCacheNexus(const size_t number_threads)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
number_threads
+
the number of nexus threads.
+ +
+
+

AcquirePixelCachePixels

+ +

AcquirePixelCachePixels() returns the pixels associated with the specified image.

+ +

The format of the AcquirePixelCachePixels() method is:

+ +
+void *AcquirePixelCachePixels(const Image *image,size_t *length,
+  ExceptionInfo *exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
length
+
the pixel cache length.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
+

GetAuthenticMetacontent

+ +

GetAuthenticMetacontent() returns the authentic metacontent corresponding with the last call to QueueAuthenticPixels() or GetVirtualPixels(). NULL is returned if the associated pixels are not available.

+ +

The format of the GetAuthenticMetacontent() method is:

+ +
+void *GetAuthenticMetacontent(const Image *image)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
+

GetAuthenticPixelQueue

+ +

GetAuthenticPixelQueue() returns the authentic pixels associated corresponding with the last call to QueueAuthenticPixels() or GetAuthenticPixels().

+ +

The format of the GetAuthenticPixelQueue() method is:

+ +
+Quantum *GetAuthenticPixelQueue(const Image image)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
+

GetAuthenticPixels

+ +

GetAuthenticPixels() obtains a pixel region for read/write access. If the region is successfully accessed, a pointer to a Quantum array representing the region is returned, otherwise NULL is returned.

+ +

The returned pointer may point to a temporary working copy of the pixels or it may point to the original pixels in memory. Performance is maximized if the selected region is part of one row, or one or more full rows, since then there is opportunity to access the pixels in-place (without a copy) if the image is in memory, or in a memory-mapped file. The returned pointer must *never* be deallocated by the user.

+ +

Pixels accessed via the returned pointer represent a simple array of type Quantum. If the image has corresponding metacontent,call GetAuthenticMetacontent() after invoking GetAuthenticPixels() to obtain the meta-content corresponding to the region. Once the Quantum array has been updated, the changes must be saved back to the underlying image using SyncAuthenticPixels() or they may be lost.

+ +

The format of the GetAuthenticPixels() method is:

+ +
+Quantum *GetAuthenticPixels(Image *image,const ssize_t x,
+  const ssize_t y,const size_t columns,const size_t rows,
+  ExceptionInfo *exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
x,y,columns,rows
+
These values define the perimeter of a region of pixels.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
+

GetOneAuthenticPixel

+ +

GetOneAuthenticPixel() returns a single pixel at the specified (x,y) location. The image background color is returned if an error occurs.

+ +

The format of the GetOneAuthenticPixel() method is:

+ +
+MagickBooleanType GetOneAuthenticPixel(const Image image,const ssize_t x,
+  const ssize_t y,Quantum *pixel,ExceptionInfo *exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
x,y
+
These values define the location of the pixel to return.
+ +
+
pixel
+
return a pixel at the specified (x,y) location.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
+

GetOneVirtualPixel

+ +

GetOneVirtualPixel() returns a single virtual pixel at the specified (x,y) location. The image background color is returned if an error occurs. If you plan to modify the pixel, use GetOneAuthenticPixel() instead.

+ +

The format of the GetOneVirtualPixel() method is:

+ +
+MagickBooleanType GetOneVirtualPixel(const Image image,const ssize_t x,
+  const ssize_t y,Quantum *pixel,ExceptionInfo exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
x,y
+
These values define the location of the pixel to return.
+ +
+
pixel
+
return a pixel at the specified (x,y) location.
-

Examples of ImageMagick Usage shows how to use ImageMagick from the command-line to accomplish any of these tasks and much more. Also, see Fred's ImageMagick Scripts: a plethora of command-line scripts that perform geometric transforms, blurs, sharpens, edging, noise removal, and color manipulations. With Magick.NET, use ImageMagick without having to install ImageMagick on your server or desktop.

+
+
exception
+
return any errors or warnings in this structure.
-

News

+
+
+

GetOneVirtualPixelInfo

-

Now that ImageMagick version 7 is released, we continue to maintain the legacy release of ImageMagick, version 6, at https://legacy.imagemagick.org. Learn how ImageMagick version 7 differs from previous versions with our porting guide.

+

GetOneVirtualPixelInfo() returns a single pixel at the specified (x,y) location. The image background color is returned if an error occurs. If you plan to modify the pixel, use GetOneAuthenticPixel() instead.

-

ImageMagick best practices strongly encourages you to configure a security policy that suits your local environment.

+

The format of the GetOneVirtualPixelInfo() method is:

-

As an analog to linear (RGB) and non-linear (sRGB) color colorspaces, as of ImageMagick 7.0.7-17, we introduce the LinearGray colorspace. Gray is non-linear grayscale and LinearGray is linear (e.g. -colorspace linear-gray).

+
+MagickBooleanType GetOneVirtualPixelInfo(const Image image,
+  const VirtualPixelMethod virtual_pixel_method,const ssize_t x,
+  const ssize_t y,PixelInfo *pixel,ExceptionInfo exception)
+
-

Want more performance from ImageMagick? Try these options:

+

A description of each parameter follows:

- -

If these options are prohibitive, you can reduce the quality of the image results. The default build is Q16 HDRI. If you disable HDRI, you use half the memory and instead of predominately floating point operations, you use the typically more efficient integer operations. The tradeoff is reduced precision and you cannot process out of range pixel values (e.g. negative). If you build the Q8 non-HDRI version of ImageMagick, you again reduce the memory requirements in half-- and once again there is a tradeoff, even less precision and no out of range pixel values. For a Q8 non-HDRI build of ImageMagick, use these configure script options: --with-quantum-depth=8 --disable-hdri.

+
+
-

Community

-

To join the ImageMagick community, try the discourse server. You can review questions or comments (with informed responses) posed by ImageMagick users or ask your own questions. If you want to contribute image processing algorithms, other enhancements, or bug fixes, open an issue.

+
+
+
image
+
the image.
+ +
+
virtual_pixel_method
+
the virtual pixel method.
+ +
+
x,y
+
these values define the location of the pixel to return.
+ +
+
pixel
+
return a pixel at the specified (x,y) location.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
+

GetVirtualMetacontent

+ +

GetVirtualMetacontent() returns the virtual metacontent corresponding with the last call to QueueAuthenticPixels() or GetVirtualPixels(). NULL is returned if the meta-content are not available.

+ +

The format of the GetVirtualMetacontent() method is:

+ +
+const void *GetVirtualMetacontent(const Image *image)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
+

GetVirtualPixelQueue

+ +

GetVirtualPixelQueue() returns the virtual pixels associated corresponding with the last call to QueueAuthenticPixels() or GetVirtualPixels().

+ +

The format of the GetVirtualPixelQueue() method is:

+ +
+const Quantum *GetVirtualPixelQueue(const Image image)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
+

GetVirtualPixels

+ +

GetVirtualPixels() returns an immutable pixel region. If the region is successfully accessed, a pointer to it is returned, otherwise NULL is returned. The returned pointer may point to a temporary working copy of the pixels or it may point to the original pixels in memory. Performance is maximized if the selected region is part of one row, or one or more full rows, since there is opportunity to access the pixels in-place (without a copy) if the image is in memory, or in a memory-mapped file. The returned pointer must *never* be deallocated by the user.

+ +

Pixels accessed via the returned pointer represent a simple array of type Quantum. If the image type is CMYK or the storage class is PseudoClass, call GetAuthenticMetacontent() after invoking GetAuthenticPixels() to access the meta-content (of type void) corresponding to the the region.

+ +

If you plan to modify the pixels, use GetAuthenticPixels() instead.

+ +

Note, the GetVirtualPixels() and GetAuthenticPixels() methods are not thread- safe. In a threaded environment, use GetCacheViewVirtualPixels() or GetCacheViewAuthenticPixels() instead.

+ +

The format of the GetVirtualPixels() method is:

+ +
+const Quantum *GetVirtualPixels(const Image *image,const ssize_t x,
+  const ssize_t y,const size_t columns,const size_t rows,
+  ExceptionInfo *exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
x,y,columns,rows
+
These values define the perimeter of a region of pixels.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
+

QueueAuthenticPixels

+ +

QueueAuthenticPixels() queues a mutable pixel region. If the region is successfully initialized a pointer to a Quantum array representing the region is returned, otherwise NULL is returned. The returned pointer may point to a temporary working buffer for the pixels or it may point to the final location of the pixels in memory.

+ +

Write-only access means that any existing pixel values corresponding to the region are ignored. This is useful if the initial image is being created from scratch, or if the existing pixel values are to be completely replaced without need to refer to their pre-existing values. The application is free to read and write the pixel buffer returned by QueueAuthenticPixels() any way it pleases. QueueAuthenticPixels() does not initialize the pixel array values. Initializing pixel array values is the application's responsibility.

+ +

Performance is maximized if the selected region is part of one row, or one or more full rows, since then there is opportunity to access the pixels in-place (without a copy) if the image is in memory, or in a memory-mapped file. The returned pointer must *never* be deallocated by the user.

+ +

Pixels accessed via the returned pointer represent a simple array of type Quantum. If the image type is CMYK or the storage class is PseudoClass, call GetAuthenticMetacontent() after invoking GetAuthenticPixels() to obtain the meta-content (of type void) corresponding to the region. Once the Quantum (and/or Quantum) array has been updated, the changes must be saved back to the underlying image using SyncAuthenticPixels() or they may be lost.

+ +

The format of the QueueAuthenticPixels() method is:

+ +
+Quantum *QueueAuthenticPixels(Image *image,const ssize_t x,
+  const ssize_t y,const size_t columns,const size_t rows,
+  ExceptionInfo *exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
x,y,columns,rows
+
These values define the perimeter of a region of pixels.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
+

SetPixelCacheVirtualMethod

+ +

SetPixelCacheVirtualMethod() sets the "virtual pixels" method for the pixel cache and returns the previous setting. A virtual pixel is any pixel access that is outside the boundaries of the image cache.

+ +

The format of the SetPixelCacheVirtualMethod() method is:

+ +
+VirtualPixelMethod SetPixelCacheVirtualMethod(Image *image,
+  const VirtualPixelMethod virtual_pixel_method,ExceptionInfo *exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
virtual_pixel_method
+
choose the type of virtual pixel.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
+

SyncAuthenticPixels

+ +

SyncAuthenticPixels() saves the image pixels to the in-memory or disk cache. The method returns MagickTrue if the pixel region is flushed, otherwise MagickFalse.

+ +

The format of the SyncAuthenticPixels() method is:

+ +
+MagickBooleanType SyncAuthenticPixels(Image *image,
+  ExceptionInfo *exception)
+
+ +

A description of each parameter follows:

+ +
+
+ +
+
+
image
+
the image.
+ +
+
exception
+
return any errors or warnings in this structure.
+ +
+
- + + \ No newline at end of file diff --git a/www/api/channel.html b/www/api/channel.html index 96f0c4664..5dfe5c6a1 100644 --- a/www/api/channel.html +++ b/www/api/channel.html @@ -9,7 +9,7 @@ MagickCore, C API: Get or Set Image Channels @ ImageMagick - + @@ -19,19 +19,25 @@ - + + + + + + + - - - + + +