Max7219 suspend/resume
This commit is contained in:
parent
8ff25a9566
commit
c99773bae0
2 changed files with 23 additions and 5 deletions
|
@ -73,6 +73,7 @@
|
||||||
Max7219 max7219;
|
Max7219 max7219;
|
||||||
|
|
||||||
uint8_t Max7219::led_line[MAX7219_LINES]; // = { 0 };
|
uint8_t Max7219::led_line[MAX7219_LINES]; // = { 0 };
|
||||||
|
uint8_t Max7219::suspended; // = 0;
|
||||||
|
|
||||||
#define LINE_REG(Q) (max7219_reg_digit0 + ((Q) & 0x7))
|
#define LINE_REG(Q) (max7219_reg_digit0 + ((Q) & 0x7))
|
||||||
|
|
||||||
|
@ -212,6 +213,7 @@ void Max7219::send(const uint8_t reg, const uint8_t data) {
|
||||||
|
|
||||||
// Send out a single native row of bits to just one unit
|
// Send out a single native row of bits to just one unit
|
||||||
void Max7219::refresh_unit_line(const uint8_t line) {
|
void Max7219::refresh_unit_line(const uint8_t line) {
|
||||||
|
if (suspended) return;
|
||||||
#if MAX7219_NUMBER_UNITS == 1
|
#if MAX7219_NUMBER_UNITS == 1
|
||||||
send(LINE_REG(line), led_line[line]);
|
send(LINE_REG(line), led_line[line]);
|
||||||
#else
|
#else
|
||||||
|
@ -223,6 +225,7 @@ void Max7219::refresh_unit_line(const uint8_t line) {
|
||||||
|
|
||||||
// Send out a single native row of bits to all units
|
// Send out a single native row of bits to all units
|
||||||
void Max7219::refresh_line(const uint8_t line) {
|
void Max7219::refresh_line(const uint8_t line) {
|
||||||
|
if (suspended) return;
|
||||||
#if MAX7219_NUMBER_UNITS == 1
|
#if MAX7219_NUMBER_UNITS == 1
|
||||||
refresh_unit_line(line);
|
refresh_unit_line(line);
|
||||||
#else
|
#else
|
||||||
|
@ -241,9 +244,9 @@ void Max7219::set(const uint8_t line, const uint8_t bits) {
|
||||||
|
|
||||||
// Draw an integer with optional leading zeros and optional decimal point
|
// Draw an integer with optional leading zeros and optional decimal point
|
||||||
void Max7219::print(const uint8_t start, int16_t value, uint8_t size, const bool leadzero=false, bool dec=false) {
|
void Max7219::print(const uint8_t start, int16_t value, uint8_t size, const bool leadzero=false, bool dec=false) {
|
||||||
|
if (suspended) return;
|
||||||
constexpr uint8_t led_numeral[10] = { 0x7E, 0x60, 0x6D, 0x79, 0x63, 0x5B, 0x5F, 0x70, 0x7F, 0x7A },
|
constexpr uint8_t led_numeral[10] = { 0x7E, 0x60, 0x6D, 0x79, 0x63, 0x5B, 0x5F, 0x70, 0x7F, 0x7A },
|
||||||
led_decimal = 0x80, led_minus = 0x01;
|
led_decimal = 0x80, led_minus = 0x01;
|
||||||
|
|
||||||
bool blank = false, neg = value < 0;
|
bool blank = false, neg = value < 0;
|
||||||
if (neg) value *= -1;
|
if (neg) value *= -1;
|
||||||
while (size--) {
|
while (size--) {
|
||||||
|
@ -295,6 +298,7 @@ void Max7219::led_toggle(const uint8_t x, const uint8_t y) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Max7219::send_row(const uint8_t row) {
|
void Max7219::send_row(const uint8_t row) {
|
||||||
|
if (suspended) return;
|
||||||
#if _ROT == 0 || _ROT == 180 // Native Lines are horizontal too
|
#if _ROT == 0 || _ROT == 180 // Native Lines are horizontal too
|
||||||
#if MAX7219_X_LEDS <= 8
|
#if MAX7219_X_LEDS <= 8
|
||||||
refresh_unit_line(LED_IND(0, row)); // A single unit line
|
refresh_unit_line(LED_IND(0, row)); // A single unit line
|
||||||
|
@ -308,6 +312,7 @@ void Max7219::send_row(const uint8_t row) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void Max7219::send_column(const uint8_t col) {
|
void Max7219::send_column(const uint8_t col) {
|
||||||
|
if (suspended) return;
|
||||||
#if _ROT == 90 || _ROT == 270 // Native Lines are vertical too
|
#if _ROT == 90 || _ROT == 270 // Native Lines are vertical too
|
||||||
#if MAX7219_Y_LEDS <= 8
|
#if MAX7219_Y_LEDS <= 8
|
||||||
refresh_unit_line(LED_IND(col, 0)); // A single unit line
|
refresh_unit_line(LED_IND(col, 0)); // A single unit line
|
||||||
|
@ -344,8 +349,8 @@ void Max7219::clear_column(const uint8_t col) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Plot the low order bits of val to the specified row of the matrix.
|
* Plot the low order bits of val to the specified row of the matrix.
|
||||||
* With 4 Max7219 units in the chain, it's possible to set 32 bits at once with
|
* With 4 Max7219 units in the chain, it's possible to set 32 bits at
|
||||||
* one call to the function (if rotated 90° or 180°).
|
* once with a single call to the function (if rotated 90° or 270°).
|
||||||
*/
|
*/
|
||||||
void Max7219::set_row(const uint8_t row, const uint32_t val) {
|
void Max7219::set_row(const uint8_t row, const uint32_t val) {
|
||||||
if (row >= MAX7219_Y_LEDS) return error(PSTR("set_row"), row);
|
if (row >= MAX7219_Y_LEDS) return error(PSTR("set_row"), row);
|
||||||
|
@ -359,8 +364,8 @@ void Max7219::set_row(const uint8_t row, const uint32_t val) {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Plot the low order bits of val to the specified column of the matrix.
|
* Plot the low order bits of val to the specified column of the matrix.
|
||||||
* With 4 Max7219 units in the chain, it's possible to set 32 bits at once with
|
* With 4 Max7219 units in the chain, it's possible to set 32 bits at
|
||||||
* one call to the function (if rotated 90° or 180°).
|
* once with a single call to the function (if rotated 0° or 180°).
|
||||||
*/
|
*/
|
||||||
void Max7219::set_column(const uint8_t col, const uint32_t val) {
|
void Max7219::set_column(const uint8_t col, const uint32_t val) {
|
||||||
if (col >= MAX7219_X_LEDS) return error(PSTR("set_column"), col);
|
if (col >= MAX7219_X_LEDS) return error(PSTR("set_column"), col);
|
||||||
|
@ -692,6 +697,12 @@ void Max7219::idle_tasks() {
|
||||||
last_depth = current_depth;
|
last_depth = current_depth;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// After resume() automatically do a refresh()
|
||||||
|
if (suspended == 0x80) {
|
||||||
|
suspended = 0;
|
||||||
|
refresh();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // MAX7219_DEBUG
|
#endif // MAX7219_DEBUG
|
||||||
|
|
|
@ -88,6 +88,12 @@ public:
|
||||||
// Refresh all units
|
// Refresh all units
|
||||||
static inline void refresh() { for (uint8_t i = 0; i < 8; i++) refresh_line(i); }
|
static inline void refresh() { for (uint8_t i = 0; i < 8; i++) refresh_line(i); }
|
||||||
|
|
||||||
|
// Suspend / resume updates to the LED unit
|
||||||
|
// Use these methods to speed up multiple changes
|
||||||
|
// or to apply updates from interrupt context.
|
||||||
|
static inline void suspend() { suspended++; }
|
||||||
|
static inline void resume() { suspended--; suspended |= 0x80; }
|
||||||
|
|
||||||
// Update a single native line on all units
|
// Update a single native line on all units
|
||||||
static void refresh_line(const uint8_t line);
|
static void refresh_line(const uint8_t line);
|
||||||
|
|
||||||
|
@ -126,6 +132,7 @@ public:
|
||||||
static void idle_tasks();
|
static void idle_tasks();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
static uint8_t suspended;
|
||||||
static void error(const char * const func, const int32_t v1, const int32_t v2=-1);
|
static void error(const char * const func, const int32_t v1, const int32_t v2=-1);
|
||||||
static void noop();
|
static void noop();
|
||||||
static void set(const uint8_t line, const uint8_t bits);
|
static void set(const uint8_t line, const uint8_t bits);
|
||||||
|
|
Reference in a new issue