2016-07-25 09:04:22 +02:00
|
|
|
#ifndef _INTERNALS_DISPLAY_H
|
2017-03-26 18:38:32 +02:00
|
|
|
#define _INTERNALS_DISPLAY_H
|
2016-07-06 11:28:51 +02:00
|
|
|
|
2016-07-25 22:38:47 +02:00
|
|
|
#include <stdint.h>
|
2017-03-26 18:38:32 +02:00
|
|
|
#include <stddef.h>
|
2016-07-25 22:38:47 +02:00
|
|
|
|
2017-03-26 18:38:32 +02:00
|
|
|
extern uint32_t *vram;
|
2016-07-06 11:28:51 +02:00
|
|
|
|
2016-07-25 22:38:47 +02:00
|
|
|
//---
|
|
|
|
// Rectangle masks.
|
|
|
|
//
|
|
|
|
// The concept of 'rectangle masks' is used several times in this module.
|
2017-03-26 18:38:32 +02:00
|
|
|
// It relies on the fact that operations affecting a rectangle act the
|
|
|
|
// same for all lines, and line operation is very optimized. A rectangle
|
|
|
|
// mask is a set of integers, where each bit indicate whether a specific
|
|
|
|
// pixel is affected (1) by the operation, or not (0).
|
2016-07-25 22:38:47 +02:00
|
|
|
//
|
2017-03-26 18:38:32 +02:00
|
|
|
// For example to clear a rectangle such as (14, 16, 112, 48), the masks
|
|
|
|
// will need to hold 0003ffff ffffffff ffffffff ffff0000. Bitwise-
|
|
|
|
// combining them with video ram long entries yields very good performance
|
|
|
|
// as compared to operation on single pixels. Each bitwise operation will
|
|
|
|
// produce different results, which is very flexible.
|
2016-07-25 22:38:47 +02:00
|
|
|
//
|
2017-03-26 18:38:32 +02:00
|
|
|
// This technique can also be used in subtle cases with patterns more
|
|
|
|
// complicated than rectangles, but within this module this is unlikely to
|
|
|
|
// happen.
|
2016-07-25 22:38:47 +02:00
|
|
|
//---
|
|
|
|
|
|
|
|
/*
|
|
|
|
adjustRectangle()
|
|
|
|
Adjusts the given rectangle coordinates to ensure that :
|
2017-03-26 18:38:32 +02:00
|
|
|
- the rectangle is entirely contained in the screen;
|
|
|
|
- x1 < x2;
|
|
|
|
- y1 < y2,
|
|
|
|
which is needed when working with screen rectangles. Returns non-zero
|
|
|
|
if the rectangle is outside the screen, which usually means there is
|
|
|
|
nothing to do.
|
2016-07-25 22:38:47 +02:00
|
|
|
*/
|
2016-08-14 19:57:58 +02:00
|
|
|
int adjustRectangle(int *x1, int *y1, int *x2, int *y2);
|
2016-07-25 22:38:47 +02:00
|
|
|
|
|
|
|
/*
|
|
|
|
getMasks()
|
|
|
|
Computes the rectangle masks needed to affect pixels located between x1
|
|
|
|
and x2 (both included). The four masks are stored in the third argument
|
|
|
|
(seen as an array).
|
|
|
|
*/
|
2017-03-26 18:38:32 +02:00
|
|
|
void getMasks(size_t x1, size_t x2, uint32_t *masks);
|
2016-07-25 22:38:47 +02:00
|
|
|
|
2016-07-25 09:04:22 +02:00
|
|
|
#endif // _INTERNALS_DISPLAY_H
|