Module: ChunkyPNG::Canvas::StreamExporting

Included in:
ChunkyPNG::Canvas
Defined in:
lib/chunky_png/canvas/stream_exporting.rb

Overview

Methods to save load a canvas from to stream, encoded in RGB, RGBA, BGR or ABGR format.

Instance Method Summary collapse

Instance Method Details

#to_abgr_streamString

Creates an ABGR-formatted pixelstream with the pixel data from this canvas.

Note that this format is fast but bloated, because no compression is used and the internal representation is left intact. To reconstruct the canvas, the width and height should be known.

Returns:

  • (String)

    The RGBA-formatted pixel data.



53
54
55
# File 'lib/chunky_png/canvas/stream_exporting.rb', line 53

def to_abgr_stream
  pixels.pack("V*")
end

#to_alpha_channel_streamString

Creates a stream of the alpha channel of this canvas.

Returns:

  • (String)

    The 0-255 alpha values of all pixels packed as string



32
33
34
# File 'lib/chunky_png/canvas/stream_exporting.rb', line 32

def to_alpha_channel_stream
  pixels.pack("C*")
end

#to_grayscale_streamString

Creates a grayscale stream of this canvas.

This method assume sthat this image is fully grayscale, i.e. R = G = B for every pixel. The alpha channel will not be included in the stream.

Returns:

  • (String)

    The 0-255 grayscale values of all pixels packed as string.



42
43
44
# File 'lib/chunky_png/canvas/stream_exporting.rb', line 42

def to_grayscale_stream
  pixels.pack("nX" * pixels.length)
end

#to_rgb_streamString

Creates an RGB-formatted pixelstream with the pixel data from this canvas.

Note that this format is fast but bloated, because no compression is used and the internal representation is almost left intact. To reconstruct the canvas, the width and height should be known.

Returns:

  • (String)

    The RGB-formatted pixel data.



25
26
27
# File 'lib/chunky_png/canvas/stream_exporting.rb', line 25

def to_rgb_stream
  pixels.pack("NX" * pixels.length)
end

#to_rgba_streamString

Creates an RGB-formatted pixelstream with the pixel data from this canvas.

Note that this format is fast but bloated, because no compression is used and the internal representation is left intact. To reconstruct the canvas, the width and height should be known.

Returns:

  • (String)

    The RGBA-formatted pixel data.



14
15
16
# File 'lib/chunky_png/canvas/stream_exporting.rb', line 14

def to_rgba_stream
  pixels.pack("N*")
end