Seven Segments Displays Agnostic Library for ESP32 (Arduino) v3.3.0
A library that provides a class that models a Seven Segment Display and provides an unified API through it's members independently of the display technology.
|
Abstract class that models displays that don't need permanent MCU data updating to keep the data correctly displayed. More...
#include <SevenSegDispHw.h>
Additional Inherited Members | |
Public Member Functions inherited from SevenSegDispHw | |
SevenSegDispHw () | |
Default class constructor. | |
SevenSegDispHw (uint8_t *ioPins, uint8_t dspDigits=4, bool commAnode=true, uint8_t dspDigitsQtyMax=0) | |
Class constructor. | |
virtual | ~SevenSegDispHw () |
Class destructor. | |
virtual bool | begin (uint32_t updtLps=0) |
Sets up the hardware display to work, and starts the display activities. | |
virtual bool | end () |
Reverts the begin(uint32_t) actions, stopping the display activities, turning the display off and freeing the resources used by the Seven Segment display hardware object. | |
virtual uint8_t | getBrghtnssLvl () |
Returns the current display brightness level setting for the display. | |
virtual uint8_t | getBrghtnssMaxLvl () |
Returns the maximum display brightness level setting allowed for the display. | |
virtual uint8_t | getBrghtnssMinLvl () |
Returns the minimum display brightness level setting for the display. | |
bool | getCommAnode () |
Returns a value indicating if the display module component of the display hardware uses a common anode or a common cathode led wiring. | |
uint8_t * | getDspBuffPtr () |
Returns a pointer to the display buffer. | |
uint8_t | getHwDspDigitsQty () |
Returns the quantity of digits of the display module. | |
virtual bool | getIsOn () |
Returns the state of the display. | |
uint8_t * | getxcdDspBuffPtr () |
Returns a pointer to an array holding the contents for the digits/ports available from the display controller but not used for plain digits display. | |
virtual void | ntfyUpdDsply () |
Notifies the SevenSegDispHw component object of a change of content available in the display buffer, so that the object proceeds to update the display. | |
virtual bool | setBrghtnssLvl (const uint8_t &newBrghtnssLvl) |
Sets the brightness level for the display. | |
virtual bool | setDigitsOrder (uint8_t *newOrderPtr) |
Sets a mapping to relate the display buffer positions to the display port assigned to exhibit it's contents. | |
void | setDspBuffPtr (uint8_t *newDspBuffPtr) |
Sets the pointer to the Display Buffer memory area. | |
virtual void | turnOff () |
Turns the display module off. | |
virtual void | turnOn () |
Turns the display module on. | |
virtual void | turnOn (const uint8_t &newBrghtnssLvl) |
Turns the display module on set at the provided brightness level. | |
Protected Attributes inherited from SevenSegDispHw | |
uint8_t | _allLedsOff {} |
Value to set in the display port to set all leds off (a "space"), dependent of _commAnode. | |
uint8_t | _brghtnssLvl {0} |
Current display brightness level. | |
uint8_t | _brghtnssLvlMax {0} |
Maximum display brightness level. | |
uint8_t | _brghtnssLvlMin {0} |
Minimum display brightness level. | |
uint8_t * | _dspBlankBuffPtr {nullptr} |
Pointer to a display buffer filled with _allLedsOff ("spaces") to use as display buffer while in "Off State". | |
uint8_t * | _dspBuffPtr {nullptr} |
Pointer to the display buffer, will be provided by the SevenSegDisplays object when it's instantiated. | |
uint8_t * | _dspBuffPtrBkp {nullptr} |
Pointer to the display buffer, copy of the original _dspBuffPtr to be used as backup. | |
bool | _isOn {false} |
Current display status: On/Off. | |
uint8_t * | _xcdDspBuffPtr {nullptr} |
A pointer to a buffer the size of the exceeding digits used to control display specific amenities. | |
uint8_t | _xcdDspDigitsQty {} |
Number of unused available display ports, its the difference (_dspDigitsQtyMax - _dspDigitsQty), being the size of the array pointed by _xcdDspBuffPtr. |
Abstract class that models displays that don't need permanent MCU data updating to keep the data correctly displayed.
The lack of need of periodic intervention from the MCU implies that the display controller component includes a "display driver" chip (or chipset) that takes care of the display update and refreshing. So this is a base class for Seven Segment display hardware based on different display controller component chips. The MCU sends the data to be displayed and the chip required commands through diverse channels and protocols depending on the specific chip.
The chip then connects to the display module component through their output pins. The hardware developer might decide to implement the display module component wiring according to the project requirements, but all the chips modeled by this class and it's subclasses share the same characteristics: