-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpictor.h
189 lines (166 loc) · 6.55 KB
/
pictor.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
/* Pictor.h VERSION 0.3.2
* Screen driver for the IlMatto and 2.2" screen combo
* Use port A for control & port C for data.
*
* Note that this code is subject to change, check the changelog when updating.
* Project by Henry Wilson, Terra Barber, Emma Curati-Alasonatti and Chris Turner.
*
* This work is licensed under the Creative Commons Attribution-ShareAlike 3.0 licence
* This licence can be found at http://creativecommons.org/licenses/
*/
#ifndef PICTOR
#define PICTOR
#ifndef PICTOR_FONTSTART
#define PICTOR_FONTSTART ' '
#endif
#ifndef PICTOR_FONTEND
#define PICTOR_FONTEND '~'
#endif
// Generic libraries
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
// AVR libraries
#include <avr/io.h>
//#include <avr/interrupt.h>
#include <util/delay.h>//needed for screen initialisation
#include <avr/pgmspace.h> //TODO: Work out where this really should go...
// POINT STRUCTURE TODO: Look into signed mode.
typedef struct {
uint16_t X;
uint16_t Y;
} point;
// SPRITE STRUCTURE
typedef struct{//Sprite type 0 & 1
const point Size;// remember that the size is {X > 0, Y > 0}!
uint16_t* RGB; //can be in PROGMEM
}sprite;
typedef struct{//Sprite type 2 & 3
const point Size;
uint8_t* data; //can be in PROGMEM
uint16_t FGcolour;
uint16_t BGcolour;
}spriteMono;
typedef struct{//Sprite type 4, 5, 6 & 7
const point Size;
uint8_t* data; //can be in PROGMEM
uint16_t* palette; //can be in PROGMEM
}spriteEncoded;
typedef struct{//Sprite type 8, 9, A & B
const point Size;
uint8_t* data; //can be in PROGMEM
uint16_t* palette; //can be in PROGMEM
}spritePalette;
// FONT STRUCTURE
#define font uint8_t
static uint8_t pictorRot = 0;
// DATA PORTS -- don't use port B if you intend to use USB!
#define CTRLPORT PORTA
#define CTRLDDR DDRA
#define DATAPORT PORTC
#define DATADDR DDRC
#define DATAPINS PINC
// CONRTOL BITS
#define BACKLIGHT 0b00000010
#define RESET 0b11111011
#define WRITE 0b11110111
#define COMND 0b11101111
#define READ 0b11011111
#define VSYNC 0b01000000
// USEFUL
#define ON 1
#define OFF 0
#define INVERT -1
// POINTS
#define ORIGIN (point){0, 0}
#define UNIT_POINT (point){1, 1}
#define PICTOR_MAX (point){239,319}
#define PICTOR_SIZE (point){240,320}
// COLOURS RRRRRGGGGGGBBBBB
#define BLACK 0b0000000000000000
#define WHITE 0b1111111111111111
#define RED 0b1111100000000000
#define ORANGE 0b1111101011100000
#define YELLOW 0b1111111111100000
#define GREEN 0b0000011111100000
#define CYAN 0b0000011111111111
#define BLUE 0b0000000000011111
#define MAGENTA 0b1111100000011111
// COLOUR MODIFIERS
#define PALE 0b1000010000010000 |
#define DEEP 0b0111001111001110 &
#define DARK 0b0011000111000110 &
// Create a colour encoded in 656-RGB from individual RGB bytes.
uint16_t encode656Colour(const uint8_t Red, const uint8_t Green, const uint8_t Blue);
//===============
// BASE LCD CMDS
//===============
// Sends a command byte to the screen.
inline void pictorCmdWrite(const uint8_t Cmd);
// Sends a data byte to the screen.
inline void pictorByteWrite(const uint8_t Data);
// Sends two data bytes to the screen.
inline void pictorWordWrite(uint16_t Value);
// Returns a data byte read from the screen.
inline uint8_t pictorByteRead();
// Returns a word from two data bytes read from the screen.
inline uint16_t pictorWordRead();
// Sets the state of the back-light, 1 = ON, 0 = OFF, -1 = TOGGLE
void pictorBacklightState(const int8_t State);
// Toggles the VSYNC pin to update the screen in VSYNC mode
void pictorFrame();
//================
// LCD ARRAY CMDS
//================
// Writes a command and a byte array containing its parameters to the screen.
void pictorWrite(const uint8_t Cmd, const uint8_t* Buffer, const uint8_t Count);
// Writes a command and reads out an array of byte data into a buffer from the screen.
void pictorRead(const uint8_t Cmd, uint8_t* Buffer, const uint8_t Count);
//====================
// LCD COMPOSITE CMDS
//====================
// Sets a drawing canvas on the screen.
void pictorCanvasSet(const point A, const point B);
void pictorSetRotation(const uint8_t rotation);
//=========================
// LCD DRAW CHAR FUNCTIONS
//=========================
// Draws Char onto the screen at Pos with two colours of Font.
void pictorDrawC(const unsigned char Char, const point Pos, const uint16_t ForegroundColour, const uint16_t BackgroundColour, const font* Font, uint8_t scale);
// Draws String onto the screen at Pos with two colours of Font.
uint8_t pictorDrawS(const unsigned char* Buffer, point Pos, const uint16_t ForegroundColour, const uint16_t BackgroundColour, const font* Font, uint8_t scale);
uint8_t pictorDrawSP(const unsigned char* Buffer, point Pos, const uint16_t ForegroundColour, const uint16_t BackgroundColour, const font* Font, uint8_t scale);
//=========================
// LCD DRAW Number FUNCTIONS
//=========================
// Draws a Number in decimal onto the screen at Pos, with two colours of Font, padded to fill len spaces(use a len of 0 to ignore padding).
void pictorDrawD(const int16_t Number, const point Pos, const uint16_t ForegroundColour, const uint16_t BackgroundColour, const font* Font, uint8_t scale, uint8_t len);
// Draws a Value in hex onto the screen at Pos with two colours of Font.
uint8_t pictorDrawX(const uint8_t Value, const point Pos, const uint16_t ForegroundColour, const uint16_t BackgroundColour, const font* Font, uint8_t scale);
//=================
// LCD DRAW SHAPES
//=================
// Draws a single pixel with Colour at Pos
void pictorDrawPixel(const point Pos, const uint16_t Colour);
// Draws a line with Colour between points A and B, using Bresenham's algorithm.
void pictorDrawLine(point A, point B, const uint16_t Colour);
// Draws a solid box with Colour between points A and B.
void pictorDrawBox(point A, point B, const uint16_t Colour);
// Fills the screen with Colour.
void pictorDrawAll(const uint16_t Colour);
//draw part of a sprite selected by X1 and X2
void pictorDrawSpritePartial(const sprite* Sprite, const point Pos, const uint8_t Scale, point X1, point X2);
// Draws a Sprite of type Type, top left aligned at Pos scaled by Scale.
void pictorDrawSpriteType(const void* Sprite, const point Pos, const uint8_t type, const uint8_t Scale);
// Draws a circle using Bresenham's algorithm with a given centre point and radius
void pictorDrawCircle(const point Centre, const uint8_t Radius, const uint16_t Colour);
//====================
// LCD INTITALISATION
//====================
// Initialise the screen. Mode is a bit-field.
void pictorInit(const uint8_t Mode);
// Dump the entire of ram and program memory to the screen
void pictorMemDump();
#include "pictor.c"
//#include <avr/pgmspace.h>
#endif