-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathweather_16x2.py
executable file
·60 lines (53 loc) · 1.88 KB
/
weather_16x2.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#!/usr/bin/python3
from time import sleep
from gpiozero import MCP3008
import lcddriver
vref = 3.3
channels = [0,0,0,0,0,0,0,0]
temperatures = [0,0]
light_levels = [0,0]
count = 0
lcd = lcddriver.lcd() # create object for lcd control
lcd.lcd_clear() # clear LCD ready for start
def update():
lcd.lcd_display_string('{:^16}'.format(row_one), 1)
lcd.lcd_display_string('{:^16}'.format(row_two), 2)
# display a centered intro message
row_one = '{:^16}'.format("RasPiO Analog Zero")
row_two = '{:^16}'.format("16x2 Weather Kit")
update()
sleep(3)
# Wiring instructions
#
# Wire up 2x TMP36 so the middle pins go to A0 and A1
# Wire up 2x LDR. One leg to 3V3 other leg to one end
# of 10k resistor AND A6 or A7.
# Other end of 10k resistor goes to GND
while True:
for x in range(8):
adc = MCP3008(channel=x)
volts = 0.0
for y in range(20):
volts = volts + (vref * adc.value)
volts = volts / 20.0
if x < 2:
temperatures[x] = '{:4.1f}'.format((volts - 0.5) * 100)
if x > 5:
light_levels[x-6] = '{:4.1f}'.format(volts / vref * 100)
volts = '{:.3f}'.format(volts)
channels[x] = volts
# on-screen output useful for debug when tweaking
# shows the actual voltage at each analog input
print("channel " + str(x) + ":", volts,"Volts")
# update the character LCD once every cycle then a short delay
# because we have limited characters, we alternate display
if x == 7:
if count % 2 == 0:
row_one = "Temp 0: " + temperatures[0] + "C"
row_two = "Temp 1: " + temperatures[1] + "C"
else:
row_one = "Light 0: " + light_levels[0] + "%"
row_two = "Light 1: " + light_levels[1] + "%"
update()
count += 1
sleep(0.2) # you can adjust refresh rate here