A modified version of the GDEP015OC1 library that supports x-or as a color.

Fork of GDEP015OC1 by aconno dev team

Committer:
ivo_n
Date:
Mon Jan 16 15:48:53 2017 +0000
Revision:
8:cd51988ee35d
Parent:
7:70c58d3cbc8b
Child:
9:1f1e705a5f02
Added fillRectangle; Added an enumerator for the colors (black and white) and inversion as a color.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Anunnaki 3:dc7b794b59b7 1 /**
Anunnaki 3:dc7b794b59b7 2 * Created by Filip Hormot (f.hormot@gmail.com) on 14/09/16.
Anunnaki 3:dc7b794b59b7 3 */
Anunnaki 1:4fff95e316c9 4 #include "mbed.h"
Anunnaki 1:4fff95e316c9 5 #include "GDEP015OC1.h"
Anunnaki 3:dc7b794b59b7 6 #include "5x7.h"
Anunnaki 1:4fff95e316c9 7
Anunnaki 2:1c8f73aa2a16 8 static const unsigned char _lutFull[] = {
Anunnaki 2:1c8f73aa2a16 9 0x02, 0x02, 0x01, 0x11, 0x12, 0x12, 0x22, 0x22, 0x66, 0x69, 0x69, 0x59, 0x58, 0x99, 0x99,
Anunnaki 2:1c8f73aa2a16 10 0x88, 0x00, 0x00, 0x00, 0x00, 0xF8, 0xB4, 0x13, 0x51, 0x35, 0x51, 0x51, 0x19, 0x01, 0x00
Anunnaki 2:1c8f73aa2a16 11 };
Anunnaki 2:1c8f73aa2a16 12
Anunnaki 7:70c58d3cbc8b 13 static const unsigned char _lutPart[] = {
Anunnaki 7:70c58d3cbc8b 14 0x10, 0x18, 0x18, 0x08, 0x18, 0x18, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
Anunnaki 7:70c58d3cbc8b 15 0x00, 0x00, 0x00, 0x00, 0x00, 0x13, 0x14, 0x44, 0x12, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00
Anunnaki 7:70c58d3cbc8b 16 };
Anunnaki 7:70c58d3cbc8b 17
Anunnaki 2:1c8f73aa2a16 18 GDEP015OC1::GDEP015OC1(SPI& spi, PinName cs=p5, PinName dc=p6, PinName rst=p7, PinName busy=p8) : _spi(spi), _cs(cs), _dc(dc), _rst(rst), _busy(busy){
Anunnaki 6:45d2ec037fd6 19 _bold = true;
Anunnaki 6:45d2ec037fd6 20 _italic = false;
Anunnaki 1:4fff95e316c9 21 _init();
Anunnaki 1:4fff95e316c9 22 }
Anunnaki 1:4fff95e316c9 23
Anunnaki 2:1c8f73aa2a16 24 void GDEP015OC1::_spiCommand(unsigned char command){
Anunnaki 2:1c8f73aa2a16 25 _cs = _dc = 0;
Anunnaki 2:1c8f73aa2a16 26 wait_us(1);
Anunnaki 2:1c8f73aa2a16 27
Anunnaki 2:1c8f73aa2a16 28 _spi.write(command);
Anunnaki 2:1c8f73aa2a16 29 }
Anunnaki 2:1c8f73aa2a16 30
Anunnaki 2:1c8f73aa2a16 31 void GDEP015OC1::_spiData(unsigned char data){
Anunnaki 2:1c8f73aa2a16 32 _cs = 0;
Anunnaki 2:1c8f73aa2a16 33 _dc = 1;
Anunnaki 2:1c8f73aa2a16 34 wait_us(1);
Anunnaki 2:1c8f73aa2a16 35
Anunnaki 2:1c8f73aa2a16 36 _spi.write(data);
Anunnaki 2:1c8f73aa2a16 37 }
Anunnaki 2:1c8f73aa2a16 38
Anunnaki 2:1c8f73aa2a16 39 void GDEP015OC1::_init(void){
Anunnaki 2:1c8f73aa2a16 40 _rst = _cs = 1;
Anunnaki 3:dc7b794b59b7 41 empty();
Anunnaki 1:4fff95e316c9 42 }
Anunnaki 1:4fff95e316c9 43
Anunnaki 7:70c58d3cbc8b 44 void GDEP015OC1::_wakeUp(bool partial){
Anunnaki 2:1c8f73aa2a16 45 _rst = 0;
Anunnaki 2:1c8f73aa2a16 46 wait_ms(10);
Anunnaki 2:1c8f73aa2a16 47 _rst = 1;
Anunnaki 2:1c8f73aa2a16 48 wait_ms(10);
Anunnaki 1:4fff95e316c9 49
Anunnaki 2:1c8f73aa2a16 50 //Stage 3
Anunnaki 2:1c8f73aa2a16 51 //Driver Output control
Anunnaki 2:1c8f73aa2a16 52 _spiCommand(0x01);
Anunnaki 2:1c8f73aa2a16 53 _spiData(0xC7);
Anunnaki 2:1c8f73aa2a16 54 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 55 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 56 //Softstart
Anunnaki 2:1c8f73aa2a16 57 _spiCommand(0x0C);
Anunnaki 2:1c8f73aa2a16 58 _spiData(0xD7);
Anunnaki 2:1c8f73aa2a16 59 _spiData(0xD6);
Anunnaki 2:1c8f73aa2a16 60 _spiData(0x9D);
Anunnaki 2:1c8f73aa2a16 61
Anunnaki 2:1c8f73aa2a16 62 _spiCommand(0x22);
Anunnaki 2:1c8f73aa2a16 63 _spiData(0xF0);
Anunnaki 2:1c8f73aa2a16 64
Anunnaki 2:1c8f73aa2a16 65 //VCOM setting
Anunnaki 2:1c8f73aa2a16 66 _spiCommand(0x2C);
Anunnaki 2:1c8f73aa2a16 67 _spiData(0xA8);
Anunnaki 2:1c8f73aa2a16 68 //Dummy line period
Anunnaki 2:1c8f73aa2a16 69 _spiCommand(0x3A);
Anunnaki 2:1c8f73aa2a16 70 _spiData(0x1A);
Anunnaki 2:1c8f73aa2a16 71 //Gate line width
Anunnaki 2:1c8f73aa2a16 72 _spiCommand(0x3B);
Anunnaki 2:1c8f73aa2a16 73 _spiData(0x08);
Anunnaki 2:1c8f73aa2a16 74 //Set data entry mode
Anunnaki 2:1c8f73aa2a16 75 _spiCommand(0x11);
Anunnaki 2:1c8f73aa2a16 76 _spiData(0x01); //DO NOT TOUCH THIS! (MUST BE 0x01)
Anunnaki 2:1c8f73aa2a16 77
Anunnaki 2:1c8f73aa2a16 78 //Gate driver start position
Anunnaki 2:1c8f73aa2a16 79 _spiCommand(0x0F);
Anunnaki 2:1c8f73aa2a16 80 _spiData(0x2B);
Anunnaki 2:1c8f73aa2a16 81 _spiData(0x01);
Anunnaki 2:1c8f73aa2a16 82
Anunnaki 2:1c8f73aa2a16 83 //VGH VGL
Anunnaki 2:1c8f73aa2a16 84 _spiCommand(0x03);
Anunnaki 2:1c8f73aa2a16 85 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 86 //VSH, VSL
Anunnaki 2:1c8f73aa2a16 87 _spiCommand(0x04);
Anunnaki 2:1c8f73aa2a16 88 _spiData(0x0A);
Anunnaki 2:1c8f73aa2a16 89
Anunnaki 2:1c8f73aa2a16 90 //Define X display size
Anunnaki 2:1c8f73aa2a16 91 _spiCommand(0x44);
Anunnaki 2:1c8f73aa2a16 92 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 93 _spiData(0x18);
Anunnaki 2:1c8f73aa2a16 94 //Define Y display size
Anunnaki 2:1c8f73aa2a16 95 _spiCommand(0x45);
Anunnaki 2:1c8f73aa2a16 96 _spiData(0xC7);
Anunnaki 2:1c8f73aa2a16 97 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 98 _spiData(0x2B);
Anunnaki 2:1c8f73aa2a16 99 _spiData(0x01);
Anunnaki 2:1c8f73aa2a16 100
Anunnaki 2:1c8f73aa2a16 101 //Define X RAM address
Anunnaki 2:1c8f73aa2a16 102 _spiCommand(0x4E);
Anunnaki 2:1c8f73aa2a16 103 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 104 //Define Y RAM address
Anunnaki 2:1c8f73aa2a16 105 _spiCommand(0x4F);
Anunnaki 2:1c8f73aa2a16 106 _spiData(0xC7);
Anunnaki 2:1c8f73aa2a16 107 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 108
Anunnaki 2:1c8f73aa2a16 109 //Border waveform control
Anunnaki 2:1c8f73aa2a16 110 _spiCommand(0x3C);
Anunnaki 2:1c8f73aa2a16 111 _spiData(0x33);
Anunnaki 2:1c8f73aa2a16 112
Anunnaki 2:1c8f73aa2a16 113 //Write LUT
Anunnaki 2:1c8f73aa2a16 114 _spiCommand(0x32);
Anunnaki 7:70c58d3cbc8b 115 if(partial){
Anunnaki 7:70c58d3cbc8b 116 for(uint8_t i = 0; i<30;i++){
Anunnaki 7:70c58d3cbc8b 117 _spiData(_lutPart[i]);
Anunnaki 7:70c58d3cbc8b 118 }
Anunnaki 7:70c58d3cbc8b 119 } else{
Anunnaki 7:70c58d3cbc8b 120 for(uint8_t i = 0; i<30;i++){
Anunnaki 7:70c58d3cbc8b 121 _spiData(_lutFull[i]);
Anunnaki 7:70c58d3cbc8b 122 }
Anunnaki 7:70c58d3cbc8b 123 }
Anunnaki 2:1c8f73aa2a16 124
Anunnaki 2:1c8f73aa2a16 125 //Power on
Anunnaki 2:1c8f73aa2a16 126 _spiCommand(0x22);
Anunnaki 2:1c8f73aa2a16 127 _spiData(0xC0);
Anunnaki 2:1c8f73aa2a16 128
Anunnaki 2:1c8f73aa2a16 129 //Define X RAM address
Anunnaki 2:1c8f73aa2a16 130 _spiCommand(0x4E);
Anunnaki 2:1c8f73aa2a16 131 _spiData(0x00);
Anunnaki 2:1c8f73aa2a16 132 //Define Y RAM address
Anunnaki 2:1c8f73aa2a16 133 _spiCommand(0x4F);
Anunnaki 2:1c8f73aa2a16 134 _spiData(0xC7);
Anunnaki 2:1c8f73aa2a16 135 _spiData(0x00);
Anunnaki 1:4fff95e316c9 136 }
Anunnaki 1:4fff95e316c9 137
Anunnaki 2:1c8f73aa2a16 138 void GDEP015OC1::_sleep(void){
Anunnaki 2:1c8f73aa2a16 139 while(_busy == BUSY_STATE);
Anunnaki 2:1c8f73aa2a16 140
Anunnaki 2:1c8f73aa2a16 141 _spiCommand(0x10);
Anunnaki 2:1c8f73aa2a16 142 _spiData(0x01);
Anunnaki 2:1c8f73aa2a16 143 }
Anunnaki 2:1c8f73aa2a16 144
Anunnaki 6:45d2ec037fd6 145 /*
Anunnaki 6:45d2ec037fd6 146 * If you touch this function satan will feast on your soul for an eternity!
Anunnaki 6:45d2ec037fd6 147 * IM NOT PLAYING AROUND DONT FUCKING TOUCH IT!
Anunnaki 6:45d2ec037fd6 148 * You are thinking about it...
Anunnaki 6:45d2ec037fd6 149 * .
Anunnaki 6:45d2ec037fd6 150 * .
Anunnaki 6:45d2ec037fd6 151 * .
Anunnaki 6:45d2ec037fd6 152 * DONT!
Anunnaki 6:45d2ec037fd6 153 */
Anunnaki 2:1c8f73aa2a16 154 unsigned char GDEP015OC1::_pixelConv(unsigned char *data, int i){
Anunnaki 2:1c8f73aa2a16 155 uint8_t pix = 0x00;
Anunnaki 2:1c8f73aa2a16 156 for(uint8_t x = 0; x < 8; x++){
Anunnaki 2:1c8f73aa2a16 157 pix |= ((*(data + (i*200)%5000 + (24-i/200) + x*25)>>((i/25)%8))&(0x01))<<(7-x);
Anunnaki 2:1c8f73aa2a16 158 }
Anunnaki 3:dc7b794b59b7 159 return pix^0xFF;
Anunnaki 2:1c8f73aa2a16 160 }
Anunnaki 2:1c8f73aa2a16 161
Anunnaki 2:1c8f73aa2a16 162 uint8_t GDEP015OC1::_mirrorData(uint8_t data){
Anunnaki 2:1c8f73aa2a16 163 uint8_t mirror = 0x00;
Anunnaki 2:1c8f73aa2a16 164 for(uint8_t i=0; i<8; i++)
Anunnaki 2:1c8f73aa2a16 165 mirror |= ((data>>i) & 0x01) << (7 - i);
Anunnaki 2:1c8f73aa2a16 166
Anunnaki 2:1c8f73aa2a16 167 return mirror;
Anunnaki 2:1c8f73aa2a16 168 }
Anunnaki 2:1c8f73aa2a16 169
Anunnaki 4:86114342ce8f 170 void GDEP015OC1::fill(unsigned char data, int x){
Anunnaki 4:86114342ce8f 171 _buffer[x] = data;
Anunnaki 4:86114342ce8f 172 }
Anunnaki 4:86114342ce8f 173
Anunnaki 2:1c8f73aa2a16 174 void GDEP015OC1::empty(void){
Anunnaki 2:1c8f73aa2a16 175 for(uint16_t x=0; x<5000; x++)
Anunnaki 2:1c8f73aa2a16 176 _buffer[x] = 0x00;
Anunnaki 2:1c8f73aa2a16 177 }
Anunnaki 2:1c8f73aa2a16 178
Anunnaki 2:1c8f73aa2a16 179 void GDEP015OC1::write(void){
Anunnaki 7:70c58d3cbc8b 180 _wakeUp(true);
Anunnaki 7:70c58d3cbc8b 181
Anunnaki 7:70c58d3cbc8b 182 _spiCommand(0x24);
Anunnaki 7:70c58d3cbc8b 183 for(int16_t x=0; x>=0 && x<200; x++){
Anunnaki 7:70c58d3cbc8b 184 for(int16_t y=24; y>=0 && y<25; y--){
Anunnaki 7:70c58d3cbc8b 185 _spiData(_mirrorData(_pixelConv(_buffer, x*25+y)));
Anunnaki 7:70c58d3cbc8b 186 wait_us(10);
Anunnaki 7:70c58d3cbc8b 187 }
Anunnaki 7:70c58d3cbc8b 188 }
Anunnaki 7:70c58d3cbc8b 189
Anunnaki 7:70c58d3cbc8b 190 _spiCommand(0x22);
Anunnaki 7:70c58d3cbc8b 191 _spiData(0x04);
Anunnaki 7:70c58d3cbc8b 192 _spiCommand(0x22);
Anunnaki 7:70c58d3cbc8b 193 _spiData(0x08);
Anunnaki 7:70c58d3cbc8b 194
Anunnaki 7:70c58d3cbc8b 195 //Update
Anunnaki 7:70c58d3cbc8b 196 _spiCommand(0x22);
Anunnaki 7:70c58d3cbc8b 197 _spiData(0xC7);
Anunnaki 7:70c58d3cbc8b 198 _spiCommand(0x20);
Anunnaki 7:70c58d3cbc8b 199
Anunnaki 7:70c58d3cbc8b 200 _sleep();
Anunnaki 7:70c58d3cbc8b 201 }
Anunnaki 7:70c58d3cbc8b 202
Anunnaki 7:70c58d3cbc8b 203 void GDEP015OC1::writeFull(void){
Anunnaki 7:70c58d3cbc8b 204 _wakeUp(false);
Anunnaki 2:1c8f73aa2a16 205
Anunnaki 2:1c8f73aa2a16 206 _spiCommand(0x24);
Anunnaki 2:1c8f73aa2a16 207 for(int16_t x=0; x>=0 && x<200; x++){
Anunnaki 2:1c8f73aa2a16 208 for(int16_t y=24; y>=0 && y<25; y--){
Anunnaki 2:1c8f73aa2a16 209 _spiData(_mirrorData(_pixelConv(_buffer, x*25+y)));
Anunnaki 2:1c8f73aa2a16 210 wait_us(10);
Anunnaki 2:1c8f73aa2a16 211 }
Anunnaki 2:1c8f73aa2a16 212 }
Anunnaki 2:1c8f73aa2a16 213
Anunnaki 2:1c8f73aa2a16 214 _spiCommand(0x22);
Anunnaki 2:1c8f73aa2a16 215 _spiData(0x04);
Anunnaki 2:1c8f73aa2a16 216 _spiCommand(0x22);
Anunnaki 2:1c8f73aa2a16 217 _spiData(0x08);
Anunnaki 2:1c8f73aa2a16 218
Anunnaki 2:1c8f73aa2a16 219 //Update
Anunnaki 2:1c8f73aa2a16 220 _spiCommand(0x22);
Anunnaki 2:1c8f73aa2a16 221 _spiData(0xC7);
Anunnaki 2:1c8f73aa2a16 222 _spiCommand(0x20);
Anunnaki 2:1c8f73aa2a16 223
Anunnaki 2:1c8f73aa2a16 224 _sleep();
Anunnaki 2:1c8f73aa2a16 225 }
Anunnaki 2:1c8f73aa2a16 226
ivo_n 8:cd51988ee35d 227 void GDEP015OC1::drawPixel(uint16_t startX, uint16_t startY, Color color=eBlack){
Anunnaki 2:1c8f73aa2a16 228 if(startX>199 || startY>199) return;
Anunnaki 2:1c8f73aa2a16 229
Anunnaki 2:1c8f73aa2a16 230 uint16_t i = startX/8 + startY*25;
Anunnaki 2:1c8f73aa2a16 231
ivo_n 8:cd51988ee35d 232 switch(color) {
ivo_n 8:cd51988ee35d 233 case eWhite :
ivo_n 8:cd51988ee35d 234 _buffer[i] = (_buffer[i] & (0xFF^(1<<(7-startX%8))));
ivo_n 8:cd51988ee35d 235 break;
ivo_n 8:cd51988ee35d 236 case eBlack :
ivo_n 8:cd51988ee35d 237 _buffer[i] = (_buffer[i] | (1<<(7-startX%8)));
ivo_n 8:cd51988ee35d 238 break;
ivo_n 8:cd51988ee35d 239 case eInvert :
ivo_n 8:cd51988ee35d 240 _buffer[i] = (_buffer[i] ^ (1<<(7-startX%8)));
ivo_n 8:cd51988ee35d 241 break;
ivo_n 8:cd51988ee35d 242 }
Anunnaki 2:1c8f73aa2a16 243 }
Anunnaki 2:1c8f73aa2a16 244
Anunnaki 2:1c8f73aa2a16 245
ivo_n 8:cd51988ee35d 246 void GDEP015OC1::drawLine(uint16_t startX, uint16_t startY, uint16_t stopX, uint16_t stopY, Color color=eBlack){
Anunnaki 2:1c8f73aa2a16 247 int dx = abs(stopX-startX), sx = startX<stopX ? 1 : -1;
Anunnaki 2:1c8f73aa2a16 248 int dy = abs(stopY-startY), sy = startY<stopY ? 1 : -1;
Anunnaki 2:1c8f73aa2a16 249 int err = (dx>dy ? dx : -dy)/2, e2;
Anunnaki 2:1c8f73aa2a16 250
Anunnaki 2:1c8f73aa2a16 251 for(;;){
Anunnaki 2:1c8f73aa2a16 252 drawPixel(startX,startY,color);
Anunnaki 2:1c8f73aa2a16 253 if (startX==stopX && startY==stopY) break;
Anunnaki 2:1c8f73aa2a16 254 e2 = err;
Anunnaki 2:1c8f73aa2a16 255 if (e2 >-dx) { err -= dy; startX += sx; }
Anunnaki 2:1c8f73aa2a16 256 if (e2 < dy) { err += dx; startY += sy; }
Anunnaki 2:1c8f73aa2a16 257 }
Anunnaki 3:dc7b794b59b7 258 }
Anunnaki 3:dc7b794b59b7 259
ivo_n 8:cd51988ee35d 260 void GDEP015OC1::drawTriangle(uint16_t x1, uint16_t y1, uint16_t x2, uint16_t y2, uint16_t x3, uint16_t y3, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 261 drawLine(x1, y1, x2, y2, color);
Anunnaki 3:dc7b794b59b7 262 drawLine(x2, y2, x3, y3, color);
Anunnaki 3:dc7b794b59b7 263 drawLine(x3, y3, x1, y1, color);
Anunnaki 3:dc7b794b59b7 264 }
Anunnaki 3:dc7b794b59b7 265
ivo_n 8:cd51988ee35d 266 void GDEP015OC1::drawRectangle(uint16_t startX, uint16_t startY, uint16_t stopX, uint16_t stopY, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 267 drawLine(startX, startY, stopX, startY, color);
Anunnaki 3:dc7b794b59b7 268 drawLine(stopX, startY, stopX, stopY, color);
Anunnaki 3:dc7b794b59b7 269 drawLine(stopX, stopY, startX, stopY, color);
Anunnaki 3:dc7b794b59b7 270 drawLine(startX, stopY, startX, startY, color);
Anunnaki 3:dc7b794b59b7 271 }
Anunnaki 3:dc7b794b59b7 272
ivo_n 8:cd51988ee35d 273 void GDEP015OC1::fillRectangle(uint16_t startX, uint16_t startY, uint16_t stopX, uint16_t stopY, Color color=eBlack){
ivo_n 8:cd51988ee35d 274 for(int x = startX; x<stopX; x++)
ivo_n 8:cd51988ee35d 275 {
ivo_n 8:cd51988ee35d 276 drawLine(x, startY, x, stopY, color);
ivo_n 8:cd51988ee35d 277 }
ivo_n 8:cd51988ee35d 278 drawLine(startX, startY, stopX, startY, color);
ivo_n 8:cd51988ee35d 279 drawLine(stopX, startY, stopX, stopY, color);
ivo_n 8:cd51988ee35d 280 drawLine(stopX, stopY, startX, stopY, color);
ivo_n 8:cd51988ee35d 281 drawLine(startX, stopY, startX, startY, color);
ivo_n 8:cd51988ee35d 282 }
ivo_n 8:cd51988ee35d 283
ivo_n 8:cd51988ee35d 284
ivo_n 8:cd51988ee35d 285 void GDEP015OC1::drawCircle(uint16_t startX, uint16_t startY, uint16_t radius, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 286 int d,x,y;
Anunnaki 3:dc7b794b59b7 287
Anunnaki 3:dc7b794b59b7 288 d=3-2*radius;
Anunnaki 3:dc7b794b59b7 289 x=0;
Anunnaki 3:dc7b794b59b7 290 y=radius;
Anunnaki 3:dc7b794b59b7 291 while(x<=y){
Anunnaki 3:dc7b794b59b7 292 drawPixel(startX+x,startY+y,color);
Anunnaki 3:dc7b794b59b7 293 drawPixel(startX-y,startY-x,color);
Anunnaki 3:dc7b794b59b7 294 drawPixel(startX+y,startY-x,color);
Anunnaki 3:dc7b794b59b7 295 drawPixel(startX-y,startY+x,color);
Anunnaki 3:dc7b794b59b7 296 drawPixel(startX+y,startY+x,color);
Anunnaki 3:dc7b794b59b7 297 drawPixel(startX-x,startY-y,color);
Anunnaki 3:dc7b794b59b7 298 drawPixel(startX+x,startY-y,color);
Anunnaki 3:dc7b794b59b7 299 drawPixel(startX-x,startY+y,color);
Anunnaki 3:dc7b794b59b7 300
Anunnaki 3:dc7b794b59b7 301 if(d<=0)
Anunnaki 3:dc7b794b59b7 302 d=d+4*x+6;
Anunnaki 3:dc7b794b59b7 303 else{
Anunnaki 3:dc7b794b59b7 304 d=d+4*x-4*y+10;
Anunnaki 3:dc7b794b59b7 305 y--;
Anunnaki 3:dc7b794b59b7 306 }
Anunnaki 3:dc7b794b59b7 307 x++;
Anunnaki 3:dc7b794b59b7 308 }
Anunnaki 3:dc7b794b59b7 309 }
Anunnaki 3:dc7b794b59b7 310
ivo_n 8:cd51988ee35d 311 void GDEP015OC1::fillCircle(uint16_t startX, uint16_t startY, uint16_t radius, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 312 for(uint16_t r = 1;r<=radius; r++){
Anunnaki 3:dc7b794b59b7 313 drawCircle(startX, startY, r, color);
Anunnaki 3:dc7b794b59b7 314 drawCircle(startX+1, startY, r-1, color);
Anunnaki 3:dc7b794b59b7 315 drawCircle(startX-1, startY, r-1, color);
Anunnaki 3:dc7b794b59b7 316 }
Anunnaki 3:dc7b794b59b7 317 }
Anunnaki 3:dc7b794b59b7 318
ivo_n 8:cd51988ee35d 319 void GDEP015OC1::drawEllipse(uint16_t startX, uint16_t startY, uint16_t width, uint16_t height, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 320 int a2 = width*width;
Anunnaki 3:dc7b794b59b7 321 int b2 = height*height;
Anunnaki 3:dc7b794b59b7 322 int fa2 = 4*a2, fb2 = 4*b2;
Anunnaki 3:dc7b794b59b7 323 int x, y, sigma;
Anunnaki 3:dc7b794b59b7 324
Anunnaki 3:dc7b794b59b7 325 //First half
Anunnaki 3:dc7b794b59b7 326 for(int x = 0, y = height, sigma = 2*b2+a2*(1-2*height); b2*x <= a2*y; x++){
Anunnaki 3:dc7b794b59b7 327 drawPixel(startX+x,startY+y,color);
Anunnaki 3:dc7b794b59b7 328 drawPixel(startX-x,startY+y,color);
Anunnaki 3:dc7b794b59b7 329 drawPixel(startX+x,startY-y,color);
Anunnaki 3:dc7b794b59b7 330 drawPixel(startX-x,startY-y,color);
Anunnaki 3:dc7b794b59b7 331 if(sigma >= 0){
Anunnaki 3:dc7b794b59b7 332 sigma += fa2 * (1-y);
Anunnaki 3:dc7b794b59b7 333 y--;
Anunnaki 3:dc7b794b59b7 334 }
Anunnaki 3:dc7b794b59b7 335 sigma += b2 * ((4 * x) + 6);
Anunnaki 3:dc7b794b59b7 336 }
Anunnaki 3:dc7b794b59b7 337 //Second half
Anunnaki 3:dc7b794b59b7 338 for (x = width, y = 0, sigma = 2*a2+b2*(1-2*width); a2*y <= b2*x; y++){
Anunnaki 3:dc7b794b59b7 339 drawPixel(startX+x,startY+y,color);
Anunnaki 3:dc7b794b59b7 340 drawPixel(startX-x,startY+y,color);
Anunnaki 3:dc7b794b59b7 341 drawPixel(startX+x,startY-y,color);
Anunnaki 3:dc7b794b59b7 342 drawPixel(startX-x,startY-y,color);
Anunnaki 3:dc7b794b59b7 343 if (sigma >= 0){
Anunnaki 3:dc7b794b59b7 344 sigma += fb2 * (1 - x);
Anunnaki 3:dc7b794b59b7 345 x--;
Anunnaki 3:dc7b794b59b7 346 }
Anunnaki 3:dc7b794b59b7 347 sigma += a2 * ((4 * y) + 6);
Anunnaki 3:dc7b794b59b7 348 }
Anunnaki 3:dc7b794b59b7 349 }
Anunnaki 3:dc7b794b59b7 350
ivo_n 8:cd51988ee35d 351 void GDEP015OC1::fillEllipse(uint16_t startX, uint16_t startY, uint16_t width, uint16_t height, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 352 for(uint16_t w = width; w > 0; w--){
Anunnaki 3:dc7b794b59b7 353 drawEllipse(startX, startX, w, height, color);
Anunnaki 3:dc7b794b59b7 354 }
Anunnaki 3:dc7b794b59b7 355 drawLine(startX, startY-height, startX, startY+height, color);
Anunnaki 3:dc7b794b59b7 356 }
Anunnaki 3:dc7b794b59b7 357
ivo_n 8:cd51988ee35d 358 void GDEP015OC1::writeChar(char character, uint16_t startX, uint16_t startY, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 359 unsigned char letter[FONT_WIDTH];
Anunnaki 3:dc7b794b59b7 360
Anunnaki 3:dc7b794b59b7 361 //Grab data for the corresponding font
Anunnaki 3:dc7b794b59b7 362 for(uint8_t i = 0; i<FONT_WIDTH; i++)
Anunnaki 3:dc7b794b59b7 363 letter[i] = Font5x7[(character - ' ') * FONT_WIDTH + i];
Anunnaki 3:dc7b794b59b7 364
Anunnaki 3:dc7b794b59b7 365 for(uint8_t i = 0; i<FONT_WIDTH; i++){
Anunnaki 3:dc7b794b59b7 366 for(uint8_t j = 0; j<FONT_HEIGHT; j++){
Anunnaki 3:dc7b794b59b7 367 if((letter[i]>>j)&0x01){
Anunnaki 3:dc7b794b59b7 368 if(_italic){
Anunnaki 3:dc7b794b59b7 369 drawPixel(startX+i+(FONT_HEIGHT/3 - j/3), startY+j, color);
Anunnaki 3:dc7b794b59b7 370 if(_bold){
Anunnaki 3:dc7b794b59b7 371 for(uint8_t z=0; z<2; z++)
Anunnaki 3:dc7b794b59b7 372 drawPixel(startX+i-z+(FONT_HEIGHT/3- j/3), startY+j, color);
Anunnaki 3:dc7b794b59b7 373 }
Anunnaki 3:dc7b794b59b7 374 }
Anunnaki 3:dc7b794b59b7 375 else{
Anunnaki 3:dc7b794b59b7 376 drawPixel(startX+i, startY+j, color);
Anunnaki 3:dc7b794b59b7 377 if(_bold){
Anunnaki 3:dc7b794b59b7 378 for(uint8_t z=0; z<2; z++)
Anunnaki 3:dc7b794b59b7 379 drawPixel(startX+i-z, startY+j, color);
Anunnaki 3:dc7b794b59b7 380 }
Anunnaki 3:dc7b794b59b7 381 }
Anunnaki 3:dc7b794b59b7 382 }
Anunnaki 3:dc7b794b59b7 383 }
Anunnaki 3:dc7b794b59b7 384 }
Anunnaki 3:dc7b794b59b7 385 }
Anunnaki 3:dc7b794b59b7 386
ivo_n 8:cd51988ee35d 387 void GDEP015OC1::writeString(char *string, uint16_t startX, uint16_t startY, Color color=eBlack){
Anunnaki 3:dc7b794b59b7 388 uint8_t length = 0;
Anunnaki 3:dc7b794b59b7 389 while(*(string+length) != '\0') length++;
Anunnaki 3:dc7b794b59b7 390
Anunnaki 3:dc7b794b59b7 391 for(uint8_t x=0; x<length; x++)
Anunnaki 4:86114342ce8f 392 writeChar(*(string+x), startX+(FONT_WIDTH+1)*x, startY, color); //FONT_WIDTH+1 gives a 1px space between the characters
Anunnaki 2:1c8f73aa2a16 393 }