Send slightly less data to Max7219
This commit is contained in:
		| @@ -210,23 +210,31 @@ void Max7219::send(const uint8_t reg, const uint8_t data) { | |||||||
|   CRITICAL_SECTION_END; |   CRITICAL_SECTION_END; | ||||||
| } | } | ||||||
|  |  | ||||||
| // Send out a single native row of bits to all units | // Send out a single native row of bits to just one unit | ||||||
| void Max7219::refresh_line(const uint8_t line) { | void Max7219::refresh_unit_line(const uint8_t line) { | ||||||
|  |   #if MAX7219_NUMBER_UNITS == 1 | ||||||
|  |     send(LINE_REG(line), led_line[line]); | ||||||
|  |   #else | ||||||
|     for (uint8_t u = MAX7219_NUMBER_UNITS; u--;) |     for (uint8_t u = MAX7219_NUMBER_UNITS; u--;) | ||||||
|     send(LINE_REG(line), led_line[(u << 3) | (line & 0x7)]); |       if (u == (line >> 3)) send(LINE_REG(line), led_line[line]); else noop(); | ||||||
|  |   #endif | ||||||
|   pulse_load(); |   pulse_load(); | ||||||
| } | } | ||||||
|  |  | ||||||
| // Send out a single native row of bits to just one unit | // Send out a single native row of bits to all units | ||||||
| void Max7219::refresh_unit_line(const uint8_t line) { | void Max7219::refresh_line(const uint8_t line) { | ||||||
|  |   #if MAX7219_NUMBER_UNITS == 1 | ||||||
|  |     refresh_unit_line(line); | ||||||
|  |   #else | ||||||
|     for (uint8_t u = MAX7219_NUMBER_UNITS; u--;) |     for (uint8_t u = MAX7219_NUMBER_UNITS; u--;) | ||||||
|     if (u == (line >> 3)) send(LINE_REG(line), led_line[line]); else noop(); |       send(LINE_REG(line), led_line[(u << 3) | (line & 0x7)]); | ||||||
|  |   #endif | ||||||
|   pulse_load(); |   pulse_load(); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Max7219::set(const uint8_t line, const uint8_t bits) { | void Max7219::set(const uint8_t line, const uint8_t bits) { | ||||||
|   led_line[line] = bits; |   led_line[line] = bits; | ||||||
|   refresh_line(line); |   refresh_unit_line(line); | ||||||
| } | } | ||||||
|  |  | ||||||
| #if ENABLED(MAX7219_NUMERIC) | #if ENABLED(MAX7219_NUMERIC) | ||||||
| @@ -268,7 +276,7 @@ void Max7219::led_set(const uint8_t x, const uint8_t y, const bool on) { | |||||||
|   if (x > MAX7219_X_LEDS - 1 || y > MAX7219_Y_LEDS - 1) return error(PSTR("led_set"), x, y); |   if (x > MAX7219_X_LEDS - 1 || y > MAX7219_Y_LEDS - 1) return error(PSTR("led_set"), x, y); | ||||||
|   if (BIT_7219(x, y) == on) return; |   if (BIT_7219(x, y) == on) return; | ||||||
|   XOR_7219(x, y); |   XOR_7219(x, y); | ||||||
|   refresh_line(LED_IND(x, y)); |   refresh_unit_line(LED_IND(x, y)); | ||||||
| } | } | ||||||
|  |  | ||||||
| void Max7219::led_on(const uint8_t x, const uint8_t y) { | void Max7219::led_on(const uint8_t x, const uint8_t y) { | ||||||
| @@ -287,20 +295,28 @@ 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 _ROT == 0 || _ROT == 180 |   #if _ROT == 0 || _ROT == 180            // Native Lines are horizontal too | ||||||
|     refresh_line(LED_IND(0, row)); |     #if MAX7219_X_LEDS <= 8 | ||||||
|  |       refresh_unit_line(LED_IND(0, row)); // A single unit line | ||||||
|     #else |     #else | ||||||
|  |       refresh_line(LED_IND(0, row));      // Same line, all units | ||||||
|  |     #endif | ||||||
|  |   #else                                   // Native lines are vertical | ||||||
|     UNUSED(row); |     UNUSED(row); | ||||||
|     refresh(); |     refresh();                            // Actually a column | ||||||
|   #endif |   #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| void Max7219::send_column(const uint8_t col) { | void Max7219::send_column(const uint8_t col) { | ||||||
|   #if _ROT == 90 || _ROT == 270 |   #if _ROT == 90 || _ROT == 270           // Native Lines are vertical too | ||||||
|     refresh_line(LED_IND(col, 0)); |     #if MAX7219_Y_LEDS <= 8 | ||||||
|  |       refresh_unit_line(LED_IND(col, 0)); // A single unit line | ||||||
|     #else |     #else | ||||||
|  |       refresh_line(LED_IND(col, 0));      // Same line, all units | ||||||
|  |     #endif | ||||||
|  |   #else                                   // Native lines are horizontal | ||||||
|     UNUSED(col); |     UNUSED(col); | ||||||
|     refresh(); |     refresh();                            // Actually a row | ||||||
|   #endif |   #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -544,7 +560,7 @@ void Max7219::quantity16(const uint8_t pos, const uint8_t ov, const uint8_t nv) | |||||||
|   for (uint8_t i = _MIN(nv, ov); i < _MAX(nv, ov); i++) |   for (uint8_t i = _MIN(nv, ov); i < _MAX(nv, ov); i++) | ||||||
|     #if MAX7219_X_LEDS == 8 |     #if MAX7219_X_LEDS == 8 | ||||||
|       #if MAX7219_Y_LEDS == 8 |       #if MAX7219_Y_LEDS == 8 | ||||||
|         led_set(i >> 1, pos + (i & 1), nv >= ov); // single 8x8 LED matrix.  Use two lines to get 16 LED's |         led_set(i >> 1, pos + (i & 1), nv >= ov); // Single 8x8 LED matrix.  Use two lines to get 16 LED's | ||||||
|       #else |       #else | ||||||
|         led_set(pos, i, nv >= ov);                // The Max7219 Y-Axis has at least 16 LED's.  So use a single column |         led_set(pos, i, nv >= ov);                // The Max7219 Y-Axis has at least 16 LED's.  So use a single column | ||||||
|       #endif |       #endif | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user