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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
|
""" Imports """
import logging
import smbus
import sys
import time
import json
import i2cPixel
""" Decalrations """
pixels = 348 # Change this to the appropriate number for your setup
addresses = [0, 24, 25, 35] # legg til en start og en stopp for hvert trinn
def hexToRgb(value):
value = value.lstrip('#')
lv = len(value)
return tuple(int(value[i:i+lv/3], 16) for i in range(0, lv, lv/3))
def lightStaircase(direction):
repeats = len(addresses)
repeats = repeats / 2
if direction == "up":
loopCondition = repeats
else:
loopCondition = 0
return true
def errorHandler(type, errorMsg):
if type == 1: # Debug
logging.debug(errorMsg)
print("Debug Message: See logfile")
elif type == 2: # info
logging.info(errorMsg)
elif type == 3: # Warning
logging.warning(errorMsg)
elif type == 4: # Error
logging.error(errorMsg)
print("Error: See logfile")
elif type == 5: # Error
logging.critical(errorMsg)
print("Critical Error: See logfile")
else:
logging.critical(errorMsg)
print("Something went terribly wrong! Not even the errorhandler was able to find out what. Which basically means 'You are doomed'")
def setup():
""" Setup Log File """
logging.basicConfig(filename='error.log',level=logging.DEBUG,mode='w')
""" Print first line of log file """
logging.info('Starting App')
""" Set time """
start_time = time.time()
""" Setup i2c communication """
i2cPixel.version()
i2cPixel.setBus(1)
i2cPixel.setAddress(0x04)
""" Wait for heartbeat from Arduino """
while True:
try:
if i2cPixel.greeting():
print "Arduino is Online"
time.sleep(1)
break
except Exception:
pass
"""i = 0
while i < pixels:
i2cPixel.setPixel(i, 0, 0, 0)
i2cPixel.show()"""
def main():
print "GO!"
timer = time.time()
i = 0
while i < pixels:
i2cPixel.setPixel(i, 255, 255, 255)
i2cPixel.show()
i = i + 1
print("--- %s seconds ---" % (time.time() - timer))
timer = time.time()
i = 0
while i < pixels:
i2cPixel.setPixel(i, 255, 255, 255)
i = i + 1
i2cPixel.show()
print("--- %s seconds ---" % (time.time() - timer))
pixelsPerStair = [21, 23, 23, 24, 25, 27, 31, 33, 28, 26, 25, 24, 24]
i = 0
o = 0
j = 0
timer = time.time()
while i < len(pixelsPerStair):
time1 = time.time()
mellomRekning = o + pixelsPerStair[i]
if j == 0:
color = (255, 0, 225)
j = j + 1
elif j == 1:
color = (0, 63, 255)
j = j + 1
elif j == 2:
color = (25, 255, 0)
j = j + 1
elif j == 3:
color = (255, 0, 4)
j = j + 1
else:
color = (255, 250, 0)
j = 0
while o <= mellomRekning:
i2cPixel.setPixel(o, *color)
o = o + 1
i2cPixel.show()
i = i + 1
print("--- %s seconds ---" % (time.time() - timer))
""" Start script """
setup() #configure
main() #Start main
|