-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathstomplooper.py
executable file
·132 lines (102 loc) · 3.44 KB
/
stomplooper.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
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
#!/usr/bin/python
import RPi.GPIO as GPIO
import time, sys
import threading
import subprocess
from playback import Playback
from recorder import Recorder
from footswitch import Footswitch
switch = 19
yellowLED = 21
redLED = 23
audiofile = None
RESET_DURATION = 2.0
GPIO.setmode(GPIO.BOARD)
GPIO.setup(switch, GPIO.IN)
GPIO.setup(redLED, GPIO.OUT)
GPIO.output(redLED, 0)
GPIO.setup(yellowLED, GPIO.OUT)
GPIO.output(yellowLED, 0)
def playAudio():
global audiofile
if audiofile != None:
#subprocess.Popen(["mpg123", "-q", audiofile])
subprocess.Popen(["aplay", "-q", audiofile])
Playback.debug = 0
class LEDBlinker(Playback):
def play(self,duration):
playAudio()
ledDuration = 0.1 if duration > 0.2 else duration/2
GPIO.output(redLED, 1)
time.sleep( ledDuration )
GPIO.output(redLED, 0)
class MyButton(Footswitch):
debug = True
def __init__(self,pin,statusModePressed, bouncetime, timer_timeout):
Footswitch.__init__(self,pin,statusModePressed, bouncetime )
self.recorder = Recorder()
self.playback = None
self.lastPressed = 0
self.acceptRelease = False
self.timerThread = None
self.timer_timeout = timer_timeout
def pressed(self):
if MyButton.debug:
print "pressed"
GPIO.output(redLED, 1)
playAudio()
if self.playback != None:
if self.playback.is_alive():
self.playback.stop()
GPIO.output(yellowLED,0)
self.recorder = Recorder() # create new recorder; drop old recording
self.playback = None
self.recorder.record()
if len(self.recorder.recordings) > 0 and self.timer_timeout > 0.0:
self.startTimer(self.recorder.recordings[0])
def released(self,duration):
if MyButton.debug:
print "released", duration
GPIO.output(redLED, 0)
self.stopTimer()
if self.playback != None:
return
if len(self.recorder.recordings) > 0:
# if button was pressed more than 2/3 of the first recorded duration, start the playback
if duration > 0.66 * self.recorder.recordings[0]:
print "start PB in by release", duration
self.startPlayback(duration)
else:
if duration > RESET_DURATION:
if MyButton.debug:
print "reset"
self.recorder = Recorder() # reset
def startPlayback(self, gap):
if self.playback != None:
return
self.playback = LEDBlinker(self.recorder.recordings,gap)
self.playback.start()
GPIO.output(yellowLED,1)
self.recorder = Recorder() # create new recorder; drop old recording and status
def startTimer(self,timeout):
def timerEvent():
self.acceptRelease = False
if MyButton.debug:
print "start PB by timer", timeout
self.startPlayback(timeout)
self.timerThread = threading.Timer(self.timer_timeout, timerEvent, ())
self.timerThread.daemon = True
self.timerThread.start()
def stopTimer(self):
if self.timerThread != None:
self.timerThread.cancel()
## main
bttn = MyButton(switch,0, 2, 1.0)
if len(sys.argv) > 1:
audiofile = sys.argv[1]
try:
while True:
time.sleep(5)
except KeyboardInterrupt:
GPIO.cleanup()
sys.exit()