Sha256: c2b30f4f65b1ae5ab36ddaaf78a66f28174386455e578ed78deae72b9c6bc5e0
Contents?: true
Size: 1.61 KB
Versions: 1
Compression:
Stored size: 1.61 KB
Contents
# A colour object representing YIQ (NTSC) colour encoding. class Color::YIQ # Creates a YIQ colour object from fractional values 0 .. 1. # # Color::YIQ.new(0.3, 0.2, 0.1) def self.from_fraction(y = 0, i = 0, q = 0) color = Color::YIQ.new color.y = y color.i = i color.q = q color end # Creates a YIQ colour object from percentages 0 .. 100. # # Color::YIQ.new(10, 20, 30) def initialize(y = 0, i = 0, q = 0) @y = y / 100.0 @i = i / 100.0 @q = q / 100.0 end # Compares the other colour to this one. The other colour will be # converted to YIQ before comparison, so the comparison between a YIQ # colour and a non-YIQ colour will be approximate and based on the other # colour's #to_yiq conversion. If there is no #to_yiq conversion, this # will raise an exception. This will report that two YIQ values are # equivalent if all component colours are within COLOR_TOLERANCE of each # other. def ==(other) other = other.to_yiq other.kind_of?(Color::YIQ) and ((@y - other.y).abs <= Color::COLOR_TOLERANCE) and ((@i - other.i).abs <= Color::COLOR_TOLERANCE) and ((@q - other.q).abs <= Color::COLOR_TOLERANCE) end def to_yiq self end def brightness @y end def to_grayscale Color::GrayScale.new(@y) end alias to_greyscale to_grayscale def y @y end def y=(yy) @y = Color.normalize(yy) end def i @i end def i=(ii) @i = Color.normalize(ii) end def q @q end def q=(qq) @q = Color.normalize(qq) end def inspect "YIQ [%.2f%%, %.2f%%, %.2f%%]" % [ @y * 100, @i * 100, @q * 100 ] end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
color-1.4.2 | lib/color/yiq.rb |