// ported from LCD_screen void clear(uint16_t colour) { uint16_t oldOrientation = _orientation; bool oldPenSolid = _penSolid; setOrientation(0); setPenSolid(true); rectangle(0, 0, screenSizeX()-1, screenSizeY()-1, colour); setOrientation(oldOrientation); setPenSolid(oldPenSolid); }
// ported from LCD_screen void circle(uint16_t x0, uint16_t y0, uint16_t radius, uint16_t colour) { int16_t f = 1 - radius; int16_t ddF_x = 1; int16_t ddF_y = -2 * radius; int16_t x = 0; int16_t y = radius; if (_penSolid == false) { point(x0, y0+radius, colour); point(x0, y0-radius, colour); point(x0+radius, y0, colour); point(x0-radius, y0, colour); while (x < y) { if (f >= 0) { y--; ddF_y += 2; f += ddF_y; } x++; ddF_x += 2; f += ddF_x; point(x0 + x, y0 + y, colour); point(x0 - x, y0 + y, colour); point(x0 + x, y0 - y, colour); point(x0 - x, y0 - y, colour); point(x0 + y, y0 + x, colour); point(x0 - y, y0 + x, colour); point(x0 + y, y0 - x, colour); point(x0 - y, y0 - x, colour); } } else { while (x<y) { if (f >= 0) { y--; ddF_y += 2; f += ddF_y; } x++; ddF_x += 2; f += ddF_x; line(x0 + x, y0 + y, x0 - x, y0 + y, colour); line(x0 + x, y0 - y, x0 - x, y0 - y, colour); line(x0 + y, y0 - x, x0 + y, y0 + x, colour); line(x0 - y, y0 - x, x0 - y, y0 + x, colour); } setPenSolid(true); rectangle(x0-x, y0-y, x0+x, y0+y, colour); } }
// ported from LCS_screen_font void gText(uint16_t x0, uint16_t y0, uint8_t *s, uint32_t length, uint16_t textColour, uint16_t backColour, uint32_t ix, uint32_t iy) { uint8_t c; uint32_t line, line1, line2; uint32_t x, y; uint32_t i, j, k; if ((ix > 1) || (iy > 1) || !_fontSolid) { if ((_fontSize == 0) && ((ix > 1) || (iy > 1))) { bool oldPenSolid = _penSolid; setPenSolid(true); for (k=0; k<length; k++) { x = x0 + 6 * k * ix; y = y0; c = s[k]-' '; for ( i=0; i<6; i++ ) { line = _getCharacter(c, i); for ( j = 0; j<8; j++) { if (bitRead(line, j)) rectangle(x+i*ix, y+j*iy, x+i*ix+ix-1, y+j*iy+iy-1, textColour); else if (_fontSolid) rectangle(x+i*ix, y+j*iy, x+i*ix+ix-1, y+j*iy+iy-1, backColour); } } } setPenSolid(oldPenSolid); } else { if (_fontSize == 0) { for (k=0; k<length; k++) { c = s[k]-' '; for (i=0; i<6; i++) { line = _getCharacter(c, i); for (j=0; j<8; j++) if (bitRead(line, j)) point(x0 + 6*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 6*k + i, y0 + j, backColour); } } } else if (_fontSize == 1) { for (k=0; k<length; k++) { c = s[k]-' '; for (i=0; i<8; i++) { line = _getCharacter(c, 2*i); line1 =_getCharacter(c, 2*i+1); for (j=0; j<8; j++) { if (bitRead(line, j)) point(x0 + 8*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 8*k + i, y0 + j, backColour); if (bitRead(line1, j)) point(x0 + 8*k + i, y0 +8 + j, textColour); else if ((_fontSolid) && (j<4)) point(x0 + 8*k + i, y0 +8 + j, backColour); } } } } else if (_fontSize == 2) { for (k=0; k<length; k++) { c = s[k]-' '; for (i=0; i<12; i++) { line = _getCharacter(c, 2*i); line1 =_getCharacter(c, 2*i+1); for (j=0; j<8; j++) { if (bitRead(line, j)) point(x0 + 12*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 12*k + i, y0 + j, backColour); if (bitRead(line1, j)) point(x0 + 12*k + i, y0 +8 + j, textColour); else if (_fontSolid) point(x0 + 12*k + i, y0 +8 + j, backColour); } } } } else if (_fontSize == 3) { for (k=0; k<length; k++) { c = s[k]-' '; for (i=0; i<16; i++) { line =_getCharacter(c, 3*i); line1 =_getCharacter(c, 3*i+1); line2 =_getCharacter(c, 3*i+2); for (j=0; j<8; j++) { if (bitRead(line, j)) point(x0 + 16*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 16*k + i, y0 + j, backColour); if (bitRead(line1, j)) point(x0 + 16*k + i, y0 +8 + j, textColour); else if (_fontSolid) point(x0 + 16*k + i, y0 +8 + j, backColour); if (bitRead(line2, j)) point(x0 + 16*k + i, y0 +16 + j, textColour); else if (_fontSolid) point(x0 + 16*k + i, y0 +16 + j, backColour); } } } } } } else { uint8_t c; uint32_t i, j, k; if (_fontSize == 0) { for (k=0; k<length; k++) { c = s[k]-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<6; i++) { line = _getCharacter(c, i); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } } } else if (_fontSize == 1) { for (k=0; k<length; k++) { c = s[k]-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<8; i++) { line = _getCharacter(c, 2*i); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } for (j=0; j<4; j++) { for (i=0; i<8; i++) { line = _getCharacter(c, 2*i+1); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } } } else if (_fontSize == 2) { for (k=0; k<length; k++) { c = s[k]-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<12; i++) { line = _getCharacter(c, 2*i); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } for (j=0; j<8; j++) { for (i=0; i<12; i++) { line = _getCharacter(c, 2*i+1); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } } } else if (_fontSize == 3) { for (k=0; k<length; k++) { c = s[k]-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<16; i++) { line = _getCharacter(c, 3*i); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } for (j=0; j<8; j++) { for (i=0; i<16; i++) { line = _getCharacter(c, 3*i+1); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } for (j=0; j<8; j++) { for (i=0; i<16; i++) { line = _getCharacter(c, 3*i+2); if (bitRead(line, j)) { _writeData16(textColour); } else { _writeData16(backColour); } } } } } } }
void LCD_screen_font::gText(uint16_t x0, uint16_t y0, String s, uint16_t textColour, uint16_t backColour, uint8_t ix, uint8_t iy) { uint8_t c; uint8_t line, line1, line2, line3; uint16_t x, y; uint8_t i, j, k; if ((ix > 1) || (iy > 1) || !_fontSolid) { if ((_fontSize == 0) && ((ix > 1) || (iy > 1))) { bool oldPenSolid = _penSolid; setPenSolid(true); for (k=0; k<s.length(); k++) { x = x0 + 6 * k * ix; y = y0; c = s.charAt(k)-' '; for ( i=0; i<6; i++ ) { line = _getCharacter(c, i); for ( j = 0; j<8; j++) { if (bitRead(line, j)) rectangle(x+i*ix, y+j*iy, x+i*ix+ix-1, y+j*iy+iy-1, textColour); else if (_fontSolid) rectangle(x+i*ix, y+j*iy, x+i*ix+ix-1, y+j*iy+iy-1, backColour); } } } setPenSolid(oldPenSolid); } else { #if (MAX_FONT_SIZE > 0) if (_fontSize == 0) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; for (i=0; i<6; i++) { line = _getCharacter(c, i); for (j=0; j<8; j++) if (bitRead(line, j)) point(x0 + 6*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 6*k + i, y0 + j, backColour); } } } #if (MAX_FONT_SIZE > 1) else if (_fontSize == 1) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; for (i=0; i<8; i++) { line = _getCharacter(c, 2*i); line1 =_getCharacter(c, 2*i+1); for (j=0; j<8; j++) { if (bitRead(line, j)) point(x0 + 8*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 8*k + i, y0 + j, backColour); if (bitRead(line1, j)) point(x0 + 8*k + i, y0 +8 + j, textColour); else if ((_fontSolid) && (j<4)) point(x0 + 8*k + i, y0 +8 + j, backColour); } } } } #if (MAX_FONT_SIZE > 2) else if (_fontSize == 2) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; for (i=0; i<12; i++) { line = _getCharacter(c, 2*i); line1 =_getCharacter(c, 2*i+1); for (j=0; j<8; j++) { if (bitRead(line, j)) point(x0 + 12*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 12*k + i, y0 + j, backColour); if (bitRead(line1, j)) point(x0 + 12*k + i, y0 +8 + j, textColour); else if (_fontSolid) point(x0 + 12*k + i, y0 +8 + j, backColour); } } } } #if (MAX_FONT_SIZE > 3) else if (_fontSize == 3) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; for (i=0; i<16; i++) { line =_getCharacter(c, 3*i); line1 =_getCharacter(c, 3*i+1); line2 =_getCharacter(c, 3*i+2); for (j=0; j<8; j++) { if (bitRead(line, j)) point(x0 + 16*k + i, y0 + j, textColour); else if (_fontSolid) point(x0 + 16*k + i, y0 + j, backColour); if (bitRead(line1, j)) point(x0 + 16*k + i, y0 +8 + j, textColour); else if (_fontSolid) point(x0 + 16*k + i, y0 +8 + j, backColour); if (bitRead(line2, j)) point(x0 + 16*k + i, y0 +16 + j, textColour); else if (_fontSolid) point(x0 + 16*k + i, y0 +16 + j, backColour); } } } } #endif #endif #endif #endif } } else { uint8_t c; uint8_t line, line1; uint16_t x, y; uint8_t i, j, k; uint8_t highTextColour = highByte(textColour); uint8_t lowTextColour = lowByte(textColour); uint8_t highBackColour = highByte(backColour); uint8_t lowBackColour = lowByte(backColour); #if (MAX_FONT_SIZE > 0) if (_fontSize == 0) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<6; i++) { line = _getCharacter(c, i); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } } } #if (MAX_FONT_SIZE > 1) else if (_fontSize == 1) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<8; i++) { line = _getCharacter(c, 2*i); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } for (j=0; j<4; j++) { for (i=0; i<8; i++) { line = _getCharacter(c, 2*i+1); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } } } #if (MAX_FONT_SIZE > 2) else if (_fontSize == 2) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<12; i++) { line = _getCharacter(c, 2*i); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } for (j=0; j<8; j++) { for (i=0; i<12; i++) { line = _getCharacter(c, 2*i+1); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } } } #if (MAX_FONT_SIZE > 3) else if (_fontSize == 3) { for (k=0; k<s.length(); k++) { c = s.charAt(k)-' '; _setWindow(x0 +fontSizeX()*k, y0, x0 +fontSizeX()*(k+1)-1, y0+fontSizeY()-1); for (j=0; j<8; j++) { for (i=0; i<16; i++) { line = _getCharacter(c, 3*i); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } for (j=0; j<8; j++) { for (i=0; i<16; i++) { line = _getCharacter(c, 3*i+1); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } for (j=0; j<8; j++) { for (i=0; i<16; i++) { line = _getCharacter(c, 3*i+2); if (bitRead(line, j)) { _writeData88(highTextColour, lowTextColour); } else { _writeData88(highBackColour, lowBackColour); } } } } } #endif #endif #endif #endif } }