summaryrefslogtreecommitdiff
path: root/wasp
diff options
context:
space:
mode:
authorDaniel Thompson <daniel@redfelineninja.org.uk>2020-04-14 19:03:04 (GMT)
committerDaniel Thompson <daniel@redfelineninja.org.uk>2020-04-14 19:03:04 (GMT)
commit10706a9704fc75dac2e623341652b8b6f1fdf23f (patch)
tree8c555ddfcdec04fd9f7b93f1f6b647efb2999902 /wasp
parent5fc802fb786d8122bd4ae0dbe6e400d4b43dbd32 (diff)
wasp: stopwatch: Replace the stub with a "real" implementation
There are still some holes here. In particular the RTC resolution on nRF devices (such as PineTime) is currently a full second (meaning the centiseconds will always be zero. Nevertheless that isn't the apps fault... as we can see when we run on the simulator.
Diffstat (limited to 'wasp')
-rw-r--r--wasp/apps/stopwatch.py120
-rw-r--r--wasp/boards/pinetime/manifest.py4
2 files changed, 122 insertions, 2 deletions
diff --git a/wasp/apps/stopwatch.py b/wasp/apps/stopwatch.py
index 60c0f9f..5a19ddd 100644
--- a/wasp/apps/stopwatch.py
+++ b/wasp/apps/stopwatch.py
@@ -3,17 +3,133 @@
import wasp
import icons
+import fonts
class StopwatchApp():
- NAME = 'Stopwatch'
+ NAME = 'Timer'
ICON = icons.app
+ def __init__(self):
+ self._meter = wasp.widgets.BatteryMeter()
+ self._reset()
+ self._count = 999*6000
+
def foreground(self):
"""Activate the application."""
+ self._last_clock = ( -1, -1, -1, -1, -1, -1 )
+
self._draw()
+ wasp.system.request_tick(97)
+ wasp.system.request_event(wasp.EventMask.TOUCH |
+ wasp.EventMask.BUTTON)
+
+ def sleep(self):
+ return True
+
+ def wake(self):
+ self._update()
+
+ def press(self, button, state):
+ if not state:
+ return
+
+ if self._started_at:
+ self._update()
+ self._started_at = 0
+ else:
+ uptime = wasp.watch.rtc.get_uptime_ms()
+ uptime //= 10
+ self._started_at = uptime - self._count
+ self._update()
+
+ def touch(self, event):
+ if self._started_at:
+ self._update()
+ self._splits.insert(0, self._count)
+ del self._splits[4:]
+ else:
+ self._reset()
+ self._update()
+
+ self._draw_splits()
+
+ def tick(self, ticks):
+ self._update()
+
+ def _reset(self):
+ self._started_at = 0
+ self._count = 0
+ self._last_count = -1
+ self._splits = []
+
+ def _draw_splits(self):
+ draw = wasp.watch.drawable
+ splits = self._splits
+ if 0 == len(splits):
+ draw.fill(0, 0, 120, 240, 120)
+ return
+ y = 240 - 12 - (len(splits) * 24)
+ for i, s in enumerate(splits):
+ if s:
+ centisecs = s
+ secs = centisecs // 100
+ centisecs %= 100
+ minutes = secs // 60
+ secs %= 60
+
+ t = '#{} {:02}:{:02}.{:02}'.format(i+1, minutes, secs, centisecs)
+ else:
+ t = ''
+
+ draw.set_font(fonts.sans24)
+ w = fonts.width(fonts.sans24, t)
+ draw.string(t, 0, y + (i*24), 240)
def _draw(self):
"""Draw the display from scratch."""
draw = wasp.watch.drawable
draw.fill()
- draw.string(self.NAME, 0, 6, width=240)
+
+ self._update()
+ self._meter.draw()
+ self._draw_splits()
+
+ def _update(self):
+ # Before we do anything else let's make sure _count is
+ # up to date
+ if self._started_at:
+ uptime = wasp.watch.rtc.get_uptime_ms()
+ uptime //= 10
+ self._count = uptime - self._started_at
+ if self._count > 999*60*100:
+ self._reset()
+
+ draw = wasp.watch.drawable
+
+ # Lazy update of the clock and battery meter
+ now = wasp.watch.rtc.get_localtime()
+ if now[4] != self._last_clock[4]:
+ t1 = '{:02}:{:02}'.format(now[3], now[4])
+ draw.set_font(fonts.sans24)
+ draw.string(t1, 48, 16, 240-96)
+ self._last_clock = now
+ self._meter.update()
+
+ if self._last_count != self._count:
+ centisecs = self._count
+ secs = centisecs // 100
+ centisecs %= 100
+ minutes = secs // 60
+ secs %= 60
+
+ t1 = '{}:{:02}'.format(minutes, secs)
+ t2 = '{:02}'.format(centisecs)
+
+ draw.set_font(fonts.sans36)
+ w = fonts.width(fonts.sans36, t1)
+ draw.string(t1, 180-w, 120-36)
+ draw.fill(0, 0, 120-36, 180-w, 36)
+
+ draw.set_font(fonts.sans24)
+ draw.string(t2, 180, 120-36+18, width=46)
+ self._last_count = self._count
diff --git a/wasp/boards/pinetime/manifest.py b/wasp/boards/pinetime/manifest.py
index d22f360..97641d6 100644
--- a/wasp/boards/pinetime/manifest.py
+++ b/wasp/boards/pinetime/manifest.py
@@ -4,11 +4,13 @@
freeze('.', 'watch.py', opt=3)
freeze('../..',
(
+ 'apps/__init__.py',
'apps/clock.py',
'apps/flashlight.py',
'apps/launcher.py',
'apps/pager.py',
'apps/settings.py',
+ 'apps/stopwatch.py',
'apps/testapp.py',
'boot.py',
'demo.py',
@@ -19,8 +21,10 @@ freeze('../..',
'drivers/signal.py',
'drivers/st7789.py',
'drivers/vibrator.py',
+ 'fonts/__init__.py',
'fonts/clock.py',
'fonts/sans24.py',
+ 'fonts/sans36.py',
'icons.py',
'logo.py',
'shell.py',