Some Image
and ImageList
methods, such as read
and write
, accept an "optional arguments" block in
which you can set attributes that modify the method's output. These attributes belong to the Image::Info
class. The
Image::Info
class exists only to accept optional arguments for those
Image
and ImageList
methods.
This page explains the methods defined in the
Image::Info
class. Generally, each Image
or ImageList
method that uses the Image::Info
class to get
optional arguments will only accept some of the attributes listed on this page, that is, only those attributes that are meaningful for the particular
method. Any other attributes that you set are ignored. Also, some attributes are only used by a subset of the image formats. See the ImageMagick
documentation for more information.
Remember, you do not ever need to create an
Image::Info
object. The object is created for you before the optional arguments block is entered and destroyed after the block is exited.
All the attributes in the Image::Info
class are read/write. For simplicity, and because usually you only set these attributes, this page
only describes the setter version of each attribute method.
self[format, key] = value ->
self
self[key] = value -> self
Define an option. An alternative to define, below. Use this method to set options for reading or writing certain image formats. The list of supported options changes from release to release. For a list of the valid image formats, keys, and values, refer to the documentation for the -define option for the release of ImageMagick installed on your system.
to_s
. Use nil
to set the key to a
null value.
The "user" option is unique to RMagick. It may be set to any string. If this option is used when creating an image via one of the methods listed below
then the new image gets the value assigned as a property as if
img["user"]
had been used. In addition, the value is displayed in the string returned by Image#inspect
. The "user" property
can be used to help distinguish otherwise similar images when debugging.
For example,
img = Magick::Image.new(10,10) do |options| options['user'] = __FILE__ + ':' + __LINE__.to_s end #=> 10x10 DirectClass 16-bit user:test.rb:3
These methods propagate the value of the "user" option to new image(s):
Image.new, ImageList.new, ImageList.new_image, Image.capture, Image.from_blob, ImageList.from_blob, Image.read, ImageList.read, Image.read_inline,
and Image.ping
.
self
options["tiff", "bits-per-sample"] = 2
SetImageOption
self[format, key] -> value
self[key] ->
value
Returns the value of the specified option for the specified format.
The value of the option. Always a string.
options["tiff", "bits-per-sample"] #=> 2
GetImageOption
self.channel([channel [, channel...]])
Restrict the method to the specified channel(s). This attribute is set-only.
The arguments may be any ChannelType values.
If you call channel
with no arguments, all channels are included. If you do not call channel
at all, the channels
used do not include the alpha channel.
self.define(format, key[, value])
Define a format-specific option. See []=, above.
to_s
. If omitted, the key is simply defined to
an null value.
self
options.define("tiff", "bits-per-sample", 2)
SetImageOption
self.undefine(format, key)
Delete an option definition set by []= or define. This is not the same as setting the option to a null value.
The undefine
method removes the option name from the list of options for the specified format.
self
options.undefine("tiff", "bits-per-sample")
self.antialias= true
or
false
Control antialiasing of rendered Postscript and Postscript or TrueType fonts.
The default is true
.
self.attenuate= number
Lessen (or intensify) when adding noise to an image.
self.authenticate= string
Decrypt an image with this password.
This attribute can be used to specify the password to be used when reading an image or image sequence that is in an encrypted format, such as PDF.
self.background_color= string or pixel
Set the image background color. The default is "white".
A color name or a Pixel.
self.border_color= string or pixel
Set the image border color. The default is "#dfdfdf".
A color name or a Pixel.
self.caption= string
When used with Image.read, assigns a caption to an image. The caption is an image property:
img = Magick::Image.read("xc:white") do |options| options.caption = "a new caption" options.size = "20x20" end p img.first.properties #=> {"caption"=>"a new caption"} p img.first['caption'] #=> "a new caption"
A string.
self.colorspace= colorspace
self.comment= string
Use this option to assign a specific comment to the image, when writing to an image format that supports comments.
You can include the image filename, type, width, height, or other image attribute by embedding special format characters listed under the annotate method.
self.compression= type
Specifies the type of compression used when writing the image. Only some image formats support compression. For those that do, only some compression types are supported. If you specify an compression type that is not supported, the default compression type (usually NoCompression) is used instead.
Some compression types support varying levels of compression. See the
quality
attribute.
The following table shows the image formats that support compression. For each format, the right-hand column shows the supported compression types. The default compression type is shown in bold.
Format | Compression Types |
---|---|
BMP | NoCompression, RLECompression |
DIB | NoCompression, RLECompression |
FPX | NoCompression, JPEGCompression |
GIF | LZWCompression |
JNG | NoCompression, JPEGCompression |
JP2 | JPEGCompression, LosslessJPEGCompression |
JPG | JPEGCompression, LosslessJPEGCompression |
MIFF | NoCompression, RLECompression |
MNG | NoCompression, JPEGCompression |
PALM | NoCompression, FaxCompression, RLECompression |
PDB | NoCompression, RLECompression |
NoCompression, JPEGCompression, LZWCompression, ZipCompression | |
PICT | NoCompression, JPEGCompression |
PNG | NoCompression, ZIPCompression |
PS | NoCompression, RLECompression |
PS2 | RLECompression, FaxCompression, JPEGCompression, LZWCompression, NoCompression |
PS3 | FaxCompression, JPEGCompression, LZWCompression, NoCompression, RLECompression, ZipCompression |
TIFF | NoCompression, FaxCompression, Group4Compression, JPEGCompression, LZWCompression, RLECompression, ZipCompression |
self.density= string or geometry
Specifies the vertical and horizontal resolution in pixels. The default density is "72.0x72.0". This attribute can be used when writing JBIG, PCL, PS, PS2, and PS3 format images.
This attribute can also be used to specify the width and height of HISTOGRAM format images. For HISTOGRAM, the default is 256x200.
The argument can be either a string in the form "XxY" where "X" is the horizontal resolution and "Y" is the vertical resolution, or a
Geometry object where width
is the horizontal resolution and height
is the vertical
resolution.
self.delay= integer
This attribute is useful for regulating the animation of image sequences. delay/100 seconds must expire before the display of the next image. The default is no delay between each showing of the image sequence. The maximum delay is 65535.
self.depth= integer
Specifies the image depth.
Either 8, 16, or 32. You can specify 16 and 32 only when ImageMagick was compiled with a QuantumDepth that allows these depth values.
Use depth
to specify the depth of CMYK, GRAY, RGB, RGBA, MAP, and XC format images. See also size
.
self.dispose= type
The argument indicates the way in which the graphic is to be treated after being displayed.
A DisposeType constant.
self.dither= true
or
false
This attribute can be used when writing GIF images.
Apply Floyd/Steinberg error diffusion to the image. The basic strategy of dithering is to trade intensity resolution for spatial resolution by averaging the intensities of several neighboring pixels. Images which suffer from severe contouring when reducing colors can be improved with this option.
self.endian= type
Specify the endian of the image when reading the image file.
One of the following Magick::EndianType enum values:
self.extract= string or geometry
Specifies a portion of an image to be extracted when the image is constituted. This attribute can be used to identify a subset of an image that is otherwise too large to keep in memory.
Either a geometry string or a
Geometry object. For example: options.extract = "200x200+100+100"
.
self.filename= string
See capture.
self.fill= string or pixel
Specifies the fill color to use when creating an image with the "caption:" format..
A color name or a pixel.
self.font= string
Set the text rendering font.
self.format= string
self.fuzz= number or string
Set the level of "fuzziness" for comparing pixels. By default the pixels must be identical to be considered equal. The larger the
fuzz
value the more difference is tolerated. See Image#fuzz.
The argument may be a numeric value or a string in the form "NN%". In the second case, the argument is computed as a percentage of
QuantumRange. For example, a value of '5%' sets fuzz
to 0.05*QuantumRange.
self.gravity= gravity
The direction text gravitates to when annotating the image.
The direction you choose specifies where to position the text when annotating the image. For example, a gravity of
CenterGravity
forces the text to be centered within the image. By default, the image gravity is NorthWestGravity
.
This attribute can be used to position the text when creating an image with the "caption:" format.
A GravityType constant.
self.image_type= image_type
The image type classification. For example, GrayscaleType. Don't confuse this attribute with the format such as "GIF" or "JPG".
An ImageType constant.
self.interlace= type
[S]pecify the type of interlacing scheme for raw image formats such as RGB or YUV. NoInterlace means do not interlace, LineInterlace uses scanline interlacing, and PlaneInterlace uses plane interlacing. PartitionInterlace is like PlaneInterlace except the different planes are saved to individual files (e.g. image.R, image.G, and image.B). Use LineInterlace or PlaneInterlace to create an interlaced GIF or progressive JPEG image. The default is NoInterlace.
An InterlaceType constant.
self.label= string
Use this option to assign a specific label to the image, when writing to an image format that supports labels, such as TIFF, PNG, MIFF, or PostScript. You can include the the image filename, type, width, height, or other image attribute by embedding special format characters. See annotate for details.
self.matte_color= string or pixel
Set the image transparent color. The default is "#bdbdbd".
A color name or a pixel.
self.monochrome= true
or
false
self.number_scenes= integer
Set the scene number of an image or the first image in a sequence.
self.orientation=type
self.origin=string or geometry
Set the image origin.
A geometry string of the form +x+y
(a "-" may be used instead of "+" to indicate a negative offset) or
a Geometry object.
self.page= string or geometry
Set the equivalent size of the Postscript page. The default is "612x792>".
A geometry string or a Geometry object.
self.pointsize= number
Set the font size in points. Useful when creating "caption:" format images, for example.
self.quality= integer
The compression level for JPEG, MPEG, JPEG-2000, MIFF, MNG, and PNG image format. Corresponds to ImageMagick's -quality option. The default is 75. See Compressing image files.
self.sampling_factor= string
sampling factors used by JPEG or MPEG-2 encoder and YUV decoder/encoder.
This attribute specifies the sampling factors to be used by the JPEG encoder for chroma downsampling. If this attribute is omitted, the JPEG library will use its own default values. When reading or writing the YUV format and when writing the M2V (MPEG-2) format, use sampling-factor="2x1" to specify the 4:2:2 downsampling method.
A string in the form "horizontal-factorxvertical-factor"
self.scene= number
Set the scene number of an image or the first image in a sequence.
self.server_name= string
Set the X11 display to obtain fonts from.
self.size= string or geometry
Set the width and height of the image when reading a built-in image format that does not have an inherent size, or when reading an image from a multi-resolution file format such as Photo CD, JBIG, or JPEG.
Use size
to specify the width and height of images in the CMYK, DIB, EMF, GRAY, RGB, RGBA, UYVY, YUV, or XC formats, the width and height
of some built in formats, or the subimage size of PTIF-format images.
A geometry string or a Geometry object.
self.stroke= string or pixel
Specifies the stroke color to use when creating an image with the "caption:" format..
A color name or a pixel.
self.stroke_width= number
Specifies the stroke width to use when creating an image with the "caption:" format..
The stroke width.
self.texture= image
Set a texture to tile onto the image background. Corresponds to the -texture option to ImageMagick's convert and mogrify commands. This attribute is set-only.
An image
self.transparent_color= string or pixel
The transparent color. Sometimes used for saving to image formats such as GIF and PNG8 which uses this color to represent boolean transparency. This does not make a color transparent, just defines what color the transparent color will be in the color palette of the saved image.
This attribute allows you to have both a opaque visible color as well as a transparent color of the same color value without conflict. That is you can use the same color for both the transparent and opaque color areas within an image. This in turn frees to you to select a transparent color that is appropriate when a image is displayed by application that does not handle a transparent color index, while allowing RMagick to correctly handle images of this type.
self.tile_offset= string or geometry
Specifies the offset for tile images, relative to the background image it will be tiled on.
This attribute is useful with the "tile:" and "pattern:" image formats.
A geometry string or a Geometry object.
self.undercolor= string or pixel
Specifies the undercolor color to use when creating an image with the "caption:" format..
A color name or a pixel.
self.units= unit
self.view= string
FlashPix viewing parameters.