[2.0.x] Max7219 cleanup, simplify, and extend (#11575)
This commit is contained in:
@ -32,7 +32,7 @@
|
||||
*
|
||||
* I - Initialize (clear) the matrix
|
||||
* F - Fill the matrix (set all bits)
|
||||
* P - Dump the LEDs[] array values
|
||||
* P - Dump the led_line[] array values
|
||||
* C<column> - Set a column to the 8-bit value V
|
||||
* R<row> - Set a row to the 8-bit value V
|
||||
* X<pos> - X position of an LED to set or toggle
|
||||
@ -43,45 +43,47 @@
|
||||
*/
|
||||
void GcodeSuite::M7219() {
|
||||
if (parser.seen('I')) {
|
||||
Max7219_Clear();
|
||||
Max7219_register_setup();
|
||||
max7219.clear();
|
||||
max7219.register_setup();
|
||||
}
|
||||
|
||||
if (parser.seen('F'))
|
||||
for (uint8_t x = 0; x < MAX7219_X_LEDS; x++)
|
||||
Max7219_Set_Column(x, 0xFFFFFFFF);
|
||||
max7219.set_column(x, 0xFFFFFFFF);
|
||||
|
||||
const uint32_t v = parser.ulongval('V');
|
||||
|
||||
if (parser.seenval('R')) {
|
||||
const uint32_t r = parser.value_int();
|
||||
Max7219_Set_Row(r, parser.ulongval('V'));
|
||||
return;
|
||||
const uint8_t r = parser.value_byte();
|
||||
max7219.set_row(r, v);
|
||||
}
|
||||
else if (parser.seenval('C')) {
|
||||
const uint32_t c = parser.value_int();
|
||||
Max7219_Set_Column(c, parser.ulongval('V'));
|
||||
return;
|
||||
const uint8_t c = parser.value_byte();
|
||||
max7219.set_column(c, v);
|
||||
}
|
||||
|
||||
if (parser.seenval('X') || parser.seenval('Y')) {
|
||||
else if (parser.seenval('X') || parser.seenval('Y')) {
|
||||
const uint8_t x = parser.byteval('X'), y = parser.byteval('Y');
|
||||
if (parser.seenval('V'))
|
||||
Max7219_LED_Set(x, y, parser.boolval('V'));
|
||||
max7219.led_set(x, y, parser.boolval('V'));
|
||||
else
|
||||
Max7219_LED_Toggle(x, y);
|
||||
max7219.led_toggle(x, y);
|
||||
}
|
||||
else if (parser.seen('D')) {
|
||||
const uint8_t r = parser.value_byte();
|
||||
if (r < MAX7219_ROWS) {
|
||||
max7219.led_line[r] = v;
|
||||
return max7219.all(r);
|
||||
}
|
||||
}
|
||||
|
||||
if (parser.seen('P')) {
|
||||
for (int8_t x = 0; x < 8 * MAX7219_NUMBER_UNITS; x++) {
|
||||
SERIAL_ECHOPAIR("LEDs[", x);
|
||||
SERIAL_ECHO("]=");
|
||||
for (int8_t j = 7; j >= 0; j--) {
|
||||
if ( LEDs[x] & (0x01<<j) )
|
||||
SERIAL_ECHO("1");
|
||||
else
|
||||
SERIAL_ECHO("0");
|
||||
}
|
||||
SERIAL_EOL();
|
||||
return;
|
||||
for (uint8_t r = 0; r < MAX7219_ROWS; r++) {
|
||||
SERIAL_ECHOPGM("led_line[");
|
||||
if (r < 10) SERIAL_CHAR('_');
|
||||
SERIAL_ECHO(r);
|
||||
SERIAL_ECHO("]=");
|
||||
for (uint8_t b = 8; b--;) SERIAL_CHAR('0' + TEST(max7219.led_line[r], b));
|
||||
SERIAL_EOL();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user