_LibreLightDesk.py 103 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953
  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, version 2 of the License.
  8. LibreLight is distributed in the hope that it will be useful,
  9. but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. GNU General Public License for more details.
  12. You should have received a copy of the GNU General Public License
  13. along with LibreLight. If not, see <http://www.gnu.org/licenses/>.
  14. (c) 2012 micha@uxsrv.de
  15. """
  16. import random
  17. rnd_id = str(random.randint(1000,9000))
  18. rnd_id += " Beta 22.02 "
  19. import subprocess
  20. rnd_id += subprocess.check_output(['git', 'rev-parse', '--short', 'HEAD']).decode('ascii').strip()
  21. try:
  22. xtitle = __file__
  23. except:
  24. xtitle = "__file__"
  25. if "/" in xtitle:
  26. xtitle = xtitle.split("/")[-1]
  27. import sys
  28. sys.stdout.write("\x1b]2;"+str(xtitle)+" "+str(rnd_id)+"\x07") # terminal title
  29. import json
  30. import time
  31. import sys
  32. import os
  33. import _thread as thread
  34. import traceback
  35. import tkinter
  36. import tkinter as tk
  37. from tkinter import font
  38. import tkinter.simpledialog
  39. import lib.chat as chat
  40. import lib.motion as motion
  41. from collections import OrderedDict
  42. CUES = OrderedDict()
  43. groups = OrderedDict()
  44. class Modes():
  45. def __init__(self):
  46. self.modes = {}
  47. self.__cfg = {}
  48. self.__cb = None
  49. def val(self,mode,value=None):
  50. if value is not None:
  51. return self.set(mode,value)
  52. elif mode in self.modes:
  53. return self.modes[mode]
  54. def get(self,mode,value=None):
  55. return slef.val(mode,value)
  56. def __check(self,mode):
  57. if mode not in self.modes:
  58. self.modes[mode] = 0
  59. self.__cfg[mode] = 0
  60. def cfg(self,mode,data={}):
  61. self.__check(mode)
  62. if type(data) is dict:
  63. for k in data:
  64. v = data[k]
  65. if v not in self.__cfg:
  66. self.__cfg[k] = v
  67. return 1
  68. elif type(data) is str:
  69. if data in self.__cfg:
  70. return self.__cfg[data]
  71. def set(self,mode,value):
  72. protected = ["BLIND","CLEAR","STONY_FX"]
  73. self.__check(mode)
  74. out = 0
  75. if mode == "CLEAR":
  76. return 1
  77. elif mode == "ESC":
  78. for m in self.modes:
  79. print("ESC",m)
  80. if m == "COPY":
  81. PRESETS.clear_copy()
  82. if m == "MOVE":
  83. PRESETS.clear_move()
  84. if m != "BLIND":
  85. self.modes[m] = 0
  86. self.callback(m)
  87. out = 1
  88. return 1
  89. elif value:
  90. for m in self.modes:
  91. if m not in protected and mode not in protected and m != mode:
  92. if self.modes[m]:
  93. self.modes[m]= 0
  94. self.callback(m)
  95. if self.modes[mode]:
  96. if modes == "MOVE":
  97. PRESETS.clear_move()
  98. if modes == "COPY":
  99. PRESETS.clear_copy()
  100. self.modes[mode] = 0 # value
  101. else:
  102. self.modes[mode] = 1 #value
  103. out = 1
  104. else:
  105. self.modes[mode] = 0 #value
  106. if modes == "COPY":
  107. PRESETS.clear_copy()
  108. if modes == "MOVE":
  109. PRESETS.clear_move()
  110. self.callback(mode)
  111. return value
  112. def set_cb(self,cb):
  113. if cb:
  114. self.__cb = cb
  115. def callback(self,mode):
  116. if self.__cb is not None and mode in self.modes:
  117. value = self.modes[mode]
  118. self.__cb(mode=mode,value=value)
  119. modes = Modes()
  120. #modes.val("BLIND", 0)
  121. #modes.modes["BLIND"] = 0
  122. modes.modes["ESC"] = 0
  123. modes.modes["REC"] = 0
  124. modes.modes["EDIT"] = 0
  125. modes.modes["MOVE"] = 0
  126. modes.modes["FLASH"] = 0
  127. modes.modes["GO"] = 0
  128. modes.modes["DEL"] = 0
  129. modes.modes["STONY_FX"] = 0
  130. modes.modes["SELECT"] = 0
  131. modes.modes["CFG-BTN"] = 0
  132. modes.modes["LABEL"] = 0
  133. def xcb(mode,value=None):
  134. print("xcb","MODE CALLBACK",mode,value)
  135. if mode == "STONY_FX":
  136. print("xcb",modes.val("STONY_FX"))
  137. #modes.set_cb(xcb)
  138. POS = ["PAN","TILT","MOTION"]
  139. COLOR = ["RED","GREEN","BLUE","COLOR"]
  140. BEAM = ["GOBO","G-ROT","PRISMA","P-ROT","FOCUS","SPEED"]
  141. INT = ["DIM","SHUTTER","STROBE","FUNC"]
  142. #client = chat.tcp_sender(port=50001)
  143. jclient = chat.tcp_sender()#port=50001)
  144. import zlib
  145. def jclient_send(data):
  146. t_start = time.time()
  147. jtxt = data
  148. jtxt = json.dumps(jtxt)
  149. jtxt = jtxt.encode()
  150. #jtxt = zlib.compress(jtxt)
  151. jclient.send(b"\00 "+ jtxt +b"\00 ")
  152. print(round((time.time()-t_start)*1000,4),"milis")
  153. cprint(round(time.time(),4),color="yellow")
  154. class _FadeTime():
  155. def __init__(self):
  156. self._value = 2
  157. self._on = 1
  158. def inc(self,value=None):
  159. if value is not None:
  160. if type(value) is float:
  161. self._value += round(value,4)
  162. else:
  163. self._value += value
  164. return self._value
  165. def val(self,value=None):
  166. if value is not None:
  167. if type(value) is float:
  168. self._value = round(value,4)
  169. else:
  170. self._value = value
  171. return self._value
  172. def on(self):
  173. self._on = 1
  174. def off(self):
  175. self._on = 0
  176. def _is(self):
  177. if self._on:
  178. return 1
  179. return 0
  180. FADE = _FadeTime() #2 #0.1 #1.13
  181. fx_move_prm = {"SIZE":20,"SPEED":100,"OFFSET":50,"BASE":"-","START":0}
  182. fx_prm = {"SIZE":200,"SPEED":30,"OFFSET":255,"BASE":"-","START":0,"MODE":0,"MO":0,"DIR":1,"INVERT":0,"WING":2,"WIDTH":25}
  183. fx_modes = ["RED","GREEN","BLUE","MAG","YELLOW","CYAN"]
  184. fx_mo = ["sinus","on","on2","bump","bump2","fade","cosinus"]
  185. def build_cmd(dmx,val,args=[],flash=0,xpfx="",attr=""):
  186. if not args:
  187. args.append(FADE.val())
  188. cmd=""
  189. if xpfx:
  190. pfx=xpfx
  191. elif flash:
  192. pfx ="df"
  193. else:
  194. pfx ="d"
  195. if type(val) is float or type(val) is int:
  196. cmd += ",{}{}:{:0.4f}".format(pfx,dmx,val)
  197. else:
  198. cmd += ",{}{}:{}".format(pfx,dmx,val)
  199. if flash:
  200. cmd += ":0:0"#.format(val)
  201. else:
  202. for val in args:
  203. if type(val) is float or type(val) is int:
  204. cmd += ":{:0.4f}".format(val)
  205. else:
  206. cmd += ":{}".format(val)
  207. if attr:
  208. cmd += ":"+str(attr)
  209. cprint("build_cmd",cmd,color="red")
  210. return cmd
  211. def update_raw_dmx(data ,value=None,args=[],xfade=0,flash=0,pfx="d",fx=0):
  212. if flash:
  213. xfade = 0
  214. if not args: # and xfade is not None:# and FADE._is():
  215. args.append(xfade)
  216. else:
  217. args[0] = xfade
  218. cmd = []
  219. jcmd = []
  220. if flash:
  221. pfx += "f"
  222. for row in data:
  223. jxcmd={}
  224. if type(value) is float:
  225. jxcmd["VALUE"] = value #round(value,3)
  226. else:
  227. jxcmd["VALUE"] = value
  228. jxcmd["args"] = []
  229. if fx:
  230. if value is not None:
  231. # z.b. flush off
  232. xcmd = str(value)+":"+row["FX"].split(":",1)[-1]
  233. jxcmd["FX"] = row["FX"].split(":",1)[-1]
  234. else:
  235. xcmd = row["FX"]
  236. jxcmd["FX"] = row["FX"]
  237. if row["FX2"]:
  238. jxcmd["FX2"] = row["FX2"]
  239. else:
  240. if row["VALUE"] is None:
  241. xcmd = ""
  242. else:
  243. if value is not None:
  244. if type(value) is float:
  245. xcmd = "{:0.4f}".format(value)
  246. else:
  247. xcmd = "{}".format(value)
  248. else:
  249. v=row["VALUE"]
  250. xcmd = "{:0.4f}".format(v)
  251. #cprint([v])
  252. if type(v) is float:
  253. jxcmd["VALUE"] = v #round(v,3)
  254. else:
  255. jxcmd["VALUE"] = v
  256. for arg in args:
  257. if type(arg) is float:
  258. xcmd += ":{:0.4f}".format(arg)
  259. jxcmd["args"].append(v)#round(arg,3))
  260. else:
  261. xcmd += ":{}".format(arg)
  262. jxcmd["args"].append(arg)#round(arg,3))
  263. #print( "pack: FIX",row["FIX"],row["ATTR"], xcmd)
  264. #xcmd += ":{}".format(row["ATTR"])
  265. v= xfade #FADE.val() #rxcmd["args"][0]
  266. if type( v ) is float:
  267. jxcmd["FADE"] = round(v,4)
  268. else:
  269. jxcmd["FADE"] = v
  270. #if ("VALUE" in jxcmd and jxcmd["VALUE"] is not None) or "FX" in jxcmd and jxcmd["FX"]:
  271. jcmd.append( jxcmd)
  272. cmd.append( xcmd)
  273. #if xcmd:
  274. # cprint("update_raw_dmx j",jxcmd,color="red")
  275. # cprint("update_raw_dmx x",xcmd,color="red")
  276. return cmd,jcmd
  277. def update_dmx(attr,data,value=None,args=None,flash=0,pfx=""):
  278. xfade = 0
  279. if not args:
  280. args=[]
  281. xfade = FADE.val()
  282. args.append(xfade)
  283. #global modes #BLIND
  284. #print("update_dmx",data)
  285. dmx = data["DMX"]
  286. dmx = (data["UNIVERS"]*512)+data["DMX"]
  287. val = None
  288. cmd=""
  289. try:
  290. if attr == "DIM" and data["ATTRIBUT"][attr]["NR"] < 0: #VDIM
  291. #print( "VDIM")
  292. for attr in data["ATTRIBUT"]:
  293. dmx = (data["UNIVERS"]*512) + data["DMX"]
  294. dmx = data["DMX"]
  295. if data["ATTRIBUT"][attr]["NR"] < 0: #virtual channels
  296. continue
  297. dmx += data["ATTRIBUT"][attr]["NR"]-1
  298. mode = ""
  299. if "MODE" in data["ATTRIBUT"][attr]:
  300. mode = data["ATTRIBUT"][attr]["MODE"]
  301. #print(attr)
  302. val = data["ATTRIBUT"][attr]["VALUE"]
  303. if data["ATTRIBUT"][attr]["MASTER"]:
  304. val = val * (data["ATTRIBUT"]["DIM"]["VALUE"] / 255.)
  305. if val is not None:
  306. #cmd += ",d{}:{:0.4f}".format(dmx,int(val))
  307. if value is not None:
  308. val = value
  309. if mode == "F": #FADE
  310. cmd += build_cmd(dmx,val,args=args,flash=flash,xpfx=pfx,attr=attr)
  311. else:
  312. cmd += build_cmd(dmx,val,args=[0],flash=flash,xpfx=pfx,attr=attr)
  313. #print("cmd",cmd)
  314. elif data["ATTRIBUT"][attr]["NR"] > 0:
  315. dmx += data["ATTRIBUT"][attr]["NR"]-1
  316. val = data["ATTRIBUT"][attr]["VALUE"]
  317. mode = ""
  318. if "MODE" in data["ATTRIBUT"][attr]:
  319. mode = data["ATTRIBUT"][attr]["MODE"]
  320. if data["ATTRIBUT"][attr]["MASTER"]:
  321. #if "VDIM" in data["ATTRIBUT"]:
  322. if "DIM" in data["ATTRIBUT"] and data["ATTRIBUT"]["DIM"]["NR"] < 0: #VDIM
  323. val = val * (data["ATTRIBUT"]["DIM"]["VALUE"] / 255.)
  324. if val is not None:
  325. #cmd += ",d{}:{}".format(dmx,int(val))
  326. if value is not None:
  327. val = value
  328. if mode == "F": #FADE
  329. cmd += build_cmd(dmx,val,args=args,flash=flash,xpfx=pfx,attr=attr)
  330. else:
  331. cmd += build_cmd(dmx,val,args=[0],flash=flash,xpfx=pfx,attr=attr)
  332. #print("cmd",cmd)
  333. if modes.val("BLIND"):
  334. cmd=""
  335. cprint("update_dmx",cmd,color="red")
  336. return cmd
  337. except Exception as e:
  338. cprint("== cb EXCEPT",e,color="red")
  339. cprint("Error on line {}".format(sys.exc_info()[-1].tb_lineno),color="red")
  340. cprint(''.join(traceback.format_exception(None, e, e.__traceback__)),color="red")
  341. raise e
  342. class dummy_event():
  343. def __init__(self):
  344. self.num =0
  345. self.type = 4 #press 5 release
  346. self.set_value=-1
  347. gcolor = 1
  348. def cprint(*text,color="blue",space=" ",end="\n"):
  349. #return 0 #disable print dbg
  350. if not gcolor:
  351. print(text)
  352. return 0
  353. if color == "green":
  354. txt = '\033[92m'
  355. elif color == "red":
  356. txt = '\033[0;31m\033[1m'
  357. elif color == "yellow":
  358. txt = '\033[93m\033[1m'
  359. elif color == "cyan":
  360. txt = '\033[96m'
  361. else:
  362. txt = '\033[94m'
  363. for t in text:
  364. txt += str(t ) +" "
  365. #HEADER = '\033[95m'
  366. #OKBLUE = '\033[94m'
  367. #OKCYAN = '\033[96m'
  368. #OKGREEN = '\033[92m'
  369. #WARNING = '\033[93m'
  370. #FAIL = '\033[91m'
  371. #ENDC = '\033[0m'
  372. #BOLD = '\033[1m'
  373. #UNDERLINE = '\033[4m'
  374. txt += '\033[0m'
  375. print(txt,end=end)
  376. #return txt
  377. cprint("________________________________")
  378. class Xevent():
  379. def __init__(self,fix,elem,attr=None,data=None,mode=None):
  380. self.fix = fix
  381. self.data=data
  382. self.attr = attr
  383. self.elem = elem
  384. self.mode = mode
  385. def fx(self,event):
  386. cprint("Xevent.fx",self.attr,self.fix,event)
  387. jdatas = []
  388. fx2 = {}
  389. if event.num == 4:
  390. cprint("FX:COLOR CHANGE",fx_prm,color="red")
  391. txt = "FX:RED"
  392. fx_prm["MODE"] += 1
  393. if fx_prm["MODE"] > len(fx_modes):
  394. fx_prm["MODE"]=0
  395. txt = "FX:\n"+fx_modes[fx_prm["MODE"]]
  396. master.elem_fx_commands["FX:RED"]["text"] = txt
  397. elif event.num == 5:
  398. cprint("FX:COLOR CHANGE",fx_prm,color="red")
  399. txt = "FX:RED"
  400. fx_prm["MODE"] -= 1
  401. if fx_prm["MODE"] < 0:
  402. fx_prm["MODE"]= len(fx_modes)-1
  403. txt = "FX:\n"+fx_modes[fx_prm["MODE"]]
  404. master.elem_fx_commands["FX:RED"]["text"] = txt
  405. elif event.num == 1:
  406. cmd = ""
  407. offset = 0
  408. offset_flag=0
  409. start = fx_prm["START"]
  410. base = fx_prm["BASE"]
  411. #FIXTURES.start_fx(attr)
  412. xfixtures = []
  413. # WING's and BLOCK's
  414. fix_active =FIXTURES.get_active()
  415. for fix in fix_active:
  416. if fix == "CFG":
  417. continue
  418. xfixtures.append(fix)
  419. x=0
  420. if fx_prm["DIR"] < 0:
  421. xfixtures = xfixtures[::-1]
  422. x=-1
  423. if not xfixtures:
  424. cprint("470 fx() ... init no fixture selected",color="red")
  425. return 0
  426. wings = []
  427. if fx_prm["WING"]:
  428. l = len(xfixtures)
  429. w = l // fx_prm["WING"]
  430. teiler = l//w
  431. if teiler < 2:
  432. teiler = 2
  433. for i in range(teiler):
  434. j = i*w
  435. wing = xfixtures[j:j+w]
  436. if i%2==0:
  437. wing = wing[::-1]
  438. print("wing",i,"j",j,"w",w,"wing",wing)
  439. wings.append(wing)
  440. if l > j+w:
  441. wing = xfixtures[j+w:]
  442. wings.append(wing)
  443. else:
  444. wings.append(xfixtures)
  445. print("FX442 ",xfixtures)
  446. print("FX442 ",fx_prm,x)
  447. for wing in wings:
  448. print("wing",wing)
  449. wlen = len(wing)
  450. coffset= 0 # 1024/wlen * (offset/255)
  451. if fx_prm["DIR"]:
  452. offset = 0
  453. else:
  454. offset = 1024
  455. for fix in wing:
  456. data = FIXTURES.fixtures[fix]
  457. #print( "ADD FX",fix)
  458. for attr in data["ATTRIBUT"]:
  459. jdata = {"MODE":"FX"}
  460. jdata["VALUE"] = None
  461. jdata["FIX"] = fix
  462. jdata["DMX"] = FIXTURES.get_dmx(fix,attr)
  463. jdata["ATTR"] =attr
  464. if attr.endswith("-FINE"):
  465. continue
  466. csize = fx_prm["SIZE"]
  467. cspeed = fx_prm["SPEED"]
  468. cstart = fx_prm["START"]
  469. cbase = fx_prm["BASE"]
  470. width = fx_prm["WIDTH"]
  471. invert = fx_prm["INVERT"]
  472. #cstart = start
  473. coffset= round(offset,1)
  474. #cbase = base
  475. fx=""
  476. if "SIN" in self.attr:
  477. fx = "sinus"
  478. elif "FD" in self.attr:
  479. fx = "fade"
  480. elif "ON2" in self.attr:
  481. fx = "on2"
  482. elif "ON" in self.attr:
  483. fx = "on"
  484. elif "BUM2" in self.attr:
  485. fx = "bump2"
  486. elif "BUM" in self.attr:
  487. fx = "bump"
  488. elif "COS" in self.attr:
  489. fx = "cosinus"
  490. if fx:
  491. if fx_prm["SPEED"] < 0:
  492. fx = "off"
  493. else:
  494. if ":DIM" in self.attr:
  495. base=""
  496. ffxb= fx_mo[fx_prm["MO"]]
  497. if attr == "DIM":
  498. if fx_prm["SPEED"] < 0:
  499. fx = "off"
  500. else:
  501. fx = ffxb #"fade"
  502. elif ":TILT" in self.attr:
  503. base=""
  504. if attr == "PAN":
  505. fx = "off"
  506. if attr == "TILT":
  507. if fx_prm["SPEED"] < 0:
  508. fx = "off"
  509. else:
  510. fx = "sinus"
  511. elif ":PAN" in self.attr:
  512. base=""
  513. if attr == "PAN":
  514. if fx_prm["SPEED"] < 0:
  515. fx = "off"
  516. else:
  517. fx = "cosinus"
  518. if attr == "TILT":
  519. fx = "off"
  520. elif ":CIR" in self.attr:
  521. base=""
  522. if attr == "PAN":
  523. if fx_prm["SPEED"] < 0:
  524. fx = "off"
  525. else:
  526. fx = "cosinus"
  527. if attr == "TILT":
  528. if fx_prm["SPEED"] < 0:
  529. fx = "off"
  530. else:
  531. fx = "sinus"
  532. elif ":RED" in self.attr:
  533. ffxb= fx_mo[fx_prm["MO"]]
  534. ffx= "off" #fx_mo[fx_prm["MO"]]
  535. if "RED" in fx_modes[fx_prm["MODE"]]:#
  536. base="-"
  537. if attr == "RED":
  538. #coffset=0
  539. #cspeed=0
  540. fx=ffx
  541. if attr == "GREEN":
  542. fx = ffxb# "off"
  543. if attr == "BLUE":
  544. fx = ffxb#"off"
  545. elif "GREEN" in fx_modes[fx_prm["MODE"]]:#fx_prm["MODE"]:#in self.attr:
  546. base="-"
  547. if attr == "RED":
  548. fx = ffxb#"off"
  549. elif "GREEN" in fx_modes[fx_prm["MODE"]]:#fx_prm["MODE"]:#in self.attr:
  550. if attr == "GREEN":
  551. fx = ffxb# "off"
  552. #cspeed=0
  553. #coffset=0
  554. fx=ffx
  555. if attr == "BLUE":
  556. fx = ffxb#"off"
  557. elif "BLUE" in fx_modes[fx_prm["MODE"]]:#fx_prm["MODE"]:#self.attr:
  558. base="-"
  559. if attr == "RED":
  560. fx = ffxb# "off"
  561. if attr == "GREEN":
  562. fx = ffxb# "off"
  563. if attr == "BLUE":
  564. fx = ffxb# "off"
  565. #cspeed=0
  566. #coffset=0
  567. fx=ffx
  568. elif "YELLOW" in fx_modes[fx_prm["MODE"]]:#fx_prm["MODE"]:#self.attr:
  569. base="-"
  570. if attr == "RED":
  571. fx = ffxb# "off"
  572. #cspeed=0
  573. #coffset=0
  574. fx=ffx
  575. if attr == "GREEN":
  576. fx = ffxb# "off"
  577. #cspeed=0
  578. #coffset=0
  579. fx=ffx
  580. if attr == "BLUE":
  581. fx = "off"
  582. elif "CYAN" in fx_modes[fx_prm["MODE"]]:#fx_prm["MODE"]:#self.attr:
  583. base="-"
  584. if attr == "RED":
  585. fx = ffxb# "off"
  586. if attr == "GREEN":
  587. fx = ffxb# "off"
  588. #cspeed=0
  589. #coffset=0
  590. fx=ffx
  591. if attr == "BLUE":
  592. fx = ffxb# "off"
  593. #cspeed=0
  594. #coffset=0
  595. fx=ffx
  596. elif "MAG" in fx_modes[fx_prm["MODE"]]:#fx_prm["MODE"]:#self.attr:
  597. base="-"
  598. if attr == "RED":
  599. fx = ffxb# "off"
  600. fx=ffx
  601. #cspeed=0
  602. #coffset=0
  603. if attr == "GREEN":
  604. fx = ffxb# "off"
  605. if attr == "BLUE":
  606. fx = ffxb# "off"
  607. fx=ffx
  608. #cspeed=0
  609. #coffset=0
  610. else:
  611. cprint("FX: unbekant",fx_modes[fx_prm["MODE"]],color="red")
  612. #if fx:
  613. fxtype = fx
  614. #if data["ATTRIBUT"][attr]["ACTIVE"] and fx:
  615. # fjdata = {}
  616. # fjdata["TYPE"] = fxtype
  617. # fjdata["SIZE"] = round(csize,2)
  618. # fjdata["SPEED"] = round(cspeed,2)
  619. # fjdata["START"] = cstart
  620. # fjdata["OFFSET"]= round(coffset,2)
  621. # fjdata["BASE"] = cbase
  622. # jdata["FX2"] = fjdata
  623. # print(jdata)
  624. # #jdatas.append(jdata)
  625. fxtype = fx
  626. if fx:
  627. #fx += ":{:0.0f}:{:0.0f}:{:0.0f}:{:0.0f}:{}:".format(fx_prm["SIZE"],fx_prm["SPEED"],start,offset,base)
  628. fx += ":{:0.0f}:{:0.0f}:{:0.0f}:{:0.0f}:{}:".format(csize,cspeed,cstart,coffset,cbase)
  629. #jdata["FX"] = fx
  630. offset_flag=1
  631. #print("ADD FX",fix,attr,fx,data["ATTRIBUT"][attr]["ACTIVE"])
  632. if "FX" not in data["ATTRIBUT"][attr]:
  633. data["ATTRIBUT"][attr]["FX"] =""
  634. if "FX2" not in data["ATTRIBUT"][attr]:
  635. data["ATTRIBUT"][attr]["FX2"] ={}
  636. if data["ATTRIBUT"][attr]["ACTIVE"] and fx:
  637. print("++ADD FX",fix,attr,fx)
  638. #data["ATTRIBUT"][attr]["FX"] = fx #"sinus:40:100:10"
  639. cmd+=update_dmx(attr,data,pfx="fx",value=fx)#,flash=FLASH)
  640. fjdata = {}
  641. fjdata["TYPE"] = fxtype
  642. fjdata["SIZE"] = round(csize,2)
  643. fjdata["SPEED"] = round(cspeed,2)
  644. fjdata["WIDTH"] = int(width)
  645. fjdata["START"] = cstart
  646. fjdata["OFFSET"]= round(coffset,2)
  647. fjdata["INVERT"]= int(invert)
  648. fjdata["BASE"] = cbase
  649. jdata["FX2"] = fjdata
  650. data["ATTRIBUT"][attr]["FX2"] = fjdata
  651. jdatas.append(jdata)
  652. print(jdata)
  653. if fx_prm["OFFSET"] > 0.5 and offset_flag:
  654. offset_flag=0
  655. #offset += fx_prm["OFFSET"] # add offset on next fixture
  656. #offset += 1024/wlen * (fx_prm["OFFSET"]/255)
  657. if fx_prm["DIR"]:
  658. offset += 1024/wlen * (fx_prm["OFFSET"]/255)
  659. else:
  660. offset -= 1024/wlen * (fx_prm["OFFSET"]/255)
  661. offset = round(offset,2)
  662. #print("offset",offset)
  663. if cmd and not modes.val("BLIND"):
  664. #client.send(cmd)
  665. jclient_send(jdatas)
  666. master.refresh_fix()
  667. def command(self,event):
  668. if self.mode == "COMMAND":
  669. if self.attr == "CLEAR":
  670. if event.num == 1:
  671. ok = FIXTURES.clear()
  672. if ok:
  673. master.refresh_fix()
  674. modes.val(self.attr,0)
  675. elif self.attr.startswith("SZ:"):#SIN":
  676. #global fx_prm
  677. k = "SIZE"
  678. if event.num == 1:
  679. pass
  680. elif event.num == 2:
  681. pass
  682. elif event.num == 4:
  683. if fx_prm[k] <= 0:
  684. fx_prm[k] = 1
  685. fx_prm[k] +=5
  686. elif event.num == 5:
  687. fx_prm[k] -=5
  688. #fx_prm[k] =int(fx_prm[k])
  689. if fx_prm[k] > 4000:
  690. fx_prm[k] = 4000
  691. if fx_prm[k] < 0:
  692. fx_prm[k] =0
  693. if fx_prm[k] == 6: #bug
  694. fx_prm[k] =5
  695. self.data.elem_fx_commands[self.attr]["text"] = "SZ:\n{:0.0f}".format(fx_prm[k])
  696. cprint(fx_prm)
  697. elif self.attr.startswith("SP:"):#SIN":
  698. #global fx_prm
  699. k = "SPEED"
  700. if event.num == 1:
  701. fx_prm[k] = 6
  702. elif event.num == 3:
  703. fx_prm[k] = 60
  704. elif event.num == 4:
  705. if fx_prm[k] <= 0:
  706. fx_prm[k] = 0.06
  707. elif fx_prm[k] < 5:
  708. fx_prm[k] *=1.2
  709. else:
  710. fx_prm[k] +=5 #1.1
  711. elif event.num == 5:
  712. if fx_prm[k] <= 5:
  713. fx_prm[k] *=0.8
  714. else:
  715. fx_prm[k] -= 5 #1.1
  716. #fx_prm[k] =int(fx_prm[k])
  717. if fx_prm[k] > 4000:
  718. fx_prm[k] = 4000
  719. if fx_prm[k] < 0.05:
  720. fx_prm[k] =0
  721. if fx_prm[k] > 5 and fx_prm[k] < 10: #bug
  722. fx_prm[k] =5
  723. if fx_prm[k] < 0:
  724. self.data.elem_fx_commands[self.attr]["text"] = "SP:\noff".format(fx_prm[k])
  725. else:
  726. self.data.elem_fx_commands[self.attr]["text"] = "SP:\n{:0.02f}".format(fx_prm[k])
  727. cprint(fx_prm)
  728. elif self.attr.startswith("ST:"):#SIN":
  729. #global fx_prm
  730. k = "START"
  731. if event.num == 1:
  732. pass
  733. elif event.num == 2:
  734. pass
  735. elif event.num == 4:
  736. if fx_prm[k] <= 0:
  737. fx_prm[k] = 1
  738. fx_prm[k] += 5 #1.1
  739. elif event.num == 5:
  740. fx_prm[k] -= 5 #1.1
  741. #fx_prm[k] =int(fx_prm[k])
  742. if fx_prm[k] > 4000:
  743. fx_prm[k] = 4000
  744. if fx_prm[k] < 5:
  745. fx_prm[k] =0
  746. if fx_prm[k] == 6: #bug
  747. fx_prm[k] =5
  748. self.data.elem_fx_commands[self.attr]["text"] = "ST:\n{:0.0f}".format(fx_prm[k])
  749. cprint(fx_prm)
  750. elif self.attr.startswith("MO:"):# on,sinus,bump
  751. #global fx_prm
  752. k = "MO"
  753. if event.num == 1:
  754. pass
  755. elif event.num == 2:
  756. pass
  757. elif event.num == 4:
  758. fx_prm[k] -=1
  759. if fx_prm[k] < 0:
  760. fx_prm[k] = len(fx_mo)-1
  761. elif event.num == 5:
  762. fx_prm[k] +=1
  763. if fx_prm[k] >= len(fx_mo):
  764. fx_prm[k] = 0
  765. txt = fx_mo[fx_prm[k]]
  766. self.data.elem_fx_commands[self.attr]["text"] = "MO:\n{}".format(txt)
  767. cprint(fx_prm)
  768. elif self.attr.startswith("WIDTH:"):#SIN":
  769. #global fx_prm
  770. k = "WIDTH"
  771. if event.num == 1:
  772. pass
  773. elif event.num == 2:
  774. pass
  775. elif event.num == 4:
  776. if fx_prm[k] <= 0:
  777. fx_prm[k] = 1
  778. fx_prm[k] += 5 #*=1.1
  779. elif event.num == 5:
  780. fx_prm[k] -=5 #/=1.1
  781. #fx_prm[k] =int(fx_prm[k])
  782. if fx_prm[k] > 100:
  783. fx_prm[k] = 100
  784. if fx_prm[k] < 5:
  785. fx_prm[k] =0
  786. if fx_prm[k] == 6: #bug
  787. fx_prm[k] =5
  788. self.data.elem_fx_commands[self.attr]["text"] = "WIDTH:\n{:0.0f}".format(fx_prm[k])
  789. cprint(fx_prm)
  790. elif self.attr.startswith("DIR:"):#SIN":
  791. #global fx_prm
  792. k = "DIR"
  793. if event.num == 1:
  794. pass
  795. elif event.num == 2:
  796. pass
  797. elif event.num == 4:
  798. fx_prm[k] = 1
  799. elif event.num == 5:
  800. fx_prm[k] =-1
  801. txt = fx_prm[k]
  802. self.data.elem_fx_commands[self.attr]["text"] = "DIR:\n{}".format(fx_prm[k])
  803. cprint(fx_prm)
  804. elif self.attr.startswith("INVERT:"):#SIN":
  805. #global fx_prm
  806. k = "INVERT"
  807. if event.num == 1:
  808. pass
  809. elif event.num == 2:
  810. pass
  811. elif event.num == 4:
  812. fx_prm[k] = 1
  813. elif event.num == 5:
  814. fx_prm[k] =0
  815. if fx_prm[k] == 6: #bug ?
  816. fx_prm[k] =5
  817. self.data.elem_fx_commands[self.attr]["text"] = k+":\n{}".format(fx_prm[k])
  818. cprint(fx_prm)
  819. elif self.attr.startswith("WING:"):#SIN":
  820. #global fx_prm
  821. k = "WING"
  822. if event.num == 1:
  823. pass
  824. elif event.num == 2:
  825. pass
  826. elif event.num == 4:
  827. fx_prm[k] += 1
  828. elif event.num == 5:
  829. fx_prm[k] -=1
  830. if fx_prm[k] > 100:
  831. fx_prm[k] = 100
  832. if fx_prm[k] < 1:
  833. fx_prm[k] =1
  834. txt = fx_prm[k]
  835. self.data.elem_fx_commands[self.attr]["text"] = "WING:\n{}".format(fx_prm[k])
  836. cprint(fx_prm)
  837. elif self.attr.startswith("OF:"):#SIN":
  838. #global fx_prm
  839. k = "OFFSET"
  840. if event.num == 1:
  841. pass
  842. elif event.num == 2:
  843. pass
  844. elif event.num == 4:
  845. if fx_prm[k] <= 0:
  846. fx_prm[k] = 1
  847. fx_prm[k] +=5 #*=1.1
  848. elif event.num == 5:
  849. fx_prm[k] -=5 #/=1.1
  850. #fx_prm[k] =int(fx_prm[k])
  851. if fx_prm[k] > 512:
  852. fx_prm[k] = 512
  853. if fx_prm[k] < 5:
  854. fx_prm[k] =0
  855. if fx_prm[k] == 6: #bug
  856. fx_prm[k] =5
  857. self.data.elem_fx_commands[self.attr]["text"] = "OF:\n{:0.0f}".format(fx_prm[k])
  858. cprint(fx_prm)
  859. elif self.attr.startswith("BS:"):
  860. k = "BASE"
  861. if event.num == 1:
  862. fx_prm[k] = "0"
  863. elif event.num == 2:
  864. pass
  865. elif event.num == 4:
  866. fx_prm[k] = "+"
  867. elif event.num == 5:
  868. fx_prm[k] = "-"
  869. self.data.elem_fx_commands[self.attr]["text"] = "BS:\n{}".format(fx_prm[k])
  870. elif self.attr.startswith("FX:"):#SIN":
  871. self.fx(event)
  872. elif self.attr == "FX OFF":
  873. if event.num == 1:
  874. FIXTURES.fx_off("all")
  875. CONSOLE.fx_off("all")
  876. CONSOLE.flash_off("all")
  877. master.refresh_fix()
  878. return 0
  879. elif self.attr == "FADE":
  880. fade = FADE.val()
  881. print("EVENT CHANGE FADE",fade)
  882. if fade < 0.01:
  883. FADE.val(0.01)
  884. elif fade > 100.0:
  885. fade = 100
  886. if event.num == 4:
  887. fade *= 1.1
  888. elif event.num == 5:
  889. fade /= 1.1
  890. elif event.num == 1:
  891. if FADE._is():
  892. FADE.off()# = 0
  893. self.data.elem_commands[self.attr]["bg"] = "grey"
  894. else:
  895. FADE.on()# = 1
  896. self.data.elem_commands[self.attr]["bg"] = "green"
  897. elif event.num == 2:
  898. if fade > 1 and fade < 4:
  899. fade = 4
  900. elif fade > 3 and fade < 6:
  901. fade = 6
  902. elif fade > 5 and fade < 7:
  903. fade = 8
  904. elif fade > 7 and fade < 9:
  905. fade = 10
  906. elif fade > 9:
  907. fade = 0.01
  908. elif fade < 1:
  909. fade = 1.1
  910. fade = round(fade,3)
  911. FADE.val(fade)
  912. self.data.elem_commands[self.attr]["text"] = "Fade{:0.2f}".format(fade)
  913. elif self.attr == "BACKUP":
  914. modes.val(self.attr,1)
  915. PRESETS.backup_presets()
  916. FIXTURES.backup_patch()
  917. #time.sleep(1)
  918. modes.val(self.attr,0)
  919. else:
  920. if event.num == 1:
  921. print("ELSE",self.attr)
  922. modes.val(self.attr,1)
  923. return 0
  924. def cb(self,event):
  925. cprint("EVENT cb",self.attr,self.mode,event,color='yellow')
  926. print(["type",event.type,"num",event.num])
  927. try:
  928. change = 0
  929. if "keysym" in dir(event):
  930. if "Escape" == event.keysym:
  931. ok = FIXTURES.clear()
  932. master.refresh_fix()
  933. return 0
  934. if self.mode == "COMMAND":
  935. self.command(event)
  936. elif self.mode == "ROOT":
  937. if event.keysym=="Escape":
  938. pass
  939. elif self.mode == "INPUT":
  940. print("INP",self.data.entry.get())
  941. if event.keycode == 36:
  942. x=self.data.entry.get()
  943. #client.send(x)
  944. elif self.mode == "INPUT2":
  945. print("INP2",self.data.entry2.get())
  946. if event.keycode == 36:
  947. x=self.data.entry2.get()
  948. #client.send(x)
  949. elif self.mode == "INPUT3":
  950. print("INP3",self.data.entry3.get())
  951. if event.keycode == 36:
  952. x=self.data.entry3.get()
  953. #client.send(x)
  954. elif self.mode == "PRESET":
  955. nr = self.attr #int(self.attr.split(":")[1])-1
  956. if event.num == 1:
  957. if str(event.type) == '4': #4 ButtonPress
  958. if modes.val("REC"):
  959. self.data.preset_rec(nr)
  960. modes.val("REC",0)
  961. elif modes.val("DEL"):
  962. ok=PRESETS.delete(nr)
  963. if ok:
  964. modes.val("DEL",0)
  965. master.refresh_exec()
  966. elif modes.val("COPY"):
  967. ok=PRESETS.copy(nr)
  968. if ok:
  969. modes.val("COPY",0)
  970. master.refresh_exec()
  971. elif modes.val("MOVE"):
  972. ok=PRESETS.move(nr)
  973. if ok:
  974. modes.val("MOVE",0)
  975. master.refresh_exec()
  976. elif modes.val("CFG-BTN"):
  977. master.btn_cfg(nr)
  978. elif modes.val("LABEL"):#else:
  979. master.label(nr)
  980. elif modes.val("EDIT"):
  981. FIXTURES.clear()
  982. self.data.preset_select(nr)
  983. self.data.preset_go(nr,xfade=0,event=event,val=255)
  984. modes.val("EDIT", 0)
  985. master.refresh_fix()
  986. elif modes.val("SELECT"):
  987. self.data.preset_select(nr)
  988. else:
  989. self.data.preset_go(nr,event=event,val=255)
  990. else:
  991. self.data.preset_go(nr,xfade=0,event=event,val=0)
  992. if event.num == 3:
  993. if not modes.val("REC"):
  994. self.data.preset_go(nr,xfade=0,event=event,val=255)
  995. return 0
  996. elif self.mode == "INPUT":
  997. return 0
  998. if self.mode == "ENCODER":
  999. cprint("ENC",self.fix,self.attr,self.mode)
  1000. cprint(self.data)
  1001. val=""
  1002. if event.num == 1:
  1003. val ="click"
  1004. elif event.num == 4:
  1005. val ="+"
  1006. elif event.num == 5:
  1007. val ="-"
  1008. if val:
  1009. FIXTURES.encoder(fix=self.fix,attr=self.attr,xval=val)
  1010. master.refresh_fix()
  1011. except Exception as e:
  1012. cprint("== cb EXCEPT",e,color="red")
  1013. cprint("Error on line {}".format(sys.exc_info()[-1].tb_lineno),color="red")
  1014. cprint(''.join(traceback.format_exception(None, e, e.__traceback__)),color="red")
  1015. def wheel(event,d=None):
  1016. print("wheel",event,d)
  1017. import copy
  1018. class Element():
  1019. def __init__(self):
  1020. self.__data = {}
  1021. def set(self,key,val):
  1022. self.__data[key] = val
  1023. class Base():
  1024. def __init__(self):
  1025. show_name = "GloryCamp2021"
  1026. #show_name = "JMS"
  1027. show_name = "DemoShow"
  1028. #show_name = "Dimmer"
  1029. self.home = os.environ['HOME']
  1030. self.show_path = self.home +"/LibreLight/"
  1031. try:
  1032. f = open(self.show_path+"init.txt","r")
  1033. for line in f.readlines():
  1034. cprint(line)
  1035. if not line.startswith("#"):
  1036. show_name = line.strip()
  1037. show_name = show_name.replace(".","")
  1038. show_name = show_name.replace("\\","")
  1039. show_name = show_name.replace("/","")
  1040. except Exception as e:
  1041. cprint("shownamw exception",color="red")
  1042. if not os.path.isdir(self.show_path):
  1043. os.mkdir(self.show_path)
  1044. self.show_path += "/show/"
  1045. if not os.path.isdir(self.show_path):
  1046. os.mkdir(self.show_path)
  1047. self.show_path += "/" +show_name +"/"
  1048. if not os.path.isdir(self.show_path):
  1049. os.mkdir(self.show_path)
  1050. pass
  1051. def _load(self,filename):
  1052. xfname = self.show_path+"/"+str(filename)+".sav"
  1053. print("load",xfname)
  1054. f = open(xfname,"r")
  1055. lines = f.readlines()
  1056. f.close()
  1057. data = OrderedDict()
  1058. labels = OrderedDict()
  1059. for line in lines:
  1060. key,label,rdata = line.split("\t",2)
  1061. key = int(key)
  1062. #print(xfname,"load",key,label)
  1063. #print(line)
  1064. jdata = json.loads(rdata,object_pairs_hook=OrderedDict)
  1065. nrnull = 0
  1066. print(jdata)
  1067. #if "ATTRIBUT" in jdata: # translate old FIXTURES.fixtures start with 0 to 1
  1068. # for attr in jdata["ATTRIBUT"]:
  1069. # row = jdata["ATTRIBUT"][attr]
  1070. # if type(row) is OrderedDict:
  1071. # #print(row)
  1072. # if "VALUE" in row:
  1073. # v = row["VALUE"]
  1074. # if type(v) is float:
  1075. # v = round(v,4)
  1076. # jdata["ATTRIBUT"][attr]["VALUE"] = round(v,4)
  1077. # print("preset v",key,label,attr,v)
  1078. if "ATTRIBUT" in jdata: # translate old FIXTURES.fixtures start with 0 to 1
  1079. for attr in jdata["ATTRIBUT"]:
  1080. pass
  1081. #if "VALUE" in jdata["ATTRIBUT"][attr]:
  1082. # v = jdata["ATTRIBUT"][attr]["VALUE"]
  1083. # if type(v) is float:
  1084. # jdata["ATTRIBUT"][attr]["VALUE"] = round(v,4)
  1085. # #print("fix v",attr,v)
  1086. #if "NR" in jdata["ATTRIBUT"][attr]:
  1087. # nr = jdata["ATTRIBUT"][attr]["NR"]
  1088. # if nr == 0:
  1089. # nrnull = 1
  1090. # break
  1091. if nrnull:
  1092. print("DMX NR IS NULL",attr,"CHANGE +1")
  1093. for attr in jdata["ATTRIBUT"]:
  1094. if "NR" in jdata["ATTRIBUT"][attr]:
  1095. nr = jdata["ATTRIBUT"][attr]["NR"]
  1096. if nr >= 0:
  1097. jdata["ATTRIBUT"][attr]["NR"] +=1
  1098. data[key] = jdata
  1099. labels[key] = label
  1100. return data,labels
  1101. def _backup(self,filename,data,labels):
  1102. #fixture
  1103. #xfname = "show/"+show_name+"/"+str(filename)+".sav"
  1104. xfname = self.show_path+"/"+str(filename)+".sav"
  1105. print("backup",xfname)
  1106. f = open(xfname,"w")
  1107. for key in data:
  1108. line = data[key]
  1109. #print(line)
  1110. label = "label"
  1111. if key in labels:
  1112. label = labels[key]
  1113. if label == "Name-"+str(key):
  1114. label = ""
  1115. #print(xfname,"load",key,label,len(line))
  1116. f.write( "{}\t{}\t{}\n".format( key,label,json.dumps(line) ) )
  1117. f.close()
  1118. class Event():
  1119. def __init__(self,name):
  1120. self.name=name
  1121. #print("init",self)
  1122. def event(self,event):
  1123. print(self.name,event)
  1124. class scroll():
  1125. def __init__(self,canvas):
  1126. self.canvas=canvas
  1127. def config(self,event):
  1128. canvas = self.canvas
  1129. canvas.configure(scrollregion=canvas.bbox("all"))#,width=400,height=200)
  1130. def hex_to_rgb(hex):
  1131. return tuple(int(hex[i:i+2], 16) for i in (0, 2, 4))
  1132. class cb():
  1133. def __init__(self,win):
  1134. self.win = win
  1135. def _callback(self,event):
  1136. clobj=event.widget
  1137. ## undermouse=find_withtag(master.CURRENT)
  1138. undermouse=self.win.find_closest(self.win.CURRENT)
  1139. print( repr(undermouse))
  1140. def callback(self,event):
  1141. print(__file__,self,"callback",event)
  1142. cnv = self.win
  1143. item = cnv.find_closest(cnv.canvasx(event.x), cnv.canvasy(event.y))[0]
  1144. tags = cnv.gettags(item)
  1145. #cnv.itemconfigure(self.tag, text=tags[0])
  1146. print(tags,item)
  1147. color = cnv.itemcget(item, "fill")
  1148. cnv.itemconfig("all", width=1)#filla="green")
  1149. cnv.itemconfig(item, width=3)#filla="green")
  1150. print(color)
  1151. print( hex_to_rgb(color[1:]))
  1152. class GUI(Base):
  1153. def __init__(self):
  1154. super().__init__()
  1155. self.load()
  1156. self._XX = 0
  1157. self.all_attr =["DIM","PAN","TILT"]
  1158. self.elem_attr = {}
  1159. self.fx_commands =["STONY_FX","FX OFF","\n"
  1160. ,"FX:CIR","FX:PAN","FX:TILT","MO:ON""\n"
  1161. ,"MSZ:","MSP:","MST:","MOF:","MBS:-","\n"
  1162. ,"FX:DIM","FX:\nRED", "WIDTH:\n25","DIR:\n1","INVERT:\n0","WING:\n2","\n"
  1163. ,"SZ:\n","SP:\n","ST:\n","OF:\n","BS:\n-","\n"
  1164. , "FX:SIN","FX:COS","FX:BUM","FX:BUM2","FX:FD","FX:ON","FX:ON2" ]
  1165. self.commands =["\n","ESC","CFG-BTN","LABEL","BACKUP","DEL","\n"
  1166. ,"SELECT","FLASH","GO","FADE","MOVE","\n"
  1167. ,"BLIND","CLEAR","REC","EDIT","COPY","\n"
  1168. ]
  1169. self.elem_fx_commands = {}
  1170. self.val_fx_commands = {}
  1171. self.elem_commands = {}
  1172. self.val_commands = {}
  1173. self.elem_presets = {}
  1174. for i in range(8*8*8):
  1175. if i not in PRESETS.val_presets:
  1176. name = "Preset:"+str(i+1)+":\nXYZ"
  1177. #self.presets[i] = [i]
  1178. PRESETS.val_presets[i] = OrderedDict() # FIX
  1179. PRESETS.val_presets[i]["CFG"] = OrderedDict() # CONFIG
  1180. PRESETS.label_presets[i] = "-"
  1181. modes.set_cb(self.xcb)
  1182. def button_refresh(self,name,color,color2=None,fg=None):
  1183. cprint("button_refresh",name,color)
  1184. #if color == "gold":
  1185. # color2 = "yellow"
  1186. if color2 is None:
  1187. color2 = color
  1188. if name in self.elem_commands:
  1189. self.elem_commands[name]["bg"] = color
  1190. self.elem_commands[name].config(activebackground=color2)
  1191. if fg:
  1192. self.elem_commands[name]["fg"] = fg
  1193. print(dir(self.elem_commands[name]))
  1194. elif name in self.elem_fx_commands:
  1195. #todo
  1196. self.elem_fx_commands[name]["bg"] = color
  1197. self.elem_fx_commands[name].config(activebackground=color2)
  1198. if fg:
  1199. self.elem_fx_commands[name]["fg"] = fg
  1200. print(dir(self.elem_fx_commands[name]))
  1201. def btn_cfg(self,nr):
  1202. txt = PRESETS.btn_cfg(nr)
  1203. txt = tkinter.simpledialog.askstring("CFG-BTN","GO=GO FL=FLASH\nSEL=SELECT EXE:"+str(nr+1),initialvalue=txt)
  1204. if txt:
  1205. PRESETS.btn_cfg(nr,txt)
  1206. self.elem_presets[nr]["text"] = PRESETS.get_btn_txt(nr)
  1207. modes.val("CFG-BTN",0)
  1208. def label(self,nr):
  1209. txt = PRESETS.label(nr)
  1210. txt = tkinter.simpledialog.askstring("LABEL","EXE:"+str(nr+1),initialvalue=txt)
  1211. if txt:
  1212. PRESETS.label(nr,txt)
  1213. self.elem_presets[nr]["text"] = PRESETS.get_btn_txt(nr)
  1214. modes.val("LABEL", 0)
  1215. def xcb(self,mode,value=None):
  1216. cprint("MODE CALLBACK",mode,value,color="green",end="")
  1217. #cprint(self,"xcb","MODE CALLBACK",mode,value,color="green")
  1218. if value:
  1219. cprint("===== ON ======",color="red")
  1220. self.button_refresh(mode,color="red")#,fg="blue")
  1221. else:
  1222. cprint("===== OFF ======",color="red")
  1223. self.button_refresh(mode,color="lightgrey")#,fg="black")
  1224. def load(self,fname=""):
  1225. pass
  1226. def exit(self):
  1227. print("__del__",self)
  1228. PRESETS.backup_presets()
  1229. #print("********************************************************")
  1230. FIXTURES.backup_patch()
  1231. #print("*********del",self,"***********************************************")
  1232. def refresh_exec(self):
  1233. refresher.reset() # = Refresher()
  1234. def _refresh_exec(self):
  1235. cprint("PRESET.refresh_exec()")
  1236. self._XX +=1
  1237. for k in PRESETS.val_presets:
  1238. label = ""
  1239. if k not in self.elem_presets:
  1240. cprint("ERROR",k ,"not in elem_presets continue")
  1241. continue
  1242. if k in PRESETS.label_presets:
  1243. label = PRESETS.label_presets[k]
  1244. #print([label])
  1245. b = self.elem_presets[k]
  1246. if k in PRESETS.val_presets and len(PRESETS.val_presets[k]) :
  1247. sdata = PRESETS.val_presets[k]
  1248. #print("sdata7654",sdata)
  1249. BTN="go"
  1250. if "CFG" in sdata:#["BUTTON"] = "GO"
  1251. if "BUTTON" in sdata["CFG"]:
  1252. BTN = sdata["CFG"]["BUTTON"]
  1253. txt=str(k)+":"+str(BTN)+":"+str(len(sdata)-1)+"\n"+label
  1254. #txt+=str(self._XX)
  1255. b["text"] = txt
  1256. b["bg"] = "yellow"
  1257. b.config(activebackground="yellow")
  1258. if len(sdata) > 1:
  1259. fx_color = 0
  1260. val_color = 0
  1261. for fix in sdata:
  1262. if fix == "CFG":
  1263. continue
  1264. #print( "$$$$",fix,sdata[fix])
  1265. for attr in sdata[fix]:
  1266. if "FX2" in sdata[fix][attr]:
  1267. if sdata[fix][attr]["FX2"]:
  1268. fx_color = 1
  1269. if "FX" in sdata[fix][attr]:
  1270. if sdata[fix][attr]["FX"]:
  1271. fx_color = 1
  1272. if "VALUE" in sdata[fix][attr]:
  1273. if sdata[fix][attr]["VALUE"] is not None:
  1274. val_color = 1
  1275. b["fg"] = "black"
  1276. if val_color:
  1277. b["bg"] = "gold"
  1278. b.config(activebackground="#ffaa55")
  1279. if fx_color:
  1280. b["fg"] = "blue"
  1281. else:
  1282. if fx_color:
  1283. b["bg"] = "cyan"
  1284. b.config(activebackground="#55d4ff")
  1285. else:
  1286. b["bg"] = "grey"
  1287. b.config(activebackground="#aaaaaa")
  1288. if "\n" in txt:
  1289. txt = txt.split("\n")[0]
  1290. if "SEL" in txt:
  1291. b["fg"] = "black"
  1292. b["bg"] = "#5555ff"
  1293. b.config(activebackground="#6666ff")
  1294. elif "GO" in txt:
  1295. b["fg"] = "black"
  1296. elif "FL" in txt:
  1297. b["fg"] = "#7f00ff"
  1298. def refresh_fix(self):
  1299. refresher.reset() # = Refresher()
  1300. def _refresh_fix(self):
  1301. for fix in FIXTURES.fixtures:
  1302. sdata = FIXTURES.fixtures[fix]
  1303. for attr in sdata["ATTRIBUT"]:
  1304. if "FINE" in attr:
  1305. continue
  1306. v2 = sdata["ATTRIBUT"][attr]["VALUE"]
  1307. if fix in self.elem_attr:
  1308. elem = self.elem_attr[fix][attr]
  1309. #print( attr,v2)
  1310. elem["text"] = "{} {:0.2f}".format(attr,v2)
  1311. if sdata["ATTRIBUT"][attr]["ACTIVE"]:
  1312. elem["bg"] = "yellow"
  1313. elem.config(activebackground="yellow")
  1314. else:
  1315. elem["bg"] = "grey"
  1316. elem.config(activebackground="grey")
  1317. if "FX2" not in sdata["ATTRIBUT"][attr]: # insert FX2 excetption
  1318. sdata["ATTRIBUT"][attr]["FX2"] = OrderedDict()
  1319. if sdata["ATTRIBUT"][attr]["FX"]:
  1320. elem["fg"] = "blue"
  1321. elif sdata["ATTRIBUT"][attr]["FX2"]:
  1322. elem["fg"] = "red"
  1323. else:
  1324. elem["fg"] = "black"
  1325. def preset_rec(self,nr):
  1326. print("------- STORE PRESET")
  1327. data = FIXTURES.get_active()
  1328. if modes.val("STONY_FX"):
  1329. PRESETS.rec(nr,data,"STONY_FX")
  1330. modes.val("STONY_FX",0)
  1331. else:
  1332. PRESETS.rec(nr,data)
  1333. sdata=data
  1334. PRESETS.val_presets[nr] = sdata
  1335. master.refresh_exec()
  1336. return 1
  1337. def preset_select(self,nr):
  1338. print("SELECT PRESET")
  1339. sdata = PRESETS.val_presets[nr]
  1340. cmd = ""
  1341. for fix in sdata:
  1342. if fix == "CFG":
  1343. continue
  1344. for attr in sdata[fix]:
  1345. v2 = sdata[fix][attr]["VALUE"]
  1346. v2_fx = sdata[fix][attr]["FX"]
  1347. #print( self.data.elem_attr)
  1348. if fix in self.elem_attr:
  1349. elem = self.elem_attr[fix][attr]
  1350. FIXTURES.fixtures[fix]["ATTRIBUT"][attr]["ACTIVE"] = 1
  1351. elem["bg"] = "yellow"
  1352. def preset_go(self,nr,val=None,xfade=None,event=None):
  1353. t_start = time.time()
  1354. if xfade is None and FADE._is():
  1355. xfade = FADE.val()
  1356. print("GO PRESET FADE",nr,val)
  1357. rdata = PRESETS.get_raw_map(nr)
  1358. if not rdata:
  1359. return 0
  1360. print("???????")
  1361. cfg = PRESETS.get_cfg(nr)
  1362. print("''''''''")
  1363. #virtcmd = FIXTURES.get_virtual(rdata)
  1364. if not cfg:
  1365. cprint("NO CFG",cfg,nr)
  1366. return 0
  1367. xFLASH = 0
  1368. value=None
  1369. cprint("preset_go",nr,cfg)
  1370. if modes.val("SELECT") or ( "BUTTON" in cfg and cfg["BUTTON"] == "SEL") and val: #FLASH
  1371. self.preset_select(nr)
  1372. elif modes.val("FLASH") or ( "BUTTON" in cfg and cfg["BUTTON"] == "FL"): #FLASH
  1373. xFLASH = 1
  1374. xfade = 0
  1375. if type(val) is not None and val == 0 :
  1376. value = "off"
  1377. if event:
  1378. if str(event.type) == "ButtonRelease" or event.type == '5' :
  1379. # 4 fix vor ThinkPad / Debian 11
  1380. if xFLASH:
  1381. value = "off"
  1382. cprint("preset_go() FLUSH",value,color="red")
  1383. fcmd = FIXTURES.update_raw(rdata,update=0)
  1384. self._preset_go(rdata,cfg,fcmd,value,xfade=xfade,xFLASH=xFLASH)
  1385. elif not val:
  1386. cprint("preset_go() STOP",value,color="red")
  1387. elif modes.val("GO") or ( "BUTTON" in cfg and cfg["BUTTON"] in ["go","GO"]):
  1388. fcmd = FIXTURES.update_raw(rdata)
  1389. self._preset_go(rdata,cfg,fcmd,value,xfade=xfade,xFLASH=xFLASH)
  1390. if not (modes.val("FLASH") or ( "BUTTON" in cfg and cfg["BUTTON"] == "FL")): #FLASH
  1391. self.refresh_exec()
  1392. self.refresh_fix()
  1393. cprint("preset_go",time.time()-t_start)
  1394. def _preset_go(self,rdata,cfg,fcmd,value=None,xfade=None,event=None,xFLASH=0):
  1395. if xfade is None and FADE._is():
  1396. xfade = FADE.val()
  1397. cprint("PRESETS._preset_go()",len(rdata))
  1398. vvcmd,jvvcmd = update_raw_dmx( rdata ,value,[],xfade=xfade )
  1399. fxcmd,jfxcmd = update_raw_dmx( rdata ,value,[],xfade=xfade,fx=1)
  1400. cmd = []
  1401. for vcmd,d in [[jvvcmd,"d"],[jfxcmd,"fx"]]:
  1402. if xFLASH:
  1403. d+="f"
  1404. for i,v in enumerate(fcmd):
  1405. if xFLASH:
  1406. vcmd[i]["FLASH"] = 1
  1407. DMX = fcmd[i]["DMX"]
  1408. if "VALUE" in vcmd[i] and type(vcmd[i]["VALUE"]) is float:
  1409. vcmd[i]["VALUE"] = round(vcmd[i]["VALUE"],3)
  1410. if value is not None:
  1411. vcmd[i]["VALUE"] = value
  1412. if value == "off":
  1413. if "FX2" in vcmd:
  1414. vcmd[i]["FX2"]["TYPE"] = value
  1415. if DMX and vcmd[i]:
  1416. vcmd[i]["DMX"] = DMX
  1417. if "VIRTUAL" in fcmd[i]:
  1418. for a in fcmd[i]["VIRTUAL"]:
  1419. DMX = fcmd[i]["VIRTUAL"][a]
  1420. if DMX and vcmd[i]:
  1421. vcmd[i]["DMX"] = DMX
  1422. #if vcmd[i]["VALUE"] is not None or ("FX2" in vcmd[i] and vcmd[i]["FX2"]):
  1423. # cprint("jvcmd",vcmd[i])
  1424. # cmd.append(vcmd[i])
  1425. #elif vcmd[i]["VALUE"] is not None or ("FX" in vcmd[i] and vcmd[i]["FX"]):
  1426. # cprint("jvcmd",vcmd[i])
  1427. # cmd.append(vcmd[i])
  1428. #cprint("jvcmd",vcmd[i])
  1429. cmd.append(vcmd[i])
  1430. if cmd and not modes.val("BLIND"):
  1431. jclient_send(cmd)
  1432. def draw_sub_dim(self,fix,data,c=0,r=0,frame=None):
  1433. i=0
  1434. if frame is None:
  1435. frame = tk.Frame(root,bg="black")
  1436. frame.pack(fill=tk.X, side=tk.TOP)
  1437. if fix not in self.elem_attr:
  1438. self.elem_attr[fix] = {}
  1439. for attr in data["ATTRIBUT"]:
  1440. if attr not in self.all_attr:
  1441. self.all_attr.append(attr)
  1442. if attr not in self.elem_attr[fix]:
  1443. self.elem_attr[fix][attr] = []
  1444. if attr.endswith("-FINE"):
  1445. continue
  1446. v= data["ATTRIBUT"][attr]["VALUE"]
  1447. b = tk.Button(frame,bg="lightblue", text=""+str(fix)+" "+data["NAME"],width=4)
  1448. b.bind("<Button>",Xevent(fix=fix,mode="D-SELECT",elem=b).cb)
  1449. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1450. c+=1
  1451. b = tk.Button(frame,bg="grey", text=str(attr)+' '+str(round(v,2)),width=6)
  1452. self.elem_attr[fix][attr] = b
  1453. b.bind("<Button>",Xevent(fix=fix,elem=b,attr=attr,mode="ENCODER",data=data).cb)
  1454. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1455. c+=1
  1456. if c >=12:
  1457. c=0
  1458. r+=1
  1459. return c,r
  1460. def draw_patch(self,yframe):
  1461. xframe = tk.Frame(yframe,bg="black")
  1462. xframe.pack()
  1463. def yview(event):
  1464. print("yevent",event)
  1465. yyy=20.1
  1466. xframe.yview_moveto(yyy)
  1467. i=0
  1468. c=0
  1469. r=0
  1470. for fix in FIXTURES.fixtures:
  1471. i+=1
  1472. data = FIXTURES.fixtures[fix]
  1473. b = tk.Button(xframe,bg="lightblue", text="FIX:"+str(fix)+" "+data["NAME"],width=20)
  1474. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  1475. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1476. c+=1
  1477. #r+=1
  1478. if fix not in self.elem_attr:
  1479. self.elem_attr[fix] = {}
  1480. patch = ["DMX","UNIVERS"]
  1481. for k in patch:
  1482. v=data[k]
  1483. b = tk.Button(xframe,bg="grey", text=str(k)+' '+str(v),width=8)
  1484. #self.elem_attr[fix][attr] = b
  1485. #b.bind("<Button>",Xevent(fix=fix,elem=b,attr=attr,data=data).cb)
  1486. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1487. c+=1
  1488. if c >=8:
  1489. c=1
  1490. r+=1
  1491. for attr in data["ATTRIBUT"]:
  1492. if attr not in self.all_attr:
  1493. self.all_attr.append(attr)
  1494. if attr not in self.elem_attr[fix]:
  1495. self.elem_attr[fix][attr] = []
  1496. if attr.endswith("-FINE"):
  1497. continue
  1498. v= data["ATTRIBUT"][attr]["VALUE"]
  1499. b = tk.Button(xframe,bg="grey", text=str(attr)+' '+str(round(v,2)),width=8)
  1500. #self.elem_attr[fix][attr] = b
  1501. #b.bind("<Button>",Xevent(fix=fix,elem=b,attr=attr,data=data).cb)
  1502. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1503. c+=1
  1504. if c >=8:
  1505. c=1
  1506. r+=1
  1507. c=0
  1508. r+=1
  1509. def draw_fix(self,xframe,yframe=None):
  1510. r=0
  1511. c=0
  1512. frame_dim=xframe
  1513. if yframe:
  1514. frame_dim=yframe
  1515. frame_fix=xframe
  1516. root = frame_dim
  1517. dim_frame = tk.Frame(root,bg="black")
  1518. dim_frame.pack(fill=tk.X, side=tk.TOP)
  1519. root = frame_fix
  1520. fix_frame = tk.Frame(root,bg="black")
  1521. fix_frame.pack(fill=tk.X, side=tk.TOP)
  1522. i=0
  1523. c=0
  1524. r=0
  1525. dim_end=0
  1526. for fix in FIXTURES.fixtures:
  1527. i+=1
  1528. data = FIXTURES.fixtures[fix]
  1529. #print("draw_fix", fix ,data )
  1530. if(len(data["ATTRIBUT"].keys()) <= 1):
  1531. c,r=self.draw_sub_dim(fix,data,c=c,r=r,frame=dim_frame)
  1532. else:
  1533. if not dim_end:
  1534. dim_end=1
  1535. c=0
  1536. r=0
  1537. #self._draw_fix(fix,data,root=fix_frame)
  1538. frame = fix_frame
  1539. b = tk.Button(frame,bg="lightblue", text="FIX:"+str(fix)+" "+data["NAME"],width=20)
  1540. b.bind("<Button>",Xevent(fix=fix,mode="SELECT",elem=b).cb)
  1541. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1542. c+=1
  1543. #r+=1
  1544. if fix not in self.elem_attr:
  1545. self.elem_attr[fix] = {}
  1546. for attr in data["ATTRIBUT"]:
  1547. if attr.endswith("-FINE"):
  1548. continue
  1549. if attr not in self.all_attr:
  1550. self.all_attr.append(attr)
  1551. if attr not in self.elem_attr[fix]:
  1552. self.elem_attr[fix][attr] = ["line1348",fix,attr]
  1553. v= data["ATTRIBUT"][attr]["VALUE"]
  1554. b = tk.Button(frame,bg="grey", text=str(attr)+' '+str(round(v,2)),width=8)
  1555. self.elem_attr[fix][attr] = b
  1556. b.bind("<Button>",Xevent(fix=fix,elem=b,attr=attr,mode="ENCODER",data=data).cb)
  1557. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1558. c+=1
  1559. if c >=8:
  1560. c=1
  1561. r+=1
  1562. c=0
  1563. r+=1
  1564. def draw_enc(self,xframe):
  1565. root2 = xframe
  1566. i=0
  1567. c=0
  1568. r=0
  1569. frame = tk.Frame(root2,bg="black")
  1570. frame.pack( side=tk.TOP,expand=1,fill="both")
  1571. b = tk.Button(frame,bg="lightblue", text="ENCODER",width=6)
  1572. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1573. c+=1
  1574. for attr in self.all_attr:
  1575. if attr.endswith("-FINE"):
  1576. continue
  1577. v=0
  1578. b = tk.Button(frame,bg="orange", text=str(attr)+'',width=6)
  1579. b.bind("<Button>",Xevent(fix=0,elem=b,attr=attr,data=self,mode="ENCODER").cb)
  1580. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1581. c+=1
  1582. if c >=8:
  1583. c=0
  1584. r+=1
  1585. def draw_fx(self,xframe):
  1586. frame_fx=xframe
  1587. i=0
  1588. c=0
  1589. r=0
  1590. frame = tk.Frame(frame_fx,bg="black")
  1591. frame.pack(fill=tk.X, side=tk.TOP)
  1592. b = tk.Button(frame,bg="lightblue", text="FX.",width=6)
  1593. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  1594. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1595. c+=1
  1596. for comm in self.fx_commands:
  1597. if comm == "\n":
  1598. c=0
  1599. r+=1
  1600. continue
  1601. v=0
  1602. b = tk.Button(frame,bg="lightgrey", text=str(comm),width=6,height=2)
  1603. if comm not in self.elem_fx_commands:
  1604. comm = comm.replace("\n","")
  1605. self.elem_fx_commands[comm] = b
  1606. self.val_fx_commands[comm] = 0
  1607. b.bind("<Button>",Xevent(fix=0,elem=b,attr=comm,data=self,mode="COMMAND").cb)
  1608. if comm == "BLIND":
  1609. b["bg"] = "grey"
  1610. elif comm == "CLEAR":
  1611. b["bg"] = "grey"
  1612. elif comm == "STONY_FX":
  1613. b["bg"] = "grey"
  1614. elif comm == "FADE":
  1615. b["bg"] = "green"
  1616. elif comm == "FX OFF":
  1617. b["bg"] = "magenta"
  1618. elif comm[:3] == "FX:":
  1619. b["text"] = comm #"BS:{}".format(fx_prm["BASE"])
  1620. b["bg"] = "#ffbf00"
  1621. elif comm == "MO:on":
  1622. b["text"] = comm #"BS:{}".format(fx_prm["BASE"])
  1623. b["bg"] = "lightgreen"
  1624. elif comm == "MO:on":
  1625. b["text"] = comm #"BS:{}".format(fx_prm["BASE"])
  1626. b["bg"] = "lightgreen"
  1627. elif comm == "SZ:":
  1628. b["text"] = "SZ:\n{:0.0f}".format(fx_prm["SIZE"])
  1629. b["bg"] = "lightgreen"
  1630. elif comm == "SP:":
  1631. b["text"] = "SP:\n{:0.0f}".format(fx_prm["SPEED"])
  1632. b["bg"] = "lightgreen"
  1633. elif comm == "ST:":
  1634. b["bg"] = "lightgreen"
  1635. b["text"] = "ST:\n{:0.0f}".format(fx_prm["START"])
  1636. elif comm == "OF:":
  1637. b["bg"] = "lightgreen"
  1638. b["text"] = "OF:\n{:0.0f}".format(fx_prm["OFFSET"])
  1639. elif comm == "BS:-":
  1640. b["bg"] = "lightgreen"
  1641. b["text"] = "BS:\n{}".format(fx_prm["BASE"])
  1642. elif comm[0] == "M":
  1643. b["text"] = comm #"BS:{}".format(fx_prm["BASE"])
  1644. b["bg"] = "lightgrey"
  1645. if comm:
  1646. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1647. c+=1
  1648. if c >=6:
  1649. c=0
  1650. r+=1
  1651. def draw_command(self,xframe):
  1652. frame_cmd=xframe
  1653. i=0
  1654. c=0
  1655. r=0
  1656. frame = tk.Frame(frame_cmd,bg="black")
  1657. frame.pack(fill=tk.X, side=tk.TOP)
  1658. b = tk.Button(frame,bg="lightblue", text="COMM.",width=6)
  1659. #b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  1660. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1661. #r+=1
  1662. c+=1
  1663. for comm in self.commands:
  1664. if comm == "\n":
  1665. c=0
  1666. r+=1
  1667. continue
  1668. v=0
  1669. b = tk.Button(frame,bg="lightgrey", text=str(comm),width=6,height=2)
  1670. if comm not in self.elem_commands:
  1671. self.elem_commands[comm] = b
  1672. self.val_commands[comm] = 0
  1673. b.bind("<Button>",Xevent(fix=0,elem=b,attr=comm,data=self,mode="COMMAND").cb)
  1674. if comm == "BLIND":
  1675. b["bg"] = "grey"
  1676. if comm == "CLEAR":
  1677. b["bg"] = "grey"
  1678. if comm == "STONY_FX":
  1679. b["bg"] = "grey"
  1680. if comm == "FADE":
  1681. b["bg"] = "green"
  1682. if comm == "FX OFF":
  1683. b["bg"] = "magenta"
  1684. if comm == "SZ:":
  1685. b["text"] = "SZ:{:0.0f}".format(fx_prm["SIZE"])
  1686. if comm == "SP:":
  1687. b["text"] = "SP:{:0.0f}".format(fx_prm["SPEED"])
  1688. if comm == "FADE":
  1689. b["text"] = "FADE:{:0.02f}".format(FADE.val())
  1690. if comm == "ST:":
  1691. b["text"] = "ST:{:0.0f}".format(fx_prm["START"])
  1692. if comm == "OF:":
  1693. b["text"] = "OF:{:0.0f}".format(fx_prm["OFFSET"])
  1694. if comm == "BS:":
  1695. b["text"] = "BS:{}".format(fx_prm["BASE"])
  1696. if comm:
  1697. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1698. c+=1
  1699. if c >=5:
  1700. c=0
  1701. r+=1
  1702. def draw_preset(self,xframe):
  1703. i=0
  1704. c=0
  1705. r=0
  1706. root = xframe
  1707. frame = tk.Frame(root,bg="black")
  1708. frame.pack(fill=tk.X, side=tk.TOP)
  1709. i=0
  1710. for k in PRESETS.val_presets:
  1711. if i%(8*8)==0 or i ==0:
  1712. c=0
  1713. b = tk.Label(frame,bg="black", text="X" )
  1714. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1715. r+=1
  1716. c=0
  1717. b = tk.Button(frame,bg="lightblue", text="EXEC " )
  1718. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1719. c+=1
  1720. b = tk.Button(frame,bg="lightblue", text="PAGE " + str(int(i/(8*8))+1) )
  1721. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1722. c+=1
  1723. b = tk.Button(frame,bg="lightblue", text="<NAME>" )
  1724. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1725. r+=1
  1726. c=0
  1727. i+=1
  1728. v=0
  1729. label = ""
  1730. #if k in PRESETS.label_presets:
  1731. # label = PRESETS.label_presets[k]
  1732. # #print([label])
  1733. sdata=PRESETS.val_presets[k]
  1734. BTN="go"
  1735. if "CFG" in sdata:#["BUTTON"] = "GO"
  1736. if "BUTTON" in sdata["CFG"]:
  1737. BTN = sdata["CFG"]["BUTTON"]
  1738. txt=str(k+1)+":"+str(BTN)+":"+str(len(sdata)-1)+"\n"+label
  1739. b = tk.Button(frame,bg="grey", text=txt,width=8,height=2)
  1740. b.bind("<Button>",Xevent(fix=0,elem=b,attr=k,data=self,mode="PRESET").cb)
  1741. b.bind("<ButtonRelease>",Xevent(fix=0,elem=b,attr=k,data=self,mode="PRESET").cb)
  1742. if k not in self.elem_presets:
  1743. self.elem_presets[k] = b
  1744. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1745. c+=1
  1746. if c >=8:
  1747. c=0
  1748. r+=1
  1749. self.refresh_exec()
  1750. def draw_input(self):
  1751. i=0
  1752. c=0
  1753. r=0
  1754. frame = tk.Frame(root2,bg="black")
  1755. frame.pack(fill=tk.X, side=tk.TOP)
  1756. b = tk.Label(frame,bg="black", text="------------------------ ---------------------------------------")
  1757. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1758. r=0
  1759. frame = tk.Frame(root2,bg="black")
  1760. frame.pack(fill=tk.X, side=tk.TOP)
  1761. b = tk.Label(frame, text="send:")
  1762. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1763. c+=1
  1764. b = tk.Entry(frame,bg="grey", text="",width=50)
  1765. self.entry = b
  1766. b.bind("<Button>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT").cb)
  1767. b.bind("<Key>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT").cb)
  1768. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1769. b.insert("end","d0:127,fx241:sinus:50:50:10,fx243:cosinus:50:50:10,d201:127,fx201:sinus:50:300:10")
  1770. r+=1
  1771. b = tk.Entry(frame,bg="grey", text="",width=20)
  1772. self.entry2 = b
  1773. b.bind("<Button>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT2").cb)
  1774. b.bind("<Key>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT2").cb)
  1775. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1776. b.insert("end","d1:0:4")
  1777. r+=1
  1778. b = tk.Entry(frame,bg="grey", text="",width=20)
  1779. self.entry3 = b
  1780. b.bind("<Button>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT3").cb)
  1781. #b.bind("<B1-Motion>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT3").cb)
  1782. b.bind("<Key>",Xevent(fix=0,elem=b,attr="INPUT",data=self,mode="INPUT3").cb)
  1783. b.grid(row=r, column=c, sticky=tk.W+tk.E)
  1784. b.insert("end","fx:alloff:::")
  1785. def draw_colorpicker(self,xframe):
  1786. import lib.colorpicker as colp
  1787. class _CB():
  1788. def __init__(self):
  1789. self.old_color = (0,0,0)
  1790. def cb(self,event,data):
  1791. cprint("colorpicker CB")
  1792. if "color" in data and self.old_color != data["color"] or event.num==2:
  1793. self.old_color = data["color"]
  1794. else:
  1795. return 0
  1796. color = data["color"]
  1797. print("e",event,data)
  1798. print("e",dir(event))#.keys())
  1799. try:
  1800. print("e.state",event.state)
  1801. except:pass
  1802. set_fade = FADE.val() #fade
  1803. if "color" in data and (event.num == 1 or event.num == 3 or event.num==2 or event.state in [256,1024]):
  1804. cr=None
  1805. cg=None
  1806. cb=None
  1807. if event.num == 1:
  1808. set_fade=FADE.val() #fade
  1809. cr = color[0]
  1810. cg = color[1]
  1811. cb = color[2]
  1812. elif event.num == 3:
  1813. cr = color[0]
  1814. cg = color[1]
  1815. cb = color[2]
  1816. set_fade=0
  1817. elif event.num == 2:
  1818. cr= "click"
  1819. cg= "click"
  1820. cb= "click"
  1821. elif event.state == 256:
  1822. cr = color[0]
  1823. cg = color[1]
  1824. cb = color[2]
  1825. set_fade=0
  1826. else:
  1827. set_fade=0
  1828. if cr is not None:
  1829. FIXTURES.encoder(fix=0,attr="RED",xval=cr,xfade=set_fade)
  1830. if cg is not None:
  1831. FIXTURES.encoder(fix=0,attr="GREEN",xval=cg,xfade=set_fade)
  1832. if cb is not None:
  1833. FIXTURES.encoder(fix=0,attr="BLUE",xval=cb,xfade=set_fade)
  1834. master.refresh_fix()
  1835. print("PICK COLOR:",data["color"])
  1836. _cb=_CB()
  1837. colp.colorpicker(xframe,width=600,height=100, xcb=_cb.cb)
  1838. return 0
  1839. canvas=tk.Canvas(xframe,width=600,height=100)
  1840. canvas["bg"] = "yellow" #"green"
  1841. canvas.pack()
  1842. # RGB
  1843. x=0
  1844. y=0
  1845. j=0
  1846. d = 20
  1847. for i in range(0,d+1):
  1848. fi = int(i*255/d)
  1849. f = 255-fi
  1850. if i > d/2:
  1851. pass#break
  1852. color = '#%02x%02x%02x' % (f, fi, fi)
  1853. print( "farbe", i*10, j, f,fi,fi,color)
  1854. r = canvas.create_rectangle(x, y, x+20, y+20, fill=color)
  1855. x+=20
  1856. def render(self):
  1857. #Xroot.bind("<Key>",Xevent(fix=0,elem=None,attr="ROOT",data=self,mode="ROOT").cb)
  1858. self.draw_input()
  1859. def ScrollFrame(root,width=50,height=100,bd=1):
  1860. #print("ScrollFrame init",width,height)
  1861. aframe=tk.Frame(root,relief=tk.GROOVE)#,width=width,height=height,bd=bd)
  1862. #aframe.place(x=0,y=0)
  1863. aframe.pack(side="left",fill="both",expand=1) #x=0,y=0)
  1864. canvas=tk.Canvas(aframe,width=width-24,height=height)
  1865. canvas["bg"] = "black" #"green"
  1866. bframe=tk.Frame(canvas)#,width=width,height=height)
  1867. bframe["bg"] = "blue"
  1868. scrollbar=tk.Scrollbar(aframe,orient="vertical",command=canvas.yview,width=20)
  1869. canvas.configure(yscrollcommand=scrollbar.set)
  1870. scrollbar.pack(side="right",fill="y")
  1871. canvas.pack(side="left",expand=1,fill="both")
  1872. canvas.create_window((0,0),window=bframe,anchor='nw')
  1873. bframe.bind("<Configure>",scroll(canvas).config)
  1874. canvas.bind("<Button>",Event("XXX").event)
  1875. canvas.bind("<Key>",Event("XXX").event)
  1876. canvas.bind("<KeyRelease>",Event("XXX").event)
  1877. return bframe
  1878. #frame = ScrollFrame(root)
  1879. class GUIHandler():
  1880. def __init__(self):
  1881. pass
  1882. def update(self,fix,attr,args={}):
  1883. print("GUIHandler.update()",fix,attr,args)
  1884. for i,k in enumerate(args):
  1885. v = args[k]
  1886. #print("GUI-H", i,k,v)
  1887. class Fixtures(Base):
  1888. def __init__(self):
  1889. super().__init__()
  1890. #self.load()
  1891. self.fixtures = OrderedDict()
  1892. self.gui = GUIHandler()
  1893. def load_patch(self):
  1894. filename="patch"
  1895. d,l = self._load(filename)
  1896. self.fixtures = OrderedDict()
  1897. for i in l:
  1898. sdata = d[i]
  1899. for attr in sdata["ATTRIBUT"]:
  1900. sdata["ATTRIBUT"][attr]["ACTIVE"] = 0
  1901. #print("load",filename,sdata)
  1902. #if "CFG" not in sdata:
  1903. # sdata["CFG"] = OrderedDict()
  1904. self.fixtures[str(i)] = sdata
  1905. #PRESETS.label_presets = l
  1906. def backup_patch(self):
  1907. filename = "patch"
  1908. data = self.fixtures
  1909. labels = {}
  1910. for k in data:
  1911. labels[k] = k
  1912. self._backup(filename,data,labels)
  1913. def fx_off(self,fix=None):
  1914. if not fix or fix == "all":
  1915. #self.data.elem_fx_commands[self.attr]["bg"] = "magenta"
  1916. for fix in self.fixtures:
  1917. data = self.fixtures[fix]
  1918. for attr in data["ATTRIBUT"]:
  1919. data["ATTRIBUT"][attr]["FX"] = ""
  1920. data["ATTRIBUT"][attr]["FX2"] = OrderedDict()
  1921. def get_attr(self,fix,attr):
  1922. if fix in self.fixtures:
  1923. data = self.fixtures[fix]
  1924. if "ATTRIBUT" in data:
  1925. if attr in data["ATTRIBUT"]:
  1926. return data["ATTRIBUT"][attr]
  1927. def get_dmx(self,fix,attr):
  1928. #cprint("get_dmx",[fix,attr])
  1929. if fix in self.fixtures:
  1930. data = self.fixtures[fix]
  1931. if "DMX" in data:
  1932. DMX = int(data["DMX"])
  1933. else:
  1934. return -1
  1935. if "UNIVERS" in data:
  1936. DMX += (int(data["UNIVERS"])*512)
  1937. adata = self.get_attr(fix,attr)
  1938. #-hier ende 8.2.22
  1939. #cprint("adata",adata,DMX)
  1940. if adata:
  1941. if "NR" in adata:
  1942. NR = adata["NR"]
  1943. if NR:
  1944. DMX+=NR-1
  1945. else:
  1946. return -2
  1947. return DMX
  1948. return -4
  1949. return -3
  1950. def update_raw(self,rdata,update=1):
  1951. cprint("update_raw",len(rdata))
  1952. cmd = []
  1953. for i,d in enumerate(rdata):
  1954. xcmd = {"DMX":""}
  1955. #print("fix:",i,d)
  1956. fix = d["FIX"]
  1957. attr = d["ATTR"]
  1958. v2 = d["VALUE"]
  1959. v2_fx = d["FX"]
  1960. if fix not in self.fixtures:
  1961. continue
  1962. sdata = self.fixtures[fix] #shortcat
  1963. ATTR = sdata["ATTRIBUT"]
  1964. sDMX = 0
  1965. if sdata["DMX"] > 0:
  1966. #print( sdata)
  1967. sDMX = (sdata["UNIVERS"]*512)+sdata["DMX"]
  1968. #sDMX =sdata["DMX"]
  1969. #else:
  1970. # continue
  1971. if attr not in ATTR:
  1972. continue
  1973. #DMX = FIXTURES.get_dmx(fix)
  1974. if ATTR[attr]["NR"] >= 0:
  1975. DMX = sDMX+ATTR[attr]["NR"]-1
  1976. xcmd["DMX"] = str(DMX)
  1977. else:
  1978. if attr == "DIM" and ATTR[attr]["NR"] < 0:
  1979. xcmd["VIRTUAL"] = {}
  1980. for a in ATTR:
  1981. if ATTR[a]["MASTER"]:
  1982. xcmd["VIRTUAL"][a] = sDMX+ATTR[a]["NR"]-1
  1983. #print( "VIRTUAL",xcmd)
  1984. cmd.append(xcmd)
  1985. v=ATTR[attr]["VALUE"]
  1986. if v2 is not None and update:
  1987. ATTR[attr]["VALUE"] = v2
  1988. #self.data.elem_attr[fix][attr]["text"] = str(attr)+' '+str(round(v,2))
  1989. text = str(attr)+' '+str(round(v,2))
  1990. #self.gui.update(fix,attr,args={"text":text})
  1991. #print("END 5454 _=_=_=_=_==_")
  1992. #cprint("update_raw",cmd,color="red")
  1993. return cmd
  1994. def encoder(self,fix,attr,xval="",xfade=0):
  1995. #cprint("FIXTURES.encoder",fix,attr,xval,xfade,color="yellow")
  1996. if attr == "CLEAR":
  1997. self.clear()
  1998. return 0
  1999. if fix not in self.fixtures:
  2000. jdata=[{"MODE":"---"}]
  2001. ii =0
  2002. jclient_send(jdata)
  2003. for fix in self.fixtures:
  2004. ii+=1
  2005. #cprint(fix,attr,xval)
  2006. data = self.fixtures[fix]
  2007. if attr in data["ATTRIBUT"]:
  2008. if xval == "click":
  2009. self.select(fix,attr,mode="on")
  2010. elif data["ATTRIBUT"][attr]["ACTIVE"]:
  2011. if fix: # prevent endless recursion
  2012. self.encoder(fix,attr,xval,xfade)
  2013. jdata=[{"MODE":ii}]
  2014. jclient_send(jdata)
  2015. return 0
  2016. data = self.fixtures[fix]
  2017. if xval == "click":
  2018. #cprint(data)
  2019. return self.select(fix,attr,mode="toggle")
  2020. v2=data["ATTRIBUT"][attr]["VALUE"]
  2021. change=0
  2022. increment = 4.11
  2023. jdata = {"MODE":"ENC"}
  2024. if xval == "+":
  2025. v2+= increment
  2026. jdata["INC"] = increment
  2027. change=1
  2028. elif xval == "-":
  2029. jdata["INC"] = increment*-1
  2030. v2-= increment
  2031. change=1
  2032. elif type(xval) is int or type(xval) is float:
  2033. v2 = xval
  2034. change=1
  2035. if v2 < 0:
  2036. v2=0
  2037. elif v2 > 256:
  2038. v2=256
  2039. jdata["VALUE"] = round(v2,4)
  2040. jdata["FIX"] = fix
  2041. jdata["ATTR"] = attr
  2042. jdata["DMX"] = FIXTURES.get_dmx(fix,attr)
  2043. out = {}
  2044. if change:
  2045. data["ATTRIBUT"][attr]["ACTIVE"] = 1
  2046. data["ATTRIBUT"][attr]["VALUE"] = round(v2,4)
  2047. jdata["FADE"] = 0
  2048. if xfade:
  2049. jdata["FADE"] = xfade
  2050. if not modes.val("BLIND"):
  2051. jdata = [jdata]
  2052. print(jdata)
  2053. jclient_send(jdata)
  2054. return v2
  2055. def get_active(self):
  2056. cprint("get_active",self,"get_active")
  2057. CFG = OrderedDict()
  2058. sdata = OrderedDict()
  2059. sdata["CFG"] = CFG # OrderedDict()
  2060. sdata["CFG"]["FADE"] = FADE.val()
  2061. sdata["CFG"]["DEALY"] = 0
  2062. #sdata["CFG"]["BUTTON"] = "GO"
  2063. for fix in self.fixtures:
  2064. data = self.fixtures[fix]
  2065. for attr in data["ATTRIBUT"]:
  2066. if data["ATTRIBUT"][attr]["ACTIVE"]:
  2067. if fix not in sdata:
  2068. sdata[fix] = {}
  2069. if attr not in sdata[fix]:
  2070. sdata[fix][attr] = OrderedDict()
  2071. if not modes.val("STONY_FX"):
  2072. sdata[fix][attr]["VALUE"] = data["ATTRIBUT"][attr]["VALUE"]
  2073. #sdata[fix][attr]["FADE"] = FADE.val() #fade
  2074. else:
  2075. sdata[fix][attr]["VALUE"] = None #data["ATTRIBUT"][attr]["VALUE"]
  2076. if "FX" not in data["ATTRIBUT"][attr]:
  2077. data["ATTRIBUT"][attr]["FX"] =""
  2078. if "FX2" not in data["ATTRIBUT"][attr]:
  2079. data["ATTRIBUT"][attr]["FX2"] ={}
  2080. sdata[fix][attr]["FX"] = data["ATTRIBUT"][attr]["FX"]
  2081. sdata[fix][attr]["FX2"] = data["ATTRIBUT"][attr]["FX2"]
  2082. return sdata
  2083. def select(self,fix=None,attr=None,mode="on"):
  2084. cprint("FIXTURES.select()",fix,attr,mode,color="yellow")
  2085. out = 0
  2086. if fix in self.fixtures:
  2087. data = self.fixtures[fix]
  2088. if attr in data["ATTRIBUT"]:
  2089. if mode == "on":
  2090. if not data["ATTRIBUT"][attr]["ACTIVE"]:
  2091. data["ATTRIBUT"][attr]["ACTIVE"] = 1
  2092. out = 1
  2093. elif mode == "off":
  2094. if data["ATTRIBUT"][attr]["ACTIVE"]:
  2095. data["ATTRIBUT"][attr]["ACTIVE"] = 0
  2096. out = 1
  2097. elif mode == "toggle":
  2098. if data["ATTRIBUT"][attr]["ACTIVE"]:
  2099. data["ATTRIBUT"][attr]["ACTIVE"] = 0
  2100. else:
  2101. data["ATTRIBUT"][attr]["ACTIVE"] = 1
  2102. out = 1
  2103. return out
  2104. def clear(self):
  2105. out = 0
  2106. for fix in self.fixtures:
  2107. data = self.fixtures[fix]
  2108. for attr in data["ATTRIBUT"]:
  2109. if attr.endswith("-FINE"):
  2110. continue
  2111. if data["ATTRIBUT"][attr]["ACTIVE"]:
  2112. out +=1
  2113. data["ATTRIBUT"][attr]["ACTIVE"] = 0
  2114. return out
  2115. class Presets(Base):
  2116. def __init__(self):
  2117. super().__init__()
  2118. #self.load()
  2119. self._last_copy = None
  2120. self._last_move = None
  2121. def load_presets(self):
  2122. filename="presets"
  2123. d,l = self._load(filename)
  2124. for i in d:
  2125. sdata = d[i]
  2126. if "CFG" not in sdata:
  2127. sdata["CFG"] = OrderedDict()
  2128. if "FADE" not in sdata["CFG"]:
  2129. sdata["CFG"]["FADE"] = 4
  2130. if "DELAY" not in sdata["CFG"]:
  2131. sdata["CFG"]["DELAY"] = 0
  2132. if "BUTTON" not in sdata["CFG"]:
  2133. sdata["CFG"]["BUTTON"] = "GO"
  2134. self.val_presets = d
  2135. self.label_presets = l
  2136. def check_cfg(self,nr=None):
  2137. cprint("PRESETS.check_cfg()",nr)
  2138. ok = 0
  2139. if nr is not None:
  2140. ok += self._check_cfg(nr)
  2141. else:
  2142. for nr in self.val_presets:
  2143. ok += self._check_cfg(nr)
  2144. return ok
  2145. def _check_cfg(self,nr):
  2146. #cprint("PRESETS._check_cfg()",nr)
  2147. ok=0
  2148. if nr in self.val_presets:
  2149. sdata = self.val_presets[nr]
  2150. if "CFG" not in sdata:
  2151. sdata["CFG"] = OrderedDict()
  2152. ok += 1
  2153. if "FADE" not in sdata["CFG"]:
  2154. sdata["CFG"]["FADE"] = 4
  2155. ok += 1
  2156. if "DELAY" not in sdata["CFG"]:
  2157. sdata["CFG"]["DELAY"] = 0
  2158. ok += 1
  2159. if "BUTTON" not in sdata["CFG"]:
  2160. sdata["CFG"]["BUTTON"] = "GO"
  2161. ok += 1
  2162. if ok:
  2163. cprint("REPAIR CFG's",nr,sdata["CFG"],color="red")
  2164. else:
  2165. cprint("nr not in data ",nr,color="red")
  2166. return ok
  2167. def backup_presets(self):
  2168. filename = "presets"
  2169. data = self.val_presets
  2170. labels = self.label_presets
  2171. self._backup(filename,data,labels)
  2172. def get_cfg(self,nr):
  2173. cprint("PRESETS.get_cfg()",nr)
  2174. self.check_cfg(nr)
  2175. if nr not in self.val_presets:
  2176. cprint("get_cfg",self,"error get_cfg no nr:",nr,color="red")
  2177. return {}
  2178. if "CFG" in self.val_presets[nr]:
  2179. return self.val_presets[nr]["CFG"]
  2180. def clean(self,nr):
  2181. if nr not in self.val_presets:
  2182. self.val_presets[nr] = OrderedDict()
  2183. #self.val_presets[nr]["VALUE"] = 0
  2184. #self.val_presets[nr]["FX"] = ""
  2185. sdata = self.val_presets[nr]
  2186. for fix in sdata:
  2187. #print("exec.clear()",nr,fix,sdata[fix])
  2188. for attr in sdata[fix]:
  2189. row = sdata[fix][attr]
  2190. if fix == "CFG":
  2191. continue
  2192. if "VALUE" not in row:
  2193. row["VALUE"] = None
  2194. if "FX" not in row:
  2195. row["FX"] = ""
  2196. if "FX2" not in row:
  2197. row["FX2"] = OrderedDict()
  2198. elif row["FX2"]:
  2199. for k in ["SIZE","SPEED","START","OFFSET"]:
  2200. row["FX2"][k] = int( row["FX2"][k] )
  2201. row["FX"] = ""
  2202. if "FX" in row and row["FX"] and not row["FX2"]: # rebuild old FX to Dict-FX2
  2203. #"off:0:0:0:16909:-:"
  2204. x = row["FX"].split(":")
  2205. print(x,len(x))
  2206. #'FX2': {'TYPE': 'sinus', 'SIZE': 200, 'SPEED': 30, 'START': 0, 'OFFSET': 2805, 'BASE': '-'}}
  2207. if len(x) >= 6:
  2208. row["FX2"]["TYPE"] = x[0]
  2209. row["FX2"]["SIZE"] = int(x[1])
  2210. row["FX2"]["SPEED"] = int(x[2])
  2211. row["FX2"]["START"] = int(x[3])
  2212. row["FX2"]["OFFSET"] = int(x[4])
  2213. row["FX2"]["BASE"] = x[5]
  2214. row["FXOLD"] = row["FX"]
  2215. row["FX"] = ""
  2216. #cprint("exec.clear()",nr,fix,row)
  2217. def get_raw_map(self,nr):
  2218. self.clean(nr)
  2219. print("get_raw_map",nr)
  2220. sdata = self.val_presets[nr]
  2221. cmd = ""
  2222. out = []
  2223. dmx=-1
  2224. for fix in sdata:
  2225. if fix == "CFG":
  2226. #print("CFG",nr,sdata[fix])
  2227. continue
  2228. for attr in sdata[fix]:
  2229. x = {}
  2230. #print("RAW",attr)
  2231. x["FIX"] = fix
  2232. x["ATTR"] = attr
  2233. x["VALUE"] = sdata[fix][attr]["VALUE"]
  2234. x["FX"] = sdata[fix][attr]["FX"]
  2235. x["FX2"] = sdata[fix][attr]["FX2"]
  2236. #x["DMX"] = sdata[fix][attr]["NR"]
  2237. out.append(x)
  2238. return out
  2239. def get_btn_txt(self,nr):
  2240. sdata=self.val_presets[nr]
  2241. BTN="go"
  2242. if "CFG" in sdata:
  2243. if "BUTTON" in sdata["CFG"]:
  2244. BTN = sdata["CFG"]["BUTTON"]
  2245. _label = self.label_presets[nr] # = label
  2246. txt=str(nr+1)+":"+str(BTN)+":"+str(len(sdata)-1)+"\n"+_label
  2247. print("get_btn_txt",nr,[txt])
  2248. return txt
  2249. def btn_cfg(self,nr,txt=None):
  2250. if nr not in self.val_presets:
  2251. return ""
  2252. if "CFG" not in self.val_presets[nr]:
  2253. self.val_presets[nr]["CFG"] = OrderedDict()
  2254. if "BUTTON" not in self.val_presets[nr]["CFG"]:
  2255. self.val_presets[nr]["CFG"]["BUTTON"] = ""
  2256. if type(txt) is str:
  2257. self.val_presets[nr]["CFG"]["BUTTON"] = txt
  2258. if self.val_presets[nr]["CFG"]["BUTTON"] is None:
  2259. self.val_presets[nr]["CFG"]["BUTTON"] = ""
  2260. print("EEE", self.val_presets[nr]["CFG"]["BUTTON"] )
  2261. return self.val_presets[nr]["CFG"]["BUTTON"]
  2262. def label(self,nr,txt=None):
  2263. if nr not in self.label_presets:
  2264. return ""
  2265. if type(txt) is str:
  2266. self.label_presets[nr] = txt
  2267. print("set label",nr,[txt])
  2268. print("??? ?? set label",nr,[txt])
  2269. return self.label_presets[nr]
  2270. def clear_move(self):
  2271. cprint("PRESETS.clear_move()",end=" ")
  2272. self.clear_copy()
  2273. def clear_copy(self):
  2274. cprint("PRESETS.clear_copy()",end=" ")
  2275. if self._last_copy is not None:
  2276. cprint("=OK=",color="red")
  2277. self._last_copy = None
  2278. else:
  2279. cprint("=NONE=",color="green")
  2280. def copy(self,nr,overwrite=1):
  2281. cprint("PRESETS._copy",nr,"last",self._last_copy)
  2282. if nr:
  2283. if self._last_copy is not None:
  2284. ok = self._copy(self._last_copy,nr,overwrite=overwrite)
  2285. return ok #ok
  2286. else:
  2287. self._last_copy = nr
  2288. cprint("PRESETS.copy START ",color="red")
  2289. return 0
  2290. return 1 # on error reset move
  2291. def _copy(self,nr_from,nr_to,overwrite=1):
  2292. cprint("PRESETS._copy",nr_from,"to",nr_to)
  2293. self.check_cfg(nr_from)
  2294. if self._last_copy is None:
  2295. cprint("PRESETS._copy last nr is None")
  2296. return 0
  2297. if nr_from in self.val_presets and nr_to in self.val_presets:
  2298. fdata = self.val_presets[nr_from]
  2299. tdata = self.val_presets[nr_to]
  2300. #cprint(fdata)
  2301. flabel = self.label_presets[nr_from]
  2302. tlabel = self.label_presets[nr_to]
  2303. self.val_presets[nr_to] = copy.deepcopy(fdata)
  2304. self.label_presets[nr_to] = flabel
  2305. if not overwrite: #default
  2306. cprint("overwrite",overwrite)
  2307. self.val_presets[nr_from] = copy.deepcopy(tdata)
  2308. self.label_presets[nr_from] = tlabel
  2309. #self.label_presets[nr_from] = "MOVE"
  2310. self.clear_copy()
  2311. cprint("PRESETS.copy OK",color="red")
  2312. return 1
  2313. def move(self,nr):
  2314. cprint("PRESETS.move",self._last_copy,"to",nr)
  2315. if nr:
  2316. last = self._last_copy
  2317. ok= self.copy(nr,overwrite=0)
  2318. if ok and last:
  2319. cprint("PRESETS.move OK",color="red")
  2320. #self.delete(last)
  2321. return ok #ok
  2322. return 0 # on error reset move
  2323. def delete(self,nr):
  2324. cprint("PRESETS.delete",nr)
  2325. ok=0
  2326. if nr in self.val_presets:
  2327. self.val_presets[nr] = OrderedDict()
  2328. self.label_presets[nr] = ""
  2329. ok = 1
  2330. self.check_cfg(nr)
  2331. return ok
  2332. def rec(self,nr,data,arg=""):
  2333. print("rec",self,"rec()",data,arg)
  2334. self.check_cfg(nr)
  2335. self.val_presets[nr] = data
  2336. return 1
  2337. class GUI_grid():
  2338. def __init__(self,root,data,title="tilte",width=800):
  2339. self.data = data
  2340. self.frame = tk.Frame(root,bg="black",width=width)
  2341. self.frame.pack(fill=tk.BOTH, side=tk.LEFT)
  2342. r=0
  2343. c=0
  2344. i=1
  2345. for row in data:
  2346. self.b = tk.Button(self.frame,bg="lightblue", text=row["text"],width=11,height=4)
  2347. #self.b.bind("<Button>",Xevent(fix=fix,elem=b).cb)
  2348. self.b.grid(row=r, column=c, sticky=tk.W+tk.E)#,anchor="w")
  2349. c+=1
  2350. if c % 8 == 0:
  2351. r+=1
  2352. c=0
  2353. i+=1
  2354. self.frame.pack()
  2355. class BEvent():
  2356. def __init__(self,data,cb):
  2357. self._data = data
  2358. self._cb = cb
  2359. def cb(self,event):
  2360. #print(self,event)
  2361. self._cb(event,self._data)
  2362. class GUI_menu():
  2363. def __init__(self,root,data,title="tilte",width=800):
  2364. global tk
  2365. self.data = data
  2366. self.frame = tk.Frame(root,bg="black",width=width)
  2367. self.frame.pack(fill=tk.BOTH, side=tk.LEFT)
  2368. r=0
  2369. c=0
  2370. i=1
  2371. self.b = tk.Label(self.frame,bg="lightblue", text="MAIN:MENU",width=10,height=1)
  2372. self.b.grid(row=r, column=c, sticky=tk.W+tk.E)#,anchor="w")
  2373. r+=1
  2374. for row in data:
  2375. #print(i)
  2376. #row = data[i]
  2377. self.b = tk.Button(self.frame,bg="lightblue", text=row["text"],width=10,height=3)
  2378. self.b.bind("<Button>",BEvent({"NR":i,"text":row["text"]},self.callback).cb)
  2379. self.b.grid(row=r, column=c, sticky=tk.W+tk.E)#,anchor="w")
  2380. r+=1
  2381. i+=1
  2382. self.frame.pack()
  2383. def callback(self,event,data={}):
  2384. print("callback543",self,event,data)
  2385. window_manager.top(data["text"])# = WindowManager()
  2386. lf_nr = 0
  2387. class GUIWindow():
  2388. def __init__(self,title="tilte",master=0,width=100,height=100,left=None,top=None):
  2389. global lf_nr
  2390. if master:
  2391. self.tk = tkinter.Tk()
  2392. defaultFont = tkinter.font.nametofont("TkDefaultFont")
  2393. print(defaultFont)
  2394. defaultFont.configure(family="FreeSans",
  2395. size=10,
  2396. weight="bold")
  2397. #self.tk.option_add("*Font", FontBold)
  2398. else:
  2399. self.tk = tkinter.Toplevel()
  2400. #print(title,self.tk.__doc__)
  2401. self.tk["bg"] = "black"
  2402. self.tk.bind("<Button>",self.callback)
  2403. self.tk.bind("<Key>",self.callback)
  2404. self.tk.bind("<KeyRelease>",self.callback)
  2405. self.tk.title(""+str(title)+" "+str(lf_nr)+":"+str(rnd_id))
  2406. lf_nr+=1
  2407. #self.tk.geometry("270x600+0+65")
  2408. geo ="{}x{}".format(width,height)
  2409. if left is not None:
  2410. geo += "+{}".format(left)
  2411. if top is not None:
  2412. geo += "+{}".format(top)
  2413. #self._event_clear = Xevent(fix=0,elem=None,attr="CLEAR",data=self,mode="ROOT").cb
  2414. self.tk.geometry(geo)
  2415. def title(self,title=None):
  2416. if title is None:
  2417. return self.tk.title()
  2418. else:
  2419. return self.tk.title(title)
  2420. def show(self):
  2421. pass
  2422. def mainloop(self):
  2423. try:
  2424. self.tk.mainloop()
  2425. finally:
  2426. self.tk.quit()
  2427. def callback(self,event,data={}):#value=255):
  2428. print()
  2429. print()
  2430. cprint("<GUI>",event,color="yellow")
  2431. cprint("<GUI>",event.state,data,[event.type],color="yellow")
  2432. value = 255
  2433. if "Release" in str(event.type) or str(event.type) == '5' or str(event.type) == '3':
  2434. value = 0
  2435. if "keysym" in dir(event):
  2436. if "Escape" == event.keysym:
  2437. FIXTURES.clear()
  2438. modes.val("ESC",1)
  2439. master.refresh_fix()
  2440. elif event.keysym in "ebfclrms" and value:
  2441. if "e" == event.keysym:
  2442. modes.val("EDIT",1)
  2443. elif "b" == event.keysym:
  2444. modes.val("BLIND",1)
  2445. elif "f" == event.keysym:
  2446. modes.val("FLASH",1)
  2447. elif "c" == event.keysym:
  2448. modes.val("CFG-BTN",1)
  2449. elif "l" == event.keysym:
  2450. modes.val("LABEL",1)
  2451. elif "r" == event.keysym:
  2452. modes.val("REC",1)
  2453. elif "m" == event.keysym:
  2454. x=modes.val("MOVE",1)
  2455. if not x:
  2456. PRESETS.clear_move()
  2457. elif "s" == event.keysym:
  2458. modes.val("SELECT",1)
  2459. elif event.keysym in ["1","2","3","4","5","6","7","8","9","0"]:
  2460. nr = int( event.keysym)
  2461. if nr == 0:
  2462. nr =10
  2463. cprint("F-KEY",value,nr)
  2464. xfade = 0
  2465. if FADE._is():
  2466. xfade = 0
  2467. master.preset_go(128-1+nr,xfade=xfade,val=value)
  2468. elif event.keysym in ["F1","F2","F3","F4","F5","F6","F7","F8","F9","F10","F11","F12"]:
  2469. nr = int( event.keysym[1])-1
  2470. cprint("F-KEY",value,nr)
  2471. xfade = 0
  2472. if FADE._is():
  2473. xfade = 0
  2474. master.preset_go(65-1+nr,xfade=xfade,val=value)
  2475. elif "End" == event.keysym:
  2476. FIXTURES.fx_off("all")
  2477. CONSOLE.fx_off("all")
  2478. CONSOLE.flash_off("all")
  2479. elif "Delete" == event.keysym:
  2480. #PRESETS.delete(nr)
  2481. if value:
  2482. modes.val("DEL",1)
  2483. class WindowManager():
  2484. def __init__(self):
  2485. self.windows = {}
  2486. self.nr= 0
  2487. self.first=""
  2488. def new(self,w,name=""):
  2489. if not self.first:
  2490. if name:
  2491. self.first = name
  2492. else:
  2493. self.first = str(self.nr)
  2494. w.tk.attributes('-topmost',True)
  2495. if name:
  2496. self.windows[str(name)] = w
  2497. else:
  2498. self.windows[str(self.nr)] = w
  2499. self.nr+=1
  2500. #w.show()
  2501. def mainloop(self):
  2502. self.windows[self.first].mainloop()
  2503. def top(self,name):
  2504. name = str(name)
  2505. if name in self.windows:
  2506. self.windows[name].tk.attributes('-topmost',True)
  2507. self.windows[name].tk.attributes('-topmost',False)
  2508. else:
  2509. print(name,"not in self.windows",self.windows.keys())
  2510. class Console():
  2511. def __init__(self):
  2512. pass
  2513. def flash_off(self,fix):
  2514. pass#client.send("df0:alloff:::,")
  2515. def fx_off(self,fix):
  2516. cprint("Console.fx_off()",fix)
  2517. if not fix or fix == "all":
  2518. #client.send("fx0:alloff:,fxf:alloff:,")
  2519. #client.send("df0:alloff:::,")
  2520. j = []
  2521. if 0:
  2522. jdata = {'VALUE': None, 'args': [], 'FX': 'alloff::::', 'FADE': 2, 'DMX': '0'}
  2523. j.append(jdata)
  2524. jdata = {'VALUE': None, 'args': [], 'FX': 'alloff::::', 'FADE': 2,'FLASH':1, 'DMX': '0'}
  2525. j.append(jdata)
  2526. else:
  2527. jdata = {'VALUE': None, 'args': [], 'FX2': {"TYPE":"alloff"}, 'FADE': 2,'FLASH':1, 'DMX': '1'}
  2528. j.append(jdata)
  2529. jclient_send(j)
  2530. return 0
  2531. window_manager = WindowManager()
  2532. CONSOLE = Console()
  2533. PRESETS = Presets()
  2534. PRESETS.load_presets()
  2535. FIXTURES = Fixtures()
  2536. FIXTURES.load_patch()
  2537. master = GUI()
  2538. class Refresher():
  2539. def __init__(self):
  2540. self.time = time.time()+1
  2541. def reset(self):
  2542. self.time = time.time()+.1
  2543. def refresh(self):
  2544. if time.time() > self.time:
  2545. if time.time() < self.time+2:
  2546. #self.time = time.time()+1
  2547. self._refresh()
  2548. def _refresh(self):
  2549. master._refresh_fix()
  2550. master._refresh_exec()
  2551. def loop(self,args={}):
  2552. while 1:
  2553. self.refresh()
  2554. time.sleep(0.1)
  2555. refresher = Refresher()
  2556. thread.start_new_thread(refresher.loop,())
  2557. w = GUIWindow("MAIN",master=1,width=100,height=450,left=0,top=65)
  2558. data = []
  2559. #data.append({"text":"COMMAND"})
  2560. data.append({"text":"EXEC"})
  2561. data.append({"text":"DIMMER"})
  2562. data.append({"text":"FIXTURES"})
  2563. f = GUI_menu(w.tk,data)
  2564. window_manager.new(w)
  2565. name="EXEC"
  2566. w = GUIWindow(name,master=0,width=800,height=400,left=110,top=65)
  2567. w1 = ScrollFrame(w.tk,width=800,height=400)
  2568. #frame_exe = w.tk
  2569. master.draw_preset(w1)#w.tk)
  2570. window_manager.new(w,name)
  2571. name="DIMMER"
  2572. w = GUIWindow(name,master=0,width=800,height=400,left=110,top=65)
  2573. w2 = ScrollFrame(w.tk,width=800,height=400)
  2574. #frame_dim = w1 # w.tk
  2575. #master.draw_dim(w1.tk)
  2576. window_manager.new(w,name)
  2577. name="FIXTURES"
  2578. w = GUIWindow(name,master=0,width=800,height=400,left=110,top=65)
  2579. w1 = ScrollFrame(w.tk,width=800,height=400)
  2580. #frame_fix = w1 #w.tk
  2581. master.draw_fix(w1,w2)#.tk)
  2582. window_manager.new(w,name)
  2583. name="ENCODER"
  2584. ww = GUIWindow(name,master=0,width=800,height=50,left=110,top=500)
  2585. Xroot = ww.tk
  2586. w = None
  2587. root = tk.Frame(Xroot,bg="black",width="10px")
  2588. print("print pack",root)
  2589. root.pack(fill=tk.BOTH,expand=0, side=tk.LEFT)
  2590. root3 = tk.Frame(Xroot,bg="black",width="20px")
  2591. root3.pack(fill=tk.BOTH,expand=0, side=tk.LEFT)
  2592. root2 = tk.Frame(Xroot,bg="black",width="1px")
  2593. master.draw_enc(root2)
  2594. root2.pack(fill=tk.BOTH,expand=0, side=tk.LEFT)
  2595. name = "COMMAND"
  2596. w = GUIWindow(name,master=0,width=350,height=200,left=920,top=65)
  2597. master.draw_command(w.tk)
  2598. window_manager.new(w,name)
  2599. name="PATCH"
  2600. w = GUIWindow(name,master=0,width=800,height=400,left=110,top=65)
  2601. w1 = ScrollFrame(w.tk,width=800,height=400)
  2602. master.draw_patch(w1)
  2603. window_manager.new(w,name)
  2604. name="FX"
  2605. w = GUIWindow(name,master=0,width=410,height=250,left=920,top=305)
  2606. #frame_fx = w.tk
  2607. master.draw_fx(w.tk)
  2608. window_manager.new(w,name)
  2609. #LibreLightDesk
  2610. name="COLORPICKER"
  2611. w = GUIWindow(name,master=0,width=580,height=100,left=80,top=620)
  2612. master.draw_colorpicker(w.tk)
  2613. window_manager.new(w,name)
  2614. #Xroot = tk.Tk()
  2615. #Xroot["bg"] = "black" #white
  2616. #Xroot.title( xtitle+" "+str(rnd_id) )
  2617. #Xroot.geometry("1024x800+130+65")
  2618. master.render()
  2619. #w = frame_fix #GUIWindow("OLD",master=0,width=800,height=500,left=130,top=65)
  2620. window_manager.new(w,name)
  2621. try:
  2622. #root.mainloop()
  2623. #tk.mainloop()
  2624. window_manager.mainloop()
  2625. finally:
  2626. master.exit()