2016-05-20 22:04:15 +02:00
|
|
|
//---
|
2016-07-04 18:30:25 +02:00
|
|
|
//
|
|
|
|
// gint drawing module: display
|
|
|
|
//
|
2017-03-26 18:38:32 +02:00
|
|
|
// This module does most of the monochrome drawing. It manages the video
|
|
|
|
// memory although image rendering and text rendering, as complex tasks,
|
|
|
|
// are left to other modules (bopti and tales, respectively).
|
2016-07-04 18:30:25 +02:00
|
|
|
//
|
2016-05-20 22:04:15 +02:00
|
|
|
//---
|
|
|
|
|
2016-07-04 18:30:25 +02:00
|
|
|
#ifndef _DISPLAY_H
|
2017-03-26 18:38:32 +02:00
|
|
|
#define _DISPLAY_H
|
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-05 11:49:05 +02:00
|
|
|
//---
|
2017-03-26 18:38:32 +02:00
|
|
|
// Drawing-related types and constants.
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
#define DWIDTH 128 /* Width of the screen */
|
|
|
|
#define DHEIGHT 64 /* Height of the screen */
|
2016-07-28 18:12:07 +02:00
|
|
|
|
2016-05-05 22:33:15 +02:00
|
|
|
/*
|
2017-03-26 18:38:32 +02:00
|
|
|
color_t
|
|
|
|
Defines all colors that the library knows about:
|
|
|
|
- white is exactly what you think it is;
|
|
|
|
- light is a light gray used by the gray module;
|
|
|
|
- dark is a dark gray, also used by the gray engine;
|
|
|
|
- black is nothing more than black; (sorry)
|
|
|
|
- none means transparent, but is shorter to write.
|
|
|
|
There are also some transformation-associated colors:
|
|
|
|
- invert reverses the intensity of the color (white -> black, dark ->
|
|
|
|
light, etc);
|
|
|
|
- lighten is some kind of partially-transparent white. It lightens the
|
|
|
|
color which it is drawn onto (black -> dark, light -> light);
|
|
|
|
- lighten2 is the same as lighten, except it lightens more (black ->
|
|
|
|
light, light -> white);
|
|
|
|
- darken is the exact opposite of lighten (light -> dark, black ->
|
|
|
|
black).
|
|
|
|
- darken2 is the same to darken as lighten2 to lighten (white -> dark,
|
|
|
|
dark -> black);
|
|
|
|
All transformations except invert only operate when the gray engine is
|
|
|
|
running.
|
2016-05-05 22:33:15 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
typedef enum
|
2016-05-05 11:49:05 +02:00
|
|
|
{
|
2017-03-26 18:38:32 +02:00
|
|
|
color_white = 0,
|
|
|
|
color_light = 1,
|
|
|
|
color_dark = 2,
|
|
|
|
color_black = 3,
|
|
|
|
color_none = 4,
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
color_invert = 5,
|
|
|
|
color_lighten = 6,
|
|
|
|
color_lighten2 = 7,
|
|
|
|
color_darken = 8,
|
|
|
|
color_darken2 = 9,
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
} color_t;
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
// The bopti module provides bitmap rendering functions.
|
|
|
|
#include <bopti.h>
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
// The tales module provides text rendering functions but requires the color_t
|
|
|
|
// type definition.
|
|
|
|
#include <tales.h>
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
2017-03-26 18:38:32 +02:00
|
|
|
// Video RAM management.
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
display_getLocalVRAM()
|
2017-03-26 18:38:32 +02:00
|
|
|
Returns gint's local video RAM address. Gint does not use the system's
|
|
|
|
buffer because it is misaligned. This function always returns the same
|
|
|
|
address. Both the display and the gray module heavily use this buffer;
|
|
|
|
make sure you don't interfere with them if you access it.
|
|
|
|
This function does not necessarily returns the video ram that is
|
|
|
|
currently in use; call display_getCurrentVRAM() for this.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
uint32_t *display_getLocalVRAM(void);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2016-05-05 22:33:15 +02:00
|
|
|
/*
|
|
|
|
display_getCurrentVRAM()
|
2017-03-26 18:38:32 +02:00
|
|
|
Returns the current monochrome video ram buffer. This function usually
|
|
|
|
returns the parameter of the last call to display_useVRAM(), or the
|
|
|
|
local vram address (which is default when the library starts).
|
|
|
|
The return value of this function is undefined if the gray engine is
|
|
|
|
running.
|
2016-05-05 22:33:15 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
uint32_t *display_getCurrentVRAM(void);
|
2016-05-05 22:33:15 +02:00
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
/*
|
|
|
|
display_useVRAM()
|
2017-03-26 18:38:32 +02:00
|
|
|
Changes the current monochrome video ram address. The argument must be
|
|
|
|
a 4-aligned 1024-byte buffer because the library's design requires it.
|
|
|
|
This function refuses misaligned buffers but trusts that enough space
|
|
|
|
is available; failing to provide enough memory may 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
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void display_useVRAM(uint32_t *vram);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Global drawing functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
dupdate()
|
2017-03-26 18:38:32 +02:00
|
|
|
Pushes the video RAM to the physical screen. This function also works
|
|
|
|
when the gray engine is running, but that's probably not what you want.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void dupdate(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
dclear()
|
2017-03-26 18:38:32 +02:00
|
|
|
Clears the whole video ram, making all pixels white.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
|
|
|
void dclear(void);
|
|
|
|
|
|
|
|
/*
|
2017-03-26 18:38:32 +02:00
|
|
|
drect()
|
|
|
|
Draws a rectangle on the screen. This function can use any color which
|
|
|
|
is not associated with the gray engine, including the reverse operator.
|
|
|
|
Both end points (x1, y1) and (x2, y2) are affected as well.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void drect(int x1, int y1, int x2, int y2, color_t operator);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Local drawing functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
dpixel()
|
2017-03-26 18:38:32 +02:00
|
|
|
Changes a pixel's color in the video ram. The result may depend on the
|
|
|
|
current color of the pixel.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void dpixel(size_t x, size_t y, color_t operator);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
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.
|
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void dline(int x1, int y1, int x2, int y2, color_t operator);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
#endif // _DISPLAY_H
|