2016-07-25 09:04:22 +02:00
|
|
|
#ifndef _INTERNALS_BOPTI_H
|
2017-03-26 18:38:32 +02:00
|
|
|
#define _INTERNALS_BOPTI_H
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
#include <stdint.h>
|
2016-07-14 21:10:51 +02:00
|
|
|
#include <display.h>
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
2017-04-13 21:59:13 +02:00
|
|
|
channel_t
|
|
|
|
Indicates what operation a layer is made for. Each operation affects
|
|
|
|
the video ram differently (setting or clearing pixels, transparency,
|
|
|
|
etc). An image is made of several layers.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
typedef enum
|
2016-07-06 11:28:51 +02:00
|
|
|
{
|
2017-04-13 21:59:13 +02:00
|
|
|
channel_full_alpha = 0x01,
|
|
|
|
channel_light_alpha = 0x02,
|
|
|
|
channel_dark_alpha = 0x04,
|
2016-07-06 11:28:51 +02:00
|
|
|
|
2017-04-13 21:59:13 +02:00
|
|
|
channel_mono = 0x08,
|
|
|
|
channel_light = 0x10,
|
|
|
|
channel_dark = 0x20,
|
|
|
|
|
|
|
|
} channel_t;
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
2017-04-13 21:59:13 +02:00
|
|
|
format_t
|
|
|
|
Describes the various combination of layer channels that are allowed by
|
|
|
|
bopti. Technically one could try other formats but they're not of much
|
|
|
|
use (transparent gray is even totally useless).
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
typedef enum
|
2016-07-06 11:28:51 +02:00
|
|
|
{
|
2017-04-13 21:59:13 +02:00
|
|
|
format_mono = channel_mono,
|
|
|
|
format_mono_alpha = format_mono | channel_full_alpha,
|
|
|
|
format_gray = channel_light | channel_dark,
|
|
|
|
format_gray_alpha = format_gray | channel_full_alpha,
|
|
|
|
format_greater_alpha = format_mono | channel_light_alpha |
|
|
|
|
channel_dark_alpha
|
|
|
|
} format_t;
|
2016-07-06 11:28:51 +02:00
|
|
|
|
2016-07-14 21:10:51 +02:00
|
|
|
/*
|
2017-04-13 21:59:13 +02:00
|
|
|
structure_t
|
|
|
|
Basically an image's dimensions, data pointer, and a few other useful
|
|
|
|
information such as the pitch in bytes.
|
2016-07-14 21:10:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
typedef struct
|
2016-07-14 21:10:51 +02:00
|
|
|
{
|
|
|
|
int width, height;
|
|
|
|
int layer_size;
|
|
|
|
|
2017-01-20 21:11:00 +01:00
|
|
|
const uint8_t *data;
|
2016-07-14 21:10:51 +02:00
|
|
|
int columns;
|
|
|
|
int end_size, end_bytes;
|
2017-04-13 21:59:13 +02:00
|
|
|
|
|
|
|
} structure_t;
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
/*
|
2017-04-13 21:59:13 +02:00
|
|
|
command_t
|
|
|
|
The parameters of a drawing operation. A pointer to such a structure is
|
|
|
|
created by the public functions and passed down to the module's
|
|
|
|
sub-functions during rendering.
|
2016-07-14 21:10:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
typedef struct command_t
|
2016-07-14 21:10:51 +02:00
|
|
|
{
|
|
|
|
// Channel being drawn.
|
2017-04-13 21:59:13 +02:00
|
|
|
channel_t channel;
|
2016-07-14 21:10:51 +02:00
|
|
|
// Operation used (whether bopti_op_mono() or bopti_op_gray()).
|
2017-04-13 21:59:13 +02:00
|
|
|
void (*op)(int offset, uint32_t operator, struct command_t *command);
|
2016-07-14 21:10:51 +02:00
|
|
|
// Portion of the bitmap which is drawn. 'top' and 'bottom' refer to
|
|
|
|
// lines where 'left' and 'right' refer to column ids.
|
|
|
|
int left, right, top, bottom;
|
|
|
|
// Position of the bitmap on the screen.
|
|
|
|
int x, y;
|
2017-04-13 21:59:13 +02:00
|
|
|
// Rectangle masks that define the drawing area.
|
2016-07-14 21:10:51 +02:00
|
|
|
uint32_t masks[4];
|
2017-04-13 21:59:13 +02:00
|
|
|
// Video rams being used.
|
|
|
|
union {
|
|
|
|
// Different names, same fate. (Kingdom Hearts II)
|
|
|
|
uint32_t *vram;
|
|
|
|
uint32_t *v1;
|
|
|
|
};
|
|
|
|
uint32_t *v2;
|
|
|
|
|
|
|
|
} command_t;
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
// The video ram addresses are set by the public functions and used internally
|
|
|
|
// by the module.
|
|
|
|
// Monochrome video ram, light and dark buffers (in this order).
|
2017-03-26 18:38:32 +02:00
|
|
|
extern uint32_t *bopti_vram, *bopti_v1, *bopti_v2;
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
2017-04-13 21:59:13 +02:00
|
|
|
// Internal bopti routines.
|
2016-07-06 11:28:51 +02:00
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
bopti_op()
|
|
|
|
Operates on a vram long. The operator will often not contain 32 bits of
|
|
|
|
image information. Since neutral bits are not the same for all
|
2016-07-14 21:10:51 +02:00
|
|
|
operations, a mask is used to indicate which bits should be used for
|
|
|
|
the operation. This mask is taken for the image's rectangle masks (see
|
2017-04-13 21:59:13 +02:00
|
|
|
the 'display' module internal header for more information on rectangle
|
|
|
|
masks). Which operation is performed is determined by the channel
|
|
|
|
setting of the command argument.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
void bopti_op_mono(int offset, uint32_t operator, command_t *c);
|
|
|
|
void bopti_op_gray(int offset, uint32_t operator, command_t *c);
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
bopti_grid() -- general form
|
|
|
|
bopti_grid_a32() -- when x is a multiple of 32
|
|
|
|
|
|
|
|
Draws the grid at the beginning of a layer's data. The length of this
|
|
|
|
grid is always a multiple of 32.
|
|
|
|
The need for bopti_grid_a32() is not only linked to optimization,
|
|
|
|
because bopti_grid() will perform a 32-bit shift when x is a multiple
|
|
|
|
of 32, which is undefined behavior.
|
2017-04-13 21:59:13 +02:00
|
|
|
bopti_grid() automatically calls bopti_grid_a32() when required.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2016-07-14 21:10:51 +02:00
|
|
|
void bopti_grid_a32(const uint32_t *layer, int columns, int height,
|
2017-04-13 21:59:13 +02:00
|
|
|
command_t *c);
|
|
|
|
void bopti_grid(const uint32_t *layer, int columns, int height, command_t *c);
|
2016-07-06 11:28:51 +02:00
|
|
|
/*
|
|
|
|
bopti_end_get()
|
|
|
|
Returns an operator for the end of a line, whose width is lower than 32
|
|
|
|
(by design: otherwise, it would have been a column). The given pointer
|
|
|
|
is read and updated so that it points to the next line at the end of
|
|
|
|
the operation.
|
|
|
|
*/
|
|
|
|
uint32_t bopti_end_get1(const unsigned char **data);
|
|
|
|
uint32_t bopti_end_get2(const unsigned char **data);
|
|
|
|
|
|
|
|
/*
|
|
|
|
bopti_rest() -- general form
|
|
|
|
bopti_rest_nover() -- when the end does not overlap two vram longs
|
|
|
|
|
|
|
|
Draws the end of a layer, which can be considered as a whole layer
|
|
|
|
whose with is lower than 32. (Actually is it lower or equal to 16;
|
2016-07-14 21:10:51 +02:00
|
|
|
otherwise it would have been a column and the end would be empty). The
|
2017-04-13 21:59:13 +02:00
|
|
|
'size' arguments is in bytes, thus 1 or 2.
|
2016-07-14 21:10:51 +02:00
|
|
|
Unlike bopti_grid_a32(), bopti_end_nover() is not called automatically
|
|
|
|
by bopti_end().
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
void bopti_end_nover(const unsigned char *end, int size, command_t *c);
|
|
|
|
void bopti_end(const unsigned char *end, int size, command_t *c);
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
bopti()
|
2017-04-13 21:59:13 +02:00
|
|
|
Draws a layer's data in the video ram areas specified in the command
|
|
|
|
argument.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
void bopti(const unsigned char *layer, structure_t *s, command_t *c);
|
2016-07-06 11:28:51 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
getStructure()
|
2017-04-13 21:59:13 +02:00
|
|
|
Determines the image size (large images have a somehow different
|
|
|
|
structure), the data pointer and a few dimensions inside the image.
|
2016-07-06 11:28:51 +02:00
|
|
|
*/
|
2017-04-13 21:59:13 +02:00
|
|
|
void getStructure(image_t *img, structure_t *structure);
|
2016-07-06 11:28:51 +02:00
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
#endif // _INTERNALS_BOPTI_H
|