Image.capture(silent=false
, frame=false
, descend=false
, screen=false
, borders=false
) [ { optional arguments } ] ->
image
Reads an image from an X window. Unless you identify a
window to capture via the optional arguments block,
when capture
is invoked the cursor will turn into
a cross. Click the cursor on the window to be captured.
Within the optional arguments block, specify
self.filename = "root"
to capture the entire
desktop. To programatically specify the window to be captured,
use self.filename = window_id
, where window_id is
the id displayed by xwininfo(1).
true
, suppress the beeps that signal the
start and finish of the capture process. The bell rings once
to signal the start of the capture and twice to signal the
finish.true
, include the window frame.true
, obtain image
by descending window hierarchy.true
, specifies that the GetImage request used to obtain the image
should be done on the root window, rather than directly on
the specified window. In this way, you can obtain pieces of
other windows that overlap the specified window, and more
importantly, you can capture menus or other popups that are
independent windows but appear over the specified
window.true
, include the border in the
image.A new image.
img = Image.capture { self.filename = "root" }
Image.combine(red_ch=nil, green_ch=nil, blue_ch=nil, opacity_ch=nil) ->image
Combines the grayscale value of the pixels in each image to form a new image.
The red channel of the image specified in the first argument is used as the red channel in the new image. The green channel of the image specified in the second argument is used as the green channel in the new image. The blue channel of the image specified in the third argument is used as the blue channel in the new image. The opacity channel of the image specified in the fourth argument is used as the opacity channel in the new image.
Any of the arguments may be nil. Trailing nil arguments may be omitted. You must specify at least one image argument.
A new image
The same results can be obtained using the composite method and the CopyRed/Green/Blue/OpacityCompositeOp CompositeOperator enum values.
CombineImages
Image.constitute(width, height, map, pixels) -> image
Creates an image from an array of pixels. This method is the
reverse of dispatch
.
Integers
or all Floats
. If the
elements are Integers
, the Integers
must be in the range [0..QuantumRange]. If the elements are
Floats
, they must be in the range [0..1].An image constructed from the pixel data.
image = Image.constitute(width, height, "RGB", pixels)
ConstituteImage
Image.from_blob(string) [ { optional arguments } ] -> array
Creates an array of images from a BLOB, that is, a Binary Large OBject. In RMagick, a BLOB is a string.
A blob can be a string containing an image file such as a JPEG or GIF. The string can contain a multi-image file such as an animated GIF or a Photoshop image with multiple layers. A blob can also be one of the strings produced by to_blob. Control the format of the created image(s) by setting additional Image::Info attributes in the optional block argument.
An array of one or more images constructed from the BLOB.
See to_blob
.
BlobToImage
Image.new(columns, rows [, fill]) [ { optional arguments } ] -> image
Fill
objectA new image.
img = Image.new(256, 64) { self.background_color = 'red' }
AllocateImage
Image.ping(filename) [ { optional arguments } ] ->
array
Image.ping(file) [ {
optional arguments } ] -> array
Creates one or more images from the image file, omitting the
pixel data. Only the attributes are stored in the images. This
method is faster than read
and
uses less memory.
An image file name or open file object. You can specify other arguments by setting Image::Info attributes in the optional block.
An array containing 0 or more images.
cheetah = Image.ping("Cheetah.jpg") » [Cheetah.jpg JPEG 1024x768 DirectClass 8-bit 101684b] p cheetah[0].rows » 768 p cheetah[0].columns » 1024
PingImage
Image.read(filename) [ { optional arguments } ] ->
array
Image.read(file) [ {
optional arguments } ] -> array
Reads all the images from the specified file.
Note: Because an
image file can contain multiple images or multiple image
layers, read
always returns an array containing 0
or more elements, one element for each image or image layer in
the file.
An image file name or open file object. You can specify other arguments by setting Image::Info attributes in the optional block.
An array containing 0 or more Image objects. If the file is a multi-image file such as an animated GIF or a Photoshop PSD file with multiple layers, the array contains an Image object for each image or layer in the file.
animated = Image.read("animated.gif") » [animated.gif GIF 127x120+0+0 PseudoClass 256c 8-bit 54395b animated.gif[1] GIF 127x120+0+0 PseudoClass 256c 8-bit 54395b, animated.gif[2] GIF 127x120+0+0 PseudoClass 256c 8-bit 54395b]
The read method does not accept a StringIO object. If you want to create an image from a string buffer, use from_blob.
ReadImage
Image.read_inline(content) [ { optional arguments } ] -> array
Converts a Base64-encoded image or multi-image sequence to an array of Image objects.
A Base64-encoded string. Generally no optional arguments are required. If the image format cannot be deduced from the image data, you can use the format attribute. If you want to extract a subset of an image sequence, see here.
An array containing 0 or more Image objects. If the content is a multi-image sequence such as an animated GIF or a Photoshop PSD file with multiple layers, the array contains an Image object for each image or layer in the file.
content = "R0lGODlhnAEuAferAAAAAAcIBggJBgw..." img = Image.read_inline(content)
img[key] -> string
Returns the value of the image property identified by
key. An image may have any number of
properties. Each property is identified by a string (or symbol)
key. The property value is a string. ImageMagick predefines
some properties, including Label
,
Comment
, Signature
, and in some cases
EXIF
.
String
or a
Symbol
.
The value of the property.
mom['Label'] = 'My Mother'
GetImageAttribute
ImageMagick calls properties "attributes." I use the word
"properties" to reduce the confusion with image object
attributes such as rows
and
columns
.
img[key] = string -> self
Sets the value of an image property. An image may have any number of properties.
self
SetImageAttribute
img <=> other_image -> -1, 0, 1
Compares two images and returns -1, 0, or 1 if img is less than, equal to, or greater than
other_image as determined by comparing
the signatures of the images. If one of the arguments is not an
image, this method raises a TypeError exception (in Ruby 1.6)
or returns nil
(in Ruby 1.8)
In addition to <=>, Image
mixes in the
Comparable
module, which defines the <, <=,
== >=, >, and between?
methods.
The difference
method compares images (for
equality only) but also returns information about the amount
two images differ, which may be more useful.
The value of img.signature
<=> other_mage.signature
.
signature, difference, compare_channel
SignatureImage
img.adaptive_blur(radius=0.0, sigma=1.0) -> image
Adaptively blurs the image by bluring more intensely near image edges and less intensely far from edges. The adaptive_blur method blurs 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 adaptive_blur selects a suitable radius for you.
A new image
AdaptiveBlurImage
img.adaptive_blur(radius=0.0, sigma=1.0 [,channel...]) -> image
The same as adaptive_blur
except only the
specified channels are blurred.
adaptive_blur
method, above.A new image
AdaptiveBlurImageChannel
img.adaptive_resize(new_width, new_height)
-> image
img.adaptive_resize(scale_factor) -> image
Resizes the image with data dependent triangulation.
You can specify the new size in two ways. Either specify the new width and height explicitly, or specify a scale factor, a number that represents the percentage change.
Use the change_geometry method to compute new dimensions for an image with constraints such as "maintain the current proportions."
A new image
AdaptiveResizeImage
img.adaptive_sharpen(radius=0.0, sigma=1.0) -> image
Adaptively sharpens the image by sharpening more intensely near image edges and less intensely far from edges. The adaptive_sharpen method sharpens 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 adaptive_sharpen selects a suitable radius for you.
A new image
AdaptiveSharpenImage
img.adaptive_sharpen(radius=0.0, sigma=1.0 [,channel...]) -> image
The same as adaptive_sharpen
except only the
specified channels are sharpened.
adaptive_sharpen
method, above.A new image
AdaptiveSharpenImageChannel
img.adaptive_threshold(width=3, height=3, offset=0) -> image
Selects an individual threshold for each pixel based on the range of intensity values in its local neighborhood. This allows for thresholding of an image whose global intensity histogram doesn't contain distinctive peaks.
A new image
bilevel_channel, random_threshold_channel, threshold
AdaptiveThresholdImage
img.add_noise(noise_type) -> image
Adds random noise to the image. The amount of time
add_noise
requires depends on the NoiseType
argument.
A NoiseType value.
A new image
The RandomNoise type was added in ImageMagick 6.3.5.
AddNoiseImage
img.add_profile(filename) -> self
Adds an ICC (a.k.a. ICM), IPTC, or generic profile. If the file contains more than one profile all the profiles are added.
The filename of a file containing the profile.
self
img.add_profile('my_cmyk.icm')
The iptc_profile and color_profile attributes provide very similar functionality, except that these attributes accept the profile data in the form of a string. The profile! method can also be used to add a profile. The type of profile must be specified and the profile data must be in the form of a string. Also see delete_profile and each_profile.
ProfileImage
img.add_noise_channel(noise_type [,channel...]) -> image
Adds random noise to the specified channel or channels in the image.
add_noise
method, above.A new image
AddNoiseImageChannel
img.affine_transform(matrix) -> image
Transforms the image as specified by the affine matrix.
See Coordinate system transformations in the Scalable Vector Graphics (SVG) 1.0 Specification for more information about transformation matrices.
An AffineMatrix
object.
A new image
The affine matrix in this example skews the receiver by π/6 radians along both axes.
AffineTransformImage
img.annotate(draw, width, height, x, y, text) [ { additional parameters } ] -> self
This is the same method as the annotate
method
in the Draw class, except that the first argument is a Draw
object. Refer to the documentation for Draw#annotate for more information.
Some users feel like annotate
is better placed in
Image than in Draw. Okay, here it is!
self
img.auto_orient -> image
Rotates or flips the image based on the image's EXIF
orientation tag. Note that only some models of modern digital
cameras can tag an image with the orientation. If the image
does not have an orientation tag, or the image is already
properly oriented, then auto_orient
returns an
exact copy of the image.
A new image
FlipImage, FlopImage, RotateImage, TransposeImage, TransverseImage
img.auto_orient! -> self
Rotates or flips the image based on the image's EXIF
orientation tag. Note that only some models of modern digital
cameras can tag an image with the orientation. If the image
does not have an orientation tag, or the image is already
properly oriented, then auto_orient!
returns
nil
.
self. or nil
if the image is already properly
oriented
img.bilevel_channel(threshold [,channel...]) -> image
Changes the value of individual pixels based on the intensity of each pixel channel. The result is a high-contrast image.
A new image
bilevel_channel(2*QuantumRange/3,
RedChannel)
adaptive_threshold, random_threshold_channel
BilevelImageChannel
img.black_threshold(red_channel [, green_channel [, blue_channel [, opacity_channel]]]) -> image
Forces all pixels below the threshold into black while leaving all pixels above the threshold unchanged.
Each channel argument is a number between 0 and QuantumRange. All arguments except the first may be omitted. If the green_channel or blue_channel argument is omitted, the default value is the red_channel value. If the opacity_channel argument is omitted, the default value is OpaqueOpacity.
A new image
white_threshold, bilevel_channel
BlackThresholdImage
img.blend(overlay, src_percentage,
dst_percentage, x_offset=0, y_offset=0)
-> image
img.blend(overlay, src_percentage,
dst_percentage, gravity, x_offset=0,
y_offset=0) -> image
Adds the overlay image to the target image according to src_percent and dst_percent.
This method corresponds to the -blend option of
ImageMagick's composite
command.
The blend
method can be called with or without
a gravity argument. The gravity, x_offset, and
y_offset arguments are described in
the documentation for watermark.
See "Blend Two Images Together" in Anthony Thyssen's Examples of ImageMagick Usage.
A new image
img.blur_channel(radius=0.0, sigma=1.0[, channel...]]) -> image
Blurs the specified channel. We
convolve the image with a Gaussian operator of the given radius
and standard deviation (sigma) . The blur_channel
method differs from gaussian_blur_channel
in that it uses a separable kernel which is faster but
mathematically equivalent to the non-separable
kernel.
For reasonable results, the radius should be larger than sigma. Use a radius of 0 and
blur_channel
selects a suitable radius for
you.
A new image
blur_image, gaussian_blur_channel, radial_blur
BlurImageChannel
img.blur_image(radius=0.0, sigma=1.0) -> image
Blurs the 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 blur_image
selects a suitable radius for you.
A new image.
gaussian_blur, motion_blur, virtual_pixel_method
BlurImage
img.border(width, height, color) -> image
Add a border around the image.
A new image
BorderImage
img.border!(width, height, color) -> self
img.change_geometry(string) {|cols,rows,image| block} -> ??? (see Returns)
img.change_geometry(geometry) {|cols,rows,image| block} -> ??? (see Returns)
The change_geometry
method supports resizing a
method by specifying constraints. For example, you can specify
that the image should be resized such that the aspect ratio
should be retained but the resulting image should be no larger
than 640 pixels wide and 480 pixels tall.
The argument may be either a geometry string or a Geometry object.
Change_geometry
yields to the block, passing new
width and height values based on the argument with respect to
self
. The return value is the return value of the
block.
Geometry
object
The value returned by the block
mona = Image.read('MonaLisa.jpg').first mona.change_geometry!('320x240') { |cols, rows, img| img.resize!(cols, rows) }
ParseSizeString
change_geometry!
is an alias for
change_geometry
.
img.changed? ->
true
or false
true
if any pixel has
been altered since the image was constituted.
IsTaintImage
img.channel(channel) -> image
Extracts a channel from the image. A channel is a particular color component of each pixel in the [image].
A ChannelType value.
An image in which the RGB values of all the pixels have been set to a gray corresponding to the specified channel value. For example, given a pixel in the original image with the value R=255, G=128, B=0 and the RedChannel argument, the equivalent pixel in the result image will have the value R=255, G=255, and B=255. For the BlueChannel argument, the pixel would have the value R=0, G=0, B=0.
The channel image preserves the tone of the selected RGB component.
ChannelImage
img.channel_depth([channel...]) -> number
Returns the maximum depth for the specified channel or channels.
The maximum depth
GetImageChannelDepth
img.channel_extrema([channel...]) -> [number, number]
Returns the minimum and maximum intensity values for the specified channel or channels.
An array. The first element in the array is the minimum value. The second element is the maximum value.
GetImageChannelExtrema
img.channel_mean([channel...]) -> [number, number]
Returns the mean and standard deviation values for the specified channel or channels.
An array. The first element in the array is the mean value. The second element is the standard deviation.
GetImageChannelMean
img.charcoal(radius=0.0, sigma=1.0) -> image
Adds a "charcoal" effect to the image. You can alter the intensity of the effect by changing the radius and sigma arguments.
A new image
CharcoalImage
img.check_destroyed ->
nil
Raises DestroyedImageError if the image has been destroyed. Returns nil otherwise.
img.chop(x, y, width, height) -> image
Removes the specified rectangle and collapses the rest of the image to fill the removed portion.
A new image
The chop rectangle is highlighted in the "before" image. The result may seem counter-intuitive!
ChopImage
img.clone -> image
Same as dup except the frozen state of the original is propogated to the new copy.
A new image
img.clut(clut_image [, channel...]) -> self
Replace the channel values in the target image with a lookup of its replacement value in an LUT gradient image.
The LUT image should be either a single row or column image of replacement colors. The lookup is controled by the -interpolate setting, especially for an LUT which is not the full length needed by the IM installed Quality (Q) level. Good setings for this is the default 'bilinear' or 'bicubic' interpolation setting for a smooth color gradient, or 'integer' for a direct unsmoothed lookup of color values.
This method is especially suited to replacing a grayscale image with specific color gradient from the CLUT image.
Note that color replacements involving transparency (alpha/matte channel) will lookup the replacement alpha/matte value using the alpha/matte value of the original image. As such correct alpha channel lookup for a pure gray-scale original image will require a copy of that grayscale to be transfered into its alpha channel before applying the -clut operator.
self
ImageMagick's -clut option.
img.color_fill_to_border(x, y, fill_color) -> image
Changes any pixel that is a neighbor of the target pixel and is not the border color to the fill color.
A new image
In this example, the aquamarine fill starts at the center of
the circle and fills to the black border. All non-black pixels
are replaced by the fill color. Contrast the result of
color_fill_to_border
with that of
color_floodfill
example, below.
ColorFloodfillImage
img.color_floodfill(x, y, fill_color) -> image
Changes any pixel that is the same color and is a neighbor of the target pixel to the fill color.
A new image
In this example, the aquamarine fill starts at the center of
the circle and replaces all neighboring white pixels. Contrast
the result of color_floodfill
with that of
color_fill_to_border
, above.
ColorFloodfillImage
img.color_histogram() -> hash
Computes the number of times each unique color appears in the image.
A hash. Each key in the hash is a Pixel representing a color that appears
in the image. The value associated with the key is the number
of times that color appears in the image. Caution: if
the image contains many colors the hash will be very large. You
may want to use the quantize
method to reduce the number of colors before using
color_histogram
.
This histogram was produced by sorting the hash returned by
color_histogram
by increasing frequency.
GetImageHistogram
img.colorize(red_pct, green_pct, blue_pct, [matte_pct, ] fill) -> image
Blend the fill color with the image pixels. The red_pct, green_pct, blue_pct and matte_pct arguments are the percentage to blend with the red, green, blue and matte channels.
.25
is 25%. The matte_pct argument
is optional.A new image
This example converts a color image to a "sepia-tone-ish"
image using the quantize and
colorize
methods.
ColorizeImage
img.colormap(index[, new_color]) -> string
Returns the color in the color map at the specified index. If the new_color argument is specified, replaces the color at that index with the new color.
Raises IndexError if the image does not contain a color map. Only PseudoClass images have a color map.
colormap
raises an IndexError. You can get the number of colors in the
color map from the colors attribute.The name of the color at the specified location in the color map
img.color_point(x, y, fill) -> image
A new image
f.color_point(50,50, 'red')
GetImagePixels, SyncImagePixels
img.color_reset!(fill) -> self
Sets all the pixels in the image to the specified fill color.
f.color_reset!(red)
img.compare_channel(img, metric [, channel...]) -> [image, float]
Compares img with the receiver.
An array. The first element is a difference image, the
second is a the value of the computed distortion represented as
a Float
.
difference, <=>, distortion_channel
ImageCompareChannels
This method was named channel_compare
in
earlier releases of RMagick. That name remains an alias for
compare_channel
.
dest.composite(src, x, y, composite_op) ->
image
dest.composite(src, gravity,
composite_op) ->
image
dest.composite(src, gravity,
x, y,
composite_op) -> image
The composite method can be called three different ways:
A new image
This example shows the effect of some of the composite operators.
composite!, dissolve, watermark
CompositeImage
dest.composite!(src, x, y, composite_op) ->
self
dest.composite!(src, gravity,
composite_op) ->
self
dest.composite!(src, gravity,
x, y,
composite_op) -> self
dest.composite_affine(src, affine) -> image
AffineMatrix
A new image
DrawAffineImage
img.compress_colormap! -> self
Removes duplicate or unused entries in the colormap. Only
PseudoClass images have
a colormap. If the image is DirectClass
then
compress_colormap!
converts it to
PseudoClass
.
f = Image.read('cbezier1.gif').first » cbezier1.gif GIF 500x350+0+0 PseudoClass 128c 8-bit 177503b f.colors » 128 f.compress_colormap! » cbezier1.gif GIF 500x350+0+0 PseudoClass 108c 8-bit 177503b f.colors » 108
CompressColormap
img.contrast(sharpen=false
) ->
image
Enhances or reduces the intensity differences between the lighter and darker elements of the image.
true
, the contrast is increased, otherwise it is
reduced.
A new image
In this example the contrast is reduced in each successive image.
contrast_stretch_channel, sigmoidal_contrast_channel
ContrastImage
img.contrast_stretch_channel(black_point [, white_point] [, channel...]) -> image
This method is a simple image enhancement technique that attempts to improve the contrast in an image by `stretching' the range of intensity values it contains to span a desired range of values. It differs from the more sophisticated histogram equalization in that it can only apply a linear scaling function to the image pixel values. As a result the `enhancement' is less harsh.
all pixels - black_point
pixels
.A new image
ContrastStretchImage
img.convolve(order, kernel) -> image
Applies a custom convolution kernel to the image.
Float
values.A new image
convolve_channel. The edge, emboss, gaussian_blur, motion_blur and sharpen methods use convolution to do their work.
ConvolveImage
See Convolution in the Hypermedia Image Processing Reference
img.convolve_channel(order, kernel [, channel...]) -> image
Applies a custom convolution kernel to the specified channel or channels in the image.
Float
values.A new image
ConvolveImageChannel
img.copy -> other_image
f2 = f.copy
CloneImage
img.crop(x, y, width, height) ->
image
img.crop(gravity, x, y, width, height) -> image
img.crop(gravity, width,
height) -> image
Extracts the specified rectangle from the image.
The crop method can be called three different ways:
crop
method retains the offset
information in the cropped image. This may cause the image to
appear to be surrounded by blank or black space when viewed
with an external viewer. This only occurs when the image is
saved in a format (such as GIF) that saves offset information.
To reset the offset data, add true
as the last
argument to crop
. For example,
cropped = img.crop(x, y, width, height, true)
You can add true
as the last argument with any
of the three argument list formats described above.
A new image
The crop rectangle is highlighted in the "before" image.
CropImage
img.crop!(x, y, width, height) ->
self
img.crop!(gravity, x, y, width, height) -> self
img.crop!(gravity, width,
height) -> self
img.crop_resized(width, height, gravity=CenterGravity) -> image
An alias for resize_to_fill.
img.cycle_colormap(amount) -> image
Displaces the colormap by a given number of positions. If you cycle the colormap a number of times you can produce a psychedelic effect.
The returned image is always a PseudoClass
image, regardless of the type of the original image.
The number of positions to cycle.
A new image
Mouse over the image to see an animation made by cycling the colormap between each copy.
CycleColormapImage
img.delete_profile(profile_name) -> self
Deletes the specified profile. This method is effectively
the same as passing a nil
2nd argument to profile!.
The profile name, "IPTC" or "ICC" for example. Specify "*" to delete all the profiles in the image.
Setting the iptc_profile attribute or color_profile attribute to nil causes the profile to be deleted. Also see strip! and add_profile.
ProfileImage
img.despeckle -> image
Reduces the speckle noise while preserving the edges.
A new image
DespeckleImage
img.destroy! -> self
Returns all the memory associated with the image to the system. After an image has been destroyed, all Image methods (except destroyed? and inspect) called on the image will raise a DestroyedImageError.
It is not possible to recover a destroyed image.
self
img.destroyed? ->
true
or false
Returns true if the image has been destroyed, false otherwise.
img.difference(other) -> array
Compares two images and computes statistics about their difference.
A small normalized mean square error...suggests the images are very similiar in spatial layout and color.
An array of three Float
values:
After difference
returns, these values are also
available from the mean_error_per_pixel,
normalized_mean_error,
and normalized_maximum_error
attributes.
img.dispatch(x, y, columns, rows,
map, float=false
) -> array
Extracts the pixel data from the specified rectangle and
returns it as an array of either Integer
or
Float
values.
The array returned by dispatch
is suitable for
use as an argument to constitute
.
String
reflecting the order of the pixel
data. It can be any combination or
order of R = red, G = green, B = blue, A = alpha, C = cyan, Y
= yellow, M = magenta, K = black, or I = intensity (for
grayscale).true
, the returned array elements will be
Float
values in the range 0..1. If
false
, the returned array elements will be
Integer
values in the range
0..QuantumRange.pixels = f.dispatch(0, 0, f.columns, f.rows, "RGB")
constitute, export_pixels, get_pixels
ExportImagePixels
This method is deprecated in ImageMagick. Use the
export_pixels
method instead.
img.displace(displacement_map, x_amplitude, y_amplitude,
x_offset=0, y_offset=0) -> image
img.displace(displacement_map, x_amplitude, y_amplitude,
gravity, x_offset=0, y_offset=0)
-> image
Uses displacement_map to move color from img to the output image.
This method corresponds to the -displace option of
ImageMagick's composite
command.
The displace
method can be called with or
without a gravity argument. The
gravity, x_offset, and y_offset
arguments are described in the documentation for watermark.
See "Composite Displacement Maps" in Anthony Thyssen's Examples of ImageMagick Usage.
A new image
img.display [ { optional arguments } ] -> self
Display the image on an X Window screen. By default, the screen is the local monitor. Right-click the window to display a context menu.
You can specify additional arguments by setting Info
attributes in a block associated with the method call.
Specifically, you can set the name of a non-default X Window
screen with the server_name
attribute.
self
The display method is not supported on native MS Windows.
DisplayImages
img.dissolve(overlay, src_percentage,
dst_percentage, x_offset=0, y_offset=0)
-> image
img.dissolve(overlay, src_percentage,
dst_percentage, gravity, x_offset=0,
y_offset=0) -> image
Composites the overlay image into the target image. The opacity of img is multiplied by dst_percentage and opacity of overlay is multiplied by src_percentage.
This method corresponds to the -dissolve option of
ImageMagick's composite
command.
The dissolve
method can be called with or
without a gravity argument. The
gravity, x_offset, and y_offset
arguments are described in the documentation for watermark.
See " Dissolve One Image Over Another" in Anthony Thyssen's Examples of ImageMagick Usage.
bgnd.dissolve(overlay, 0.50, 1.0)
A new image
img.distort(type, points,
bestfit=false
) ->
image
Distort an image using the specified distortion type and its required arguments. This method is the equivalent of ImageMagick's -distort option.
Specify one of the following values for the distortion type:
The points argument is an array of numbers. The size of the array depends on the distortion type.
If bestfit is enabled, and the distortion allows it, the destination image is adjusted to ensure the whole source image will just fit within the final destination image, which will be sized and offset accordingly. Also in many cases the virtual offset of the source image will be taken into account in the mapping.
A new image
See Distortion Operator in Anthony Thyssen's excellent Examples of ImageMagick Usage for more information about distortion operations.
img.distortion_channel(reconstructed_image, metric[, channel...]) -> float
(C)ompares one or more image channels of an image to a reconstructed image and returns the specified distortion metric.
The distortion metric, represented as a floating-point number.
GetImageChannelDistortion
img.dup -> other_image