2016-07-04 18:30:25 +02:00
|
|
|
//---
|
|
|
|
//
|
|
|
|
// gint core/drawing module: gray
|
|
|
|
//
|
|
|
|
// Runs the gray engine and handles drawing for the dual-buffer system.
|
|
|
|
//
|
|
|
|
//---
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#ifndef _GRAY_H
|
2017-03-26 18:38:32 +02:00
|
|
|
#define _GRAY_H
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
#include <stdint.h>
|
2016-07-04 18:30:25 +02:00
|
|
|
#include <display.h>
|
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
// This module provides bitmap rendering.
|
|
|
|
#include <bopti.h>
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
2016-07-04 18:30:25 +02:00
|
|
|
// Engine control.
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
|
|
|
|
2016-07-04 18:30:25 +02:00
|
|
|
/*
|
|
|
|
gray_runs()
|
|
|
|
Returns 1 if the gray engine is running, 0 otherwise.
|
|
|
|
*/
|
|
|
|
int gray_runs(void);
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
/*
|
|
|
|
gray_start()
|
|
|
|
Starts the gray engine. The control of the screen is transferred to the
|
|
|
|
gray engine.
|
|
|
|
*/
|
|
|
|
void gray_start(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gray_stop()
|
|
|
|
Stops the gray engine. The monochrome display system takes control of
|
|
|
|
the video ram.
|
|
|
|
*/
|
|
|
|
void gray_stop(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gray_lightVRAM()
|
2016-11-11 10:43:13 +01:00
|
|
|
Returns the module's light gray vram address.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
uint32_t *gray_lightVRAM(void);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
/*
|
2016-11-11 10:43:13 +01:00
|
|
|
gray_darkVRAM()
|
|
|
|
Returns the module's dark gray vram address.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
uint32_t *gray_darkVRAM(void);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
2016-05-20 22:04:15 +02:00
|
|
|
/*
|
|
|
|
gray_getDelays()
|
2016-07-04 18:30:25 +02:00
|
|
|
Returns the gray engine delays. Pointers are not set if NULL.
|
2016-05-20 22:04:15 +02:00
|
|
|
*/
|
|
|
|
void gray_getDelays(int *light, int *dark);
|
|
|
|
|
|
|
|
/*
|
|
|
|
gray_setDelays()
|
|
|
|
Changes the gray engine delays. Usually you don't need to call this,
|
|
|
|
because the engine has its default values.
|
|
|
|
Finding values that give proper grays is quite the hard part of the
|
|
|
|
gray engine. Usual values are about 1000, with light being between 75
|
|
|
|
and 90% of dark.
|
2016-07-14 21:10:51 +02:00
|
|
|
|
|
|
|
Typical values:
|
|
|
|
|
|
|
|
values stability stripes colors
|
|
|
|
---------------------------------------------------------
|
2016-08-29 11:29:07 +02:00
|
|
|
860, 1298 excellent worst static good
|
|
|
|
912, 1343 bad none very good (default)
|
|
|
|
993, 1609 medium light fast good
|
|
|
|
1325, 1607 bad light fast excellent
|
2016-07-14 21:10:51 +02:00
|
|
|
---------------------------------------------------------
|
2016-05-20 22:04:15 +02:00
|
|
|
*/
|
|
|
|
void gray_setDelays(int light, int dark);
|
|
|
|
|
2016-07-04 18:30:25 +02:00
|
|
|
|
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
//---
|
2016-07-04 18:30:25 +02:00
|
|
|
// Global drawing functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
gupdate()
|
2017-03-26 18:38:32 +02:00
|
|
|
Swaps the vram buffer sets. You need to call this function each time
|
|
|
|
you finish drawing something in the video ram. Unlike the monochrome
|
|
|
|
function dupdate(), gupdate() only does a quick operation indicating
|
|
|
|
that drawing and exposed buffers have been swapped, but nothing on the
|
|
|
|
screen will change until the gray timer fires.
|
2016-07-04 18:30:25 +02:00
|
|
|
*/
|
|
|
|
void gupdate(void);
|
2016-05-05 11:49:05 +02:00
|
|
|
|
|
|
|
/*
|
2016-07-04 18:30:25 +02:00
|
|
|
gclear()
|
2017-03-26 18:38:32 +02:00
|
|
|
Clears the gray video ram, making all pixels white.
|
2016-05-05 11:49:05 +02:00
|
|
|
*/
|
2016-07-04 18:30:25 +02:00
|
|
|
void gclear(void);
|
|
|
|
|
|
|
|
/*
|
2017-03-26 18:38:32 +02:00
|
|
|
grect()
|
|
|
|
Draws a rectangle in the gray video ram; this function accepts all
|
|
|
|
values of the color_t type, including gray operators.
|
2016-07-04 18:30:25 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void grect(int x1, int y1, int x2, int y2, color_t operator);
|
2016-07-04 18:30:25 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//---
|
|
|
|
// Local drawing functions.
|
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
gpixel()
|
2017-03-26 18:38:32 +02:00
|
|
|
Puts a pixel in the vram. This function accepts all values of the
|
|
|
|
color_t type, including gray operators.
|
2016-07-04 18:30:25 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void gpixel(size_t x, size_t y, color_t operator);
|
2016-07-04 18:30:25 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
gline()
|
2017-03-26 18:38:32 +02:00
|
|
|
Draws a line in the vram while automatically optimizing special cases.
|
|
|
|
This function supports all plain colors from the color_t type, but not
|
|
|
|
the gray operators. If you need them for horizontal or vertical lines,
|
|
|
|
you may want to use grect() as a replacement.
|
2016-07-28 18:12:07 +02:00
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void gline(int x1, int y1, int x2, int y2, color_t operator);
|
2016-07-04 18:30:25 +02:00
|
|
|
|
2016-05-05 11:49:05 +02:00
|
|
|
#endif // _GRAY_H
|