2016-05-20 22:04:15 +02:00
|
|
|
//---
|
2016-07-04 18:30:25 +02:00
|
|
|
//
|
|
|
|
// gint drawing module: display
|
|
|
|
//
|
|
|
|
// Handles vram manipulation and drawing for plain monochrome display.
|
|
|
|
//
|
2016-05-20 22:04:15 +02:00
|
|
|
//---
|
|
|
|
|
2016-07-04 18:30:25 +02:00
|
|
|
#ifndef _DISPLAY_H
|
|
|
|
#define _DISPLAY_H 1
|
2016-05-20 22:04:15 +02:00
|
|
|
|
2017-01-20 21:11:00 +01:00
|
|
|
#include <stdint.h>
|
2017-02-25 19:02:07 +01:00
|
|
|
#include <stddef.h>
|
2017-01-20 21:11:00 +01:00
|
|
|
|
2016-05-20 22:04:15 +02:00
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
2016-07-04 18:30:25 +02:00
|
|
|
// Heading declarations.
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
|
2016-07-04 18:30:25 +02:00
|
|
|
enum Color
|
2016-05-05 11:49:05 +02:00
|
|
|
{
|
2016-07-04 18:30:25 +02:00
|
|
|
Color_White = 0,
|
|
|
|
Color_Light = 1,
|
|
|
|
Color_Dark = 2,
|
|
|
|
Color_Black = 3,
|
|
|
|
Color_None = 4,
|
|
|
|
Color_Invert = 5,
|
2016-05-05 11:49:05 +02:00
|
|
|
};
|
|
|
|
|
2016-07-28 18:12:07 +02:00
|
|
|
// This header needs enum Color to be defined.
|
|
|
|
#include <tales.h>
|
|
|
|
|
2016-05-05 22:33:15 +02:00
|
|
|
/*
|
|
|
|
struct Image
|
|
|
|
This structure holds information about a bitmap encoded with fxconv.
|
|
|
|
Data is accessed using longword operations, which *requires* many
|
|
|
|
sizes to be multiples of 4 (structure alignment, data alignment, layer
|
|
|
|
size, ...).
|
|
|
|
*/
|
2016-05-05 11:49:05 +02:00
|
|
|
struct Image
|
|
|
|
{
|
2017-01-20 21:11:00 +01:00
|
|
|
uint8_t magic;
|
|
|
|
uint8_t format;
|
2016-05-20 22:04:15 +02:00
|
|
|
|
2017-01-20 21:11:00 +01:00
|
|
|
uint8_t width;
|
|
|
|
uint8_t height;
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2017-01-20 21:11:00 +01:00
|
|
|
const uint32_t data[];
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2017-01-20 21:11:00 +01:00
|
|
|
} __attribute__((packed, aligned(4)));
|
2016-05-05 22:33:15 +02:00
|
|
|
// Useful shorthand for user code.
|
2016-05-05 11:49:05 +02:00
|
|
|
typedef struct Image Image;
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-05-05 22:33:15 +02:00
|
|
|
// A few other constants.
|
2016-05-05 11:49:05 +02:00
|
|
|
#define DISPLAY_WIDTH 128
|
|
|
|
#define DISPLAY_HEIGHT 64
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Generic functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
display_getLocalVRAM()
|
2016-07-04 18:30:25 +02:00
|
|
|
Returns the local video ram address. This function always return the
|
|
|
|
same address.
|
2016-05-05 22:33:15 +02:00
|
|
|
The buffer returned by this function should not be used directly when
|
|
|
|
running the gray engine.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void *display_getLocalVRAM(void);
|
|
|
|
|
2016-05-05 22:33:15 +02:00
|
|
|
/*
|
|
|
|
display_getCurrentVRAM()
|
|
|
|
Returns the current video ram. This function usually returns the
|
|
|
|
parameter of the last call to display_useVRAM(), unless the gray engine
|
|
|
|
is running (in which case the result is undefined). Returns the local
|
|
|
|
vram address by default.
|
|
|
|
*/
|
|
|
|
void *display_getCurrentVRAM(void);
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
/*
|
|
|
|
display_useVRAM()
|
2016-07-04 18:30:25 +02:00
|
|
|
Changes the current video ram address. The argument MUST be a 4-
|
|
|
|
aligned 1024-byte buffer; otherwise any drawing operation will crash
|
|
|
|
the program.
|
2016-05-05 22:33:15 +02:00
|
|
|
This function will most likely have no effect when running the gray
|
|
|
|
engine.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void display_useVRAM(void *vram);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Global drawing functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
dupdate()
|
2016-07-04 18:30:25 +02:00
|
|
|
Displays the vram on the physical screen. Does nothing when the gray
|
|
|
|
engine is running.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void dupdate(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
dclear()
|
|
|
|
Clears the whole video ram.
|
|
|
|
*/
|
|
|
|
void dclear(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
dclear_area()
|
2016-07-04 18:30:25 +02:00
|
|
|
Clears an area of the video ram. Both (x1, y1) and (x2, y2) are
|
|
|
|
cleared.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void dclear_area(int x1, int y1, int x2, int y2);
|
|
|
|
|
|
|
|
/*
|
|
|
|
dreverse_area()
|
2016-07-04 18:30:25 +02:00
|
|
|
Reverses an area of the vram. (x1, y1) and (x2, y2) are reversed as
|
|
|
|
well.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void dreverse_area(int x1, int y1, int x2, int y2);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Local drawing functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
dpixel()
|
2016-07-04 18:30:25 +02:00
|
|
|
Puts a pixel in the vram.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void dpixel(int x, int y, enum Color color);
|
|
|
|
|
|
|
|
/*
|
|
|
|
dline()
|
2016-07-04 18:30:25 +02:00
|
|
|
Draws a line in the vram. Automatically optimizes horizontal and
|
2016-05-05 11:49:05 +02:00
|
|
|
vertical lines.
|
|
|
|
|
|
|
|
Uses an algorithm written by PierrotLL for MonochromeLib.
|
|
|
|
*/
|
|
|
|
void dline(int x1, int y1, int x2, int y2, enum Color color);
|
|
|
|
|
|
|
|
/*
|
|
|
|
dimage()
|
2016-07-04 18:30:25 +02:00
|
|
|
Displays a monochrome image in the vram. Does a real lot of
|
|
|
|
optimization.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2016-07-28 18:12:07 +02:00
|
|
|
void dimage(int x, int y, struct Image *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, struct Image *img, int left, int top,
|
|
|
|
int width, int height);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
#endif // _DISPLAY_H
|