summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJoey Castillo <jose.castillo@gmail.com>2021-10-04 10:48:04 -0400
committerJoey Castillo <jose.castillo@gmail.com>2021-10-04 14:12:39 -0400
commit7f8973a8cc55e37cd8e2d59f7eab2def0045d2a6 (patch)
tree6f212f5059a2d76e1f0a9857d90a67d67f8df4b3
parentc1ec7734c910d1eef74ebc3647dc084eeb43bbcf (diff)
downloadSensor-Watch-7f8973a8cc55e37cd8e2d59f7eab2def0045d2a6.tar.gz
Sensor-Watch-7f8973a8cc55e37cd8e2d59f7eab2def0045d2a6.tar.bz2
Sensor-Watch-7f8973a8cc55e37cd8e2d59f7eab2def0045d2a6.zip
slcd: add more special cases
-rw-r--r--watch-library/watch/watch_slcd.c19
1 files changed, 14 insertions, 5 deletions
diff --git a/watch-library/watch/watch_slcd.c b/watch-library/watch/watch_slcd.c
index c1e24308..fc8c255a 100644
--- a/watch-library/watch/watch_slcd.c
+++ b/watch-library/watch/watch_slcd.c
@@ -114,8 +114,8 @@ static const uint8_t Character_Set[] =
0b01010000, // r
0b01101101, // s
0b01111000, // t
- 0b01100010, // u (appears as superscript to work in more positions)
- 0b01100010, // v (appears as superscript to work in more positions)
+ 0b01100010, // u (appears in (u)pper half to work in more positions)
+ 0b00011100, // v (looks like u but in the lower half)
0b10111110, // w (only works in position 0)
0b01111110, // x
0b01101110, // y
@@ -169,8 +169,16 @@ void watch_clear_display() {
}
void watch_display_character(uint8_t character, uint8_t position) {
- // handle lowercase 7 if needed
- if (character == '7' && (position == 4 || position == 6)) character = '&';
+ // special cases for positions 4 and 6
+ if (position == 4 || position == 6) {
+ if (character == '7') character = '&'; // "lowercase" 7
+ if (character == 'v') character = 'u'; // bottom segment duplicated, so show in top half
+ if (character == 'J') character = 'j'; // same
+ } else if (position != 4 && position != 6) {
+ if (character == 'u') character = 'v'; // we can use the bottom segment; move to lower half
+ if (character == 'j') character = 'J'; // same but just display a normal J
+ }
+ if (position == 0) slcd_sync_seg_off(&SEGMENT_LCD_0, SLCD_SEGID(0, 15)); // clear funky ninth segment
uint64_t segmap = Segment_Map[position];
uint64_t segdata = Character_Set[character - 0x20];
@@ -189,7 +197,8 @@ void watch_display_character(uint8_t character, uint8_t position) {
segmap = segmap >> 8;
segdata = segdata >> 1;
}
- if (character == 'T' && position == 1) slcd_sync_seg_on(&SEGMENT_LCD_0, SLCD_SEGID(1, 12));
+ if (character == 'T' && position == 1) slcd_sync_seg_on(&SEGMENT_LCD_0, SLCD_SEGID(1, 12)); // add descender
+ else if (position == 0 && (character == 'B' || character == 'D')) slcd_sync_seg_on(&SEGMENT_LCD_0, SLCD_SEGID(0, 15)); // add funky ninth segment
}
void watch_display_string(char *string, uint8_t position) {