mirror of
https://git.planet-casio.com/Lephenixnoir/gint.git
synced 2025-01-04 07:53:34 +01:00
73 lines
1.7 KiB
C
73 lines
1.7 KiB
C
//---
|
|
//
|
|
// gint drawing module: bopti
|
|
//
|
|
// This module is a powerful bitmap renderer. It *heavily* relies on the
|
|
// line-based structure of the video RAM as well as the high density of
|
|
// information. A single CPU access (longword operation) can affect 32
|
|
// pixels at once, which is crucial for performance. The same goes for all
|
|
// other drawing modules, but this one typically has 350 lines of code
|
|
// just to wrap these longword accesses -- and it's blazingly fast.
|
|
//
|
|
//---
|
|
|
|
#ifndef _BOPTI_H
|
|
#define _BOPTI_H
|
|
|
|
/*
|
|
image_t
|
|
This structure holds meta-data of a bitmap encoded with fxconv. Data is
|
|
accessed using longword operations for performance considerations,
|
|
which requires that the all fields of the structure be properly aligned
|
|
and of a correct size.
|
|
*/
|
|
typedef struct
|
|
{
|
|
uint8_t magic;
|
|
uint8_t format;
|
|
|
|
uint8_t width;
|
|
uint8_t height;
|
|
|
|
const uint32_t data[];
|
|
|
|
} __attribute__((packed, aligned(4))) image_t;
|
|
|
|
/*
|
|
dimage()
|
|
Displays a monochrome image in the vram. This function does a real lot
|
|
of optimization.
|
|
*/
|
|
void dimage(int x, int y, image_t *image);
|
|
|
|
/*
|
|
dimage_part()
|
|
Draws a portion of an image, defined by its bounding rectangle.
|
|
Point (left, top) is included, but (left + width, top + height) is
|
|
excluded.
|
|
*/
|
|
void dimage_part(
|
|
int x, int y,
|
|
image_t *img,
|
|
int left, int top, int width, int height
|
|
);
|
|
|
|
/*
|
|
gimage()
|
|
Displays a gray image in the dual-vram.
|
|
*/
|
|
void gimage(int x, int y, image_t *image);
|
|
|
|
/*
|
|
gimage_part()
|
|
Draws a portion of a gray image, defined by its bounding rectangle.
|
|
Point (left, top) is included, but (left + width, top + height) is
|
|
excluded.
|
|
*/
|
|
void gimage_part(
|
|
int x, int y,
|
|
image_t *image,
|
|
int left, int top, int width, int height
|
|
);
|
|
|
|
#endif // _BOPTI_H
|