Editor3.py 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829
  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=9, weight='normal')
  31. FontBold = font.Font(family='Helvetica', size=9, weight='bold')
  32. #default_font.configure(size=9)
  33. root.option_add("*Font", Font)
  34. from collections import OrderedDict
  35. show_name = "GloryCamp2021"
  36. show_name = "GloryCamp2021"
  37. CUES = OrderedDict()
  38. groups = OrderedDict()
  39. BLIND = 0
  40. STORE = 0
  41. POS = ["PAN","TILT","MOTION"]
  42. COLOR = ["RED","GREEN","BLUE","COLOR"]
  43. BEAM = ["GOBO","G-ROT","PRISMA","P-ROT","FOCUS","SPEED"]
  44. INT = ["DIM","SHUTTER","STROBE","FUNC"]
  45. client = chat.tcp_sender()
  46. fade = 1
  47. def build_cmd(dmx,val,args=[fade]):
  48. cmd=""
  49. if type(val) is float or type(val) is int:
  50. cmd += ",d{}:{:0.4f}".format(dmx,val)
  51. else:
  52. cmd += ",d{}:{}".format(dmx,val)
  53. for val in args:
  54. if type(val) is float or type(val) is int:
  55. cmd += ":{:0.4f}".format(val)
  56. else:
  57. cmd += ":{}".format(val)
  58. return cmd
  59. def update_dmx(attr,data):
  60. global BLIND
  61. dmx = data["DMX"]
  62. val = None
  63. cmd=""
  64. if attr == "VDIM":
  65. for attr in data["ATTRIBUT"]:
  66. dmx = data["DMX"]
  67. if data["ATTRIBUT"][attr]["NR"] < 0:
  68. continue
  69. dmx += data["ATTRIBUT"][attr]["NR"]
  70. #print(attr)
  71. val = data["ATTRIBUT"][attr]["VALUE"]
  72. if data["ATTRIBUT"][attr]["MASTER"]:
  73. val = val * (data["ATTRIBUT"]["VDIM"]["VALUE"] / 255.)
  74. if val is not None:
  75. #cmd += ",d{}:{:0.4f}".format(dmx,int(val))
  76. cmd += build_cmd(dmx,val)
  77. #print("cmd",cmd)
  78. elif data["ATTRIBUT"][attr]["NR"] >= 0:
  79. dmx += data["ATTRIBUT"][attr]["NR"]
  80. val = data["ATTRIBUT"][attr]["VALUE"]
  81. if data["ATTRIBUT"][attr]["MASTER"]:
  82. if "VDIM" in data["ATTRIBUT"]:
  83. val = val * (data["ATTRIBUT"]["VDIM"]["VALUE"] / 255.)
  84. if val is not None:
  85. #cmd += ",d{}:{}".format(dmx,int(val))
  86. cmd += build_cmd(dmx,val)
  87. #print("cmd",cmd)
  88. if not BLIND:
  89. #client.send(cmd )
  90. pass
  91. else:
  92. cmd=""
  93. return cmd
  94. class Xevent():
  95. def __init__(self,fix,elem,attr=None,data=None,mode=None):
  96. self.data=data
  97. self.attr = attr
  98. self.elem = elem
  99. self.mode = mode
  100. def encoder(self,fix,attr,data,elem,action=""):
  101. if action == "click":
  102. if self.data["ATTRIBUT"][attr]["ACTIVE"]:
  103. self.data["ATTRIBUT"][attr]["ACTIVE"] = 0
  104. self.elem["bg"] = "grey"
  105. else:
  106. self.data["ATTRIBUT"][attr]["ACTIVE"] = 1
  107. self.elem["bg"] = "yellow"
  108. return 1
  109. v2=data["ATTRIBUT"][attr]["VALUE"]
  110. change=0
  111. increment = 4.11
  112. if action == "+":
  113. v2+= increment
  114. v = "+{:0.4f}".format( increment ) #) #4.11"
  115. change=1
  116. elif action == "-":
  117. v2-= 4.11
  118. v = "-{:0.4f}".format( increment ) #) #4.11"
  119. change=1
  120. if v2 < 0:
  121. v2=0
  122. elif v2 > 256:
  123. v2=256
  124. if change:
  125. data["ATTRIBUT"][attr]["ACTIVE"] = 1
  126. elem["bg"] = "yellow"
  127. #v2 = v
  128. #v = data["ATTRIBUT"][attr]["VALUE"]
  129. data["ATTRIBUT"][attr]["VALUE"] = v2
  130. elem["text"] = "{} {:0.4f}".format(attr,v2)
  131. #worker.fade_dmx(fix,attr,data,v,v2,ft=0)
  132. cmd=update_dmx(attr=attr,data=data)
  133. #data["ATTRIBUT"][attr]["VALUE"] = v2
  134. client.send(cmd)
  135. def cb(self,event):
  136. #print("cb",self,event,data)
  137. print("cb",self.attr,self.mode,event)
  138. #print(self.obj.keys())
  139. try:
  140. #v = self.data["ATTRIBUT"][self.attr]
  141. global STORE
  142. global BLIND
  143. change = 0
  144. if self.mode == "COMMAND":
  145. if self.attr == "CLEAR":
  146. if event.num == 1:
  147. if STORE:
  148. self.data.val_commands["STORE"] = 0
  149. STORE = 0
  150. self.data.elem_commands["STORE"]["bg"] = "lightgrey"
  151. else:
  152. for fix in self.data.fixtures:
  153. print( "clr",fix)
  154. data = self.data.fixtures[fix]
  155. #print("elm",self.data.elem_attr[fix])
  156. for attr in data["ATTRIBUT"]:
  157. if attr.endswith("-FINE"):
  158. continue
  159. self.data.elem_attr[fix][attr]["bg"] = "grey"
  160. data["ATTRIBUT"][attr]["ACTIVE"] = 0
  161. #print(data["ATTRIBUT"])
  162. elif self.attr == "BLIND":
  163. if event.num == 1:
  164. if self.data.val_commands[self.attr]:
  165. self.data.val_commands[self.attr] = 0
  166. BLIND = 0
  167. self.data.elem_commands[self.attr]["bg"] = "lightgrey"
  168. else:
  169. self.data.val_commands[self.attr] = 1
  170. BLIND = 1
  171. self.data.elem_commands[self.attr]["bg"] = "red"
  172. print("BLIND",self.data.val_commands)
  173. elif self.attr == "STORE":
  174. if event.num == 1:
  175. if self.data.val_commands[self.attr]:
  176. self.data.val_commands[self.attr] = 0
  177. STORE = 0
  178. self.data.elem_commands[self.attr]["bg"] = "lightgrey"
  179. else:
  180. self.data.val_commands[self.attr] = 1
  181. STORE = 1
  182. self.data.elem_commands[self.attr]["bg"] = "red"
  183. print("BLIND",self.data.val_commands)
  184. elif self.attr == "BACKUP":
  185. self.data.backup_presets()
  186. return 0
  187. elif self.mode == "INPUT":
  188. print(self.data.entry.get())
  189. if event.keycode == 36:
  190. x=self.data.entry.get()
  191. client.send(x)
  192. #self.data.entry.clean()
  193. #self.data
  194. #chat.send("")
  195. elif self.mode == "PRESET":
  196. nr = self.attr #int(self.attr.split(":")[1])-1
  197. if event.num == 1:
  198. if STORE:
  199. print("STORE PRESET")
  200. sdata = {}
  201. for fix in self.data.fixtures:
  202. data = self.data.fixtures[fix]
  203. for attr in data["ATTRIBUT"]:
  204. if data["ATTRIBUT"][attr]["ACTIVE"]:
  205. if fix not in sdata:
  206. sdata[fix] = {}
  207. if attr not in sdata[fix]:
  208. sdata[fix][attr] = data["ATTRIBUT"][attr]["VALUE"]
  209. print(sdata)
  210. self.data.val_presets[nr] = sdata
  211. if len(sdata):
  212. self.data.elem_presets[nr]["bg"] = "yellow"
  213. else:
  214. self.data.elem_presets[nr]["bg"] = "grey"
  215. #self.data.elem_presets[nr].option_add("*Font", FontBold)
  216. label = ""
  217. if nr in self.data.label_presets:
  218. #print(dir(self.data))
  219. label = self.data.label_presets[nr]
  220. self.data.elem_presets[nr]["text"] = "Preset:"+str(nr)+":\n"+str(len(sdata))+":"+label
  221. print(self.data.val_presets)
  222. self.data.val_commands["STORE"] = 0
  223. STORE = 0
  224. self.data.elem_commands["STORE"]["bg"] = "lightgrey"
  225. else:
  226. print("GO PRESET")
  227. if nr not in self.data.val_presets:
  228. self.data.val_presets[nr] = OrderedDict()
  229. sdata = self.data.val_presets[nr]
  230. cmd = ""
  231. for fix in sdata:
  232. for attr in sdata[fix]:
  233. v2 = sdata[fix][attr]
  234. #print(fix,attr,v)
  235. if fix in self.data.fixtures:
  236. #print("==",self.data.fixtures[fix]["ATTRIBUT"])
  237. if attr in self.data.fixtures[fix]["ATTRIBUT"]:
  238. data = self.data.fixtures[fix]
  239. v=self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"]
  240. self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"] = v2
  241. self.data.elem_attr[fix][attr]["text"] = str(attr)+' '+str(round(v,2))
  242. cmd+=update_dmx(attr,data)
  243. #worker.fade_dmx(fix,attr,data,v,v2)
  244. client.send(cmd )
  245. print(sdata)
  246. if event.num == 3:
  247. if not STORE:
  248. print("GO PRESET 3")
  249. if nr not in self.data.val_presets:
  250. self.data.val_presets[nr] = OrderedDict()
  251. sdata = self.data.val_presets[nr]
  252. cmd=""
  253. for fix in sdata:
  254. for attr in sdata[fix]:
  255. v2 = sdata[fix][attr]
  256. #print(fix,attr,v)
  257. if fix in self.data.fixtures:
  258. #print("==",self.data.fixtures[fix]["ATTRIBUT"])
  259. if attr in self.data.fixtures[fix]["ATTRIBUT"]:
  260. data = self.data.fixtures[fix]
  261. v=self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"]
  262. #self.data.fixtures[fix]["ATTRIBUT"][attr]["VALUE"] = v
  263. #print(str(attr)+' '+str(round(v,2)))
  264. #self.data.elem_attr[fix][attr]["text"] = str(attr)+' '+str(round(v,2))
  265. cmd+=update_dmx(attr,data)
  266. print("go",fix,attr,v,v2)
  267. #worker.fade_dmx(fix,attr,data,v,v2,ft=0)
  268. client.send(cmd )
  269. return 0
  270. elif self.mode == "INPUT":
  271. return 0
  272. if self.mode == "ENCODER":
  273. #if self.attr == "VDIM":
  274. # self.attr = "DIM"
  275. for fix in self.data.fixtures:
  276. data = self.data.fixtures[fix]
  277. for attr in data["ATTRIBUT"]:
  278. if attr.endswith("-FINE"):
  279. continue
  280. elem = self.data.elem_attr[fix][attr]
  281. if self.attr != attr:
  282. continue
  283. if event.num == 1:
  284. #self#encoder(attr=attr,data=data,elem=elem,action="click")
  285. data["ATTRIBUT"][attr]["ACTIVE"] = 1
  286. elem["bg"] = "yellow"
  287. if not data["ATTRIBUT"][attr]["ACTIVE"]:
  288. continue
  289. if event.num == 4:
  290. self.encoder(fix=fix,attr=attr,data=data,elem=elem,action="+")
  291. #if attr == "DIM":
  292. # self.encoder(attr="VDIM",data=data,elem=elem,action="+")
  293. elif event.num == 5:
  294. self.encoder(fix=fix,attr=attr,data=data,elem=elem,action="-")
  295. #if attr == "DIM":
  296. # self.encoder(attr="VDIM",data=data,elem=elem,action="-")
  297. return 0
  298. if event.num == 1:
  299. self.encoder(fix=0,attr=self.attr,data=self.data,elem=self.elem,action="click")
  300. elif event.num == 4:
  301. self.encoder(fix=0,attr=self.attr,data=self.data,elem=self.elem,action="+")
  302. elif event.num == 5:
  303. self.encoder(fix=0,attr=self.attr,data=self.data,elem=self.elem,action="-")
  304. except Exception as e:
  305. print("== cb EXCEPT",e)
  306. print("Error on line {}".format(sys.exc_info()[-1].tb_lineno))
  307. #print(self.elem["text"],self.attr,self.data)
  308. def wheel(event,d=None):
  309. print("wheel",event,d)
  310. import copy
  311. class Master():
  312. def __init__(self):
  313. self.load()
  314. self.all_attr =["DIM","VDIM","PAN","TILT"]
  315. self.elem_attr = {}
  316. self.commands =["BLIND","CLEAR","STORE","EDIT","","","","BACKUP","SET","","SELECT","ACTIVATE","","","",]
  317. self.elem_commands = {}
  318. self.val_commands = {}
  319. self.elem_presets = {}
  320. self.load_presets()
  321. for i in range(8*6):
  322. if i not in self.val_presets:
  323. name = "Preset:"+str(i+1)+":\nXYZ"
  324. #self.presets[i] = [i]
  325. self.val_presets[i] = OrderedDict()
  326. self.label_presets[i] = "-"
  327. def load(self):
  328. fixture = OrderedDict()
  329. DATA = OrderedDict()
  330. DATA["DIM"] = {"NR": 0, "MASTER": "1", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  331. fix = {"DMX": 20, "UNIVERS": 2, "NAME": "D", "ATTRIBUT": DATA}
  332. fi = copy.deepcopy(fix)
  333. fi["DMX"] = 1
  334. fi["NAME"] = "F1"
  335. fixture["1"] = fi
  336. fi = copy.deepcopy(fix)
  337. fi["DMX"] = 2
  338. fi["NAME"] = "F2"
  339. fixture["2"] = fi
  340. fi = copy.deepcopy(fix)
  341. fi["DMX"] = 3
  342. fi["NAME"] = "F3"
  343. fixture["3"] = fi
  344. fi = copy.deepcopy(fix)
  345. fi["DMX"] = 4
  346. fi["NAME"] = "F4"
  347. fixture["4"] = fi
  348. fi = copy.deepcopy(fix)
  349. fi["DMX"] = 11
  350. fi["NAME"] = "FL"
  351. fixture["11"] = fi
  352. fi = copy.deepcopy(fix)
  353. fi["DMX"] = 24
  354. fi["NAME"] = "P"
  355. fixture["24"] = fi
  356. DATA = OrderedDict()
  357. DATA["DIM"] = {"NR": 0, "MASTER": "1", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  358. DATA["RED"] = {"NR": 3, "MASTER": "", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  359. DATA["GREEN"] = {"NR": 4, "MASTER": "", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  360. DATA["BLUE"] = {"NR": 5, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  361. fix = {"DMX": 20, "UNIVERS": 2, "NAME": "IRGB", "ATTRIBUT": DATA}
  362. fi = copy.deepcopy(fix)
  363. fi["DMX"] = 401
  364. #fixture["1001"] = fi
  365. fi = copy.deepcopy(fix)
  366. fi["DMX"] = 421
  367. fi["ATTRIBUT"]["BLUE"]["VALUE"] = 22
  368. #fixture["1002"] = fi
  369. fi = copy.deepcopy(fix)
  370. fi["DMX"] = 441
  371. fi["ATTRIBUT"]["BLUE"]["VALUE"] = 22
  372. #fixture["1003"] = fi
  373. DATA = OrderedDict()
  374. DATA["VDIM"] = {"NR": -1, "MASTER": "", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  375. DATA["RED"] = {"NR": 2, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  376. DATA["GREEN"] = {"NR": 1, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  377. DATA["BLUE"] = {"NR": 0, "MASTER": "1", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  378. fix3 = {"DMX": 20, "UNIVERS": 2, "NAME": "V+RGB", "ATTRIBUT": DATA}
  379. fi = copy.deepcopy(fix3)
  380. fi["DMX"] = 330
  381. #fixture["2001"] = fi
  382. fi = copy.deepcopy(fix3)
  383. fi["DMX"] = 335
  384. #fixture["2002"] = fi
  385. fi = copy.deepcopy(fix3)
  386. fi["DMX"] = 240
  387. #fixture["2003"] = fi
  388. fi = copy.deepcopy(fix3)
  389. fi["DMX"] = 245
  390. #fixture["2004"] = fi
  391. fi = copy.deepcopy(fix3)
  392. fi["DMX"] = 250
  393. #fixture["2005"] = fi
  394. fi = copy.deepcopy(fix3)
  395. fi["DMX"] = 355
  396. #fixture["2006"] = fi
  397. DATA = OrderedDict()
  398. DATA["DIM-FINE"] = {"NR": 8, "MASTER": "", "MODE": "F", "VALUE": 5.0,"ACTIVE":0}
  399. DATA["VDIM"] = {"NR": -1, "MASTER": "", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  400. DATA["PAN"] = {"NR": 0, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  401. DATA["PAN-FINE"] = {"NR": 1, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  402. DATA["TILT"] = {"NR": 2, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  403. DATA["TILT-FINE"] = {"NR": 3, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  404. DATA["RED"] = {"NR": 6, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  405. DATA["GREEN"] = {"NR": 7, "MASTER": "1", "MODE": "F", "VALUE": 255.0,"ACTIVE":0}
  406. DATA["BLUE"] = {"NR": 8, "MASTER": "1", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  407. fixTMH = {"DMX": 20, "UNIVERS": 2, "NAME": "MH-BEAM", "ATTRIBUT": DATA}
  408. fi = copy.deepcopy(fixTMH)
  409. fi["DMX"] = 241
  410. fixture["3001"] = fi
  411. fi = copy.deepcopy(fixTMH)
  412. fi["DMX"] = 261
  413. fixture["3002"] = fi
  414. DATA = OrderedDict()
  415. DATA["DIM"] = {"NR": 17, "MASTER": "1", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  416. DATA["PAN"] = {"NR": 0, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  417. DATA["PAN-FINE"] = {"NR": 1, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  418. DATA["TILT"] = {"NR": 2, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  419. DATA["TILT-FINE"] = {"NR": 3, "MASTER": "", "MODE": "F", "VALUE": 127.0,"ACTIVE":0}
  420. DATA["COLOR"] = {"NR": 8, "MASTER": "", "MODE": "S", "VALUE": 0.0,"ACTIVE":0}
  421. DATA["GOBO"] = {"NR": 9, "MASTER": "", "MODE": "S", "VALUE": 0.0,"ACTIVE":0}
  422. DATA["G-ROT"] = {"NR": 8, "MASTER": "", "MODE": "S", "VALUE": 192.0,"ACTIVE":0}
  423. DATA["PRINSMA"] = {"NR": 10, "MASTER": "", "MODE": "S", "VALUE": 0.0,"ACTIVE":0}
  424. DATA["P-ROT"] = {"NR": 11, "MASTER": "", "MODE": "S", "VALUE": 0.0,"ACTIVE":0}
  425. DATA["FOCUS"] = {"NR": 14, "MASTER": "", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  426. DATA["ZOOM"] = {"NR": 13, "MASTER": "", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  427. DATA["FROST"] = {"NR": 15, "MASTER": "", "MODE": "F", "VALUE": 0.0,"ACTIVE":0}
  428. DATA["CONTROL"] = {"NR": 5, "MASTER": "", "MODE": "S", "VALUE": 5.0,"ACTIVE":0}
  429. fixREUSH = {"DMX": 300, "UNIVERS": 2, "NAME": "RUSH-BEAM", "ATTRIBUT": DATA}
  430. fi = copy.deepcopy(fixREUSH)
  431. fi["DMX"] = 201
  432. fixture["701"] = fi
  433. fi = copy.deepcopy(fixREUSH)
  434. fi["DMX"] = 220
  435. #fixture["702"] = fi
  436. fi = copy.deepcopy(fixREUSH)
  437. fi["DMX"] = 239
  438. #fixture["703"] = fi
  439. fi = copy.deepcopy(fixREUSH)
  440. fi["DMX"] = 258
  441. #fixture["704"] = fi
  442. fi = copy.deepcopy(fixREUSH)
  443. fi["DMX"] = 277
  444. #fixture["705"] = fi
  445. fi = copy.deepcopy(fixREUSH)
  446. fi["DMX"] = 296
  447. #fixture["706"] = fi
  448. self.fixtures = fixture
  449. def load_presets(self):
  450. filename="presets"
  451. d,l = self._load(filename)
  452. self.val_presets = d
  453. self.label_presets = l
  454. def _load(self,filename):
  455. xfname = "show/"+show_name+"/"+str(filename)+".sav"
  456. print("load",xfname)
  457. f = open(xfname,"r")
  458. lines = f.readlines()
  459. f.close()
  460. data = OrderedDict()
  461. labels = OrderedDict()
  462. for line in lines:
  463. key,label,rdata = line.split("\t",2)
  464. key = int(key)
  465. print(xfname,"load",key,label)
  466. jdata = json.loads(rdata,object_pairs_hook=OrderedDict)
  467. data[key] = jdata
  468. labels[key] = label
  469. return data,labels
  470. def backup_presets(self):
  471. filename = "presets"
  472. data = self.val_presets
  473. labels = self.label_presets
  474. self._backup(filename,data,labels)
  475. def _backup(self,filename,data,labels):
  476. #fixture
  477. xfname = "show/"+show_name+"/"+str(filename)+".sav"
  478. print("backup",xfname)
  479. f = open(xfname,"w")
  480. for key in data:
  481. line = data[key]
  482. label = "label"
  483. if key in labels:
  484. label = labels[key]
  485. if label == "Name-"+str(key):
  486. label = ""
  487. print(xfname,"load",key,label,len(line))
  488. f.write(str(key)+"\t"+label+"\t"+json.dumps(line)+"\n")
  489. f.close()
  490. def draw_dim(self,fix,data,c=0,r=0,frame=None):
  491. i=0
  492. if frame is None:
  493. frame = tk.Frame(root,bg="black")
  494. frame.pack(fill=tk.X, side=tk.TOP)
  495. #b = tk.Button(frame,bg="lightblue", text="FIX:"+str(fix)+" "+data["NAME"],width=20)
  496. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  497. #b.grid(row=r, column=c, sticky=tk.W+tk.E)
  498. #c+=1
  499. #r+=1
  500. if fix not in self.elem_attr:
  501. self.elem_attr[fix] = {}
  502. for attr in data["ATTRIBUT"]:
  503. if attr not in self.all_attr:
  504. self.all_attr.append(attr)
  505. if attr not in self.elem_attr[fix]:
  506. self.elem_attr[fix][attr] = []
  507. if attr.endswith("-FINE"):
  508. continue
  509. v= data["ATTRIBUT"][attr]["VALUE"]
  510. b = tk.Button(frame,bg="lightblue", text=""+str(fix)+" "+data["NAME"],width=4)
  511. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  512. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  513. c+=1
  514. b = tk.Button(frame,bg="grey", text=str(attr)+' '+str(round(v,2)),width=6)
  515. self.elem_attr[fix][attr] = b
  516. b.bind("<Button>",Xevent(fix=fix,elem=b,attr=attr,data=data).cb)
  517. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  518. c+=1
  519. if c >=12:
  520. c=0
  521. r+=1
  522. return c,r
  523. def draw_fix(self,fix,data):
  524. i=0
  525. c=0
  526. r=0
  527. frame = tk.Frame(root,bg="black")
  528. frame.pack(fill=tk.X, side=tk.TOP)
  529. b = tk.Button(frame,bg="lightblue", text="FIX:"+str(fix)+" "+data["NAME"],width=20)
  530. b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  531. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  532. c+=1
  533. #r+=1
  534. if fix not in self.elem_attr:
  535. self.elem_attr[fix] = {}
  536. for attr in data["ATTRIBUT"]:
  537. if attr not in self.all_attr:
  538. self.all_attr.append(attr)
  539. if attr not in self.elem_attr[fix]:
  540. self.elem_attr[fix][attr] = []
  541. if attr.endswith("-FINE"):
  542. continue
  543. v= data["ATTRIBUT"][attr]["VALUE"]
  544. b = tk.Button(frame,bg="grey", text=str(attr)+' '+str(round(v,2)),width=8)
  545. self.elem_attr[fix][attr] = b
  546. b.bind("<Button>",Xevent(fix=fix,elem=b,attr=attr,data=data).cb)
  547. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  548. c+=1
  549. if c >=14:
  550. c=1
  551. r+=1
  552. def draw_enc(self):
  553. i=0
  554. c=0
  555. r=0
  556. #frame = tk.Frame(root,bg="black")
  557. #frame.pack(fill=tk.X, side=tk.TOP)
  558. #b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  559. #b.grid(row=r, column=c, sticky=tk.W+tk.E)
  560. #r=0
  561. frame = tk.Frame(root,bg="black")
  562. frame.pack(fill=tk.X, side=tk.TOP)
  563. b = tk.Button(frame,bg="lightblue", text="ENCODER",width=10)
  564. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  565. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  566. #r+=1
  567. c+=1
  568. for attr in self.all_attr:
  569. if attr.endswith("-FINE"):
  570. continue
  571. v=0
  572. b = tk.Button(frame,bg="orange", text=str(attr)+'',width=10)
  573. b.bind("<Button>",Xevent(fix=0,elem=b,attr=attr,data=self,mode="ENCODER").cb)
  574. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  575. c+=1
  576. if c >=10:
  577. c=0
  578. r+=1
  579. def draw_command(self):
  580. i=0
  581. c=0
  582. r=0
  583. #frame = tk.Frame(root,bg="black")
  584. #frame.pack(fill=tk.X, side=tk.TOP)
  585. #b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  586. #b.grid(row=r, column=c, sticky=tk.W+tk.E)
  587. #r=0
  588. frame = tk.Frame(root,bg="black")
  589. frame.pack(fill=tk.X, side=tk.TOP)
  590. b = tk.Button(frame,bg="lightblue", text="COMMANDS",width=10)
  591. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  592. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  593. #r+=1
  594. c+=1
  595. for comm in self.commands:
  596. v=0
  597. b = tk.Button(frame,bg="lightgrey", text=str(comm),width=10)
  598. if comm not in self.elem_commands:
  599. self.elem_commands[comm] = b
  600. self.val_commands[comm] = 0
  601. b.bind("<Button>",Xevent(fix=0,elem=b,attr=comm,data=self,mode="COMMAND").cb)
  602. if comm:
  603. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  604. c+=1
  605. if c >=8:
  606. c=0
  607. r+=1
  608. def draw_preset(self):
  609. i=0
  610. c=0
  611. r=0
  612. frame = tk.Frame(root,bg="black")
  613. frame.pack(fill=tk.X, side=tk.TOP)
  614. b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  615. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  616. r=0
  617. frame = tk.Frame(root,bg="black")
  618. frame.pack(fill=tk.X, side=tk.TOP)
  619. b = tk.Button(frame,bg="lightblue", text="PRESET")
  620. #b.bind("<Button>",Xevent(elem=b).cb)
  621. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  622. r+=1
  623. for k in self.val_presets:
  624. v=0
  625. label = ""
  626. if k in self.label_presets:
  627. label = self.label_presets[k]
  628. print([label])
  629. b = tk.Button(frame,bg="grey", text="Preset:"+str(k)+"\n"+str(len(self.val_presets[k]))+":"+label,width=8,height=2)
  630. b.bind("<Button>",Xevent(fix=0,elem=b,attr=k,data=self,mode="PRESET").cb)
  631. if k in self.val_presets and len(self.val_presets[k]) :
  632. b["bg"] = "yellow"
  633. if k not in self.elem_presets:
  634. self.elem_presets[k] = b
  635. #self.val_presets[preset] = 0
  636. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  637. c+=1
  638. if c >=8:
  639. c=0
  640. r+=1
  641. def draw_input(self):
  642. i=0
  643. c=0
  644. r=0
  645. frame = tk.Frame(root,bg="black")
  646. frame.pack(fill=tk.X, side=tk.TOP)
  647. b = tk.Label(frame,bg="black", text="--------------------------------------- ---------------------------------------")
  648. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  649. r=0
  650. frame = tk.Frame(root,bg="black")
  651. frame.pack(fill=tk.X, side=tk.TOP)
  652. b = tk.Label(frame, text="send:")
  653. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  654. c+=1
  655. b = tk.Entry(frame,bg="grey", text="",width=80)
  656. self.entry = b
  657. b.bind("<Button>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT").cb)
  658. b.bind("<Key>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT").cb)
  659. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  660. b.insert("end","d0:127,fx241:sinus:50:50:10,fx243:cosinus:50:50:10,d201:127,fx201:sinus:50:300:10")
  661. def render(self):
  662. r=0
  663. c=0
  664. dim_frame = tk.Frame(root,bg="black")
  665. dim_frame.pack(fill=tk.X, side=tk.TOP)
  666. for fix in self.fixtures:
  667. data = self.fixtures[fix]
  668. print( fix )
  669. if(len(data["ATTRIBUT"].keys()) <= 1):
  670. c,r=self.draw_dim(fix,data,c=c,r=r,frame=dim_frame)
  671. else:
  672. self.draw_fix(fix,data)
  673. self.draw_enc()
  674. self.draw_command()
  675. self.draw_input()
  676. self.draw_preset()
  677. master =Master()
  678. master.render()
  679. root.mainloop()
  680. sys.exit()