aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--behaviors/ControllerOSC.py75
-rw-r--r--behaviors/TouchOSC.py3
-rw-r--r--config/6thFloorOSC.xml2
-rwxr-xr-xoscserver.py36
-rwxr-xr-xtestosc.py36
5 files changed, 78 insertions, 74 deletions
diff --git a/behaviors/ControllerOSC.py b/behaviors/ControllerOSC.py
new file mode 100644
index 0000000..0dd1b12
--- /dev/null
+++ b/behaviors/ControllerOSC.py
@@ -0,0 +1,75 @@
+from operationscore.Behavior import *
+from logger import main_log
+#import util.ColorOps as color
+import colorsys
+from numpy import array
+import pdb
+import util.ComponentRegistry as compReg
+
+speedfactor = 15
+vel_decay = .01
+
+def constrainLocation(v,c):
+ if v[0] > c[0]:
+ v[0] = c[0]
+ elif v[0]<0:
+ v[0] = 0
+
+ if v[1] > c[1]:
+ v[1] = c[1]
+ elif v[1]<0:
+ v[1] = 0
+
+ return v
+
+class ControllerOSC(Behavior):
+ def behaviorInit(self):
+ self.xy = array((0,0))
+ self.v_xy = array((0,0))
+ self.v_decay = vel_decay
+
+ self.start_hsv = [0,1,1]
+ self.dest_hsv = [0,1,1]
+ self.ssize = compReg.getComponent('Screen').getSize()[-2:] #896 x 310
+
+ def processResponse(self, sensorInputs, recursiveInputs):
+ ret = []
+ if sensorInputs:
+ data = sensorInputs[-1]#for data in sensorInputs:
+ if data['Path'] == '/sixaxis/xy':
+ #try:
+ x = data['Value'][0]
+ y = data['Value'][1]
+ if y < 0:
+ self.start_hsv[1] = 1.0+y #s
+ else:
+ self.start_hsv[2] = 1.0-y
+ self.start_hsv[0] = (x+1) * 180.0
+# if self.start_hsv[0] >= 360:
+# self.start_hsv[0] = 0
+# if self.start_hsv[0] <=0:
+# self.start_hsv[0] = 360
+#self.h = x * 360.
+
+ #except(e):
+ # pdb.set_trace()
+ elif data['Path'] == '/sixaxis/lrud':
+ val=data['Value']
+ vy = val[3] if val[3] else -val[2]
+ vx = -val[0] if val[0] else val[1]
+ #pdb.set_trace()
+ #self.v_xy = (val[1]*ssize[0], (1.0-val[0])*ssize[1])
+ self.v_xy = array((vx, vy)) * speedfactor
+ else:
+ main_log.error('Sensor Inputs: ' + str(sensorInputs))
+ self.xy = self.xy + self.v_xy
+ constrainLocation(self.xy,self.ssize)
+ self.v_xy -= self.v_decay
+ if self.v_xy[0] < 0:
+ self.v_xy[0] = 0
+ if self.v_xy[1] < 0:
+ self.v_xy[1] = 0
+ ret.append({'Color':[i*256 for i in
+ colorsys.hsv_to_rgb(*self.start_hsv)],'Location':(int(self.xy[0]), int(self.xy[1]))})
+
+ return (ret, [])
diff --git a/behaviors/TouchOSC.py b/behaviors/TouchOSC.py
index 1c41b5e..354b845 100644
--- a/behaviors/TouchOSC.py
+++ b/behaviors/TouchOSC.py
@@ -12,7 +12,8 @@ class TouchOSC(Behavior):
self.xy = (-1,-1)
def processResponse(self, sensorInputs, recursiveInputs):
ret = []
- for data in sensorInputs:
+ if sensorInputs:
+ data = sensorInputs[-1]#for data in sensorInputs:
if data['Path'] == '/1/fader1':
try:
self.h = data['Value'][0]*360.0
diff --git a/config/6thFloorOSC.xml b/config/6thFloorOSC.xml
index 792fd0c..d3f0e6f 100644
--- a/config/6thFloorOSC.xml
+++ b/config/6thFloorOSC.xml
@@ -42,7 +42,7 @@
<Args>
<Id>osc</Id>
<Port>12345</Port>
- <RefreshInterval>10</RefreshInterval>
+ <RefreshInterval>20</RefreshInterval>
</Args>
</InputElement>
<InputElement>
diff --git a/oscserver.py b/oscserver.py
deleted file mode 100755
index 6763f41..0000000
--- a/oscserver.py
+++ /dev/null
@@ -1,36 +0,0 @@
-#!/usr/bin/env python
-
-import liblo, sys
-
-# create server, listening on port 1234
-try:
- server = liblo.Server(1234)
-except liblo.ServerError, err:
- print str(err)
- sys.exit()
-
-def foo_bar_callback(path, args):
- i, f = args
- print "received message '%s' with arguments '%d' and '%f'" % (path, i, f)
-
-def foo_baz_callback(path, args, types, src, data):
- print "received message '%s'" % path
- print "blob contains %d bytes, user data was '%s'" % (len(args[0]), data)
-
-def fallback(path, args, types, src):
- print "got unknown message '%s' from '%s'" % (path, src.get_url())
- for a, t in zip(args, types):
- print "argument of type '%s': %s" % (t, a)
-
-# register method taking an int and a float
-server.add_method("/foo/bar", 'if', foo_bar_callback)
-
-# register method taking a blob, and passing user data to the callback
-server.add_method("/foo/baz", 'b', foo_baz_callback, "blah")
-
-# register a fallback for unhandled messages
-server.add_method(None, None, fallback)
-
-# loop and dispatch messages every 100ms
-while True:
- server.recv(100)
diff --git a/testosc.py b/testosc.py
deleted file mode 100755
index cea03f4..0000000
--- a/testosc.py
+++ /dev/null
@@ -1,36 +0,0 @@
-#!/usr/bin/env python
-
-import liblo, sys
-
-# create server, listening on port 1234
-try:
- server = liblo.Server(12345)
-except liblo.ServerError, err:
- print str(err)
- sys.exit()
-
-def foo_bar_callback(path, args):
- i, f = args
- print "received message '%s' with arguments '%d' and '%f'" % (path, i, f)
-
-def foo_baz_callback(path, args, types, src, data):
- print "received message '%s'" % path
- print "blob contains %d bytes, user data was '%s'" % (len(args[0]), data)
-
-def fallback(path, args, types, src):
- print "got unknown message '%s' from '%s'" % (path, src.get_url())
- for a, t in zip(args, types):
- print "argument of type '%s': %s" % (t, a)
-
-# register method taking an int and a float
-server.add_method("/foo/bar", 'if', foo_bar_callback)
-
-# register method taking a blob, and passing user data to the callback
-server.add_method("/foo/baz", 'b', foo_baz_callback, "blah")
-
-# register a fallback for unhandled messages
-server.add_method(None, None, fallback)
-
-# loop and dispatch messages every 100ms
-while True:
- server.recv(100)