apps: alarm: Fix touch handling when the alarm is ringing
Currently the widgets react to touch when the alarm is ringing (and they are invisible. For now we fix this by disabling the alarm on a touch event. Maybe the app should reject touch events since they could acidentally dismiss the alarm... but we already disable the alarm if we get a swipe event so this doesn't make things much worse than they already are! Signed-off-by: Daniel Thompson <daniel@redfelineninja.org.uk>
This commit is contained in:
parent
707c4e2fa7
commit
39c9344b14
1 changed files with 14 additions and 7 deletions
|
@ -60,8 +60,7 @@ class AlarmApp():
|
||||||
"""Activate the application."""
|
"""Activate the application."""
|
||||||
self._draw()
|
self._draw()
|
||||||
wasp.system.request_event(wasp.EventMask.TOUCH)
|
wasp.system.request_event(wasp.EventMask.TOUCH)
|
||||||
if self.ringing:
|
wasp.system.request_tick(1000)
|
||||||
wasp.system.request_tick(1000)
|
|
||||||
wasp.system.cancel_alarm(self.current_alarm, self._alert)
|
wasp.system.cancel_alarm(self.current_alarm, self._alert)
|
||||||
|
|
||||||
def background(self):
|
def background(self):
|
||||||
|
@ -74,13 +73,21 @@ class AlarmApp():
|
||||||
|
|
||||||
def tick(self, ticks):
|
def tick(self, ticks):
|
||||||
"""Notify the application that its periodic tick is due."""
|
"""Notify the application that its periodic tick is due."""
|
||||||
wasp.watch.vibrator.pulse(duty=50, ms=500)
|
if self.ringing:
|
||||||
wasp.system.keep_awake()
|
wasp.watch.vibrator.pulse(duty=50, ms=500)
|
||||||
|
wasp.system.keep_awake()
|
||||||
|
|
||||||
def touch(self, event):
|
def touch(self, event):
|
||||||
"""Notify the application of a touchscreen touch event."""
|
"""Notify the application of a touchscreen touch event."""
|
||||||
draw = wasp.watch.drawable
|
draw = wasp.watch.drawable
|
||||||
if event[1] in range(90, 150) and event[2] in range(180,240):
|
if self.ringing:
|
||||||
|
mute = wasp.watch.display.mute
|
||||||
|
self.ringing = False
|
||||||
|
mute(True)
|
||||||
|
self._draw()
|
||||||
|
mute(False)
|
||||||
|
|
||||||
|
elif event[1] in range(90, 150) and event[2] in range(180,240):
|
||||||
self.active = not self.active
|
self.active = not self.active
|
||||||
|
|
||||||
elif event[1] in range(30,90):
|
elif event[1] in range(30,90):
|
||||||
|
|
Loading…
Add table
Reference in a new issue