ReC98/th01/formats/grz.h

60 lines
2.0 KiB
C
Raw Normal View History

/// Run-length encoded, 16-color + alpha, 640×400 image format
/// ----------------------------------------------------------
/// In contrast to .GRF, .GRX decouples the RLE command stream from the pixel
/// data. This allows either multiple pixel streams (stored as planar8_t) to
/// be used with the same RLE stream, or the RLE stream to be used on its own
/// for a monochrome byte-aligned pattern.
// RLE stream format
enum grx_rle_t {
// Puts the next byte from the pixel data source. No parameters.
GC_PUT = 0,
// Followed by:
// * a uint8_t with the length of this run in 8-dot units
// * a uint8_t with the command to use for all runs (0 = put, everything
// else = skip)
GC_RUN = 1,
};
// Static arrays
#define GRX_COUNT 16
#define PLANAR_STREAM_PER_GRX_COUNT 16
// File format limit
#define GRZ_IMAGE_COUNT 16
// Loading
// -------
// All of these load the file with the given [fn] into the given [slot],
// automatically freeing any previously loaded image in there, and return 0
// on success or 1 on failure.
// Loads the [n]th GRX image, with all of its planar streams, from a .GRZ
// file.
int grz_load_single(unsigned int slot, const char *fn, int n);
// Loads the given .GRX file, with all of its planar streams.
int grx_load(unsigned int slot, const char *fn);
// Loads only the RLE stream of the given .GRX file.
int grx_load_noplanar(unsigned int slot, const char *fn);
// -------
// Display
// -------
// Equivalent to grz_put_stream(slot, 0);
void grx_put(unsigned int slot);
// Displays the planar stream with the given number of the image loaded into
// the given GRX [slot].
void grx_put_stream(unsigned int slot, int planar_stream);
// Renders only the RLE stream in the given [col] via the GRCG, using a 0xFF
// pattern for every 8 dots to be displayed.
void grx_put_col(unsigned int slot, uint4_t col);
// -------
// Frees both the RLE and any planar streams in the given GRX [slot].
void grx_free(unsigned int slot);
/// ----------------------------------------------------------