class ImageScience
Provides a clean and simple API to generate thumbnails using FreeImage as the underlying mechanism.
For more information or if you have build issues with FreeImage, see seattlerb.rubyforge.org/ImageScience.html
Constants
- VERSION
Public Class Methods
The top-level image loader opens path
and then yields the
image.
# File lib/image_science.rb, line 21
The top-level image loader, opens an image from the string
data
and then yields the image.
# File lib/image_science.rb, line 27
Public Instance Methods
Creates a square thumbnail of the image cropping the longest edge to match
the shortest edge, resizes to size
, and yields the new image.
# File lib/image_science.rb, line 73 def cropped_thumbnail(size) # :yields: image w, h = width, height l, t, r, b, half = 0, 0, w, h, (w - h).abs / 2 l, r = half, half + h if w > h t, b = half, half + w if h > w with_crop(l, t, r, b) do |img| img.thumbnail(size) do |thumb| yield thumb end end end
Returns the height of the image, in pixels.
# File lib/image_science.rb, line 43
Resizes the image to width
and height
using a
cubic-bspline filter and yields the new image.
# File lib/image_science.rb, line 55
Saves the image out to path
. Changing the file extension will
convert the file type to the appropriate format.
# File lib/image_science.rb, line 49
Creates a proportional thumbnail of the image scaled so its longest edge is
resized to size
and yields the new image.
# File lib/image_science.rb, line 59 def thumbnail(size) # :yields: image w, h = width, height scale = size.to_f / (w > h ? w : h) self.resize((w * scale).round, (h * scale).round) do |image| yield image end end
Returns the width of the image, in pixels.
# File lib/image_science.rb, line 38
Crops an image to left
, top
, right
,
and bottom
and then yields the new image.
# File lib/image_science.rb, line 33