widgets: Spinner: Add a simple spinner widget
We are able to add this to the self tests without having to create a special page. Instead we can modify the existing notifications test to utilize the spinner. Signed-off-by: Daniel Thompson <daniel@redfelineninja.org.uk>
This commit is contained in:
parent
62bca4d288
commit
2641616ff6
2 changed files with 66 additions and 19 deletions
|
@ -8,6 +8,7 @@
|
||||||
import wasp
|
import wasp
|
||||||
|
|
||||||
import gc
|
import gc
|
||||||
|
import fonts
|
||||||
import icons
|
import icons
|
||||||
import machine
|
import machine
|
||||||
|
|
||||||
|
@ -30,12 +31,12 @@ class TestApp():
|
||||||
self.scroll = wasp.widgets.ScrollIndicator()
|
self.scroll = wasp.widgets.ScrollIndicator()
|
||||||
|
|
||||||
self._checkbox = wasp.widgets.Checkbox(4, 104, 'Check me')
|
self._checkbox = wasp.widgets.Checkbox(4, 104, 'Check me')
|
||||||
|
|
||||||
self._sliders = (
|
self._sliders = (
|
||||||
wasp.widgets.Slider(32, 10, 90, 0xf800),
|
wasp.widgets.Slider(32, 10, 90, 0xf800),
|
||||||
wasp.widgets.Slider(64, 10, 140, 0x27e4),
|
wasp.widgets.Slider(64, 10, 140, 0x27e4),
|
||||||
wasp.widgets.Slider(32, 10, 190, 0x211f),
|
wasp.widgets.Slider(32, 10, 190, 0x211f),
|
||||||
)
|
)
|
||||||
|
self._spinner = wasp.widgets.Spinner(90, 60, 0, 99)
|
||||||
|
|
||||||
def foreground(self):
|
def foreground(self):
|
||||||
"""Activate the application."""
|
"""Activate the application."""
|
||||||
|
@ -86,18 +87,19 @@ class TestApp():
|
||||||
elif self.test.startswith('Fill'):
|
elif self.test.startswith('Fill'):
|
||||||
self._benchmark_fill()
|
self._benchmark_fill()
|
||||||
elif self.test == 'Notifications':
|
elif self.test == 'Notifications':
|
||||||
if event[1] < 120:
|
if self._spinner.touch(event):
|
||||||
|
notifications = wasp.system.notifications
|
||||||
|
|
||||||
|
if len(notifications) > self._spinner.value:
|
||||||
|
wasp.system.unnotify(
|
||||||
|
next(iter(notifications.keys())))
|
||||||
|
else:
|
||||||
wasp.system.notify(wasp.watch.rtc.get_uptime_ms(),
|
wasp.system.notify(wasp.watch.rtc.get_uptime_ms(),
|
||||||
{
|
{
|
||||||
"src":"Hangouts",
|
"src":"Hangouts",
|
||||||
"title":"A Name",
|
"title":"A Name",
|
||||||
"body":"message contents"
|
"body":"message contents"
|
||||||
})
|
})
|
||||||
else:
|
|
||||||
if wasp.system.notifications:
|
|
||||||
wasp.system.unnotify(
|
|
||||||
next(iter(wasp.system.notifications.keys())))
|
|
||||||
self._update_notifications()
|
|
||||||
elif self.test == 'RLE':
|
elif self.test == 'RLE':
|
||||||
self._benchmark_rle()
|
self._benchmark_rle()
|
||||||
elif self.test == 'String':
|
elif self.test == 'String':
|
||||||
|
@ -219,6 +221,7 @@ class TestApp():
|
||||||
wasp.watch.display.mute(True)
|
wasp.watch.display.mute(True)
|
||||||
draw = wasp.watch.drawable
|
draw = wasp.watch.drawable
|
||||||
draw.fill()
|
draw.fill()
|
||||||
|
draw.set_font(fonts.sans24)
|
||||||
draw.string('{} test'.format(self.test),
|
draw.string('{} test'.format(self.test),
|
||||||
0, 6, width=240)
|
0, 6, width=240)
|
||||||
|
|
||||||
|
@ -244,9 +247,8 @@ class TestApp():
|
||||||
else:
|
else:
|
||||||
draw.string("Not supported", 12, 4*24)
|
draw.string("Not supported", 12, 4*24)
|
||||||
elif self.test == 'Notifications':
|
elif self.test == 'Notifications':
|
||||||
draw.string('+', 24, 100)
|
self._spinner.value = len(wasp.system.notifications)
|
||||||
draw.string('-', 210, 100)
|
self._spinner.draw()
|
||||||
self._update_notifications()
|
|
||||||
elif self.test == 'RLE':
|
elif self.test == 'RLE':
|
||||||
draw.blit(self.ICON, 120-48, 120-32)
|
draw.blit(self.ICON, 120-48, 120-32)
|
||||||
|
|
||||||
|
@ -262,6 +264,3 @@ class TestApp():
|
||||||
|
|
||||||
draw.string('RGB565 #{:04x}'.format(rgb), 0, 6, width=240)
|
draw.string('RGB565 #{:04x}'.format(rgb), 0, 6, width=240)
|
||||||
draw.fill(rgb, 60, 35, 120, 50)
|
draw.fill(rgb, 60, 35, 120, 50)
|
||||||
|
|
||||||
def _update_notifications(self):
|
|
||||||
wasp.watch.drawable.string(str(len(wasp.system.notifications)), 0, 140, 240)
|
|
||||||
|
|
|
@ -226,6 +226,7 @@ class Checkbox():
|
||||||
draw = wasp.watch.drawable
|
draw = wasp.watch.drawable
|
||||||
im = self._im
|
im = self._im
|
||||||
if im[2]:
|
if im[2]:
|
||||||
|
draw.set_font(fonts.sans24)
|
||||||
draw.string(im[2], im[0], im[1]+6)
|
draw.string(im[2], im[0], im[1]+6)
|
||||||
self.update()
|
self.update()
|
||||||
|
|
||||||
|
@ -248,7 +249,7 @@ class Checkbox():
|
||||||
|
|
||||||
def touch(self, event):
|
def touch(self, event):
|
||||||
"""Handle touch events."""
|
"""Handle touch events."""
|
||||||
y = event[2] + 4
|
y = event[2]
|
||||||
im = self._im
|
im = self._im
|
||||||
if y >= im[1] and y < im[1]+40:
|
if y >= im[1] and y < im[1]+40:
|
||||||
self.state = not self.state
|
self.state = not self.state
|
||||||
|
@ -329,6 +330,53 @@ class Slider():
|
||||||
v = self._steps - 1
|
v = self._steps - 1
|
||||||
self.value = v
|
self.value = v
|
||||||
|
|
||||||
|
class Spinner():
|
||||||
|
"""A simple Spinner widget.
|
||||||
|
|
||||||
|
In order to have large enough hit boxes the spinner is a fairly large
|
||||||
|
widget and requires 60x120 px.
|
||||||
|
"""
|
||||||
|
def __init__(self, x, y, mn, mx, field=1):
|
||||||
|
self._im = (x, y, mn, mx, field)
|
||||||
|
self.value = mn
|
||||||
|
|
||||||
|
def draw(self):
|
||||||
|
"""Draw the slider."""
|
||||||
|
draw = watch.drawable
|
||||||
|
im = self._im
|
||||||
|
fg = draw.lighten(wasp.system.theme('slider-default'), 15)
|
||||||
|
draw.blit(icons.up_arrow, im[0]+30-8, im[1]+20, fg)
|
||||||
|
draw.blit(icons.down_arrow, im[0]+30-8, im[1]+120-20-9, fg)
|
||||||
|
self.update()
|
||||||
|
|
||||||
|
def update(self):
|
||||||
|
"""Update the spinner value."""
|
||||||
|
draw = watch.drawable
|
||||||
|
im = self._im
|
||||||
|
draw.set_font(fonts.sans28)
|
||||||
|
s = str(self.value)
|
||||||
|
if len(s) < im[4]:
|
||||||
|
s = '0' * (im[4] - len(s)) + s
|
||||||
|
draw.string(s, im[0], im[1]+60-14, width=60)
|
||||||
|
|
||||||
|
def touch(self, event):
|
||||||
|
x = event[1]
|
||||||
|
y = event[2]
|
||||||
|
im = self._im
|
||||||
|
if x >= im[0] and x < im[0]+60 and y >= im[1] and y < im[1]+120:
|
||||||
|
if y < im[1] + 60:
|
||||||
|
self.value += 1
|
||||||
|
if self.value > im[3]:
|
||||||
|
self.value = im[2]
|
||||||
|
else:
|
||||||
|
self.value -= 1
|
||||||
|
if self.value < im[2]:
|
||||||
|
self.value = im[3] - 1
|
||||||
|
|
||||||
|
self.update()
|
||||||
|
return True
|
||||||
|
|
||||||
|
return False
|
||||||
|
|
||||||
_message_string_x_coord = const(0)
|
_message_string_x_coord = const(0)
|
||||||
_message_string_y_coord = const(60)
|
_message_string_y_coord = const(60)
|
||||||
|
|
Loading…
Reference in a new issue