aboutsummaryrefslogtreecommitdiff
path: root/Raspberry Pi/python.py
blob: 3078683a5f483c726edeb993417d2f47d29a42c4 (plain) (blame)
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