Class: ImageSize

Inherits:
Object
  • Object
show all
Defined in:
lib/image_size.rb

Overview

Determine image format and size

Defined Under Namespace

Classes: FormatError, ImageReader, Size

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(data) ⇒ ImageSize

Given image as any class responding to read and eof? or data as String, finds its format and dimensions



60
61
62
63
64
65
66
# File 'lib/image_size.rb', line 60

def initialize(data)
  ir = ImageReader.new(data)
  @format = detect_format(ir)
  return unless @format

  @width, @height = send("size_of_#{@format}", ir)
end

Instance Attribute Details

#formatObject (readonly)

Image format



69
70
71
# File 'lib/image_size.rb', line 69

def format
  @format
end

#heightObject (readonly) Also known as: h

Image height



76
77
78
# File 'lib/image_size.rb', line 76

def height
  @height
end

#widthObject (readonly) Also known as: w

Image width



72
73
74
# File 'lib/image_size.rb', line 72

def width
  @width
end

Class Method Details

.dpiObject

Used for svg



50
51
52
# File 'lib/image_size.rb', line 50

def self.dpi
  @dpi || 72
end

.dpi=(dpi) ⇒ Object

Used for svg



55
56
57
# File 'lib/image_size.rb', line 55

def self.dpi=(dpi)
  @dpi = dpi.to_f
end

.path(path) ⇒ Object

Given path to image finds its format, width and height



45
46
47
# File 'lib/image_size.rb', line 45

def self.path(path)
  File.open(path, 'rb'){ |f| new(f) }
end

Instance Method Details

#sizeObject

get image width and height as an array which to_s method returns “##widthx##height



80
81
82
# File 'lib/image_size.rb', line 80

def size
  Size.new([width, height]) if format
end