ported from master branch
fixed mem leak with adding external qt event processing Conflicts: ekgplotter/ekgplotter/main.py
This commit is contained in:
parent
41e512c9ef
commit
e889b3a88c
|
@ -68,8 +68,6 @@ except ImportError as e:
|
||||||
from chaosc.osc_lib import decode_osc
|
from chaosc.osc_lib import decode_osc
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class OSCThread(threading.Thread):
|
class OSCThread(threading.Thread):
|
||||||
def __init__(self, args):
|
def __init__(self, args):
|
||||||
super(OSCThread, self).__init__()
|
super(OSCThread, self).__init__()
|
||||||
|
@ -271,7 +269,7 @@ class EkgPlot(object):
|
||||||
|
|
||||||
def update(self, osc_address, value):
|
def update(self, osc_address, value):
|
||||||
|
|
||||||
print("update"), osc_address
|
|
||||||
res = self.ekg_regex.match(osc_address)
|
res = self.ekg_regex.match(osc_address)
|
||||||
if res:
|
if res:
|
||||||
#print("matched data")
|
#print("matched data")
|
||||||
|
@ -295,7 +293,6 @@ class EkgPlot(object):
|
||||||
if res:
|
if res:
|
||||||
actor_name = res.group(1)
|
actor_name = res.group(1)
|
||||||
actor_obj = self.actors[actor_name]
|
actor_obj = self.actors[actor_name]
|
||||||
#print("matched ctl", value, actor_name, actor_obj.active)
|
|
||||||
if value == 1 and not actor_obj.active:
|
if value == 1 and not actor_obj.active:
|
||||||
#print("actor on", actor_name, actor_obj, self.active_actors)
|
#print("actor on", actor_name, actor_obj, self.active_actors)
|
||||||
actor_obj.active = True
|
actor_obj.active = True
|
||||||
|
@ -303,16 +300,14 @@ class EkgPlot(object):
|
||||||
self.plot.addItem(actor_obj.plotItem)
|
self.plot.addItem(actor_obj.plotItem)
|
||||||
self.plot.addItem(actor_obj.plotPoint)
|
self.plot.addItem(actor_obj.plotPoint)
|
||||||
self.active_actors.append(actor_obj)
|
self.active_actors.append(actor_obj)
|
||||||
assert actor_obj in self.active_actors
|
|
||||||
elif value == 0 and actor_obj.active:
|
elif value == 0 and actor_obj.active:
|
||||||
#print("actor off", actor_name, actor_obj, self.active_actors)
|
#print "actor off", actor_name
|
||||||
actor_obj.active = False
|
actor_obj.active = False
|
||||||
self.plot.removeItem(actor_obj.plotItem)
|
self.plot.removeItem(actor_obj.plotItem)
|
||||||
self.plot.removeItem(actor_obj.plotPoint)
|
self.plot.removeItem(actor_obj.plotPoint)
|
||||||
try:
|
try:
|
||||||
self.active_actors.remove(actor_obj)
|
self.active_actors.remove(actor_obj)
|
||||||
except ValueError as e:
|
except ValueError as e:
|
||||||
#print("ctl", e)
|
|
||||||
pass
|
pass
|
||||||
assert actor_obj not in self.active_actors
|
assert actor_obj not in self.active_actors
|
||||||
|
|
||||||
|
@ -346,14 +341,18 @@ class MyHandler(BaseHTTPRequestHandler):
|
||||||
actor_names = [b"bjoern", b"merle", b"uwe"]
|
actor_names = [b"bjoern", b"merle", b"uwe"]
|
||||||
num_data = 100
|
num_data = 100
|
||||||
colors = ["r", "g", "b"]
|
colors = ["r", "g", "b"]
|
||||||
self.plotter = plotter = EkgPlot(actor_names, num_data, colors)
|
|
||||||
|
|
||||||
|
qtapp = QtGui.QApplication([])
|
||||||
|
self.plotter = plotter = EkgPlot(actor_names, num_data, colors)
|
||||||
|
|
||||||
self.send_header("Content-Type", "multipart/x-mixed-replace; boundary=--aaboundary\r\n\r\n")
|
self.send_header("Content-Type", "multipart/x-mixed-replace; boundary=--aaboundary\r\n\r\n")
|
||||||
self.end_headers()
|
self.end_headers()
|
||||||
#lastTime = time.time()
|
#lastTime = time.time()
|
||||||
#fps = None
|
#fps = None
|
||||||
|
event_loop = QtCore.QEventLoop()
|
||||||
while 1:
|
while 1:
|
||||||
|
event_loop.processEvents()
|
||||||
|
qtapp.sendPostedEvents(None, 0)
|
||||||
while 1:
|
while 1:
|
||||||
try:
|
try:
|
||||||
osc_address, args = msg_queue.get_nowait()
|
osc_address, args = msg_queue.get_nowait()
|
||||||
|
@ -440,8 +439,6 @@ def main():
|
||||||
add_subscriber_group(arg_parser, "ekgplotter")
|
add_subscriber_group(arg_parser, "ekgplotter")
|
||||||
args = finalize_arg_parser(arg_parser)
|
args = finalize_arg_parser(arg_parser)
|
||||||
|
|
||||||
qtapp = QtGui.QApplication([])
|
|
||||||
|
|
||||||
http_host, http_port = resolve_host(args.http_host, args.http_port, args.address_family)
|
http_host, http_port = resolve_host(args.http_host, args.http_port, args.address_family)
|
||||||
|
|
||||||
server = JustAHTTPServer((http_host, http_port), MyHandler)
|
server = JustAHTTPServer((http_host, http_port), MyHandler)
|
||||||
|
|
Loading…
Reference in New Issue