added support for removing leading zeros in displaying numbers
This commit is contained in:
23
TM1638.cpp
23
TM1638.cpp
@@ -51,15 +51,19 @@ void TM1638::setupDisplay(boolean active, byte intensity)
|
||||
}
|
||||
|
||||
|
||||
void TM1638::setDisplayToHexNumber(unsigned long number, byte dots)
|
||||
void TM1638::setDisplayToHexNumber(unsigned long number, byte dots, boolean leadingZeros)
|
||||
{
|
||||
for (int i = 0; i < 8; i++) {
|
||||
setDisplayDigit(number & 0xF, 7 - i, (dots & (1 << i)) != 0);
|
||||
number >>= 4;
|
||||
if (!leadingZeros && number == 0) {
|
||||
clearDisplayDigit(7 - i, (dots & (1 << i)) != 0);
|
||||
} else {
|
||||
setDisplayDigit(number & 0xF, 7 - i, (dots & (1 << i)) != 0);
|
||||
number >>= 4;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void TM1638::setDisplayToDecNumber(unsigned long number, byte dots)
|
||||
void TM1638::setDisplayToDecNumber(unsigned long number, byte dots, boolean leadingZeros)
|
||||
{
|
||||
if (number > 99999999L) {
|
||||
setDisplay(ERROR);
|
||||
@@ -69,7 +73,11 @@ void TM1638::setDisplayToDecNumber(unsigned long number, byte dots)
|
||||
setDisplayDigit(number % 10, 7 - i, (dots & (1 << i)) != 0);
|
||||
number /= 10;
|
||||
} else {
|
||||
setDisplayDigit(0, 7 - i, (dots & (1 << i)) != 0);
|
||||
if (leadingZeros) {
|
||||
setDisplayDigit(0, 7 - i, (dots & (1 << i)) != 0);
|
||||
} else {
|
||||
clearDisplayDigit(7 - i, (dots & (1 << i)) != 0);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -87,6 +95,11 @@ void TM1638::setDisplayDigit(byte digit, byte pos, boolean dot)
|
||||
sendData(pos << 1, NUMBER_DATA[digit & 0xF] | (dot ? 0b10000000 : 0));
|
||||
}
|
||||
|
||||
void TM1638::clearDisplayDigit(byte pos, boolean dot)
|
||||
{
|
||||
sendData(pos << 1, (dot ? 0b10000000 : 0));
|
||||
}
|
||||
|
||||
void TM1638::setDisplay(const byte values[])
|
||||
{
|
||||
for (int i = 0; i < 8; i++) {
|
||||
|
||||
Reference in New Issue
Block a user