kopia lustrzana https://github.com/peterhinch/micropython-nano-gui
105 wiersze
3.7 KiB
Python
105 wiersze
3.7 KiB
Python
![]() |
# aclock.py Test/demo program for Adafruit ssd1351-based OLED displays
|
||
|
# Adafruit 1.5" 128*128 OLED display: https://www.adafruit.com/product/1431
|
||
|
# Adafruit 1.27" 128*96 display https://www.adafruit.com/product/1673
|
||
|
|
||
|
# The MIT License (MIT)
|
||
|
|
||
|
# Copyright (c) 2018 Peter Hinch
|
||
|
|
||
|
# Permission is hereby granted, free of charge, to any person obtaining a copy
|
||
|
# of this software and associated documentation files (the "Software"), to deal
|
||
|
# in the Software without restriction, including without limitation the rights
|
||
|
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||
|
# copies of the Software, and to permit persons to whom the Software is
|
||
|
# furnished to do so, subject to the following conditions:
|
||
|
#
|
||
|
# The above copyright notice and this permission notice shall be included in
|
||
|
# all copies or substantial portions of the Software.
|
||
|
#
|
||
|
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||
|
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||
|
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||
|
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||
|
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||
|
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||
|
# THE SOFTWARE.
|
||
|
|
||
|
# WIRING
|
||
|
# Pyb SSD
|
||
|
# 3v3 Vin
|
||
|
# Gnd Gnd
|
||
|
# X1 DC
|
||
|
# X2 CS
|
||
|
# X3 Rst
|
||
|
# X6 CLK
|
||
|
# X8 DATA
|
||
|
|
||
|
height = 96 # 1.27 inch 96*128 (rows*cols) display
|
||
|
# height = 128 # 1.5 inch 128*128 display
|
||
|
|
||
|
# Demo of initialisation procedure designed to minimise risk of memory fail
|
||
|
# when instantiating the frame buffer. The aim is to do this as early as
|
||
|
# possible before importing other modules.
|
||
|
|
||
|
import machine
|
||
|
import gc
|
||
|
from ssd1351 import SSD1351 as SSD
|
||
|
|
||
|
# Initialise hardware
|
||
|
pdc = machine.Pin('X1', machine.Pin.OUT_PP, value=0)
|
||
|
pcs = machine.Pin('X2', machine.Pin.OUT_PP, value=1)
|
||
|
prst = machine.Pin('X3', machine.Pin.OUT_PP, value=1)
|
||
|
spi = machine.SPI(1)
|
||
|
gc.collect() # Precaution before instantiating framebuf
|
||
|
ssd = SSD(spi, pcs, pdc, prst, height) # Create a display instance
|
||
|
from nanogui import Dial, Pointer, refresh, Label
|
||
|
refresh(ssd) # Initialise and clear display.
|
||
|
|
||
|
# Now import other modules
|
||
|
import cmath
|
||
|
import utime
|
||
|
from writer import CWriter
|
||
|
|
||
|
# Font for CWriter
|
||
|
import arial10
|
||
|
|
||
|
GREEN = SSD.rgb(0, 255, 0)
|
||
|
RED = SSD.rgb(255, 0, 0)
|
||
|
BLUE = SSD.rgb(0, 0, 255)
|
||
|
YELLOW = SSD.rgb(255, 255, 0)
|
||
|
BLACK = 0
|
||
|
|
||
|
def aclock():
|
||
|
uv = lambda phi : cmath.rect(1, phi) # Return a unit vector of phase phi
|
||
|
pi = cmath.pi
|
||
|
days = ('Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday',
|
||
|
'Sunday')
|
||
|
months = ('Jan', 'Feb', 'March', 'April', 'May', 'June', 'July',
|
||
|
'Aug', 'Sept', 'Oct', 'Nov', 'Dec')
|
||
|
# Instantiate CWriter
|
||
|
CWriter.set_textpos(ssd, 0, 0) # In case previous tests have altered it
|
||
|
wri = CWriter(ssd, arial10, GREEN, BLACK, verbose=False)
|
||
|
wri.set_clip(True, True, False)
|
||
|
|
||
|
# Instantiate displayable objects
|
||
|
dial = Dial(wri, 2, 2, height = 75, ticks = 12, bdcolor=None, label=120, pip=False) # Border in fg color
|
||
|
lbltim = Label(wri, 5, 85, 35)
|
||
|
hrs = Pointer(dial)
|
||
|
mins = Pointer(dial)
|
||
|
secs = Pointer(dial)
|
||
|
|
||
|
hstart = 0 + 0.7j # Pointer lengths and position at top
|
||
|
mstart = 0 + 0.92j
|
||
|
sstart = 0 + 0.92j
|
||
|
while True:
|
||
|
t = utime.localtime()
|
||
|
hrs.value(hstart * uv(-t[3]*pi/6 - t[4]*pi/360), YELLOW)
|
||
|
mins.value(mstart * uv(-t[4] * pi/30), YELLOW)
|
||
|
secs.value(sstart * uv(-t[5] * pi/30), RED)
|
||
|
lbltim.value('{:02d}.{:02d}.{:02d}'.format(t[3], t[4], t[5]))
|
||
|
dial.text('{} {} {} {}'.format(days[t[6]], t[2], months[t[1] - 1], t[0]))
|
||
|
refresh(ssd)
|
||
|
utime.sleep(1)
|
||
|
|
||
|
aclock()
|