2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/ANSI/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-10-18 16:35:48 +02:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/ANSI/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/ANSI/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/ANSI/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/ANSI/actions/workflows/jsoncheck.yml)
|
2023-10-17 14:51:45 +02:00
|
|
|
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/ANSI.svg)](https://github.com/RobTillaart/ANSI/issues)
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/ANSI/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/ANSI.svg?maxAge=3600)](https://github.com/RobTillaart/ANSI/releases)
|
2023-10-17 14:51:45 +02:00
|
|
|
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/ANSI.svg)](https://registry.platformio.org/libraries/robtillaart/ANSI)
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
# ANSI
|
|
|
|
|
|
|
|
Arduino library with basic ANSI display codes for terminal applications.
|
|
|
|
|
|
|
|
|
|
|
|
# Description
|
|
|
|
|
2023-01-31 20:16:44 +01:00
|
|
|
ANSI codes are special codes that are send to a terminal e.g. VT100 to add
|
|
|
|
attributes to displayed characters.
|
|
|
|
Typical examples are bold, blink or colour. ANSI codes are also known as escape codes.
|
|
|
|
The set of codes is large, however not all terminal types do support all codes.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-10-18 16:35:48 +02:00
|
|
|
Sending these ANSI codes to a simple ASCII only terminal like the one in the Arduino
|
|
|
|
IDE might result in garbage. So use with care.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2023-02-27 11:33:43 +01:00
|
|
|
#### Breaking change 0.2.0
|
|
|
|
|
|
|
|
The **gotoXY(x, y)** has changed as the X and Y coordinates were swapped.
|
|
|
|
|
|
|
|
The code has been updated to explicitly mention which is row and which is column.
|
|
|
|
- **gotoXY(uint8_t column, uint8_t row)**
|
|
|
|
|
|
|
|
#### Related
|
|
|
|
|
|
|
|
https://en.wikipedia.org/wiki/ANSI_escape_code
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
## Terminals tested
|
|
|
|
|
2023-01-31 20:16:44 +01:00
|
|
|
Tests are done with
|
2021-10-18 16:35:48 +02:00
|
|
|
- TeraTerm 4.102 + 4.106 (VT100, VT202, VT525 mode)
|
2023-01-31 20:16:44 +01:00
|
|
|
- Putty 0.71
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-10-18 16:35:48 +02:00
|
|
|
Other terminal program's exist so please let me know if yours is working too.
|
2021-01-29 12:31:58 +01:00
|
|
|
If not, please open an issue.
|
|
|
|
|
2021-12-13 16:45:59 +01:00
|
|
|
|
|
|
|
## Operation
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
See examples
|
2021-12-13 16:45:59 +01:00
|
|
|
|
|
|
|
|
2023-01-31 20:16:44 +01:00
|
|
|
## Interface
|
|
|
|
|
|
|
|
```cpp
|
|
|
|
#include "ansi.h"
|
|
|
|
```
|
|
|
|
|
2023-10-17 14:51:45 +02:00
|
|
|
#### Constructors
|
2023-01-31 20:16:44 +01:00
|
|
|
|
|
|
|
- **ANSI(Stream \* stream = &Serial)** wrapper around Serial.
|
|
|
|
Can be a software serial too.
|
2023-10-17 14:51:45 +02:00
|
|
|
- **VT100(Stream \* stream = &Serial)** derived class (wrapper)
|
2023-01-31 20:16:44 +01:00
|
|
|
|
|
|
|
|
|
|
|
#### Stream interface
|
|
|
|
|
2023-02-27 11:33:43 +01:00
|
|
|
- **int available()** to check if chars are available on the stream.
|
|
|
|
- **int read()** read a byte from the stream.
|
|
|
|
- **int peek()** preview the byte in the stream without fetching.
|
|
|
|
- **void flush()**
|
2023-01-31 20:16:44 +01:00
|
|
|
|
|
|
|
Stream interface also includes print(), println(), write().
|
|
|
|
|
|
|
|
|
|
|
|
#### Character modi
|
|
|
|
|
2023-02-27 11:33:43 +01:00
|
|
|
- **void normal()** normal intensity.
|
|
|
|
- **void bold()** bold or high intensity.
|
|
|
|
- **void low()** low intensity.
|
2023-01-31 20:16:44 +01:00
|
|
|
- **void underline()** idem.
|
|
|
|
- **void blink()** idem.
|
|
|
|
- **void reverse()** idem.
|
|
|
|
|
|
|
|
|
|
|
|
#### Colour
|
|
|
|
|
|
|
|
- **void foreground(uint8_t fgcolor)**
|
|
|
|
- **void background(uint8_t bgcolor)**
|
|
|
|
- **void color(uint8_t fgcolor, uint8_t bgcolor)**
|
2023-02-27 11:33:43 +01:00
|
|
|
|
|
|
|
Three helpers to map to the nearest colour.
|
2023-01-31 20:16:44 +01:00
|
|
|
- **uint8_t gray2color(uint8_t gray)**
|
|
|
|
- **uint8_t grey2color(uint8_t grey)** idem
|
|
|
|
- **uint8_t rgb2color(uint8_t r, uint8_t g, uint8_t b)**
|
|
|
|
|
2023-10-17 14:51:45 +02:00
|
|
|
- https://en.wikipedia.org/wiki/ANSI_escape_code#3-bit_and_4-bit
|
2021-12-13 16:45:59 +01:00
|
|
|
|
|
|
|
|
2023-01-31 20:16:44 +01:00
|
|
|
#### Positioning
|
2021-12-13 16:45:59 +01:00
|
|
|
|
2023-02-27 11:33:43 +01:00
|
|
|
- **void clearScreen()** clears screen and sets cursor to 0,0.
|
2023-01-31 20:16:44 +01:00
|
|
|
- **void clearLine(uint8_t clear = toEnd)** toEnd = 0,
|
2023-02-27 11:33:43 +01:00
|
|
|
toStart = 1, entireLine = 2,
|
|
|
|
- **void home()** set cursor to 0, 0
|
|
|
|
- **void gotoXY(uint8_t column, uint8_t row)** set cursor to position.
|
|
|
|
Note X == row and Y == column. See #13.
|
|
|
|
- **void cursorUp(uint8_t x)** idem.
|
|
|
|
- **void cursorDown(uint8_t x)** idem.
|
|
|
|
- **void cursorForward(uint8_t x)** idem.
|
|
|
|
- **void cursorBack(uint8_t x)** idem.
|
2023-01-31 20:16:44 +01:00
|
|
|
|
|
|
|
|
|
|
|
#### Experimental
|
|
|
|
|
2023-10-17 14:51:45 +02:00
|
|
|
Look into **ansi.h** for experimental functions and notes.
|
2022-08-24 11:00:54 +02:00
|
|
|
|
|
|
|
Version 0.1.6 added a number of experimental function that need more testing.
|
2023-01-31 20:16:44 +01:00
|
|
|
Some are working with Teraterm, others are unclear of fail.
|
|
|
|
The user can uncomment these and verify if these work with their terminal.
|
2022-08-24 11:00:54 +02:00
|
|
|
|
2023-10-17 14:51:45 +02:00
|
|
|
|
|
|
|
##### Experimental device type
|
|
|
|
|
|
|
|
The **int deviceType()** function needs more testing.
|
|
|
|
|
|
|
|
See - https://github.com/RobTillaart/ANSI/issues/9
|
|
|
|
|
|
|
|
| Type | Description |
|
|
|
|
|:-------:|:--------------|
|
|
|
|
| -1 | unknown |
|
|
|
|
| 1 | VT52 |
|
|
|
|
| 2 | VT100 |
|
|
|
|
| 3 | VT220 |
|
|
|
|
| other | unknown |
|
2022-08-24 11:00:54 +02:00
|
|
|
|
|
|
|
As always, constructive feedback is welcome.
|
|
|
|
|
|
|
|
|
2023-01-31 20:16:44 +01:00
|
|
|
## Performance
|
|
|
|
|
|
|
|
Since 0.1.5 there is some focus on performance.
|
|
|
|
Using **ansi.print()** and **ansi.println()** for printing text and numbers is
|
|
|
|
improved a bit since 0.1.4 by adding the private **write(array, length)**.
|
|
|
|
|
2023-10-17 14:51:45 +02:00
|
|
|
Since 0.2.0 the (internal) print() statements are replaced by write().
|
2023-02-27 11:33:43 +01:00
|
|
|
Although it are small improvements these add up.
|
|
|
|
|
2023-01-31 20:16:44 +01:00
|
|
|
|
2021-12-13 16:45:59 +01:00
|
|
|
## Future
|
|
|
|
|
2023-01-31 20:16:44 +01:00
|
|
|
#### Must
|
|
|
|
|
|
|
|
- improve documentation
|
|
|
|
- elaborate interface
|
|
|
|
- colour info
|
|
|
|
|
|
|
|
#### Should
|
|
|
|
|
|
|
|
- test experimental functions
|
2021-12-13 16:45:59 +01:00
|
|
|
- test more terminal programs (Linux mac)
|
2023-01-31 20:16:44 +01:00
|
|
|
- add examples
|
2021-12-13 16:45:59 +01:00
|
|
|
- DOS emulator?
|
2023-01-31 20:16:44 +01:00
|
|
|
- experimental section
|
2023-02-27 11:33:43 +01:00
|
|
|
- evaluate experimental code
|
2023-01-31 20:16:44 +01:00
|
|
|
|
|
|
|
#### Could
|
|
|
|
|
2021-12-13 16:45:59 +01:00
|
|
|
- increase functionality
|
2023-01-31 20:16:44 +01:00
|
|
|
- which codes are generic / useful ?
|
|
|
|
- investigate performance.
|
2021-12-13 16:45:59 +01:00
|
|
|
- add line buffer in write(c) to improve throughput?
|
|
|
|
- need for flush() with line buffer?
|
2023-10-17 14:51:45 +02:00
|
|
|
- move code from .h to .cpp
|
|
|
|
- more derived classes
|
2023-01-31 20:16:44 +01:00
|
|
|
|
|
|
|
#### Wont
|
|
|
|
|
2023-02-27 11:33:43 +01:00
|
|
|
- move static strings to PROGMEM? as defines?
|
|
|
|
roughly ~20 bytes progmem for 4 bytes RAM...
|
2021-12-13 16:45:59 +01:00
|
|
|
|
2023-10-17 14:51:45 +02:00
|
|
|
|
|
|
|
## Support
|
|
|
|
|
|
|
|
If you appreciate my libraries, you can support the development and maintenance.
|
|
|
|
Improve the quality of the libraries by providing issues and Pull Requests, or
|
|
|
|
donate through PayPal or GitHub sponsors.
|
|
|
|
|
|
|
|
Thank you,
|
|
|
|
|