stumpy_core
stumpy_core
Usage
This library is not very useful on its own but there are a few other libraries that allow creating a canvas from an image file or saving one to an image file.
include StumpyCore
rainbow = Canvas.new(256, 256)
(0...255).each do |x|
(0...255).each do |y|
# RGBA.from_rgb_n(values, bit_depth) is an internal helper method
# that creates an RGBA object from a rgb triplet with a given bit depth
color = RGBA.from_rgb_n(x, y, 255, 8)
rainbow[x, y] = color
end
end
# It is also possible to provide a background color,
# the default is transparent black `RGBA.new(0, 0, 0, 0)`
white = Canvas.new(256, 256, RGBA.from_hex("#ffffff"))
# If the colors for all pixels are already known when creating the canvas,
# the block syntax can be used to simplify the code:
rainbow2 = Canvas.new(256, 256) { |x, y| RGBA.from_rgb_n(x, y, 255, 8) }
checkerboard = Canvas.new(256, 256) do |x, y|
if ((x / 32) + (y / 32)).odd?
RGBA.from_hex("#ffffff")
else
RGBA.from_hex("#000000")
end
end
spectrum = Canvas.new(361, 101) { |x, y| RGBA.from_hsl(x, 100, y) }
spectrum2 = Canvas.new(361, 101) { |x, y| RGBA.from_hsba([x, 100, y], 1) }

Interface
-
StumpyCore::RGBA, 16-bit rgba colorrgba.rred channelrgba.ggreen channelrgba.bblue channelrgba.aalpha channelrgba.to_rgba8returns a tuple of 4 8-bit values{ r, g, b, a}rgba.to_rgb8returns a tuple of 3 8-bit values{ r, g, b }- Helper functions to create colors from n-bit values:
-
StumpyCore::RGBA.from_gray_n(grayscale_value, n) -
StumpyCore::RGBA.from_graya_n(grayscale_value, alpha, n) -
StumpyCore::RGBA.from_rgb_n(r, g, b, n) -
StumpyCore::RGBA.from_rgba_n(r, g, b, alpha, n)where alpha =0..1 -
StumpyCore::RGBA.from_hsl(h, s, l)whereh =
0..360°, s =0..100%, l =0..100% -
StumpyCore::RGBA.from_hsla(h, s, l, alpha) -
StumpyCore::RGBA.from_hsv(h, s, v)orStumpyCore::RGBA.from_hsb(h, s, b)whereh =
0..360°, s =0..100%, b or v =0..100% -
StumpyCore::RGBA.from_hsva(h, s, v, alpha)orStumpyCore::RGBA.from_hsba(h, s, b, alpha)where alpha =0..1 -
All of the above (except
from_gray_n) work with tuples/arrays, too:(
StumpyCore::RGBA.from_rgba_n({r, g, b, alpha}, n)) -
StumpyCore::RGBA.from_hex(color), e.g.color = "#ff0000"
-
-
StumpyCore::Canvas, two dimensional Array of RGBA valuecanvas.widthcanvas.heightcanvas[x, y] = colorto set a color,xandyneed to be in range!canvas[x, y]to get a color,xandyneed to be in range!canvas.set(x, y, color)same ascanvas[x, y] = colorcanvas.get(x, y)same ascanvas[x, y]canvas.safe_set(x, y, color)returns true if setting the color was successfulcanvas.safe_get(x, y)returnsnilifxoryare invalidcanvas.wrapping_set(x, y, color)setcombined with modulo, to ensurexandyare in rangecanvas.wrapping_get(x, y)getcombined with modulo, to ensurexandyare in range
Contributors
Thanks goes to these wonderful people (emoji key):
|
Leon
💻 |
Ian Rash
💻 |
Sam
💻 |
| :---: | :---: | :---: |
This project follows the all-contributors specification. Contributions of any kind welcome!