149 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			5.7 KiB
		
	
	
	
		
			C++
		
	
	
	
 | 
						|
/*************************************************************
 | 
						|
  This sketch implements a simple serial receive terminal
 | 
						|
  program for monitoring serial debug messages from another
 | 
						|
  board.
 | 
						|
  
 | 
						|
  Connect GND to target board GND
 | 
						|
  Connect RX line to TX line of target board
 | 
						|
  Make sure the target and terminal have the same baud rate
 | 
						|
  and serial stettings!
 | 
						|
 | 
						|
  The sketch works with the ILI9341 TFT 240x320 display and
 | 
						|
  the called up libraries.
 | 
						|
  
 | 
						|
  The sketch uses the hardware scrolling feature of the
 | 
						|
  display. Modification of this sketch may lead to problems
 | 
						|
  unless the ILI9341 data sheet has been understood!
 | 
						|
 | 
						|
  Updated by Bodmer 21/12/16 for TFT_eSPI library:
 | 
						|
  https://github.com/Bodmer/TFT_eSPI
 | 
						|
  
 | 
						|
  BSD license applies, all text above must be included in any
 | 
						|
  redistribution
 | 
						|
 *************************************************************/
 | 
						|
 | 
						|
#include <TFT_eSPI.h> // Hardware-specific library
 | 
						|
#include <SPI.h>
 | 
						|
 | 
						|
TFT_eSPI tft = TFT_eSPI();       // Invoke custom library
 | 
						|
 | 
						|
// The scrolling area must be a integral multiple of TEXT_HEIGHT
 | 
						|
#define TEXT_HEIGHT 16 // Height of text to be printed and scrolled
 | 
						|
#define BOT_FIXED_AREA 0 // Number of lines in bottom fixed area (lines counted from bottom of screen)
 | 
						|
#define TOP_FIXED_AREA 16 // Number of lines in top fixed area (lines counted from top of screen)
 | 
						|
#define YMAX 320 // Bottom of screen area
 | 
						|
 | 
						|
// The initial y coordinate of the top of the scrolling area
 | 
						|
uint16_t yStart = TOP_FIXED_AREA;
 | 
						|
// yArea must be a integral multiple of TEXT_HEIGHT
 | 
						|
uint16_t yArea = YMAX-TOP_FIXED_AREA-BOT_FIXED_AREA;
 | 
						|
// The initial y coordinate of the top of the bottom text line
 | 
						|
uint16_t yDraw = YMAX - BOT_FIXED_AREA - TEXT_HEIGHT;
 | 
						|
 | 
						|
// Keep track of the drawing x coordinate
 | 
						|
uint16_t xPos = 0;
 | 
						|
 | 
						|
// For the byte we read from the serial port
 | 
						|
byte data = 0;
 | 
						|
 | 
						|
// A few test variables used during debugging
 | 
						|
boolean change_colour = 1;
 | 
						|
boolean selected = 1;
 | 
						|
 | 
						|
// We have to blank the top line each time the display is scrolled, but this takes up to 13 milliseconds
 | 
						|
// for a full width line, meanwhile the serial buffer may be filling... and overflowing
 | 
						|
// We can speed up scrolling of short text lines by just blanking the character we drew
 | 
						|
int blank[19]; // We keep all the strings pixel lengths to optimise the speed of the top line blanking
 | 
						|
 | 
						|
void setup() {
 | 
						|
  // Setup the TFT display
 | 
						|
  tft.init();
 | 
						|
  tft.setRotation(0); // Must be setRotation(0) for this sketch to work correctly
 | 
						|
  tft.fillScreen(TFT_BLACK);
 | 
						|
  
 | 
						|
  // Setup baud rate and draw top banner
 | 
						|
  Serial.begin(9600);
 | 
						|
  
 | 
						|
  tft.setTextColor(TFT_WHITE, TFT_BLUE);
 | 
						|
  tft.fillRect(0,0,240,16, TFT_BLUE);
 | 
						|
  tft.drawCentreString(" Serial Terminal - 9600 baud ",120,0,2);
 | 
						|
 | 
						|
  // Change colour for scrolling zone text
 | 
						|
  tft.setTextColor(TFT_WHITE, TFT_BLACK);
 | 
						|
 | 
						|
  // Setup scroll area
 | 
						|
  setupScrollArea(TOP_FIXED_AREA, BOT_FIXED_AREA);
 | 
						|
 | 
						|
  // Zero the array
 | 
						|
  for (byte i = 0; i<18; i++) blank[i]=0;
 | 
						|
}
 | 
						|
 | 
						|
 | 
						|
void loop(void) {
 | 
						|
  //  These lines change the text colour when the serial buffer is emptied
 | 
						|
  //  These are test lines to see if we may be losing characters
 | 
						|
  //  Also uncomment the change_colour line below to try them
 | 
						|
  //
 | 
						|
  //  if (change_colour){
 | 
						|
  //  change_colour = 0;
 | 
						|
  //  if (selected == 1) {tft.setTextColor(TFT_CYAN, TFT_BLACK); selected = 0;}
 | 
						|
  //  else {tft.setTextColor(TFT_MAGENTA, TFT_BLACK); selected = 1;}
 | 
						|
  //}
 | 
						|
 | 
						|
  while (Serial.available()) {
 | 
						|
    data = Serial.read();
 | 
						|
    // If it is a CR or we are near end of line then scroll one line
 | 
						|
    if (data == '\r' || xPos>231) {
 | 
						|
      xPos = 0;
 | 
						|
      yDraw = scroll_line(); // It can take 13ms to scroll and blank 16 pixel lines
 | 
						|
    }
 | 
						|
    if (data > 31 && data < 128) {
 | 
						|
      xPos += tft.drawChar(data,xPos,yDraw,2);
 | 
						|
      blank[(18+(yStart-TOP_FIXED_AREA)/TEXT_HEIGHT)%19]=xPos; // Keep a record of line lengths
 | 
						|
    }
 | 
						|
    //change_colour = 1; // Line to indicate buffer is being emptied
 | 
						|
  }
 | 
						|
}
 | 
						|
 | 
						|
// ##############################################################################################
 | 
						|
// Call this function to scroll the display one text line
 | 
						|
// ##############################################################################################
 | 
						|
int scroll_line() {
 | 
						|
  int yTemp = yStart; // Store the old yStart, this is where we draw the next line
 | 
						|
  // Use the record of line lengths to optimise the rectangle size we need to erase the top line
 | 
						|
  tft.fillRect(0,yStart,blank[(yStart-TOP_FIXED_AREA)/TEXT_HEIGHT],TEXT_HEIGHT, TFT_BLACK);
 | 
						|
 | 
						|
  // Change the top of the scroll area
 | 
						|
  yStart+=TEXT_HEIGHT;
 | 
						|
  // The value must wrap around as the screen memory is a circular buffer
 | 
						|
  if (yStart >= YMAX - BOT_FIXED_AREA) yStart = TOP_FIXED_AREA + (yStart - YMAX + BOT_FIXED_AREA);
 | 
						|
  // Now we can scroll the display
 | 
						|
  scrollAddress(yStart);
 | 
						|
  return  yTemp;
 | 
						|
}
 | 
						|
 | 
						|
// ##############################################################################################
 | 
						|
// Setup a portion of the screen for vertical scrolling
 | 
						|
// ##############################################################################################
 | 
						|
// We are using a hardware feature of the display, so we can only scroll in portrait orientation
 | 
						|
void setupScrollArea(uint16_t tfa, uint16_t bfa) {
 | 
						|
  tft.writecommand(ILI9341_VSCRDEF); // Vertical scroll definition
 | 
						|
  tft.writedata(tfa >> 8);           // Top Fixed Area line count
 | 
						|
  tft.writedata(tfa);
 | 
						|
  tft.writedata((YMAX-tfa-bfa)>>8);  // Vertical Scrolling Area line count
 | 
						|
  tft.writedata(YMAX-tfa-bfa);
 | 
						|
  tft.writedata(bfa >> 8);           // Bottom Fixed Area line count
 | 
						|
  tft.writedata(bfa);
 | 
						|
}
 | 
						|
 | 
						|
// ##############################################################################################
 | 
						|
// Setup the vertical scrolling start address pointer
 | 
						|
// ##############################################################################################
 | 
						|
void scrollAddress(uint16_t vsp) {
 | 
						|
  tft.writecommand(ILI9341_VSCRSADD); // Vertical scrolling pointer
 | 
						|
  tft.writedata(vsp>>8);
 | 
						|
  tft.writedata(vsp);
 | 
						|
}
 | 
						|
 |