void Screen_HX8353E::_setWindow(uint16_t x0, uint16_t y0, uint16_t x1, uint16_t y1) { switch (_orientation) { case 0: x0 += 2; y0 += 3; x1 += 2; y1 += 3; break; case 1: x0 += 3; y0 += 2; x1 += 3; y1 += 2; break; case 2: x0 += 2; y0 += 1; x1 += 2; y1 += 1; break; case 3: x0 += 1; y0 += 2; x1 += 1; y1 += 2; break; default: break; } _writeCommand(HX8353E_CASET); _writeData16(x0); _writeData16(x1); _writeCommand(HX8353E_RASET); _writeData16(y0); _writeData16(y1); _writeCommand(HX8353E_RAMWR); }
// 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); } } } } } } }
// ported from Screen_HX8353E void _setPoint(uint16_t x1, uint16_t y1, uint16_t colour) { if( /*(x1 < 0) || */(x1 >= screenSizeX()) || /*(y1 < 0) || */(y1 >= screenSizeY()) ) return; _setWindow(x1, y1, x1+1, y1+1); _writeData16(colour); }
void Screen_HX8353E::_setPoint(uint16_t x1, uint16_t y1, uint16_t colour) { if( (x1 < 0) || (x1 >= screenSizeX()) || (y1 < 0) || (y1 >= screenSizeY()) ) return; _setWindow(x1, y1, x1+1, y1+1); _writeData16(colour); }