Editor3.py 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697
  1. #! /usr/bin/python
  2. # -*- coding: utf-8 -*-
  3. """
  4. This file is part of librelight.
  5. librelight is free software: you can redistribute it and/or modify
  6. it under the terms of the GNU General Public License as published by
  7. the Free Software Foundation, either version 2 of the License, or
  8. (at your option) any later version.
  9. librelight is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  12. GNU General Public License for more details.
  13. You should have received a copy of the GNU General Public License
  14. along with librelight. If not, see <http://www.gnu.org/licenses/>.
  15. (c) 2012 micha.rathfelder@gmail.com
  16. """
  17. import json
  18. import time
  19. import sys
  20. import _thread as thread
  21. import tkinter
  22. import tkinter as tk
  23. from tkinter import font
  24. import lib.chat as chat
  25. import lib.motion as motion
  26. root = tk.Tk()
  27. root["bg"] = "grey" #white
  28. root.title( __file__)
  29. #default_font = font.Font(family='Helvetica', size=12, weight='bold')
  30. Font = font.Font(family='Helvetica', size=10, weight='normal')
  31. FontBold = font.Font(family='Helvetica', size=10, weight='bold')
  32. #default_font.configure(size=9)
  33. root.option_add("*Font", Font)
  34. from collections import OrderedDict
  35. CUES = OrderedDict()
  36. groups = OrderedDict()
  37. BLIND = 0
  38. STORE = 0
  39. POS = ["PAN","TILT","MOTION"]
  40. COLOR = ["RED","GREEN","BLUE","COLOR"]
  41. BEAM = ["GOBO","G-ROT","PRISMA","P-ROT","FOCUS","SPEED"]
  42. INT = ["DIM","SHUTTER","STROBE","FUNC"]
  43. client = chat.tcp_sender()
  44. def update_dmx(attr,data):
  45. global BLIND
  46. dmx = data["DMX"]
  47. val = None
  48. if attr == "VDIM":
  49. for attr in data["ATTRIBUT"]:
  50. dmx = data["DMX"]
  51. if data["ATTRIBUT"][attr]["NR"] < 0:
  52. continue
  53. dmx += data["ATTRIBUT"][attr]["NR"]
  54. #print(attr)
  55. val = data["ATTRIBUT"][attr]["VALUE"]
  56. if data["ATTRIBUT"][attr]["MASTER"]:
  57. val = val * (data["ATTRIBUT"]["VDIM"]["VALUE"] / 255.)
  58. if val is not None:
  59. cmd = "d{}:{}".format(dmx,int(val))
  60. #print("cmd",cmd)
  61. if not BLIND:
  62. client.send(cmd )
  63. else:
  64. pass#print("BLIND ! cmd",cmd)
  65. elif data["ATTRIBUT"][attr]["NR"] >= 0:
  66. dmx += data["ATTRIBUT"][attr]["NR"]
  67. val = data["ATTRIBUT"][attr]["VALUE"]
  68. if data["ATTRIBUT"][attr]["MASTER"]:
  69. if "VDIM" in data["ATTRIBUT"]:
  70. val = val * (data["ATTRIBUT"]["VDIM"]["VALUE"] / 255.)
  71. if val is not None:
  72. cmd = "d{}:{}".format(dmx,int(val))
  73. #print("cmd",cmd)
  74. if not BLIND:
  75. client.send(cmd )
  76. else:
  77. pass#print("BLIND ! cmd",cmd)
  78. class Worker():
  79. def __init__(self):
  80. self.fade = OrderedDict()
  81. self.timer = time.time()
  82. def loop(self):
  83. while 1:
  84. self.next()
  85. def next(self):
  86. if self.timer+(1/30.) < time.time():
  87. try:
  88. lock.acquire()
  89. #if self.timer+1 < time.time():
  90. self.timer = time.time()
  91. #print("next")
  92. for fix in self.fade:
  93. for attr in self.fade[fix]:
  94. if 1:#len(self.fade[])>=2:
  95. fd=self.fade[fix][attr][0]
  96. x=fd.next()
  97. if x:
  98. x=fd.value
  99. #print("fade",x)
  100. data=self.fade[fix][attr][1]
  101. try:
  102. data["ATTRIBUT"][attr]["VALUE"] = x
  103. update_dmx(attr,data)
  104. except Exception as e:
  105. print("next EXCEPTION",e)
  106. finally:
  107. #lock.acquire()
  108. lock.release()
  109. else:
  110. time.sleep(0.1)
  111. def fade_dmx(self,fix,attr,data,v,v2,ft=None):
  112. if ft is None:
  113. ft = 4
  114. #print("fade_dmx",fix,attr,v,v2)
  115. try:
  116. lock.acquire()
  117. if fix not in self.fade:
  118. self.fade[fix] = OrderedDict()
  119. if attr not in self.fade[fix]:
  120. self.fade[fix][attr] = OrderedDict()
  121. self.fade[fix][attr] = [motion.FadeFast(v,v2,ft),data]
  122. finally:
  123. #lock.acquire()
  124. lock.release()
  125. worker = Worker()
  126. lock = thread.allocate_lock()
  127. thread.start_new_thread(worker.loop,())
  128. class Xevent():
  129. def __init__(self,fix,elem,attr=None,data=None,mode=None):
  130. self.data=data
  131. self.attr = attr
  132. self.elem = elem
  133. self.mode = mode
  134. def encoder(self,fix,attr,data,elem,action=""):
  135. if action == "click":
  136. if self.data["ATTRIBUT"][attr]["ACTIVE"]:
  137. self.data["ATTRIBUT"][attr]["ACTIVE"] = 0
  138. self.elem["bg"] = "grey"
  139. else:
  140. self.data["ATTRIBUT"][attr]["ACTIVE"] = 1
  141. self.elem["bg"] = "yellow"
  142. return 1
  143. v=data["ATTRIBUT"][attr]["VALUE"]
  144. change=0
  145. if action == "+":
  146. v+= 4.11
  147. change=1
  148. elif action == "-":
  149. v-= 4.11
  150. change=1
  151. if v < 0:
  152. v=0
  153. elif v > 256:
  154. v=256
  155. if change:
  156. data["ATTRIBUT"][attr]["ACTIVE"] = 1
  157. elem["bg"] = "yellow"
  158. v2 = v
  159. v = data["ATTRIBUT"][attr]["VALUE"]
  160. data["ATTRIBUT"][attr]["VALUE"] = v2
  161. elem["text"] = str(attr)+' '+str(round(v2,2))
  162. worker.fade_dmx(fix,attr,data,v,v2,ft=0)
  163. #update_dmx(attr=attr,data=data)
  164. def cb(self,event):
  165. #print("cb",self,event,data)
  166. print("cb",self.attr,self.mode,event)
  167. #print(self.obj.keys())
  168. try:
  169. #v = self.data["ATTRIBUT"][self.attr]
  170. global STORE
  171. global BLIND
  172. change = 0
  173. if self.mode == "COMMAND":
  174. if self.attr == "CLEAR":
  175. if event.num == 1:
  176. if STORE:
  177. self.data.val_commands["STORE"] = 0
  178. STORE = 0
  179. self.data.elem_commands["STORE"]["bg"] = "lightgrey"
  180. else:
  181. for fix in self.data.fixtures:
  182. print( "clr",fix)
  183. data = self.data.fixtures[fix]
  184. #print("elm",self.data.elem_attr[fix])
  185. for attr in data["ATTRIBUT"]:
  186. if attr.endswith("-FINE"):
  187. continue
  188. self.data.elem_attr[fix][attr]["bg"] = "grey"
  189. data["ATTRIBUT"][attr]["ACTIVE"] = 0
  190. #print(data["ATTRIBUT"])
  191. elif self.attr == "BLIND":
  192. if event.num == 1:
  193. if self.data.val_commands[self.attr]:
  194. self.data.val_commands[self.attr] = 0
  195. BLIND = 0
  196. self.data.elem_commands[self.attr]["bg"] = "lightgrey"
  197. else:
  198. self.data.val_commands[self.attr] = 1
  199. BLIND = 1
  200. self.data.elem_commands[self.attr]["bg"] = "red"
  201. print("BLIND",self.data.val_commands)
  202. elif self.attr == "STORE":
  203. if event.num == 1:
  204. if self.data.val_commands[self.attr]:
  205. self.data.val_commands[self.attr] = 0
  206. STORE = 0
  207. self.data.elem_commands[self.attr]["bg"] = "lightgrey"
  208. else:
  209. self.data.val_commands[self.attr] = 1
  210. STORE = 1
  211. self.data.elem_commands[self.attr]["bg"] = "red"
  212. print("BLIND",self.data.val_commands)
  213. elif self.attr == "BACKUP":
  214. self.data.backup_presets()
  215. return 0
  216. elif self.mode == "PRESET":
  217. nr = self.attr #int(self.attr.split(":")[1])-1
  218. if event.num == 1:
  219. if STORE:
  220. print("STORE PRESET")
  221. sdata = {}
  222. for fix in self.data.fixtures:
  223. data = self.data.fixtures[fix]
  224. for attr in data["ATTRIBUT"]:
  225. if data["ATTRIBUT"][attr]["ACTIVE"]:
  226. if fix not in sdata:
  227. sdata[fix] = {}
  228. if attr not in sdata[fix]:
  229. sdata[fix][attr] = data["ATTRIBUT"][attr]["VALUE"]
  230. print(sdata)
  231. self.data.val_presets[nr] = sdata
  232. if len(sdata):
  233. self.data.elem_presets[nr]["bg"] = "yellow"
  234. #self.data.elem_presets[nr].option_add("*Font", FontBold)
  235. label = ""
  236. if nr in self.data.label_presets:
  237. #print(dir(self.data))
  238. label = self.data.label_presets[nr]
  239. self.data.elem_presets[nr]["text"] = "Preset:"+str(nr)+":\n"+str(len(sdata))+":"+label
  240. print(self.data.val_presets)
  241. self.data.val_commands["STORE"] = 0
  242. STORE = 0
  243. self.data.elem_commands["STORE"]["bg"] = "lightgrey"
  244. else:
  245. print("GO PRESET")
  246. if nr not in self.data.val_presets:
  247. self.data.val_presets[nr] = OrderedDict()
  248. sdata = self.data.val_presets[nr]
  249. for fix in sdata:
  250. for attr in sdata[fix]:
  251. v2 = sdata[fix][attr]
  252. #print(fix,attr,v)
  253. if fix in self.data.fixtures:
  254. #print("==",self.data.fixtures[fix]["ATTRIBUT"])
  255. if attr in self.data.fixtures[fix]["ATTRIBUT"]:
  256. data = self.data.fixtures[fix]
  257. v=self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"]
  258. self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"] = v2
  259. self.data.elem_attr[fix][attr]["text"] = str(attr)+' '+str(round(v,2))
  260. #update_dmx(attr,data)
  261. worker.fade_dmx(fix,attr,data,v,v2)
  262. print(sdata)
  263. if event.num == 3:
  264. if not STORE:
  265. print("GO PRESET 3")
  266. if nr not in self.data.val_presets:
  267. self.data.val_presets[nr] = OrderedDict()
  268. sdata = self.data.val_presets[nr]
  269. for fix in sdata:
  270. for attr in sdata[fix]:
  271. v2 = sdata[fix][attr]
  272. #print(fix,attr,v)
  273. if fix in self.data.fixtures:
  274. #print("==",self.data.fixtures[fix]["ATTRIBUT"])
  275. if attr in self.data.fixtures[fix]["ATTRIBUT"]:
  276. data = self.data.fixtures[fix]
  277. v=self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"]
  278. #self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"] = v
  279. #print(str(attr)+' '+str(round(v,2)))
  280. #self.data.elem_attr[fix][attr]["text"] = str(attr)+' '+str(round(v,2))
  281. #update_dmx(attr,data)
  282. print("go",fix,attr,v,v2)
  283. worker.fade_dmx(fix,attr,data,v,v2,ft=0)
  284. return 0
  285. elif self.mode == "INPUT":
  286. return 0
  287. if self.mode == "ENCODER":
  288. #if self.attr == "VDIM":
  289. # self.attr = "DIM"
  290. for fix in self.data.fixtures:
  291. data = self.data.fixtures[fix]
  292. for attr in data["ATTRIBUT"]:
  293. if attr.endswith("-FINE"):
  294. continue
  295. elem = self.data.elem_attr[fix][attr]
  296. if self.attr != attr:
  297. continue
  298. if event.num == 1:
  299. #self.encoder(attr=attr,data=data,elem=elem,action="click")
  300. data["ATTRIBUT"][attr]["ACTIVE"] = 1
  301. elem["bg"] = "yellow"
  302. if not data["ATTRIBUT"][attr]["ACTIVE"]:
  303. continue
  304. if event.num == 4:
  305. self.encoder(fix=fix,attr=attr,data=data,elem=elem,action="+")
  306. #if attr == "DIM":
  307. # self.encoder(attr="VDIM",data=data,elem=elem,action="+")
  308. elif event.num == 5:
  309. self.encoder(fix=fix,attr=attr,data=data,elem=elem,action="-")
  310. #if attr == "DIM":
  311. # self.encoder(attr="VDIM",data=data,elem=elem,action="-")
  312. return 0
  313. if event.num == 1:
  314. self.encoder(fix=0,attr=self.attr,data=self.data,elem=self.elem,action="click")
  315. elif event.num == 4:
  316. self.encoder(fix=0,attr=self.attr,data=self.data,elem=self.elem,action="+")
  317. elif event.num == 5:
  318. self.encoder(fix=0,attr=self.attr,data=self.data,elem=self.elem,action="-")
  319. except Exception as e:
  320. print("== cb EXCEPT",e)
  321. print("Error on line {}".format(sys.exc_info()[-1].tb_lineno))
  322. #print(self.elem["text"],self.attr,self.data)
  323. def wheel(event,d=None):
  324. print("wheel",event,d)
  325. import copy
  326. class Master():
  327. def __init__(self):
  328. self.load()
  329. self.all_attr =["DIM","VDIM","PAN","TILT"]
  330. self.elem_attr = {}
  331. self.commands =["BLIND","CLEAR","STORE","EDIT","","","","BACKUP","SET","","SELECT","ACTIVATE","","","",]
  332. self.elem_commands = {}
  333. self.val_commands = {}
  334. self.presets = OrderedDict()
  335. self.elem_presets = {}
  336. self.val_presets = OrderedDict()
  337. self.label_presets = OrderedDict()
  338. x=self.load_presets()
  339. for i in range(8*6):
  340. if i not in self.presets:
  341. name = "Preset:"+str(i+1)+":\nXYZ"
  342. self.presets[i] = [i]
  343. self.val_presets[i] = OrderedDict()
  344. self.label_presets[i] = ""
  345. def load(self):
  346. fixture = OrderedDict()
  347. DATA = OrderedDict()
  348. DATA["DIM"] = {"NR": 0, "MASTER": "1", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  349. DATA["RED"] = {"NR": 3, "MASTER": "", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  350. DATA["GREEN"] = {"NR": 4, "MASTER": "", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  351. DATA["BLUE"] = {"NR": 5, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  352. fix = {"DMX": 20, "UNIVERS": 2, "NAME": "IRGB", "ATTRIBUT": DATA}
  353. DATA = OrderedDict()
  354. DATA["VDIM"] = {"NR": -1, "MASTER": "", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  355. DATA["RED"] = {"NR": 2, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  356. DATA["GREEN"] = {"NR": 1, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  357. DATA["BLUE"] = {"NR": 0, "MASTER": "1", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  358. fix3 = {"DMX": 20, "UNIVERS": 2, "NAME": "V+RGB", "ATTRIBUT": DATA}
  359. DATA = OrderedDict()
  360. DATA["DIM-FINE"] = {"NR": 8, "MASTER": "", "MODE": "F", "VALUE": 5.0,"ACTIVE":0}
  361. DATA["VDIM"] = {"NR": -1, "MASTER": "", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  362. DATA["PAN"] = {"NR": 0, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  363. DATA["PAN-FINE"] = {"NR": 1, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  364. DATA["TILT"] = {"NR": 2, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  365. DATA["TILT-FINE"] = {"NR": 3, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  366. DATA["RED"] = {"NR": 6, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  367. DATA["GREEN"] = {"NR": 7, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  368. DATA["BLUE"] = {"NR": 8, "MASTER": "1", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  369. fixTMH = {"DMX": 20, "UNIVERS": 2, "NAME": "MH-BEAM", "ATTRIBUT": DATA}
  370. fi = copy.deepcopy(fixTMH)
  371. fi["DMX"] = 241
  372. fixture["2001"] = fi
  373. fi = copy.deepcopy(fixTMH)
  374. fi["DMX"] = 461
  375. fixture["2002"] = fi
  376. fi = copy.deepcopy(fix3)
  377. fi["DMX"] = 441
  378. fixture["2003"] = fi
  379. fi = copy.deepcopy(fix3)
  380. fi["DMX"] = 461
  381. fixture["2005"] = fi
  382. fi = copy.deepcopy(fix)
  383. fi["DMX"] = 401
  384. fixture["1001"] = fi
  385. fi = copy.deepcopy(fix)
  386. fi["DMX"] = 421
  387. fi["ATTRIBUT"]["BLUE"]["VALUE"] = 22
  388. fixture["1002"] = fi
  389. fi = copy.deepcopy(fix)
  390. fi["DMX"] = 441
  391. fi["ATTRIBUT"]["BLUE"]["VALUE"] = 22
  392. fixture["1003"] = fi
  393. self.fixtures = fixture
  394. def load_presets(self):
  395. print("load_presets")
  396. f = open("preset.sav","r")
  397. lines = f.readlines()
  398. f.close()
  399. self.val_presets = OrderedDict()
  400. self.presets = OrderedDict()
  401. for line in lines:
  402. key,label,data = line.split("\t",2)
  403. key = int(key)
  404. print("load_presets",key)
  405. data = json.loads(data)
  406. self.val_presets[key] = data
  407. self.label_presets[key] = label
  408. self.presets[key] = 0
  409. return self.val_presets
  410. def backup_presets(self):
  411. print("backup_presets")
  412. f = open("preset.sav","w")
  413. for key in self.val_presets:
  414. preset = self.val_presets[key]
  415. label = ""#"Name-"+str(key)
  416. if key in self.label_presets:
  417. label = self.label_presets[key]
  418. if label == "Name-"+str(key):
  419. label = ""
  420. f.write(str(key)+"\t"+label+"\t"+json.dumps(preset)+"\n")
  421. f.close()
  422. def draw_fix(self,fix,data):
  423. i=0
  424. c=0
  425. r=0
  426. frame = tk.Frame(root,bg="black")
  427. frame.pack(fill=tk.X, side=tk.TOP)
  428. b = tk.Button(frame,bg="lightblue", text="FIX:"+str(fix)+" "+data["NAME"],width=20)
  429. b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  430. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  431. c+=1
  432. #r+=1
  433. if fix not in self.elem_attr:
  434. self.elem_attr[fix] = {}
  435. for attr in data["ATTRIBUT"]:
  436. if attr not in self.all_attr:
  437. self.all_attr.append(attr)
  438. if attr not in self.elem_attr[fix]:
  439. self.elem_attr[fix][attr] = []
  440. if attr.endswith("-FINE"):
  441. continue
  442. v= data["ATTRIBUT"][attr]["VALUE"]
  443. b = tk.Button(frame,bg="grey", text=str(attr)+' '+str(round(v,2)),width=10)
  444. self.elem_attr[fix][attr] = b
  445. b.bind("<Button>",Xevent(fix=fix,elem=b,attr=attr,data=data).cb)
  446. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  447. c+=1
  448. if c >=8:
  449. c=0
  450. r+=1
  451. def draw_enc(self):
  452. i=0
  453. c=0
  454. r=0
  455. frame = tk.Frame(root,bg="black")
  456. frame.pack(fill=tk.X, side=tk.TOP)
  457. b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  458. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  459. r=0
  460. frame = tk.Frame(root,bg="black")
  461. frame.pack(fill=tk.X, side=tk.TOP)
  462. b = tk.Button(frame,bg="lightblue", text="ENCODER",width=10)
  463. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  464. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  465. #r+=1
  466. c+=1
  467. for attr in self.all_attr:
  468. if attr.endswith("-FINE"):
  469. continue
  470. v=0
  471. b = tk.Button(frame,bg="orange", text=str(attr)+'',width=10)
  472. b.bind("<Button>",Xevent(fix=0,elem=b,attr=attr,data=self,mode="ENCODER").cb)
  473. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  474. c+=1
  475. if c >=8:
  476. c=0
  477. r+=1
  478. def draw_command(self):
  479. i=0
  480. c=0
  481. r=0
  482. frame = tk.Frame(root,bg="black")
  483. frame.pack(fill=tk.X, side=tk.TOP)
  484. b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  485. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  486. r=0
  487. frame = tk.Frame(root,bg="black")
  488. frame.pack(fill=tk.X, side=tk.TOP)
  489. b = tk.Button(frame,bg="lightblue", text="COMMANDS",width=10)
  490. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  491. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  492. #r+=1
  493. c+=1
  494. for comm in self.commands:
  495. v=0
  496. b = tk.Button(frame,bg="lightgrey", text=str(comm),width=10)
  497. if comm not in self.elem_commands:
  498. self.elem_commands[comm] = b
  499. self.val_commands[comm] = 0
  500. b.bind("<Button>",Xevent(fix=0,elem=b,attr=comm,data=self,mode="COMMAND").cb)
  501. if comm:
  502. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  503. c+=1
  504. if c >=8:
  505. c=0
  506. r+=1
  507. def draw_preset(self):
  508. i=0
  509. c=0
  510. r=0
  511. frame = tk.Frame(root,bg="black")
  512. frame.pack(fill=tk.X, side=tk.TOP)
  513. b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  514. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  515. r=0
  516. frame = tk.Frame(root,bg="black")
  517. frame.pack(fill=tk.X, side=tk.TOP)
  518. b = tk.Button(frame,bg="lightblue", text="PRESET")
  519. #b.bind("<Button>",Xevent(elem=b).cb)
  520. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  521. r+=1
  522. for k in self.presets:
  523. v=0
  524. label = ""
  525. if k in self.label_presets:
  526. label = self.label_presets[k]
  527. print(label)
  528. b = tk.Button(frame,bg="grey", text="Preset:"+str(k)+"\n"+str(len(self.val_presets[k]))+":"+label,width=8,height=2)
  529. b.bind("<Button>",Xevent(fix=0,elem=b,attr=k,data=self,mode="PRESET").cb)
  530. if k in self.val_presets and len(self.val_presets[k]) :
  531. b["bg"] = "yellow"
  532. if k not in self.elem_presets:
  533. self.elem_presets[k] = b
  534. #self.val_presets[preset] = 0
  535. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  536. c+=1
  537. if c >=8:
  538. c=0
  539. r+=1
  540. def draw_input(self):
  541. i=0
  542. c=0
  543. r=0
  544. frame = tk.Frame(root,bg="black")
  545. frame.pack(fill=tk.X, side=tk.TOP)
  546. b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  547. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  548. r=0
  549. frame = tk.Frame(root,bg="black")
  550. frame.pack(fill=tk.X, side=tk.TOP)
  551. b = tk.Label(frame, text="send:")
  552. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  553. c+=1
  554. b = tk.Entry(frame,bg="grey", text="",width=39)
  555. b.bind("<Button>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT").cb)
  556. b.bind("<Key>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT").cb)
  557. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  558. def render(self):
  559. for fix in self.fixtures:
  560. data = self.fixtures[fix]
  561. print( fix)
  562. self.draw_fix(fix,data)
  563. self.draw_enc()
  564. self.draw_command()
  565. self.draw_input()
  566. self.draw_preset()
  567. master =Master()
  568. master.render()
  569. root.mainloop()
  570. sys.exit()