Modified version of the DmTftLibrary, optimized for the LPC4088 Experiment Base Board
Dependents: lpc4088_ebb_dm_calc lpc4088_ebb_dm_bubbles
Fork of DmTftLibrary by
DmTftBase.cpp
- Committer:
- embeddedartists
- Date:
- 2014-09-11
- Revision:
- 12:eb97ccfe7c3f
- Parent:
- 11:8b441dd1d470
File content as of revision 12:eb97ccfe7c3f:
/********************************************************************************************** Copyright (c) 2014 DisplayModule. All rights reserved. Redistribution and use of this source code, part of this source code or any compiled binary based on this source code is permitted as long as the above copyright notice and following disclaimer is retained. DISCLAIMER: THIS SOFTWARE IS SUPPLIED "AS IS" WITHOUT ANY WARRANTIES AND SUPPORT. DISPLAYMODULE ASSUMES NO RESPONSIBILITY OR LIABILITY FOR THE USE OF THE SOFTWARE. ********************************************************************************************/ #include "DmTftBase.h" #define FONT_CHAR_WIDTH 8 #define FONT_CHAR_HEIGHT 16 extern uint8_t font[]; /* * Macro to read the 8 bits representing one line of a character. * The macro is needed as the reading is handled differently on * Arduino and Mbed platforms. */ #if defined (DM_TOOLCHAIN_ARDUINO) #define read_font_line(__char, __line) \ pgm_read_byte(&font[((uint16_t)(__char))*FONT_CHAR_HEIGHT+(__line)]) #elif defined (DM_TOOLCHAIN_MBED) #define read_font_line(__char, __line) \ font[((uint16_t)(__char))*FONT_CHAR_HEIGHT+(__line)] #endif void DmTftBase::setPixel(uint16_t x, uint16_t y, uint16_t color) { cbi(_pinCS, _bitmaskCS); if ((x < _width) && (y < _height)) { setAddress(x, y, x, y); sendData(color); } sbi(_pinCS, _bitmaskCS); } void DmTftBase::clearScreen(uint16_t color) { cbi(_pinCS, _bitmaskCS); setAddress(0,0,_width-1, _height-1); for(uint16_t i=0; i<_height; i++) { for(uint16_t j=0; j<_width; j++) { sendData(color); } } sbi(_pinCS, _bitmaskCS); } void DmTftBase::drawHorizontalLine(uint16_t x, uint16_t y, uint16_t length, uint16_t color) { cbi(_pinCS, _bitmaskCS); setAddress(x, y, x + length, y); for (int i = 0; i <= length; i++) { sendData(color); } sbi(_pinCS, _bitmaskCS); } void DmTftBase::drawVerticalLine(uint16_t x, uint16_t y, uint16_t length, uint16_t color) { cbi(_pinCS, _bitmaskCS); setAddress(x, y, x, y + length); for (int i = 0; i <= length; i++) { sendData(color); } sbi(_pinCS, _bitmaskCS); } void DmTftBase::drawLine(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1, uint16_t color) { int x = x1-x0; int y = y1-y0; int dx = abs(x), sx = x0<x1 ? 1 : -1; int dy = -abs(y), sy = y0<y1 ? 1 : -1; int err = dx+dy, e2; /* error value e_xy */ for (;;) { setPixel(x0,y0,color); e2 = 2*err; if (e2 >= dy) { /* e_xy+e_x > 0 */ if (x0 == x1) { break; } err += dy; x0 += sx; } if (e2 <= dx) { /* e_xy+e_y < 0 */ if (y0 == y1) { break; } err += dx; y0 += sy; } } } void DmTftBase::drawRectangle(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1, uint16_t color) { // Make sure x0,y0 are in the top left corner if(x0 > x1) { x0 = x0^x1; x1 = x0^x1; x0 = x0^x1; } if(y0 > y1) { y0 = y0^y1; y1 = y0^y1; y0 = y0^y1; } drawHorizontalLine(x0, y0, x1-x0, color); drawHorizontalLine(x0, y1, x1-x0, color); drawVerticalLine(x0, y0, y1-y0, color); drawVerticalLine(x1, y0, y1-y0, color); } void DmTftBase::fillRectangle(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1, uint16_t color) { unsigned long numPixels=0; unsigned long i=0; // Make sure x0,y0 are in the top left corner if(x0 > x1) { x0 = x0^x1; x1 = x0^x1; x0 = x0^x1; } if(y0 > y1) { y0 = y0^y1; y1 = y0^y1; y0 = y0^y1; } x0 = constrain(x0, 0, _width-1); x1 = constrain(x1, 0, _width-1); y0 = constrain(y0, 0, _height-1); y1 = constrain(y1, 0, _height-1); numPixels = (x1-x0+1); numPixels = numPixels*(y1-y0+1); cbi(_pinCS, _bitmaskCS); setAddress(x0,y0,x1,y1);/* start to write to display ra */ for(i=0; i < numPixels; i++) { sendData(color); } sbi(_pinCS, _bitmaskCS); } void DmTftBase::drawCircle(uint16_t x0, uint16_t y0, uint16_t r, uint16_t color) { int x = -r, y = 0, err = 2-2*r, e2; do { setPixel(x0-x, y0+y, color); setPixel(x0+x, y0+y, color); setPixel(x0+x, y0-y, color); setPixel(x0-x, y0-y, color); e2 = err; if (e2 <= y) { err += ++y*2+1; if (-x == y && e2 <= x) { e2 = 0; } } if (e2 > x) { err += ++x * 2 + 1; } } while (x <= 0); } void DmTftBase::fillCircle(uint16_t x0, uint16_t y0, uint16_t r, uint16_t color) { int x = -r, y = 0, err = 2-2*r, e2; do { drawVerticalLine(x0-x, y0-y, 2*y, color); drawVerticalLine(x0+x, y0-y, 2*y, color); e2 = err; if (e2 <= y) { err += ++y * 2 + 1; if (-x == y && e2 <= x) { e2 = 0; } } if (e2 > x) { err += ++x*2+1; } } while (x <= 0); } void DmTftBase::drawTriangle(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1, uint16_t x2, uint16_t y2, uint16_t color) { drawLine(x0, y0, x1, y1, color); drawLine(x0, y0, x2, y2, color); drawLine(x1, y1, x2, y2, color); } void DmTftBase::drawPoint(uint16_t x, uint16_t y, uint16_t radius) { if (radius == 0) { cbi(_pinCS, _bitmaskCS); setAddress(x,y,x,y); sendData(_fgColor); sbi(_pinCS, _bitmaskCS); } else { fillRectangle(x-radius,y-radius,x+radius,y+radius, _fgColor); } } void DmTftBase::drawChar(uint16_t x, uint16_t y, char ch, bool transparent) { cbi(_pinCS, _bitmaskCS); uint8_t temp; uint8_t pos,t; if ((x > (_width - FONT_CHAR_WIDTH)) || (y > (_height - FONT_CHAR_HEIGHT))) { return; } ch=ch-' '; if (!transparent) { // Clear background setAddress(x,y,x+FONT_CHAR_WIDTH-1,y+FONT_CHAR_HEIGHT-1); for(pos=0;pos<FONT_CHAR_HEIGHT;pos++) { temp = read_font_line(ch, pos); for(t=0;t<FONT_CHAR_WIDTH;t++) { if (temp & 0x01) { sendData(_fgColor); } else { sendData(_bgColor); } temp>>=1; } y++; } } else { //Draw directly without clearing background for(pos=0;pos<FONT_CHAR_HEIGHT;pos++) { temp = read_font_line(ch, pos); for(t=0;t<FONT_CHAR_WIDTH;t++) { if (temp & 0x01) { setAddress(x + t, y + pos, x + t, y + pos); sendData(_fgColor); //drawPoint(x + t, y + pos); } temp>>=1; } } } sbi(_pinCS, _bitmaskCS); } void DmTftBase::drawNumber(uint16_t x, uint16_t y, int num, int digitsToShow, bool leadingZeros) { bool minus = false; if (num < 0) { num = -num; minus = true; } for (int i = 0; i < digitsToShow; i++) { char c = ' '; if ((num == 0) && (i > 0)) { if (leadingZeros) { c = '0'; if (minus && (i == (digitsToShow-1))) { c = '-'; } } else if (minus) { c = '-'; minus = false; } } else { c = '0' + (num % 10); } drawChar(x + FONT_CHAR_WIDTH*(digitsToShow - i - 1), y, c, false); num = num / 10; } } void DmTftBase::drawString(uint16_t x, uint16_t y, const char *p) { while(*p!='\0') { if(x > (_width - FONT_CHAR_WIDTH)) { x = 0; y += FONT_CHAR_HEIGHT; } if(y > (_height - FONT_CHAR_HEIGHT)) { y = x = 0; } drawChar(x, y, *p, false); x += FONT_CHAR_WIDTH; p++; } } void DmTftBase::drawStringCentered(uint16_t x, uint16_t y, uint16_t width, uint16_t height, const char *p) { int len = strlen(p); uint16_t tmp = len * FONT_CHAR_WIDTH; if (tmp <= width) { x += (width - tmp)/2; } if (FONT_CHAR_HEIGHT <= height) { y += (height - FONT_CHAR_HEIGHT)/2; } drawString(x, y, p); } void DmTftBase::drawImage(uint16_t x, uint16_t y, uint16_t width, uint16_t height, const uint16_t* data) { const uint16_t* p = data; cbi(_pinCS, _bitmaskCS); setAddress(x,y,x+width-1,y+height-1); for (int i = width*height; i > 0; i--) { sendData(*p); p++; } sbi(_pinCS, _bitmaskCS); } void DmTftBase::select(){ cbi(_pinCS, _bitmaskCS); } void DmTftBase::unSelect() { sbi(_pinCS, _bitmaskCS); }