NAME
Device::Chip::MAX7219 - chip driver for a MAX7219
SYNOPSIS
use Device::Chip::MAX7219;
use Future::AsyncAwait;
my $chip = Device::Chip::MAX7219->new;
await $chip->mount( Device::Chip::Adapter::...->new );
await $chip->power(1);
await $chip->intensity( 2 );
await $chip->limit( 8 );
await $chip->displaytest( 1 );
await $chip->shutdown( 0 );
sleep 3;
await $chip->displaytest( 0 );
DESCRIPTION
This Device::Chip subclass provides specific communication to a Maxim
Integrated MAX7219 chip attached to a computer via an SPI adapter. As
the MAX7221 chip operates virtually identically, this chip will work
too.
This module drives a single MAX7219 chip. For situations involving
multiple chips daisy-chained together (such as on popular LED matrix
display board modules) see instead Device::Chip::MAX7219Panel.
The reader is presumed to be familiar with the general operation of
this chip; the documentation here will not attempt to explain or define
chip-specific concepts or features, only the use of this module to
access them.
METHODS
The following methods documented in an await expression return Future
instances.
write_bcd
await $chip->write_bcd( $digit, $val );
Writes the value at the given digit, setting it to BCD mode if not
already so. $val should be a single digit number or string, or one of
the special recognised characters in BCD mode of -, E, H, L, P or
space. The value may optionally be followed by a decimal point ., which
will be set on the display.
Switches the digit into BCD mode if not already so.
write_raw
await $chip->write_raw( $digit, $bits );
Writes the value at the given digit, setting the raw column lines to
the 8-bit value given.
Switches the digit into undecoded raw mode if not already so.
write_hex
await $chip->write_hex( $digit, $val );
Similar to write_bcd, but uses a segment decoder written in code rather
than on the chip itself, to turn values into sets of segments to
display. This makes it capable of displaying the letters A to F, in
addition to numbers, - and space.
set_decode
await $chip->set_decode( $bits );
Directly sets the decode mode of all the digits at once. This is more
efficient for initialising digits into BCD or raw mode, than individual
calls to write_bcd or write_raw for each digit individually.
intensity
await $chip->intensity( $value );
Sets the intensity register. $value must be between 0 and 15, with
higher values giving a more intense output.
limit
await $chip->limit( $columns );
Sets the scan limit register. $value must be between 1 and 8, to set
between 1 and 8 digits. This should only be used to adjust for the
number of LED digits or columns units physically attached to the chip;
not for normal display blanking, as it affects the overall intensity.
Note that this is not directly the value written to the LIMIT register.
shutdown
await $chip->shutdown( $off );
Sets the shutdown register, entirely blanking the display and turning
off all output if set to a true value, or restoring the display to its
previous content if set false.
Note that this is not directly the value written to the SHUTDOWN
register.
displaytest
await $chip->displaytest( $on );
Sets the display test register, overriding the output control and
turning on every LED if set to a true value, or restoring normal
operation if set to false.
AUTHOR
Paul Evans <leonerd@leonerd.org.uk>