mirror of https://github.com/MLXXXp/Arduboy2.git
Refactor text code and add char size functions
- Functions write() and drawChar() were refactored for smaller code size and to make text wrapping operate more like what would normally be expected. - A new flag variable, textRaw, has been added, along with functions setTextRawMode() and getTextRawMode() to set and read it. When set, the write() function will render the value \n (0x0a) as an "inverse white circle" instead of handling it as a newline and render value \r (0x0d) as a "musical eighth note" instead of ignoring it. - Spacing added at the end of each character is no longer factored in when determining if a character will fit on screen at the end of a line. - Checking if line wrap is neccessary is done before drawing a character, instead of doing it after drawing to prepare for the next character. This fixed a problem with requested line feeds interacting with wrapping, resulting in unexpected blank lines. - Fixed a bug that caused the drawing of characters with a transparent background to not work properly. (This is selected by setting the background color to be the same as the text color.) - Added new functions getCharacterWidth() getCharacterHeight() getCharacterSpacing() getLineSpacing() to programmatically get the dimensions of a character, given the desired text size. - Functions write() and drawChar() are now able to render a font of any character size, and with any character and line spacing, by setting variables characterWidth characterHeight characterSpacing and lineSpacing, and providing a matching font array. This doesn't affect their use with this library but has been done for the sake of code portability.
This commit is contained in:
parent
bbebec346d
commit
58a35e2ad9
|
@ -67,11 +67,16 @@ flipHorizontal KEYWORD2
|
||||||
freeRGBled KEYWORD2
|
freeRGBled KEYWORD2
|
||||||
generateRandomSeed KEYWORD2
|
generateRandomSeed KEYWORD2
|
||||||
getBuffer KEYWORD2
|
getBuffer KEYWORD2
|
||||||
|
getCharacterHeight KEYWORD2
|
||||||
|
getCharacterSpacing KEYWORD2
|
||||||
|
getCharacterWidth KEYWORD2
|
||||||
getCursorX KEYWORD2
|
getCursorX KEYWORD2
|
||||||
getCursorY KEYWORD2
|
getCursorY KEYWORD2
|
||||||
|
getLineSpacing KEYWORD2
|
||||||
getPixel KEYWORD2
|
getPixel KEYWORD2
|
||||||
getTextBackground KEYWORD2
|
getTextBackground KEYWORD2
|
||||||
getTextColor KEYWORD2
|
getTextColor KEYWORD2
|
||||||
|
getTextRawMode KEYWORD2
|
||||||
getTextSize KEYWORD2
|
getTextSize KEYWORD2
|
||||||
getTextWrap KEYWORD2
|
getTextWrap KEYWORD2
|
||||||
height KEYWORD2
|
height KEYWORD2
|
||||||
|
@ -104,6 +109,7 @@ setFrameRate KEYWORD2
|
||||||
setRGBled KEYWORD2
|
setRGBled KEYWORD2
|
||||||
setTextBackground KEYWORD2
|
setTextBackground KEYWORD2
|
||||||
setTextColor KEYWORD2
|
setTextColor KEYWORD2
|
||||||
|
setTextRawMode KEYWORD2
|
||||||
setTextSize KEYWORD2
|
setTextSize KEYWORD2
|
||||||
setTextWrap KEYWORD2
|
setTextWrap KEYWORD2
|
||||||
SPItransfer KEYWORD2
|
SPItransfer KEYWORD2
|
||||||
|
|
119
src/Arduboy2.cpp
119
src/Arduboy2.cpp
|
@ -1157,6 +1157,7 @@ Arduboy2::Arduboy2()
|
||||||
textBackground = 0;
|
textBackground = 0;
|
||||||
textSize = 1;
|
textSize = 1;
|
||||||
textWrap = 0;
|
textWrap = 0;
|
||||||
|
textRaw = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
// bootLogoText() should be kept in sync with bootLogoShell()
|
// bootLogoText() should be kept in sync with bootLogoShell()
|
||||||
|
@ -1237,64 +1238,106 @@ void Arduboy2::bootLogoExtra()
|
||||||
|
|
||||||
size_t Arduboy2::write(uint8_t c)
|
size_t Arduboy2::write(uint8_t c)
|
||||||
{
|
{
|
||||||
if (c == '\n')
|
if ((c == '\r') && !textRaw)
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (((c == '\n') && !textRaw) ||
|
||||||
|
(textWrap && (cursor_x > (WIDTH - (characterWidth * textSize)))))
|
||||||
{
|
{
|
||||||
cursor_y += textSize * 8;
|
|
||||||
cursor_x = 0;
|
cursor_x = 0;
|
||||||
|
cursor_y += fullCharacterHeight * textSize;
|
||||||
}
|
}
|
||||||
else if (c == '\r')
|
|
||||||
{
|
if ((c != '\n') || textRaw)
|
||||||
// skip em
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
{
|
||||||
drawChar(cursor_x, cursor_y, c, textColor, textBackground, textSize);
|
drawChar(cursor_x, cursor_y, c, textColor, textBackground, textSize);
|
||||||
cursor_x += textSize * 6;
|
cursor_x += fullCharacterWidth * textSize;
|
||||||
if (textWrap && (cursor_x > (WIDTH - textSize * 6)))
|
|
||||||
{
|
|
||||||
// calling ourselves recursively for 'newline' is
|
|
||||||
// 12 bytes smaller than doing the same math here
|
|
||||||
write('\n');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Arduboy2::drawChar
|
void Arduboy2::drawChar
|
||||||
(int16_t x, int16_t y, unsigned char c, uint8_t color, uint8_t bg, uint8_t size)
|
(int16_t x, int16_t y, uint8_t c, uint8_t color, uint8_t bg, uint8_t size)
|
||||||
{
|
{
|
||||||
uint8_t line;
|
// It is assumed that rendering characters fully off screen will be rare,
|
||||||
bool draw_background = bg != color;
|
// so let drawPixel() handle off screen checks, to reduce code size at the
|
||||||
const uint8_t* bitmap = font5x7 + c * 5;
|
// expense of slower off screen character handling.
|
||||||
|
#if 0
|
||||||
if ((x >= WIDTH) || // Clip right
|
if ((x >= WIDTH) || // Clip right
|
||||||
(y >= HEIGHT) || // Clip bottom
|
(y >= HEIGHT) || // Clip bottom
|
||||||
((x + 5 * size - 1) < 0) || // Clip left
|
((x + characterWidth * size - 1) < 0) || // Clip left
|
||||||
((y + 8 * size - 1) < 0) // Clip top
|
((y + characterHeight * size - 1) < 0) // Clip top
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
for (uint8_t i = 0; i < 6; i++ )
|
bool drawBackground = bg != color;
|
||||||
|
const uint8_t* bitmap =
|
||||||
|
&font5x7[c * characterWidth * ((characterHeight + 8 - 1) / 8)];
|
||||||
|
|
||||||
|
for (uint8_t i = 0; i < fullCharacterWidth; i++)
|
||||||
{
|
{
|
||||||
line = pgm_read_byte(bitmap++);
|
uint8_t column;
|
||||||
if (i == 5) {
|
|
||||||
line = 0x0;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (uint8_t j = 0; j < 8; j++)
|
if (characterHeight <= 8)
|
||||||
{
|
{
|
||||||
uint8_t draw_color = (line & 0x1) ? color : bg;
|
column = (i < characterWidth) ? pgm_read_byte(bitmap++) : 0;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
column = 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (draw_color || draw_background) {
|
// draw the character by columns. Top to bottom, left to right
|
||||||
for (uint8_t a = 0; a < size; a++ ) {
|
// including character spacing on the right
|
||||||
for (uint8_t b = 0; b < size; b++ ) {
|
for (uint8_t j = 0; j < characterHeight; j++)
|
||||||
drawPixel(x + (i * size) + a, y + (j * size) + b, draw_color);
|
{
|
||||||
|
if (characterHeight > 8)
|
||||||
|
{
|
||||||
|
// at this point variable "column" will be 0, either from initialization
|
||||||
|
// or by having eight 0 bits shifted in by the >>= operation below
|
||||||
|
if ((j % 8 == 0) && (i < characterWidth))
|
||||||
|
{
|
||||||
|
column = pgm_read_byte(bitmap++);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// pixelIsSet should be a bool but at the time of writing,
|
||||||
|
// the GCC AVR compiler generates less code if it's a uint8_t
|
||||||
|
uint8_t pixelIsSet = column & 0x01;
|
||||||
|
|
||||||
|
if (pixelIsSet || drawBackground)
|
||||||
|
{
|
||||||
|
for (uint8_t a = 0; a < size; a++)
|
||||||
|
{
|
||||||
|
for (uint8_t b = 0; b < size; b++)
|
||||||
|
{
|
||||||
|
drawPixel(x + (i * size) + a, y + (j * size) + b,
|
||||||
|
pixelIsSet ? color : bg);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
column >>= 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
// draw the inter-line spacing pixels for this column if required
|
||||||
|
if (drawBackground)
|
||||||
|
{
|
||||||
|
for (uint8_t j = characterHeight; j < fullCharacterHeight; j++)
|
||||||
|
{
|
||||||
|
for (uint8_t a = 0; a < size; a++)
|
||||||
|
{
|
||||||
|
for (uint8_t b = 0; b < size; b++)
|
||||||
|
{
|
||||||
|
drawPixel(x + (i * size) + a, y + (j * size) + b, bg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
line >>= 1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1366,6 +1409,16 @@ bool Arduboy2::getTextWrap()
|
||||||
return textWrap;
|
return textWrap;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Arduboy2::setTextRawMode(bool raw)
|
||||||
|
{
|
||||||
|
textRaw = raw;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Arduboy2::getTextRawMode()
|
||||||
|
{
|
||||||
|
return textRaw;
|
||||||
|
}
|
||||||
|
|
||||||
void Arduboy2::clear()
|
void Arduboy2::clear()
|
||||||
{
|
{
|
||||||
Arduboy2Base::clear();
|
Arduboy2Base::clear();
|
||||||
|
|
253
src/Arduboy2.h
253
src/Arduboy2.h
|
@ -1466,15 +1466,18 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
*
|
*
|
||||||
* Print will use the `write()` function to actually draw each character
|
* Print will use the `write()` function to actually draw each character
|
||||||
* in the screen buffer, using the library's `font5x7` font.
|
* in the screen buffer, using the library's `font5x7` font.
|
||||||
* Two character values are handled specially (and thus the font symbols that
|
* Two character values are handled specially:
|
||||||
* they represent can't be displayed):
|
|
||||||
*
|
*
|
||||||
* - ASCII newline or line feed (`\n`, 0x0A, inverse white circle).
|
* - ASCII newline/line feed (`\n`, 0x0A, inverse white circle).
|
||||||
* This will move the text cursor position to the start of the next line,
|
* This will move the text cursor position to the start of the next line,
|
||||||
* based on the current text size.
|
* based on the current text size.
|
||||||
* - ASCII carriage return (`\r`, 0x0D, musical eighth note).
|
* - ASCII carriage return (`\r`, 0x0D, musical eighth note).
|
||||||
* This character will be ignored.
|
* This character will be ignored.
|
||||||
*
|
*
|
||||||
|
* To override the special handling of the above values, to allow the
|
||||||
|
* characters they represent to be printed, text _raw_ mode can be selected
|
||||||
|
* using the `setTextRawMode()` function.
|
||||||
|
*
|
||||||
* See:
|
* See:
|
||||||
* https://www.arduino.cc/reference/en/language/functions/communication/serial/print/
|
* https://www.arduino.cc/reference/en/language/functions/communication/serial/print/
|
||||||
*
|
*
|
||||||
|
@ -1482,15 +1485,23 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* \code{.cpp}
|
* \code{.cpp}
|
||||||
* int value = 42;
|
* int value = 42;
|
||||||
*
|
*
|
||||||
* arduboy.println("Hello World"); // Prints "Hello World" and then moves the
|
* arduboy.println("Hello World"); // Prints "Hello World" and then sets the
|
||||||
* // text cursor to the start of the next line
|
* // text cursor to the start of the next line
|
||||||
* arduboy.print(value); // Prints "42"
|
* arduboy.print(value); // Prints "42"
|
||||||
* arduboy.print('\n'); // Moves the text cursor to the start of the next line
|
* arduboy.print('\n'); // Sets the text cursor to the start of the next line
|
||||||
* arduboy.print(78, HEX); // Prints "4E" (78 in hexadecimal)
|
* arduboy.print(78, HEX); // Prints "4E" (78 in hexadecimal)
|
||||||
* arduboy.print("\x03\xEA"); // Prints a heart symbol and a Greek uppercase omega
|
* arduboy.print("\x03\xEA"); // Prints a heart symbol and a Greek uppercase omega
|
||||||
|
*
|
||||||
|
* arduboy.setTextRawMode(true); // Set text "raw" mode
|
||||||
|
* arduboy.print("\r\n") // Prints a "musical eighth note"
|
||||||
|
* // followed by an "inverse white circle"
|
||||||
|
* // because we're in "raw" mode
|
||||||
|
* arduboy.setTextRawMode(false); // Exit text "raw" mode
|
||||||
* \endcode
|
* \endcode
|
||||||
*
|
*
|
||||||
* \see Arduboy2::write() Arduboy2::font5x7
|
* \see Arduboy2::setTextSize() Arduboy2::setTextColor()
|
||||||
|
* Arduboy2::setTextBackground() Arduboy2::setTextWrap()
|
||||||
|
* Arduboy2::setTextRawMode() Arduboy2::write() Arduboy2::font5x7
|
||||||
*/
|
*/
|
||||||
using Print::write;
|
using Print::write;
|
||||||
|
|
||||||
|
@ -1557,27 +1568,31 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* \details
|
* \details
|
||||||
* This is the Arduboy implemetation of the Arduino virtual `write()`
|
* This is the Arduboy implemetation of the Arduino virtual `write()`
|
||||||
* function. The single character specified is written to the the screen
|
* function. The single character specified is written to the the screen
|
||||||
* buffer at the current text cursor position. The text cursor is then
|
* buffer at the current text cursor position or possibly the start of the
|
||||||
* moved to the next character position in the screen buffer. This new cursor
|
* next line if text wrap mode is on. The text cursor is then set to the
|
||||||
* position will depend on the current text size and possibly the current
|
* next character position.
|
||||||
* wrap mode.
|
|
||||||
*
|
*
|
||||||
* Characters are rendered using the library's `font5x7` font.
|
* Characters are rendered using the library's `font5x7` font.
|
||||||
* Two character values are handled specially (and thus the font symbols that
|
* Two character values are handled specially:
|
||||||
* they represent can't be displayed):
|
|
||||||
*
|
*
|
||||||
* - ASCII newline or line feed (`\n`, 0x0A, inverse white circle).
|
* - ASCII newline/line feed (`\n`, 0x0A, inverse white circle).
|
||||||
* This will move the text cursor position to the start of the next line,
|
* This will move the text cursor position to the start of the next line,
|
||||||
* based on the current text size.
|
* based on the current text size.
|
||||||
* - ASCII carriage return (`\r`, 0x0D, musical eighth note).
|
* - ASCII carriage return (`\r`, 0x0D, musical eighth note).
|
||||||
* This character will be ignored.
|
* This character will be ignored.
|
||||||
*
|
*
|
||||||
|
* To override the special handling of the above values, to allow the
|
||||||
|
* characters they represent to be printed, text _raw_ mode can be selected
|
||||||
|
* using the `setTextRawMode()` function.
|
||||||
|
*
|
||||||
|
*
|
||||||
* \note
|
* \note
|
||||||
* This function is rather low level and, although it's available as a public
|
* This function is rather low level and, although it's available as a public
|
||||||
* function, it wouldn't normally be used. In most cases the Arduino Print
|
* function, it wouldn't normally be used. In most cases the Arduino Print
|
||||||
* class should be used for writing text.
|
* class should be used for writing text.
|
||||||
*
|
*
|
||||||
* \see Print setTextSize() setTextWrap() drawChar()
|
* \see Print setTextSize() setTextColor() setTextBackground() setTextWrap()
|
||||||
|
* setTextRawMode() drawChar() font5x7
|
||||||
*/
|
*/
|
||||||
virtual size_t write(uint8_t);
|
virtual size_t write(uint8_t);
|
||||||
|
|
||||||
|
@ -1593,9 +1608,9 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* \param size The size of the character to draw.
|
* \param size The size of the character to draw.
|
||||||
*
|
*
|
||||||
* \details
|
* \details
|
||||||
* The specified character is drawn starting at the provided
|
* The specified character is drawn starting at the provided coordinate.
|
||||||
* coordinate. The point specified by the X and Y coordinates will be the
|
* The point specified by the X and Y coordinates will be the top left
|
||||||
* top left corner of the character. The character will be rendered using the
|
* corner of the character. The character will be rendered using the
|
||||||
* library's `font5x7` font.
|
* library's `font5x7` font.
|
||||||
*
|
*
|
||||||
* \note
|
* \note
|
||||||
|
@ -1604,10 +1619,9 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* normally be used. In most cases the Arduino Print class should be used for
|
* normally be used. In most cases the Arduino Print class should be used for
|
||||||
* writing text.
|
* writing text.
|
||||||
*
|
*
|
||||||
* \see Print write() setTextColor() setTextBackground() setTextSize()
|
* \see Print write() font5x7
|
||||||
* font5x7
|
|
||||||
*/
|
*/
|
||||||
void drawChar(int16_t x, int16_t y, unsigned char c, uint8_t color, uint8_t bg, uint8_t size);
|
void drawChar(int16_t x, int16_t y, uint8_t c, uint8_t color, uint8_t bg, uint8_t size);
|
||||||
|
|
||||||
/** \brief
|
/** \brief
|
||||||
* Set the location of the text cursor.
|
* Set the location of the text cursor.
|
||||||
|
@ -1689,6 +1703,7 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* Set the text foreground color.
|
* Set the text foreground color.
|
||||||
*
|
*
|
||||||
* \param color The color to be used for following text.
|
* \param color The color to be used for following text.
|
||||||
|
* The values `WHITE` or `BLACK` should be used.
|
||||||
*
|
*
|
||||||
* \see setTextBackground() getTextColor()
|
* \see setTextBackground() getTextColor()
|
||||||
*/
|
*/
|
||||||
|
@ -1699,7 +1714,7 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
*
|
*
|
||||||
* \return The color that will be used to display any following text.
|
* \return The color that will be used to display any following text.
|
||||||
*
|
*
|
||||||
* \see setTextColor()
|
* \see setTextColor() getTextBackground()
|
||||||
*/
|
*/
|
||||||
uint8_t getTextColor();
|
uint8_t getTextColor();
|
||||||
|
|
||||||
|
@ -1707,6 +1722,15 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* Set the text background color.
|
* Set the text background color.
|
||||||
*
|
*
|
||||||
* \param bg The background color to be used for following text.
|
* \param bg The background color to be used for following text.
|
||||||
|
* The values `WHITE` or `BLACK` should be used.
|
||||||
|
*
|
||||||
|
* The background pixels of following characters will be set to the
|
||||||
|
* specified color.
|
||||||
|
*
|
||||||
|
* However, if the background color is set to be the same as the text color,
|
||||||
|
* the background will be transparent. Only the foreground pixels will be
|
||||||
|
* drawn. The background pixels will remain as they were before the character
|
||||||
|
* was drawn.
|
||||||
*
|
*
|
||||||
* \see setTextColor() getTextBackground()
|
* \see setTextColor() getTextBackground()
|
||||||
*/
|
*/
|
||||||
|
@ -1717,7 +1741,7 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
*
|
*
|
||||||
* \return The background color that will be used to display any following text.
|
* \return The background color that will be used to display any following text.
|
||||||
*
|
*
|
||||||
* \see setTextBackground()
|
* \see setTextBackground() getTextColor()
|
||||||
*/
|
*/
|
||||||
uint8_t getTextBackground();
|
uint8_t getTextBackground();
|
||||||
|
|
||||||
|
@ -1727,15 +1751,13 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* \param s The text size multiplier. Must be 1 or higher.
|
* \param s The text size multiplier. Must be 1 or higher.
|
||||||
*
|
*
|
||||||
* \details
|
* \details
|
||||||
* Setting a text size of 1 will result in standard size characters which
|
* Setting a text size of 1 will result in standard size characters with
|
||||||
* occupy 6x8 pixels (the result of 5x7 characters with spacing on the
|
* one pixel for each bit in the bitmap for a character. The value specified
|
||||||
* right and bottom edges).
|
* is a multiplier. A value of 2 will double the width and height.
|
||||||
|
* A value of 3 will triple the dimensions, etc.
|
||||||
*
|
*
|
||||||
* The value specified is a multiplier. A value of 2 will double the
|
* \see getTextSize() getCharacterWidth() getCharacterHeight()
|
||||||
* size so they will occupy 12x16 pixels. A value of 3 will result in
|
* getCharacterSpacing() getLineSpacing() font5x7
|
||||||
* 18x24, etc.
|
|
||||||
*
|
|
||||||
* \see getTextSize()
|
|
||||||
*/
|
*/
|
||||||
void setTextSize(uint8_t s);
|
void setTextSize(uint8_t s);
|
||||||
|
|
||||||
|
@ -1744,7 +1766,8 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
*
|
*
|
||||||
* \return The size that will be used for any following text.
|
* \return The size that will be used for any following text.
|
||||||
*
|
*
|
||||||
* \see setTextSize()
|
* \see setTextSize() getCharacterWidth() getCharacterHeight()
|
||||||
|
* getCharacterSpacing() getLineSpacing() font5x7
|
||||||
*/
|
*/
|
||||||
uint8_t getTextSize();
|
uint8_t getTextSize();
|
||||||
|
|
||||||
|
@ -1754,14 +1777,15 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* \param w `true` enables text wrap mode. `false` disables it.
|
* \param w `true` enables text wrap mode. `false` disables it.
|
||||||
*
|
*
|
||||||
* \details
|
* \details
|
||||||
* Text wrap mode is enabled by specifying `true`. In wrap mode, the text
|
* Text wrap mode is enabled by specifying `true`. In wrap mode, if a
|
||||||
* cursor will be moved to the start of the next line (based on the current
|
* character to be drawn would end up partially or fully past the right edge
|
||||||
* text size) if the following character wouldn't fit entirely at the end of
|
* of the screen (based on the current text size), it will be placed at the
|
||||||
* the current line.
|
* start of the next line. The text cursor will be adjusted accordingly.
|
||||||
*
|
*
|
||||||
* If wrap mode is disabled, characters will continue to be written to the
|
* If wrap mode is disabled, characters will always be written at the current
|
||||||
* same line. A character at the right edge of the screen may only be
|
* text cursor position. A character near the right edge of the screen may
|
||||||
* partially displayed and additional characters will be off screen.
|
* only be partially displayed and characters drawn at a position past the
|
||||||
|
* right edge of the screen will remain off screen.
|
||||||
*
|
*
|
||||||
* \see getTextWrap()
|
* \see getTextWrap()
|
||||||
*/
|
*/
|
||||||
|
@ -1776,11 +1800,138 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
*/
|
*/
|
||||||
bool getTextWrap();
|
bool getTextWrap();
|
||||||
|
|
||||||
|
/** \brief
|
||||||
|
* Set or disable text raw mode, allowing special characters to be displayed.
|
||||||
|
*
|
||||||
|
* \param raw `true` enables text raw mode. `false` disables it.
|
||||||
|
*
|
||||||
|
* \details
|
||||||
|
* In text _raw_ mode, character values that would normally be treated
|
||||||
|
* specially will instead be displayed. The special characters are:
|
||||||
|
*
|
||||||
|
* - ASCII newline/line feed (`\n`, 0x0A, inverse white circle).
|
||||||
|
* - ASCII carriage return (`\r`, 0x0D, musical eighth note).
|
||||||
|
*
|
||||||
|
* All other characters can be displayed regardless of whether raw mode
|
||||||
|
* is enabled or not.
|
||||||
|
*
|
||||||
|
* \see getTextRawMode() Print
|
||||||
|
*/
|
||||||
|
void setTextRawMode(bool raw);
|
||||||
|
|
||||||
|
/** \brief
|
||||||
|
* Get the current state of text raw mode.
|
||||||
|
*
|
||||||
|
* \return `true` if text raw mode is enabled, `false` if disabled.
|
||||||
|
*
|
||||||
|
* \see setTextRawMode()
|
||||||
|
*/
|
||||||
|
bool getTextRawMode();
|
||||||
|
|
||||||
/** \brief
|
/** \brief
|
||||||
* Clear the display buffer and set the text cursor to location 0, 0.
|
* Clear the display buffer and set the text cursor to location 0, 0.
|
||||||
*/
|
*/
|
||||||
void clear();
|
void clear();
|
||||||
|
|
||||||
|
/** \brief
|
||||||
|
* Get the width, in pixels, of a character in the library's font.
|
||||||
|
*
|
||||||
|
* \param textSize The text size the character would be drawn at
|
||||||
|
* (optional; defaults to 1).
|
||||||
|
*
|
||||||
|
* \return The width, in pixels, that a character will occupy, not including
|
||||||
|
* inter-character spacing.
|
||||||
|
*
|
||||||
|
* \details
|
||||||
|
* Returns the width, in pixels, occupied by a character in the font used by
|
||||||
|
* the library for text functions. The result will be based on the provided
|
||||||
|
* text size, or size 1 if not included. Since the font is monospaced, all
|
||||||
|
* characters will occupy the same width for a given text size.
|
||||||
|
*
|
||||||
|
* The width does not include the spacing added after each character by the
|
||||||
|
* library text functions. The `getCharacterSpacing()` function can be used
|
||||||
|
* to obtain the character spacing value.
|
||||||
|
*
|
||||||
|
* \see getCharacterHeight() getCharacterSpacing()
|
||||||
|
* getTextSize() setTextSize() font5x7
|
||||||
|
*/
|
||||||
|
static constexpr uint8_t getCharacterWidth(uint8_t textSize = 1)
|
||||||
|
{
|
||||||
|
return characterWidth * textSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief
|
||||||
|
* Get the number of pixels added after each character to provide spacing.
|
||||||
|
*
|
||||||
|
* \param textSize The text size the character would be drawn at
|
||||||
|
* (optional; defaults to 1).
|
||||||
|
*
|
||||||
|
* \return The number of pixels of space added after each character.
|
||||||
|
*
|
||||||
|
* \details
|
||||||
|
* Returns the number of pixels added to the right of each character,
|
||||||
|
* to provide spacing, when drawn by the library text functions.
|
||||||
|
* The result will be based on the provided text size, or size 1 if not
|
||||||
|
* included.
|
||||||
|
*
|
||||||
|
* \see getCharacterWidth() getLineSpacing()
|
||||||
|
* getTextSize() setTextSize() font5x7
|
||||||
|
*/
|
||||||
|
static constexpr uint8_t getCharacterSpacing(uint8_t textSize = 1)
|
||||||
|
{
|
||||||
|
return characterSpacing * textSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief
|
||||||
|
* Get the height, in pixels, of a character in the library's font.
|
||||||
|
*
|
||||||
|
* \param textSize The text size the character would be drawn at
|
||||||
|
* (optional; defaults to 1).
|
||||||
|
*
|
||||||
|
* \return The height, in pixels, that a character will occupy.
|
||||||
|
*
|
||||||
|
* \details
|
||||||
|
* Returns the height, in pixels, that a character will occupy when drawn
|
||||||
|
* using the library text functions. The result will be based on the
|
||||||
|
* provided text size, or size 1 if not included.
|
||||||
|
*
|
||||||
|
* \see getCharacterWidth() getLineSpacing()
|
||||||
|
* getTextSize() setTextSize() font5x7
|
||||||
|
*/
|
||||||
|
static constexpr uint8_t getCharacterHeight(uint8_t textSize = 1)
|
||||||
|
{
|
||||||
|
return characterHeight * textSize;
|
||||||
|
}
|
||||||
|
|
||||||
|
/** \brief
|
||||||
|
* Get the number of pixels added below each character to provide
|
||||||
|
* line spacing.
|
||||||
|
*
|
||||||
|
* \param textSize The text size the character would be drawn at
|
||||||
|
* (optional; defaults to 1).
|
||||||
|
*
|
||||||
|
* \return The number of pixels of space added below each character.
|
||||||
|
*
|
||||||
|
* \details
|
||||||
|
* Returns the number of pixels added below each character, to provide
|
||||||
|
* spacing for wrapped lines, when drawn by the library text functions.
|
||||||
|
* The result will be based on the provided text size, or size 1 if
|
||||||
|
* not included.
|
||||||
|
*
|
||||||
|
* \note
|
||||||
|
* For this library, the value returned will be 0 because no spacing is added
|
||||||
|
* between lines. This function is included so that it can be used to write
|
||||||
|
* code that would be easily portable for use with a suite of equivalent
|
||||||
|
* functions that rendered text with added line spacing.
|
||||||
|
*
|
||||||
|
* \see getCharacterHeight() getCharacterSpacing()
|
||||||
|
* getTextSize() setTextSize() font5x7
|
||||||
|
*/
|
||||||
|
static constexpr uint8_t getLineSpacing(uint8_t textSize = 1)
|
||||||
|
{
|
||||||
|
return lineSpacing * textSize;
|
||||||
|
}
|
||||||
|
|
||||||
/** \brief
|
/** \brief
|
||||||
* The font used for text functions.
|
* The font used for text functions.
|
||||||
*
|
*
|
||||||
|
@ -1809,17 +1960,22 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
* \note
|
* \note
|
||||||
* \parblock
|
* \parblock
|
||||||
* The library's text functions, except `drawChar()`, handle two character
|
* The library's text functions, except `drawChar()`, handle two character
|
||||||
* values specially (and thus the font symbols that they represent can't be
|
* values specially:
|
||||||
* displayed using these functions):
|
|
||||||
*
|
*
|
||||||
* - ASCII newline or line feed (`\n`, 0x0A, inverse white circle).
|
* - ASCII newline/line feed (`\n`, 0x0A, inverse white circle).
|
||||||
* This will move the text cursor position to the start of the next line,
|
* This will move the text cursor position to the start of the next line,
|
||||||
* based on the current text size.
|
* based on the current text size.
|
||||||
* - ASCII carriage return (`\r`, 0x0D, musical eighth note).
|
* - ASCII carriage return (`\r`, 0x0D, musical eighth note).
|
||||||
* This character will be ignored.
|
* This character will be ignored.
|
||||||
|
*
|
||||||
|
* To override the special handling of the above values, to allow the
|
||||||
|
* characters they represent to be printed, text _raw_ mode can be selected
|
||||||
|
* using the `setTextRawMode()` function.
|
||||||
* \endparblock
|
* \endparblock
|
||||||
*
|
*
|
||||||
* \see Print write() readUnitName() writeUnitName()
|
* \see Print write() drawChar() setTextRawMode()
|
||||||
|
* getCharacterWidth() getCharacterHeight()
|
||||||
|
* getCharacterSpacing() getLineSpacing() readUnitName() writeUnitName()
|
||||||
*/
|
*/
|
||||||
static const PROGMEM uint8_t font5x7[];
|
static const PROGMEM uint8_t font5x7[];
|
||||||
|
|
||||||
|
@ -1830,6 +1986,19 @@ class Arduboy2 : public Print, public Arduboy2Base
|
||||||
uint8_t textBackground;
|
uint8_t textBackground;
|
||||||
uint8_t textSize;
|
uint8_t textSize;
|
||||||
bool textWrap;
|
bool textWrap;
|
||||||
|
bool textRaw;
|
||||||
|
|
||||||
|
// Width and height of a font5x7 character
|
||||||
|
// (not including inter-character spacing)
|
||||||
|
static constexpr uint8_t characterWidth = 5;
|
||||||
|
static constexpr uint8_t characterHeight = 8;
|
||||||
|
// Width of inter-character spacing
|
||||||
|
static constexpr uint8_t characterSpacing = 1;
|
||||||
|
// Height of inter-line spacing
|
||||||
|
static constexpr uint8_t lineSpacing = 0;
|
||||||
|
// Character sizes including spacing
|
||||||
|
static constexpr uint8_t fullCharacterWidth = characterWidth + characterSpacing;
|
||||||
|
static constexpr uint8_t fullCharacterHeight = characterHeight + lineSpacing;
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue