_LibreLightDesk.py 68 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313
  1. #! /usr/bin/python
  2. # -*- coding: utf-8 -*-
  3. """
  4. (c) 2012 micha@librelight.de
  5. SPDX-License-Identifier: GPL-2.0-only
  6. """
  7. import random
  8. import subprocess
  9. import string
  10. import copy
  11. import traceback
  12. import json
  13. import time
  14. import sys
  15. import os
  16. import _thread as thread
  17. for i in range(30):
  18. print() # boot space
  19. IS_GUI = 0
  20. if __name__ == "__main__":
  21. IS_GUI = 1
  22. import tool.movewin as movewin
  23. import lib.fixlib as fixlib
  24. import lib.libwin as libwin
  25. import lib.libtk as libtk
  26. import lib.libconfig as libconfig
  27. rnd_id = str(random.randint(100,900))
  28. rnd_id += " beta"
  29. rnd_id2 = ""
  30. rnd_id3 = ""
  31. _ENCODER_WINDOW = None
  32. __run_main = 0
  33. if __name__ == "__main__":
  34. __run_main = 1
  35. else:
  36. import __main__
  37. if "unittest" not in dir(__main__):
  38. __run_main = 1
  39. import tool.git as git
  40. rnd_id += git.get_all()
  41. try:
  42. xtitle = __file__
  43. except:
  44. xtitle = "__file__"
  45. if "/" in xtitle:
  46. xtitle = xtitle.split("/")[-1]
  47. sys.stdout.write("\x1b]2;"+str(xtitle)+" "+str(rnd_id)+"\x07") # terminal title
  48. HOME = os.getenv('HOME')
  49. space_font = None
  50. INIT_OK = 0
  51. _global_short_key = 1
  52. path = "/home/user/LibreLight/"
  53. #os.chdir(path)
  54. f = open(path+"init.txt","r")
  55. lines=f.readlines()
  56. f.close()
  57. out = []
  58. for line in lines:
  59. if line != "EASY\n":
  60. out.append(line)
  61. f = open(path+"init.txt","w")
  62. f.writelines(out)
  63. f.close()
  64. if "--easy" in sys.argv:
  65. f = open(path+"init.txt","a")
  66. f.write("EASY\n")
  67. f.close()
  68. if not os.path.isdir(path+"show/EASY"):
  69. cmd = "cp -vrf '/opt/LibreLight/Xdesk/home/LibreLight/show/EASY' '{}/show/EASY' ".format(path)
  70. print(cmd)
  71. #input()
  72. os.system(cmd)
  73. # check if EASY show exist !
  74. from lib.cprint import cprint
  75. cprint("________________________________")
  76. def cb(**args):
  77. cprint("MAIN.cb DUMMY",**args,color="red")
  78. import lib.zchat as chat
  79. import lib.motion as motion
  80. from collections import OrderedDict
  81. _FIX_FADE_ATTR = ["PAN","TILT","DIM","RED","GREEN","BLUE","WHITE","CYAN","YELLOW","MAGENTA","FOCUS","ZOOM","FROST"]
  82. CUES = OrderedDict()
  83. groups = OrderedDict()
  84. class Modes():
  85. def __init__(self):
  86. self.modes = {}
  87. self.__cfg = {}
  88. self.__cb = None
  89. def val(self,mode,value=None): #like jquery
  90. if value is not None:
  91. return self.set(mode,value)
  92. elif mode in self.modes:
  93. return self.modes[mode]
  94. def get(self,mode,value=None):
  95. return self.val(mode,value)
  96. def __check(self,mode):
  97. if mode not in self.modes:
  98. self.modes[mode] = 0
  99. self.__cfg[mode] = 0
  100. def cfg(self,mode,data={}):
  101. self.__check(mode)
  102. if type(data) is dict:
  103. for k in data:
  104. v = data[k]
  105. if v not in self.__cfg:
  106. self.__cfg[k] = v
  107. return 1
  108. elif type(data) is str:
  109. if data in self.__cfg:
  110. return self.__cfg[data]
  111. def set(self,mode,value):
  112. protected = ["BLIND","CLEAR","REC-FX"]
  113. self.__check(mode)
  114. if mode == "CLEAR":
  115. return 1
  116. elif mode == "ESC":
  117. for m in self.modes:
  118. cprint("ESC",m)
  119. if m == "COPY":
  120. EXEC.clear_copy()
  121. if m == "MOVE":
  122. EXEC.clear_move()
  123. if m != "BLIND":
  124. self.modes[m] = 0
  125. self.callback(m)
  126. return 1
  127. if value:
  128. for m in self.modes:
  129. if m not in protected and mode not in protected and m != mode:
  130. #cprint("-#-# clear mode",mode,m,value,color="red")
  131. if self.modes[m]:
  132. self.modes[m]= 0
  133. self.callback(m)
  134. if self.modes[mode] and value == 1:
  135. if modes == "MOVE":
  136. EXEC.clear_move()
  137. if modes == "COPY":
  138. EXEC.clear_copy()
  139. self.modes[mode] = 0 # value
  140. else:
  141. self.modes[mode] = value #1 #value
  142. else:
  143. self.modes[mode] = 0 #value
  144. if modes == "COPY":
  145. EXEC.clear_copy()
  146. if modes == "MOVE":
  147. EXEC.clear_move()
  148. self.callback(mode)
  149. return value
  150. def set_cb(self,cb):
  151. if cb:
  152. self.__cb = cb
  153. def callback(self,mode):
  154. if self.__cb is not None and mode in self.modes:
  155. value = self.modes[mode]
  156. self.__cb(mode=mode,value=value)
  157. modes = Modes()
  158. #modes.val("BLIND", 0)
  159. #modes.modes["BLIND"] = 0
  160. modes.modes["ESC"] = 0
  161. modes.modes["REC"] = 0
  162. modes.modes["EDIT"] = 0
  163. modes.modes["MOVE"] = 0
  164. modes.modes["FLASH"] = 0
  165. modes.modes["GO"] = 0
  166. modes.modes["DEL"] = 0
  167. modes.modes["REC-FX"] = 0
  168. modes.modes["SELECT"] = 0
  169. modes.modes["CFG-BTN"] = 0
  170. modes.modes["LABEL"] = 0
  171. POS = ["PAN","TILT","MOTION"]
  172. COLOR = ["RED","GREEN","BLUE","COLOR"]
  173. BEAM = ["GOBO","G-ROT","PRISMA","P-ROT","FOCUS","SPEED"]
  174. INT = ["DIM","SHUTTER","STROBE","FUNC"]
  175. #client = chat.tcp_sender(port=50001)
  176. def set_exec_fader_cfg(nr,val,label="",color=""):
  177. exec_wing = window_manager.get_obj(name="EXEC-WING")
  178. if not exec_wing:
  179. return
  180. try:
  181. if len(exec_wing.fader_elem) > nr:
  182. exec_wing.fader_elem[nr].attr["text"] = label
  183. cfg = get_exec_btn_cfg(nr+80)
  184. exec_wing.fader_elem[nr].attr["bg"] = cfg["bg"]
  185. exec_wing.fader_elem[nr].attr["fg"] = cfg["fg"]
  186. #exec_wing.fader_elem[nr].attr["fx"] = cfg["fx"]
  187. except Exception as e:
  188. cprint(" set_exec_fader_cfg err:",e,color="red")
  189. print(" ",nr,val,label)
  190. raise e
  191. def set_exec_fader(nr,val,label="",color="",info="info",change=0):
  192. exec_wing = window_manager.get_obj(name="EXEC-WING")
  193. if not exec_wing:
  194. return
  195. try:
  196. exec_wing.set_fader(nr,val,color=color,info=info,change=change)
  197. except Exception as e:
  198. cprint(" - set_exec_fader err:",e,color="red")
  199. print(" ",nr,val,label)
  200. raise e
  201. def set_exec_fader_all():
  202. print()
  203. cprint( "set_exec_fader_all()",color="green")
  204. for nr in range(10):
  205. _label = EXEC.label_exec[nr+80] # = label
  206. print(" set_exec_fader_all._label =",_label)
  207. set_exec_fader(nr,0,label=_label)
  208. set_exec_fader_cfg(nr,0,label=_label)
  209. def refresh_exec_fader_cfg():
  210. cprint( "set_exec_fader_all()",color="green")
  211. for nr in range(10):
  212. _label = EXEC.label_exec[nr+80] # = label
  213. #print("_label",_label)
  214. set_exec_fader_cfg(nr,0,label=_label)
  215. # remote input - start (memcached)
  216. def JCB(x,sock=None):
  217. for i in x:
  218. jv = x[i]
  219. try:
  220. jv = json.loads(jv)
  221. jv = jv[0]
  222. #print(jv)
  223. v = jv["iVAL"]
  224. #exec_wing.set_fader(0,v)
  225. set_exec_fader(0,v)
  226. set_exec_fader(1,200-v)
  227. set_exec_fader(2,int(v/2+10))
  228. except Exception as e:
  229. cprint("exception",e)
  230. print(sys.exc_info()[2])
  231. #print("remote in:",round(time.time(),0),"x",i,v)
  232. if __name__ == "__main__":
  233. r1_server = chat.Server(port=30002)
  234. def server1_loop():
  235. while 1:
  236. r1_server.poll(cb=JCB)
  237. time.sleep(1/90)
  238. thread.start_new_thread(server1_loop,()) # SERVER
  239. import lib.jsbc as JSBC
  240. if __name__ == "__main__":
  241. r_server = chat.Server(port=30003,cb=JSBC.JSCB)
  242. def server_loop():
  243. while 1:
  244. r_server.poll(cb=JSBC.JSCB)
  245. thread.start_new_thread(server_loop,()) # SERVER
  246. import lib.fifo as FIFO
  247. if __name__ == "__main__":
  248. f_server = FIFO.read_loop() #chat.Server(port=30003,cb=JSBC.JSCB)
  249. f_server.loop(sleep=1)
  250. def f_server_read_loop():
  251. time.sleep(10)
  252. print("FIFO read_loop() __ ")
  253. while 1:
  254. try:
  255. data = f_server.read()
  256. for jdata in data:
  257. # JSCB [{'event': 'EXEC', 'EXEC': 161, 'VAL': 0, 'NR-KEY': 1}]
  258. print("FIFO:",jdata)
  259. ok=1
  260. for i in ["event","VAL","EXEC"]:
  261. if i not in jdata:
  262. ok=0
  263. if ok:
  264. if jdata["event"] != "EXEC":
  265. continue
  266. if "EXEC" in jdata:
  267. exec_nr = jdata["EXEC"]
  268. if "VAL" in jdata:
  269. val = jdata["VAL"]
  270. master.exec_go(exec_nr-1,xfade=None,val=val)
  271. else:
  272. time.sleep(0.02)
  273. except KeyboardInterrupt as e:
  274. raise e
  275. except Exception as e:
  276. print("FIFO ERR1",e)
  277. thread.start_new_thread(f_server_read_loop,()) # SERVER
  278. # read memcachd
  279. memcache = None
  280. try:
  281. import memcache
  282. except Exception as e:
  283. cprint("Exception IMPORT ERROR",e)
  284. class MC_FIX():
  285. def __init__(self,server="127.0.0.1",port=11211):
  286. cprint("MC.init() ----------" ,server,port,color="red")
  287. try:
  288. self.mc = memcache.Client(['{}:{}'.format(server,port)], debug=0)
  289. except Exception as e:
  290. cprint("-- Exception",e)
  291. def set(self,index="fix",data=[]):
  292. index = self.mc.get("index")
  293. self.mc.set("fix", data)
  294. class MC():
  295. def __init__(self,server="127.0.0.1",port=11211):
  296. cprint("MC.init() ----------" ,server,port,color="red")
  297. try:
  298. #self.mc = memcache.Client(['127.0.0.1:11211'], debug=0)
  299. self.mc = memcache.Client(['{}:{}'.format(server,port)], debug=0)
  300. #self.init()
  301. except Exception as e:
  302. cprint("-- Exception",e)
  303. # def init(self):
  304. data = {}
  305. start = time.time()
  306. delta = start
  307. index = self.mc.get("index")
  308. if index:
  309. for i in index:
  310. print(" key",i)
  311. self.last_fader_val = [-1]*512
  312. self.fader_map = []
  313. for i in range(30+1):
  314. self.fader_map.append({"UNIV":0,"DMX":0})
  315. try:
  316. fname = HOME + "/LibreLight/fader.json"
  317. f = open(fname)
  318. lines = f.readlines()
  319. cprint("FADER MAP",fname)
  320. for i,line in enumerate(lines):
  321. jdata = json.loads(line)
  322. print(" fader_map ->>",i,jdata)
  323. self.fader_map[i] = jdata
  324. except Exception as e:
  325. cprint("-- Except Fader_map",e)
  326. #exit()
  327. def ok(self):
  328. if self.mc:
  329. return 1
  330. return 0
  331. def test(self):
  332. if not self.ok():
  333. return
  334. self.mc.set("some_key", "Some value")
  335. self.value = mc.get("some_key")
  336. self.mc.set("another_key", 3)
  337. self.mc.delete("another_key")
  338. def loop(self):
  339. thread.start_new_thread(self._loop,())
  340. if not self.ok():
  341. return
  342. def _exec_fader_loop(self,x):
  343. for i, line in enumerate(self.fader_map):
  344. try:
  345. #print(i,line)
  346. dmx = int(line["DMX"])
  347. if dmx > 0:
  348. val = x[dmx-1]
  349. #print("mc val",val)
  350. #print("dmx_in change:",[i,val])
  351. change = 0
  352. if i < len(self.last_fader_val):
  353. if self.last_fader_val[i] != val:
  354. self.last_fader_val[i] = val
  355. print("dmx_in change:",[i,val])
  356. change = 1
  357. set_exec_fader(nr=i,val=val,color="#aaa",info="dmx_in",change=change)
  358. except Exception as e:
  359. cprint("MC exc:",e,color="red")
  360. traceback.print_exc()
  361. pass
  362. def _loop(self):
  363. time.sleep(20)
  364. cprint("++++++++++ start.memcachd read loop",self )
  365. ip = libconfig.load_remote_ip()
  366. print("IP:",ip)
  367. input()
  368. while 1:
  369. send = 0
  370. #print("+")
  371. try:
  372. #ip="10.10.10.13:0"
  373. #ip="ltp-out:0"
  374. #print(ip)
  375. x=self.mc.get(ip)
  376. if x:
  377. #print(ip,x)
  378. #val = x[501-1]
  379. #val = x[141-1]
  380. self._exec_fader_loop(x)
  381. time.sleep(1/10)
  382. except Exception as e:
  383. cprint("exc", e)
  384. time.sleep(1)
  385. _mc=MC()
  386. _mc.loop()
  387. console = chat.Client() #port=50001)
  388. def jclient_send(data):
  389. t_start = time.time()
  390. jtxt = data
  391. jdatas = []
  392. for jdata in data:
  393. if "CMD" in jdata:
  394. try:
  395. jdatas.append(jdata)
  396. except Exception as e:
  397. cprint("jclient_send, Exception DMX ",color="red")
  398. cprint("",jdata,color="red")
  399. cprint("-----",color="red")
  400. elif "DMX" in jdata:
  401. try:
  402. jdata["DMX"] = int(jdata["DMX"])
  403. dmx = jdata["DMX"]
  404. if "ATTR" not in jdata:
  405. # for fx off
  406. jdatas.append(jdata)
  407. else:
  408. fix = "00000"
  409. attr = "00000"
  410. if "FIX" in jdata:
  411. fix = jdata["FIX"]
  412. if "ATTR" in jdata:
  413. attr = jdata["ATTR"]
  414. dmx_fine = fixlib.get_dmx(FIXTURES.fixtures,fix,attr+"-FINE")
  415. if jdata["DMX"] != dmx_fine and dmx > 0 and dmx_fine > 0:
  416. jdata["DMX-FINE"] = dmx_fine
  417. if "DMX-FINE" in jdata:
  418. if jdata["DMX-FINE"] <= 0:
  419. del jdata["DMX-FINE"]
  420. if jdata["ATTR"].startswith("_"):
  421. pass # ignore attr._ACTIVE
  422. else:#
  423. jdata["time"] = t_start
  424. jdatas.append(jdata)
  425. #cprint("-- ",jdata,color="red")
  426. except Exception as e:
  427. cprint("jclient_send, Exception DMX ",color="red")
  428. cprint("",jdata,color="red")
  429. cprint(e,color="red")
  430. cprint("-----",color="red")
  431. jtxt = jdatas
  432. jtxt = json.dumps(jtxt)
  433. jtxt = jtxt.encode()
  434. console.send( jtxt ) #b"\00 ")
  435. cprint("{:0.04} sec.".format(time.time()-t_start),color="yellow")
  436. cprint("{:0.04} tick".format(time.time()),color="yellow")
  437. def _highlight(fix,_attr="DIM"):
  438. " patch test button "
  439. cprint("highlight",fix,"1")
  440. if fix not in FIXTURES.fixtures:
  441. return None
  442. d = FIXTURES.fixtures[fix]
  443. #for k,v in d.items():
  444. # cprint("-",k,v)
  445. DMX = d["DMX"] + d["UNIVERS"]*512
  446. if "ATTRIBUT" in d:
  447. ATTR= d["ATTRIBUT"]
  448. data = {"VALUE":200,"DMX":1}
  449. attr = ""
  450. if _attr in ATTR:
  451. attr = _attr
  452. else:
  453. return #stop
  454. cprint(attr,ATTR[attr])
  455. old_val = ATTR[attr]["VALUE"]
  456. data["DMX"] = DMX + ATTR[attr]["NR"]-1
  457. cprint(attr,ATTR[attr])
  458. cprint(data)
  459. for i in range(3):
  460. cprint("highlight",fix,"0")
  461. data["VALUE"] = 100
  462. jclient_send([data])
  463. time.sleep(0.1)
  464. cprint("highlight",fix,"1")
  465. data["VALUE"] = 234
  466. jclient_send([data])
  467. time.sleep(0.3)
  468. cprint("highlight",fix,"0")
  469. data["VALUE"] = old_val
  470. jclient_send([data])
  471. def highlight2(fix,attr="DIM"):
  472. def x():
  473. highlight(fix,attr=attr)
  474. return x
  475. def highlight(fix):
  476. cprint("highlight",fix)
  477. thread.start_new_thread(_highlight,(fix,"DIM"))
  478. thread.start_new_thread(_highlight,(fix,"RED"))
  479. thread.start_new_thread(_highlight,(fix,"GREEN"))
  480. thread.start_new_thread(_highlight,(fix,"BLUE"))
  481. class ValueBuffer():
  482. def __init__(self,_min=0,_max=255):
  483. self._value = 2
  484. self._on = 1
  485. self._min=_min
  486. self._max=_max
  487. def check(self):
  488. if self._value < self._min:
  489. self._value = self._min
  490. elif self._value > self._max:
  491. self._value = self._max
  492. def inc(self,value=None):
  493. if value is not None:
  494. if type(value) is float:
  495. self._value += round(value,4)
  496. else:
  497. self._value += value
  498. self.check()
  499. return self._value
  500. def val(self,value=None):
  501. if value is not None:
  502. if type(value) is float:
  503. self._value = round(value,4)
  504. else:
  505. self._value = value
  506. self.check()
  507. return self._value
  508. def on(self):
  509. self._on = 1
  510. def off(self):
  511. self._on = 0
  512. def _is(self):
  513. if self._on:
  514. return 1
  515. return 0
  516. FADE = ValueBuffer() #2 #0.1 #1.13
  517. FADE.val(2.0)
  518. FADE_move = ValueBuffer() #2 #0.1 #1.13
  519. FADE_move.val(4.0)
  520. DELAY = ValueBuffer() #2 #0.1 #1.13
  521. DELAY.off()
  522. DELAY.val(0.2)
  523. fx_prm_main = {}
  524. fx_prm_move = {"SIZE":40,"SPEED":8,"OFFSET":100,"BASE":"0","START":0,"MODE":0,"MO":0,"DIR":1,"INVERT":0,"WING":2,"WIDTH":100}
  525. fx_color = {"A":"red","B":"blue"}
  526. fx_prm = {"SIZE":255,"SPEED":10,"OFFSET":100,"BASE":"-","START":0,"MODE":0,"MO":0,"DIR":1,"INVERT":1,"SHUFFLE":0,"WING":2,"WIDTH":25,"2D-X":1,"2D:MODE":0}
  527. fx_x_modes = ["spiral","left","right","up","down","left_right","up_down"]
  528. fx_modes = ["RED","GREEN","BLUE","MAG","YELLOW","CYAN"]
  529. fx_mo = ["fade","on","rnd","ramp","ramp2","cosinus","sinus","static"]
  530. class FX_handler():
  531. def __init__():
  532. pass
  533. class dummy_event():
  534. def __init__(self):
  535. self.num =0
  536. self.type = 4 #press 5 release
  537. self.set_value=-1
  538. from lib import matrix
  539. import lib.fxlib as fxlib
  540. def process_matrix(xfixtures):
  541. fx_x = fx_prm["2D-X"]
  542. fx_mod = fx_x_modes[fx_prm["2D:MODE"]]
  543. r = _process_matrix(xfixtures,fx_x,fx_mod)
  544. return r
  545. def _process_matrix(xfixtures,fx_x,fx_mod):
  546. fix_count = len(xfixtures)
  547. cprint("----",fx_x,fx_mod)
  548. if fx_x > 1 and fix_count > fx_x:
  549. try:
  550. w=fx_x
  551. h=int(fix_count/fx_x)
  552. if fx_mod == "spiral":
  553. _map = matrix.spiral(w,h)
  554. elif fx_mod == "up_down":
  555. _map = matrix.up_down(w,h)
  556. elif fx_mod == "left_right":
  557. _map = matrix.left_right(w,h)
  558. elif fx_mod == "left":
  559. _map = matrix.left(w,h)
  560. elif fx_mod == "right":
  561. _map = matrix.right(w,h)
  562. elif fx_mod == "up":
  563. _map = matrix.up(w,h)
  564. elif fx_mod == "down":
  565. _map = matrix.down(w,h)
  566. else:
  567. return xfixtures # do nothing
  568. matrix.mprint(xfixtures,w,h)
  569. out = ["0"]*(w*h)
  570. for i,f in enumerate(xfixtures):
  571. if i < w*h:
  572. j = int(_map[i])
  573. cprint(["i:",i,"f:",f,"j:",j])
  574. out[j] = f
  575. matrix.mprint(out,w,h)
  576. xfixtures = out
  577. except Exception as e:
  578. cprint("matrix exception",e)
  579. return xfixtures
  580. def save_show(fpath=None,new=0):
  581. if fpath:
  582. a=EXEC.backup_exec(save_as=fpath,new=new)
  583. b=FIXTURES.backup_patch(save_as=fpath,new=new)
  584. c=libwin.save_window_position(save_as=fpath)
  585. d=movewin.store_all_sdl()
  586. else:
  587. print()
  588. print()
  589. cprint("SAVE SHOW ..",color="yellow")
  590. a=EXEC.backup_exec()
  591. b=FIXTURES.backup_patch()
  592. c=libwin.save_window_position()
  593. d=movewin.store_all_sdl()
  594. if a and b and d: # and c
  595. cprint("SAVE SHOW OK",[fpath,new],[a,b,c,d],color="green")
  596. print()
  597. print()
  598. print()
  599. return 1
  600. cprint("SAVE SHOW FAIL",[fpath,new],[a,b,c,d],color="red")
  601. print()
  602. print()
  603. print()
  604. def save_show_as(fname,new=0):
  605. print()
  606. print()
  607. fpath = showlib.generate_show_path(fname)
  608. info = "SAVE SHOW AS"
  609. if new:
  610. info = "SAVE (NEW) SHOW AS"
  611. cprint(info,fpath,fname,color="green")
  612. if showlib.create_new_show_path(fpath):
  613. return save_show(fpath,new)
  614. import lib.showlib as showlib
  615. class cb():
  616. def __init__(self,win):
  617. self.win = win
  618. def _callback(self,event):
  619. clobj=event.widget
  620. ## undermouse=find_withtag(master.CURRENT)
  621. undermouse=self.win.find_closest(self.win.CURRENT)
  622. cprint( repr(undermouse))
  623. def callback(self,event):
  624. cprint(__file__,self,"callback",event)
  625. cnv = self.win
  626. item = cnv.find_closest(cnv.canvasx(event.x), cnv.canvasy(event.y))[0]
  627. tags = cnv.gettags(item)
  628. #cnv.itemconfigure(self.tag, text=tags[0])
  629. cprint(tags,item)
  630. color = cnv.itemcget(item, "fill")
  631. cnv.itemconfig("all", width=1)#filla="green")
  632. cnv.itemconfig(item, width=3)#filla="green")
  633. cprint(color)
  634. cprint( hex_to_rgb(color[1:]))
  635. def get_exec_btn_cfg(nr):
  636. k = nr
  637. if 1:
  638. _bg = "grey"
  639. _ba = "grey"
  640. _fg = "lightgrey"
  641. _text = "N/V"
  642. txt = "None/nNone"
  643. txt1 = "None/nNone"
  644. if nr >= 0:
  645. if nr != k:
  646. return #continue
  647. label = ""
  648. if k in EXEC.label_exec:
  649. label = EXEC.label_exec[k]
  650. ifval = 0
  651. fx_only = 0
  652. fx_color = 0
  653. if k in EXEC.val_exec and len(EXEC.val_exec[k]) :
  654. sdata = EXEC.val_exec[k]
  655. sdata["CFG"]["HAVE-FX"] = 0
  656. sdata["CFG"]["HAVE-VAL"] = 0
  657. sdata["CFG"]["FIX-COUNT"] = 0
  658. BTN="go"
  659. if "CFG" in sdata:#["BUTTON"] = "GO"
  660. if "BUTTON" in sdata["CFG"]:
  661. BTN = sdata["CFG"]["BUTTON"]
  662. txt="{} {} {}\n{}".format(k+1,BTN,len(sdata)-1,label)
  663. _text = txt
  664. if len(sdata) > 1:
  665. ifval = 1
  666. val_color = 0
  667. for fix in sdata:
  668. if fix == "CFG":
  669. continue
  670. sdata["CFG"]["FIX-COUNT"] += 1
  671. for attr in sdata[fix]:
  672. if "FX2" in sdata[fix][attr]:
  673. if sdata[fix][attr]["FX2"]:
  674. fx_color = 1
  675. if "FX" in sdata[fix][attr]:
  676. if sdata[fix][attr]["FX"]:
  677. fx_color = 1
  678. if "VALUE" in sdata[fix][attr]:
  679. if sdata[fix][attr]["VALUE"] is not None:
  680. val_color = 1
  681. if val_color:
  682. sdata["CFG"]["HAVE-VAL"] += 1
  683. if fx_color:
  684. sdata["CFG"]["HAVE-FX"] += 1
  685. if val_color:
  686. _bg = "gold"
  687. _ba = "#ffaa55"
  688. if fx_color:
  689. _fg = "blue"
  690. else:
  691. if fx_color:
  692. fx_only = 1
  693. else:
  694. _bg = "grey"
  695. _ba = "#aaa"
  696. if "\n" in txt:
  697. txt1 = txt.split("\n")[0]
  698. _fg = "black"
  699. if ifval:
  700. if fx_only:
  701. _bg = "cyan"
  702. _ba = "#55d4ff"
  703. if "SEL" in txt1:
  704. _bg = "#77f"
  705. else:
  706. _bg = "grey"
  707. _fg = "darkgrey"
  708. if "SEL" in txt1:
  709. _fg = "blue"
  710. elif "ON" in txt1:
  711. _fg = "#040"
  712. elif "GO" in txt1:
  713. _fg = "#555"
  714. if "FL" in txt1:
  715. _fg = "#00e"
  716. out = {} # default
  717. out["fx"] = ""
  718. out["bg"] = "lightgrey"
  719. out["ba"] = "grey"
  720. out["fg"] = "grey"
  721. out["text"] = "?"
  722. out["fx"] = fx_color
  723. out["bg"] = _bg
  724. out["ba"] = _ba
  725. out["fg"] = _fg
  726. out["text"] = _text
  727. return out
  728. class Elem_Container():
  729. def __init__(self):
  730. self.commands = []
  731. self.val = {}
  732. self.elem = {}
  733. import lib.execlib as execlib
  734. class MASTER():
  735. def __init__(self):
  736. self.base = showlib.Base ()
  737. self.load()
  738. self._XX = 0
  739. self.all_attr =["DIM","PAN","TILT"]
  740. self.elem_attr = {}
  741. self.setup_elem = {} # Elem_Container()
  742. self.setup_cmd = ["SAVE\nSHOW","LOAD\nSHOW","NEW\nSHOW","SAVE\nSHOW AS","SAVE &\nRESTART","DRAW\nGUI","PRO\nMODE"]
  743. self.setup_cmd = ["SAVE\nSHOW","LOAD\nSHOW","NEW\nSHOW","SAVE\nSHOW AS","SAVE &\nRESTART","PRO\nMODE"]
  744. self.fx_main = Elem_Container()
  745. self.fx_main.commands =["REC-FX","FX OFF","\n"]
  746. self.fx_moves = Elem_Container()
  747. self.fx_moves.commands =[
  748. "FX:CIR","FX:PAN","FX:TILT", "WIDTH:\n100","DIR:\n0","INVERT:\n0","\n",
  749. "SHUFFLE:\n0","SIZE:\n","SPEED:\n","START:\n","OFFSET:\n","\n"
  750. ]
  751. #, "FX:SIN","FX:COS","FX:RAMP","FX:RAMP2","FX:FD","FX:ON","BASE:\n-"] #,"FX:RND" ]
  752. self.fx = Elem_Container()
  753. self.fx.commands =[
  754. "FX:DIM"," ", "WIDTH:\n25","WING:\n2","DIR:\n1","INVERT:\n1","\n","SHUFFLE:\n0"
  755. ,"SIZE:\n","SPEED:\n","START:\n","OFFSET:\n","BASE:\n-","2D-X:\n-","2D:MODE"
  756. ]
  757. self.fx_generic = Elem_Container()
  758. self.fx_generic.commands =["FX:SIN","FX:COS","FX:RAMP","FX:RAMP2","FX:FD","FX:ON","FX:STATIC"]
  759. self.fx_color = Elem_Container()
  760. self.fx_color.commands =["FX:RED","FX-C:A","FX-C:B"]
  761. self.commands = Elem_Container()
  762. self.commands.commands =["\n","ESC","CFG-BTN","LABEL","-","DEL","-","\n"
  763. ,"SELECT","FLASH","GO","-","MOVE","S-KEY","\n"
  764. ,"BLIND","CLEAR","REC","EDIT","COPY",".","\n"
  765. ]
  766. self.elem_exec = {}
  767. for i in range(8*8*8):
  768. if i not in EXEC.val_exec:
  769. name = "Preset:"+str(i+1)+":\nXYZ"
  770. #self.exec[i] = [i]
  771. EXEC.val_exec[i] = OrderedDict() # FIX
  772. EXEC.val_exec[i]["CFG"] = OrderedDict() # CONFIG
  773. EXEC.label_exec[i] = "-"
  774. modes.set_cb(self.xcb)
  775. def jclient_send(self,data):
  776. # namespace wraper
  777. if not modes.val("BLIND"):
  778. jclient_send(data)
  779. def button_refresh(self,name,color,color2=None,text="",fg=None):
  780. cprint("button_refresh",name,color)
  781. try:
  782. if color2 is None:
  783. color2 = color
  784. if text:
  785. text = "\n"+str(text)
  786. if name in self.commands.elem:
  787. self.commands.elem[name]["bg"] = color
  788. self.commands.elem[name]["text"] = name+ text
  789. self.commands.elem[name].config(activebackground=color2)
  790. if fg:
  791. self.commands.elem[name]["fg"] = fg
  792. elif name in self.fx.elem:
  793. #todo
  794. self.fx.elem[name]["bg"] = color
  795. self.fx.elem[name].config(activebackground=color2)
  796. if fg:
  797. self.fx.elem[name]["fg"] = fg
  798. # new version
  799. for elems in [self.fx_moves]:
  800. if name in elems.elem:
  801. elem = elems.elem[name]
  802. cprint("elem",elem)
  803. elem.config(bg = color)
  804. elem.config(text = name+text)
  805. elem.config(activebackground=color2)
  806. if fg and "fg" in elem:
  807. elem["fg"] = fg
  808. except Exception as e:cprint("exc",self,e)
  809. def btn_cfg(self,nr,testing=0):
  810. cfg = EXEC._btn_cfg(nr)
  811. button = EXEC.btn_cfg(nr)
  812. label = EXEC.label(nr)
  813. def _cb(data):
  814. if not data:
  815. cprint("err443",self,"_cb",data)
  816. return None
  817. cprint("btn_cfg._cb()",data)
  818. if data:
  819. if "Button" in data and type(data["Button"]) is str:
  820. txt = data["Button"]
  821. EXEC.btn_cfg(nr,txt)
  822. self.elem_exec[nr].configure(text= EXEC.get_btn_txt(nr))
  823. if "Label" in data and type(data["Label"]) is str:
  824. txt = data["Label"]
  825. EXEC.label(nr,txt)
  826. self.elem_exec[nr].configure(text= EXEC.get_btn_txt(nr))
  827. if "Delay" in data and type(data["Delay"]) is str:
  828. txt = data["Delay"]
  829. try:
  830. txt = float(txt)
  831. if "DELAY" in cfg:
  832. cfg["DELAY"] = round(txt,2)
  833. except e as Exception:
  834. print("DELAY Exception",e)
  835. if "in-Fade" in data and type(data["in-Fade"]) is str:
  836. txt = data["in-Fade"]
  837. try:
  838. txt = float(txt)
  839. if "FADE" in cfg:
  840. cfg["FADE"] = round(txt,2)
  841. except e as Exception:
  842. print("in-Fade Exception",e)
  843. if "out-Fade" in data and type(data["out-Fade"]) is str:
  844. txt = data["out-Fade"]
  845. try:
  846. txt = float(txt)
  847. cfg["OUT-FADE"] = round(txt,2)
  848. except e as Exception:
  849. print("out-Fade Exception",e)
  850. modes.val("CFG-BTN",0)
  851. master._refresh_exec(nr=nr)
  852. dialog._cb = _cb
  853. if 1: # testing:
  854. dialog.ask_exec_config(str(nr+1),button=button,label=label,cfg=cfg)
  855. else:
  856. dialog.askstring("CFG-BTN","GO=GO FL=FLASH\nSEL=SELECT EXE:"+str(nr+1),initialvalue=txt)
  857. def label(self,nr):
  858. txt = EXEC.label(nr)
  859. def _cb(data):
  860. if not data:
  861. cprint("err443",self,"_cb",data)
  862. return None
  863. txt = data["Value"]
  864. cprint("label._cb()",nr,txt)
  865. if txt:
  866. EXEC.label(nr,txt)
  867. self.elem_exec[nr].configure(text = EXEC.get_btn_txt(nr))
  868. modes.val("LABEL", 0)
  869. master._refresh_exec(nr=nr)
  870. dialog._cb= _cb #_x(nr)
  871. dialog.askstring("LABEL","EXE:"+str(nr+1),initialvalue=txt)
  872. def xcb(self,mode,value=None):
  873. cprint("MODE CALLBACK",mode,value,color="green",end="")
  874. if value:
  875. cprint("===== ON ======",color="red")
  876. txt = ""
  877. if mode == "REC-FX":
  878. modes.val("REC",0)
  879. modes.val("REC",1)
  880. if value == 2:
  881. if mode in ["MOVE","COPY"]:
  882. txt="to"
  883. self.button_refresh(mode,color="orange",text=txt)#,fg="blue")
  884. else:
  885. if mode in ["MOVE","COPY"]:
  886. txt="from"
  887. self.button_refresh(mode,color="red",text=txt)#,fg="blue",text="from")
  888. else:
  889. cprint("===== OFF ======",color="red")
  890. if mode == "REC-FX":
  891. modes.val("REC",0)
  892. self.button_refresh(mode,color="lightgrey")#,fg="black")
  893. def load(self,fname=""):
  894. pass
  895. def exit(self):
  896. cprint("__del__",self)
  897. def refresh_exec(self):
  898. refresher_exec.reset() # = tkrefresh.Refresher()
  899. def _refresh_exec(self,nr=-1):
  900. s = time.time()
  901. cprint("EXEC.refresh_exec()")
  902. refresher_exec.reset() # = tkrefresh.Refresher()
  903. self._XX +=1
  904. self._nr_ok = 0
  905. for nr in EXEC.val_exec:
  906. cfg = get_exec_btn_cfg(nr)
  907. b = self.elem_exec[nr]
  908. b.configure(fg=cfg["fg"],bg=cfg["bg"],activebackground=cfg["ba"],text=cfg["text"],fx=cfg["fx"])
  909. time.sleep(0.01)
  910. def refresh_fix(self):
  911. refresher_fix.reset() # = tkrefresh.Refresher()
  912. def _refresh_fix(self):
  913. cprint("_refresh_fix")
  914. s=time.time(); _XXX=0
  915. menu_buff = {"DIM":0,"DIM-SUB":0,"FIX":0,"FIX-SUB":0}
  916. elem_buffer = []
  917. for fix in FIXTURES.fixtures:
  918. sdata = FIXTURES.fixtures[fix]
  919. elem_attr_fix = None
  920. if fix in self.elem_attr:
  921. elem_attr_fix = self.elem_attr[fix]
  922. if "DIM" in sdata["ATTRIBUT"] and "_ACTIVE" in sdata["ATTRIBUT"] and len(sdata["ATTRIBUT"]) == 2:
  923. KEY = "DIM-SUB"
  924. else:
  925. KEY = "FIX-SUB"
  926. FIX = 0
  927. DIM = 0
  928. for attr in sdata["ATTRIBUT"]:
  929. _buff = {}
  930. row = sdata["ATTRIBUT"][attr]
  931. if attr.endswith("-FINE"):
  932. continue
  933. b_attr = attr
  934. if b_attr == "_ACTIVE":
  935. b_attr = "S"
  936. elem = None
  937. if elem_attr_fix:
  938. if b_attr not in elem_attr_fix:
  939. continue
  940. elem = elem_attr_fix[b_attr]
  941. if not elem:
  942. continue
  943. if "elem" not in _buff:
  944. _buff["elem"] = elem
  945. if not attr.startswith("_"):
  946. v2 = row["VALUE"]
  947. #_text = "{} {}".format(str(attr).rjust(4,"0"),str(v2).rjust(4,"0")) # ~0.2 sec
  948. _text = "{} {}".format(attr,v2)
  949. _buff["text"] = _text
  950. if row["ACTIVE"]:
  951. _buff["bg"] = "yellow"
  952. _buff["abg"] = "yellow"
  953. menu_buff[KEY] += 1
  954. if b_attr == "S":
  955. if KEY == "DIM-SUB":
  956. DIM =1
  957. else:
  958. FIX =1
  959. else:
  960. _buff["bg"] = "grey"
  961. _buff["abg"] = "grey"
  962. if "FX" not in row: # insert FX2 excetption
  963. row["FX"] = "" #OrderedDict()
  964. if "FX2" not in row: # insert FX2 excetption
  965. row["FX2"] = {} #OrderedDict()
  966. #print("row",fix,row)
  967. if row["FX"]:
  968. _buff["fg"] = "blue"
  969. elif row["FX2"]:
  970. _buff["fg"] = "red"
  971. else:
  972. _buff["fg"] = "black"
  973. elem_buffer.append(_buff)
  974. menu_buff["FIX"] += FIX
  975. menu_buff["DIM"] += DIM
  976. try:
  977. for row in elem_buffer:
  978. elem = row["elem"]
  979. if not elem:
  980. continue
  981. for e in row:
  982. if e == "elem":
  983. continue
  984. v = row[e]
  985. if e == "abg":
  986. elem.config(activebackground=v)
  987. else:
  988. elem[e] = v
  989. w = window_manager.get_win("FIXTURES")
  990. if w:
  991. w.update_idle_task()
  992. except Exception as e:
  993. cprint("exc434",e,color="red")
  994. cprint("fix:",_XXX,round(time.time()-s,2),color="red");_XXX += 1
  995. cprint(gui_menu)
  996. menu_buff["FIX-SUB"] -= menu_buff["FIX"]
  997. if menu_buff["FIX-SUB"]:
  998. gui_menu.config("FIXTURES","bg","yellow")
  999. gui_menu.config("FIXTURES","activebackground","yellow")
  1000. elif menu_buff["FIX"]:
  1001. gui_menu.config("FIXTURES","bg","orange")
  1002. gui_menu.config("FIXTURES","activebackground","orange")
  1003. else:
  1004. gui_menu.config("FIXTURES","bg","")
  1005. gui_menu.config("FIXTURES","activebackground","")
  1006. gui_menu.update("FIXTURES","{} : {}".format(menu_buff["FIX"],menu_buff["FIX-SUB"]))
  1007. menu_buff["DIM-SUB"] -= menu_buff["DIM"]
  1008. if menu_buff["DIM-SUB"]:
  1009. gui_menu.config("DIMMER","bg","yellow")
  1010. gui_menu.config("DIMMER","activebackground","yellow")
  1011. elif menu_buff["DIM"]:
  1012. gui_menu.config("DIMMER","bg","orange")
  1013. gui_menu.config("DIMMER","activebackground","orange")
  1014. else:
  1015. gui_menu.config("DIMMER","bg","")
  1016. gui_menu.config("DIMMER","activebackground","")
  1017. gui_menu.update("DIMMER","{} : {}".format(menu_buff["DIM"],menu_buff["DIM-SUB"]))
  1018. cprint("fix:",_XXX,round(time.time()-s),color="red"); _XXX += 1
  1019. def exec_rec(self,nr):
  1020. cprint("------- STORE EXEC")
  1021. data = fixlib.get_active(FIXTURES.fixtures)
  1022. if modes.val("REC-FX"):
  1023. EXEC.rec(nr,data,"REC-FX")
  1024. modes.val("REC-FX",0)
  1025. else:
  1026. EXEC.rec(nr,data)
  1027. sdata=data
  1028. EXEC.val_exec[nr] = sdata
  1029. master._refresh_exec()
  1030. return 1
  1031. def exec_select(self,nr):
  1032. cprint("SELECT EXEC")
  1033. sdata = EXEC.val_exec[nr]
  1034. cmd = ""
  1035. for fix in sdata:
  1036. if fix == "CFG":
  1037. continue
  1038. for attr in sdata[fix]:
  1039. #v2 = sdata[fix][attr]["VALUE"]
  1040. #v2_fx = sdata[fix][attr]["FX"]
  1041. #print( self.data.elem_attr)
  1042. #if fix in self.elem_attr:
  1043. # if attr in self.elem_attr[fix]:
  1044. # elem = self.elem_attr[fix][attr]
  1045. FIXTURES.fixtures[fix]["ATTRIBUT"][attr]["ACTIVE"] = 1
  1046. FIXTURES.fixtures[fix]["ATTRIBUT"]["_ACTIVE"]["ACTIVE"] = 1
  1047. #elem["bg"] = "yellow"
  1048. def exec_go(self,nr,val=None,xfade=None,event=None,button="",ptfade=None):
  1049. s=time.time()
  1050. t_start = time.time()
  1051. if xfade is None and FADE._is():
  1052. xfade = FADE.val()
  1053. if ptfade is None and FADE_move._is():
  1054. ptfade = FADE_move.val()
  1055. cprint("GO EXEC FADE",nr,val)
  1056. rdata = EXEC.get_raw_map(nr)
  1057. if not rdata:
  1058. return 0
  1059. cprint("???????")
  1060. cfg = EXEC.get_cfg(nr)
  1061. cprint("''''''''")
  1062. #virtcmd = FIXTURES.get_virtual(rdata)
  1063. if not cfg:
  1064. cprint("NO CFG",cfg,nr)
  1065. return 0
  1066. xFLASH = 0
  1067. value=None
  1068. cprint("exec_go",nr,cfg)
  1069. if modes.val("SELECT") or ( "BUTTON" in cfg and cfg["BUTTON"] == "SEL") and val and not button: #FLASH
  1070. self.exec_select(nr)
  1071. elif modes.val("FLASH") or ( "BUTTON" in cfg and cfg["BUTTON"] == "FL") and not button: #FLASH
  1072. xFLASH = 1
  1073. xfade = 0
  1074. if type(val) is not type(None) and val == 0 :
  1075. value = "off"
  1076. xfade=0
  1077. if "OUT-FADE" in cfg:
  1078. xfade=cfg["OUT-FADE"]
  1079. if event:
  1080. if str(event.type) == "ButtonRelease" or event.type == '5' :
  1081. value = "off"
  1082. xfade=0
  1083. if "OUT-FADE" in cfg:
  1084. xfade=cfg["OUT-FADE"]
  1085. cprint("exec_go() FLUSH",value,color="red")
  1086. #print(";",rdata)
  1087. print(";",cfg)
  1088. fcmd = FIXTURES.update_raw(rdata,update=0)
  1089. #print(":",fcmd) # raw dmx
  1090. self._exec_go(rdata,cfg,fcmd,value,xfade=xfade,xFLASH=xFLASH,nr=nr)
  1091. elif not val:
  1092. cprint("exec_go() STOP",value,color="red")
  1093. elif button == "on" or ( modes.val("ON") or ( "BUTTON" in cfg and cfg["BUTTON"] in ["on","ON"])):
  1094. fcmd = FIXTURES.update_raw(rdata)
  1095. self._exec_go(rdata,cfg,fcmd,value,xfade=0,xFLASH=xFLASH)
  1096. elif button == "go" or ( modes.val("GO") or ( "BUTTON" in cfg and cfg["BUTTON"] in ["go","GO"])):
  1097. fcmd = FIXTURES.update_raw(rdata)
  1098. e=time.time()
  1099. print("_GO TIME:","{:0.02f}".format(e-s),int(e*10)/10)
  1100. self._exec_go(rdata,cfg,fcmd,value,xfade=xfade,xFLASH=xFLASH,ptfade=ptfade,nr=nr)
  1101. e=time.time()
  1102. print("GO TIME:","{:0.02f}".format(e-s),int(e*10)/10)
  1103. return
  1104. if not (modes.val("FLASH") or ( "BUTTON" in cfg and cfg["BUTTON"] == "FL")): #FLASH
  1105. self.refresh_exec()
  1106. self.refresh_fix()
  1107. #print("IIIIIIIIIIIiiiiiiiiiiiiiiiiiii",nr,val)
  1108. #print(len(self.elem_exec) )
  1109. if len(self.elem_exec) > nr: # RED BUTTON IF PRESSED
  1110. #print("IIIIIIIIIIIiiiiiiiiiiiiiiiiiii",nr,val)
  1111. if val:# or value:
  1112. #self.elem_exec[nr].config(borderwidth=1)
  1113. self.elem_exec[nr].config(bg="red")
  1114. else:
  1115. self._refresh_exec()
  1116. cprint("exec_go",time.time()-t_start)
  1117. def _exec_go(self,rdata,cfg,fcmd,value=None,xfade=None,event=None,xFLASH=0,ptfade=0,nr=None):
  1118. if xfade is None and FADE._is():
  1119. xfade = FADE.val()
  1120. if ptfade is None and FADE_move._is():
  1121. ptfade = FADE_move.val()
  1122. cprint("EXEC._exec_go() len=",len(rdata),cfg)
  1123. if xfade is None:
  1124. xfade = cfg["FADE"]
  1125. if ptfade is None:
  1126. ptfade = cfg["FADE"]
  1127. #vcmd = reshape_exec( rdata ,value,[],xfade=xfade,fx=1)
  1128. #cprint(rdata,color="red")
  1129. vcmd = execlib.reshape_exec( rdata ,value,xfade=xfade,ptfade=ptfade)
  1130. cmd = []
  1131. delay=0
  1132. for i,v in enumerate(fcmd):
  1133. #print("go",i,v)
  1134. if xFLASH:
  1135. vcmd[i]["FLASH"] = 1
  1136. DMX = fcmd[i]["DMX"]
  1137. if "VALUE" in vcmd[i] and type(vcmd[i]["VALUE"]) is type(float):
  1138. vcmd[i]["VALUE"] = round(vcmd[i]["VALUE"],3)
  1139. if value is not None:
  1140. vcmd[i]["VALUE"] = value
  1141. if value == "off":
  1142. if "FX2" in vcmd:
  1143. vcmd[i]["FX2"]["TYPE"] = value
  1144. if "FIX" in fcmd:
  1145. vcmd[i]["FIX"] = fcmd["FIX"]
  1146. if DMX and vcmd[i]:
  1147. vcmd[i]["DMX"] = DMX
  1148. if type(nr) is not type(None):
  1149. vcmd[i]["EXEC"] = str(int(nr)+1)
  1150. cmd.append(vcmd[i])
  1151. if cmd and not modes.val("BLIND"):
  1152. jclient_send(cmd)
  1153. def render(self):
  1154. #Xroot.bind("<Key>",tk_event(fix=0,elem=None,attr="ROOT",data=self,mode="ROOT").cb)
  1155. #self.draw_input()
  1156. pass
  1157. ##draw_sub_dim
  1158. import tkgui.dialog as dialoglib
  1159. dialog = dialoglib.Dialog()
  1160. from tkgui.draw import *
  1161. from tkgui.GUI import *
  1162. class LOAD_SHOW_AND_RESTART():
  1163. def __init__(self,fname=""):
  1164. self.fname=fname
  1165. self.base = showlib.Base()
  1166. def cb(self,event=None,force=0):
  1167. print()
  1168. print()
  1169. print()
  1170. cprint("LOAD_SHOW_AND_RESTART.cb force={} name={}".format(force,self.fname),color="red" )
  1171. if not self.fname and not force:
  1172. return 0
  1173. if self.base.show_name == self.fname and not force:
  1174. cprint("filename is the same",self.fname)
  1175. return 0
  1176. if not force:
  1177. self.base._set(self.fname)
  1178. cprint("LOAD SHOW:",event,self.fname)
  1179. BASE_PATH = "/opt/LibreLight/Xdesk/"
  1180. cmd="_LibreLightDesk.py"
  1181. arg = ""
  1182. print("fork",[BASE_PATH,cmd,arg])
  1183. if "--easy" in sys.argv:
  1184. arg = "--easy"
  1185. movewin.process_kill(BASE_PATH+"tksdl/")
  1186. os.execl("/usr/bin/python3", BASE_PATH, cmd,arg)
  1187. sys.exit()
  1188. lf_nr = 0
  1189. from tkinter import PhotoImage
  1190. _shift_key = 0
  1191. class WindowManager():
  1192. def __init__(self):
  1193. self.windows = {}
  1194. self.obj = {}
  1195. self.nr= 0
  1196. self.first=""
  1197. self.window_init_buffer = {}
  1198. def update(self,w,name="",obj=None):
  1199. name = str(name)
  1200. for k in self.windows:
  1201. if k == name:
  1202. self.windows[str(name)] = w
  1203. self.obj[str(name)] = obj
  1204. def new(self,w,name="",obj=None,wcb=None):
  1205. name = str(name)
  1206. if wcb and name:
  1207. self.window_init_buffer[name] = wcb
  1208. if not self.first:
  1209. if name:
  1210. self.first = name
  1211. else:
  1212. self.first = str(self.nr)
  1213. if w:
  1214. w.tk.state(newstate='normal')
  1215. w.tk.attributes('-topmost',True)
  1216. if name:
  1217. self.windows[str(name)] = w
  1218. self.obj[str(name)] = obj
  1219. else:
  1220. self.windows[str(self.nr)] = w
  1221. self.obj[str(self.nr)] = obj
  1222. self.nr+=1
  1223. def mainloop(self):
  1224. self.windows[self.first].mainloop()
  1225. def get_win(self,name):
  1226. #cprint(".get_win(name) =",name)
  1227. name = str(name)
  1228. if name in self.windows:
  1229. out = self.windows[name]
  1230. #cprint(out)
  1231. return out
  1232. def get(self,name):
  1233. return get_win(name)
  1234. def get_obj(self,name):
  1235. name = str(name)
  1236. if name in self.windows:
  1237. out = self.obj[name]
  1238. return out
  1239. def create(self,name):
  1240. #cprint( "create WindowContainer",name)
  1241. if name in self.window_init_buffer:
  1242. c = self.window_init_buffer[name]
  1243. w,obj,cb_ok = c.create()
  1244. window_manager.update(w,name,obj)
  1245. if cb_ok:
  1246. cb_ok()
  1247. resize = 1
  1248. if "resize" in c.args:
  1249. if not c.args["resize"]:
  1250. resize = 0
  1251. #if resize:
  1252. libwin.get_window_position(_filter=name,win=w)
  1253. if name in ["ENCODER"]:
  1254. global _ENCODER_WINDOW
  1255. _ENCODER_WINDOW = w
  1256. if name in ["DIMMER","FIXTURES"]:
  1257. refresher_fix.reset() # = tkrefresh.Refresher()
  1258. def _check_window_is_open(self,name):
  1259. try:
  1260. win = self.windows[name]
  1261. if "tk" not in dir(win):
  1262. return 0
  1263. return win.tk.winfo_exists()
  1264. except Exception as e:
  1265. cprint("_check_window_is_open err",e,color="red")
  1266. def top(self,name):
  1267. name = str(name)
  1268. if name not in self.windows:
  1269. cprint(name," not in self.windows",self.windows.keys())
  1270. return
  1271. if not self._check_window_is_open(name):
  1272. cprint(" ",name," window is closed ! ")
  1273. self.create(name)
  1274. w = self.windows[name]
  1275. if not str(type(w)).startswith("<class 'function'>"):
  1276. w.tk.attributes('-topmost',True)
  1277. w.tk.attributes('-topmost',False)
  1278. w.tk.update_idletasks()
  1279. else:
  1280. print(" 2.2-",w)
  1281. w()
  1282. class Console():
  1283. def __init__(self):
  1284. pass
  1285. def flash_off(self,fix):
  1286. pass
  1287. def fx_off(self,fix):
  1288. cprint("Console.fx_off()",fix)
  1289. if not fix or fix == "all":
  1290. j = []
  1291. if 0:
  1292. jdata = {'VALUE': None, 'args': [], 'FX': 'alloff::::', 'FADE': 2, 'DMX': '0'}
  1293. j.append(jdata)
  1294. jdata = {'VALUE': None, 'args': [], 'FX': 'alloff::::', 'FADE': 2,'FLASH':1, 'DMX': '0'}
  1295. j.append(jdata)
  1296. else:
  1297. jdata = {'VALUE': None, 'args': [], 'FX2': {"TYPE":"alloff"}, 'FADE': 2,'FLASH':1, 'DMX': '1'}
  1298. j.append(jdata)
  1299. if not modes.val("BLIND"):
  1300. jclient_send(j)
  1301. return 0
  1302. window_manager = WindowManager()
  1303. CONSOLE = Console()
  1304. EXEC = execlib.EXEC()
  1305. def refresh_exec_mc():
  1306. time.sleep(10)
  1307. while 1:
  1308. try:
  1309. execlib.exec_set_mc(EXEC.label_exec,EXEC.val_exec)
  1310. except Exception as e:
  1311. print("refresh_exec_mc ERR",e)
  1312. time.sleep(5) # extra time
  1313. time.sleep(3) # refresh time
  1314. thread.start_new_thread(refresh_exec_mc,())
  1315. FIXTURES = fixlib.Fixtures()
  1316. FIXTURES.gui = GUIHandler()
  1317. def LOAD_SHOW():
  1318. EXEC.load_exec()
  1319. FIXTURES.load_patch()
  1320. LOAD_SHOW()
  1321. master = MASTER()
  1322. print("main",__name__)
  1323. import lib.tkrefresh as tkrefresh
  1324. refresher_fix = tkrefresh.Refresher()
  1325. refresher_fix.time_delta = 0.50
  1326. refresher_fix.name = "fix"
  1327. refresher_fix.reset()
  1328. refresher_fix.cb = master._refresh_fix
  1329. refresher_exec = tkrefresh.Refresher()
  1330. refresher_exec.time_delta = 10 #0
  1331. refresher_exec.name = "exec"
  1332. refresher_exec.reset()
  1333. refresher_exec.cb = master._refresh_exec
  1334. refresher_exec = tkrefresh.Refresher()
  1335. refresher_exec.time_delta = 10 #0
  1336. refresher_exec.name = "exec-fader"
  1337. refresher_exec.reset()
  1338. refresher_exec.cb = refresh_exec_fader_cfg
  1339. def loops(**args):
  1340. time.sleep(5) # wait until draw all window's
  1341. cprint("-> run loops")
  1342. thread.start_new_thread(refresher_fix.loop,())
  1343. thread.start_new_thread(refresher_exec.loop,())
  1344. thread.start_new_thread(loops,())
  1345. class window_create_sdl_buffer():
  1346. def __init__(self,args,cls,data,cb_ok=None,scroll=0,gui=None):
  1347. self.args = args.copy()
  1348. self.cls = cls
  1349. self.cb_ok = cb_ok
  1350. self.data = data
  1351. self.scroll = scroll
  1352. self.gui = gui
  1353. def create(self,hidde=0):
  1354. cprint()
  1355. return [self.cls,self.cls,None] #w,obj,cb_ok
  1356. def open_sdl_window():
  1357. cprint("open_sdl_window ... delay 1sec",color="yellow")
  1358. time.sleep(1)
  1359. if "--easy" not in sys.argv:
  1360. movewin.startup_all_sdl()
  1361. thread.start_new_thread(open_sdl_window,())
  1362. mc_fix = MC_FIX()
  1363. def mc_fix_loop():
  1364. time.sleep(5)
  1365. while 1:
  1366. try:
  1367. data = FIXTURES.fixtures
  1368. mc_fix.set(index="fix",data=data)
  1369. except Exception as e:
  1370. print("MC_FIX EXCEPTION",e)
  1371. time.sleep(1/10)
  1372. thread.start_new_thread(mc_fix_loop,())
  1373. if __run_main:
  1374. cprint("main")
  1375. TOP = libtk._POS_TOP + 15
  1376. L0 = libtk._POS_LEFT
  1377. L1 = libtk._POS_LEFT + 95
  1378. L2 = libtk._POS_LEFT + 920
  1379. W1 = 810
  1380. H1 = 550
  1381. HTB = 23 # hight of the titlebar from window manager
  1382. pos_list = libwin.read_window_position()
  1383. data = []
  1384. #data.append({"text":"COMMAND"})
  1385. #data.append({"text":"CONFIG"})
  1386. data.append({"text":"PATCH"})
  1387. data.append({"text":"DIMMER"})
  1388. data.append({"text":"FIXTURES"})
  1389. data.append({"text":"FIX-LIST"})
  1390. data.append({"text":"EXEC","name":"EXEC-BTN"})
  1391. data.append({"text":"EXEC-WING"})
  1392. data.append({"text":"---"})
  1393. data.append({"text":"SETUP"})
  1394. data.append({"text":"COMMAND"})
  1395. data.append({"text":"LIVE"})
  1396. data.append({"text":"FX"})
  1397. data.append({"text":"ENCODER"})
  1398. data.append({"text":"COLORPICKER","name":"COLOR"})
  1399. data.append({"text":"---"})
  1400. data.append({"text":"FIXTURE-EDITOR","name":"FIX-EDIT"})
  1401. data.append({"text":"CONFIG"})
  1402. data.append({"text":"SDL-MIDI"})
  1403. data.append({"text":"CLOCK"})
  1404. data.append({"text":"RAY-DMX"})
  1405. data.append({"text":"SDL-DMX"})
  1406. data.append({"text":"SDL-VPU"})
  1407. data.append({"text":"SDL-OSZI"})
  1408. data.append({"text":"---"})
  1409. data.append({"text":"---"})
  1410. data.append({"text":"- DEMO -"})
  1411. data.append({"text":"---"})
  1412. data.append({"text":"TK-EXEC"})
  1413. data.append({"text":"SDL-STAGE"})
  1414. data.append({"text":"SDL-Shader"})
  1415. data.append({"text":"TABLE"})
  1416. #data.append({"text":"MASTER-WING"})
  1417. name="MAIN"
  1418. args = {"title":"MAIN","master":1,"width":80,"height":H1,"left":L0,"top":TOP,"resize":1}
  1419. geo = libwin.split_window_position(pos_list,name)
  1420. if geo:
  1421. args.update(geo)
  1422. cls = GUI_menu
  1423. cb_ok = None
  1424. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1425. window_manager.new(None,name,wcb=c)
  1426. window_manager.top(name)
  1427. gui_menu_gui = window_manager.get_win(name)
  1428. gui_menu = window_manager.get_obj(name)
  1429. master._refresh_fix()
  1430. # =======================================================================
  1431. name="EXEC"
  1432. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1433. geo = libwin.split_window_position(pos_list,name)
  1434. if geo:
  1435. args.update(geo)
  1436. data = EXEC
  1437. cls = draw_exec #GUI_ExecWingLayout
  1438. cb_ok = None #set_exec_fader_all
  1439. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1440. window_manager.new(None,name,wcb=c)
  1441. if libwin.split_window_show(pos_list,_filter=name):
  1442. window_manager.top(name)
  1443. #print(dir(cls))
  1444. #print(cls)
  1445. #sys.exit()
  1446. # =======================================================================
  1447. name="SDL-MIDI"
  1448. def sdl_config():
  1449. cmd="nohup /usr/bin/python3 /opt/LibreLight/Xdesk/tksdl/midi.py &"
  1450. cmd="/usr/bin/python3 /opt/LibreLight/Xdesk/tksdl/midi.py " #&"
  1451. print(cmd)
  1452. #os.popen(cmd)
  1453. def xyz123(cmd):
  1454. os.system(cmd)
  1455. thread.start_new_thread(xyz123,(cmd,))
  1456. return [None,None,None]
  1457. #class window_create_sdl_buffer():
  1458. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1459. geo = libwin.split_window_position(pos_list,name)
  1460. if geo:
  1461. args.update(geo)
  1462. data = []
  1463. cls = sdl_config #: None #GUI_CONF
  1464. cb_ok = None
  1465. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1466. window_manager.new(None,name,wcb=c)
  1467. if libwin.split_window_show(pos_list,_filter=name):
  1468. window_manager.top(name)
  1469. # =======================================================================
  1470. name="SDL-VPU"
  1471. def sdl_config():
  1472. cmd="python3 /opt/LibreLight/Xdesk/vpu/watchdog_vpu.py -single"
  1473. print(cmd)
  1474. def xyz123(cmd):
  1475. os.system(cmd)
  1476. thread.start_new_thread(xyz123,(cmd,))
  1477. return [None,None,None]
  1478. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1479. geo = libwin.split_window_position(pos_list,name)
  1480. if geo:
  1481. args.update(geo)
  1482. data = []
  1483. cls = sdl_config #: None #GUI_CONF
  1484. cb_ok = None
  1485. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1486. window_manager.new(None,name,wcb=c)
  1487. if libwin.split_window_show(pos_list,_filter=name):
  1488. window_manager.top(name)
  1489. # =======================================================================
  1490. name="SDL-OSZI"
  1491. def sdl_config():
  1492. cmd="python3 /opt/LibreLight/ASP/monitor/oszi_grid.py"
  1493. print(cmd)
  1494. def xyz123(cmd):
  1495. os.system(cmd)
  1496. thread.start_new_thread(xyz123,(cmd,))
  1497. return [None,None,None]
  1498. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1499. geo = libwin.split_window_position(pos_list,name)
  1500. if geo:
  1501. args.update(geo)
  1502. data = []
  1503. cls = sdl_config #: None #GUI_CONF
  1504. cb_ok = None
  1505. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1506. window_manager.new(None,name,wcb=c)
  1507. if libwin.split_window_show(pos_list,_filter=name):
  1508. window_manager.top(name)
  1509. # =======================================================================
  1510. name="SDL-DMX"
  1511. def sdl_config():
  1512. cmd="/usr/bin/python3 /opt/LibreLight/Xdesk/tksdl/dmx.py " #&"
  1513. print(cmd)
  1514. def xyz123(cmd):
  1515. os.system(cmd)
  1516. thread.start_new_thread(xyz123,(cmd,))
  1517. return [None,None,None]
  1518. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1519. geo = libwin.split_window_position(pos_list,name)
  1520. if geo:
  1521. args.update(geo)
  1522. data = []
  1523. cls = sdl_config #: None #GUI_CONF
  1524. cb_ok = None
  1525. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1526. window_manager.new(None,name,wcb=c)
  1527. if libwin.split_window_show(pos_list,_filter=name):
  1528. window_manager.top(name)
  1529. # =======================================================================
  1530. name="RAY-DMX"
  1531. def sdl_config():
  1532. cmd="/usr/bin/python3 /opt/LibreLight/Xdesk/tkray/dmx.py " #&"
  1533. print(cmd)
  1534. def xyz123(cmd):
  1535. os.system(cmd)
  1536. thread.start_new_thread(xyz123,(cmd,))
  1537. return [None,None,None]
  1538. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1539. geo = libwin.split_window_position(pos_list,name)
  1540. if geo:
  1541. args.update(geo)
  1542. data = []
  1543. cls = sdl_config #: None #GUI_CONF
  1544. cb_ok = None
  1545. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1546. window_manager.new(None,name,wcb=c)
  1547. if libwin.split_window_show(pos_list,_filter=name):
  1548. window_manager.top(name)
  1549. # =======================================================================
  1550. name="TK-EXEC"
  1551. def sdl_config():
  1552. cmd="/usr/bin/python3 /opt/LibreLight/Xdesk/tkgui/EXEC.py " #&"
  1553. print(cmd)
  1554. def xyz123(cmd):
  1555. os.system(cmd)
  1556. thread.start_new_thread(xyz123,(cmd,))
  1557. return [None,None,None]
  1558. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1559. geo = libwin.split_window_position(pos_list,name)
  1560. if geo:
  1561. args.update(geo)
  1562. data = []
  1563. cls = sdl_config #: None #GUI_CONF
  1564. cb_ok = None
  1565. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1566. window_manager.new(None,name,wcb=c)
  1567. if libwin.split_window_show(pos_list,_filter=name):
  1568. window_manager.top(name)
  1569. # =======================================================================
  1570. name="SDL-STAGE"
  1571. def sdl_config():
  1572. cmd="/usr/bin/python3 /opt/LibreLight/Xdesk//3d/stage_3d.py " #&"
  1573. print(cmd)
  1574. def xyz123(cmd):
  1575. os.system(cmd)
  1576. thread.start_new_thread(xyz123,(cmd,))
  1577. return [None,None,None]
  1578. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1579. geo = libwin.split_window_position(pos_list,name)
  1580. if geo:
  1581. args.update(geo)
  1582. data = []
  1583. cls = sdl_config #: None #GUI_CONF
  1584. cb_ok = None
  1585. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1586. window_manager.new(None,name,wcb=c)
  1587. if libwin.split_window_show(pos_list,_filter=name):
  1588. window_manager.top(name)
  1589. # =======================================================================
  1590. name="SDL-Shader"
  1591. def sdl_config():
  1592. cmd="/usr/bin/python3 /opt/LibreLight/Xdesk//3d/demo_shaders.py " #&"
  1593. print(cmd)
  1594. #os.popen(cmd)
  1595. def xyz123(cmd):
  1596. os.system(cmd)
  1597. thread.start_new_thread(xyz123,(cmd,))
  1598. return [None,None,None]
  1599. #class window_create_sdl_buffer():
  1600. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1601. geo = libwin.split_window_position(pos_list,name)
  1602. if geo:
  1603. args.update(geo)
  1604. data = []
  1605. cls = sdl_config #: None #GUI_CONF
  1606. cb_ok = None
  1607. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1608. window_manager.new(None,name,wcb=c)
  1609. if libwin.split_window_show(pos_list,_filter=name):
  1610. window_manager.top(name)
  1611. # =======================================================================
  1612. name="FIX-LIST"
  1613. def sdl_config():
  1614. cmd="/usr/bin/python3 /opt/LibreLight/Xdesk/tksdl/fix.py " #&"
  1615. print(cmd)
  1616. #os.popen(cmd)
  1617. def xyz123(cmd):
  1618. os.system(cmd)
  1619. thread.start_new_thread(xyz123,(cmd,))
  1620. return [None,None,None]
  1621. #class window_create_sdl_buffer():
  1622. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1623. geo = libwin.split_window_position(pos_list,name)
  1624. if geo:
  1625. args.update(geo)
  1626. data = []
  1627. cls = sdl_config #: None #GUI_CONF
  1628. cb_ok = None
  1629. c = window_create_sdl_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1630. window_manager.new(None,name,wcb=c)
  1631. if libwin.split_window_show(pos_list,_filter=name):
  1632. window_manager.top(name)
  1633. # =======================================================================
  1634. name="CONFIG"
  1635. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1636. geo = libwin.split_window_position(pos_list,name)
  1637. if geo:
  1638. args.update(geo)
  1639. data = []
  1640. cls = GUI_CONF
  1641. cb_ok = None
  1642. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1643. window_manager.new(None,name,wcb=c)
  1644. if libwin.split_window_show(pos_list,_filter=name):
  1645. window_manager.top(name)
  1646. # =======================================================================
  1647. name="DIMMER"
  1648. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1649. geo = libwin.split_window_position(pos_list,name)
  1650. if geo:
  1651. args.update(geo)
  1652. cls = GUI_DIM
  1653. data = FIXTURES
  1654. ok_cb=None
  1655. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1656. window_manager.new(None,name,wcb=c)
  1657. if libwin.split_window_show(pos_list,_filter=name):
  1658. window_manager.top(name)
  1659. # =======================================================================
  1660. name="FIXTURES"
  1661. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1662. geo = libwin.split_window_position(pos_list,name)
  1663. if geo:
  1664. args.update(geo)
  1665. cls = GUI_FIX
  1666. ok_cb=None
  1667. data = FIXTURES
  1668. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1669. window_manager.new(None,name,wcb=c)
  1670. if libwin.split_window_show(pos_list,_filter=name):
  1671. window_manager.top(name)
  1672. # =======================================================================
  1673. name="FIXTURE-EDITOR"
  1674. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP}
  1675. geo = libwin.split_window_position(pos_list,name)
  1676. if geo:
  1677. args.update(geo)
  1678. data=[]
  1679. for i in range(12*6):
  1680. data.append({"text"+str(i):"test"})
  1681. import tkgui.fix as guifix
  1682. cls = guifix.GUI_FixtureEditor
  1683. cb_ok = None
  1684. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1685. window_manager.new(None,name,wcb=c)
  1686. # =======================================================================
  1687. name="MASTER-WING"
  1688. args = {"title":name,"master":0,"width":75,"height":405,"left":L0,"top":TOP+H1-220,"resize":0}
  1689. geo = libwin.split_window_position(pos_list,name)
  1690. if geo:
  1691. args.update(geo)
  1692. data=[]
  1693. for i in range(2):
  1694. data.append({"MASTER"+str(i):"MASTER"})
  1695. cls = GUI_MasterWingLayout #(w1,data)
  1696. cb_ok = None
  1697. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1698. window_manager.new(None,name,wcb=c)
  1699. if libwin.split_window_show(pos_list,_filter=name):
  1700. window_manager.top(name)
  1701. # =======================================================================
  1702. name="EXEC-WING"
  1703. args = {"title":name,"master":0,"width":600,"height":415,"left":L1,"top":TOP+H1+HTB*2,"H1":H1,"W1":W1}
  1704. geo = libwin.split_window_position(pos_list,name)
  1705. if geo:
  1706. args.update(geo)
  1707. data=[]
  1708. for i in range(10*3):
  1709. data.append({"EXEC"+str(i):"EXEC"})
  1710. cls = GUI_ExecWingLayout
  1711. cb_ok = set_exec_fader_all
  1712. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1713. window_manager.new(None,name,wcb=c)
  1714. if libwin.split_window_show(pos_list,_filter=name):
  1715. window_manager.top(name)
  1716. # =======================================================================
  1717. name="ENCODER"
  1718. args = {"title":name,"master":0,"width":620,"height":113,"left":L0+710,"top":TOP+H1+15+HTB*2}
  1719. geo = libwin.split_window_position(pos_list,name)
  1720. if geo:
  1721. args.update(geo)
  1722. cls = draw_enc #(master,w.tk)#Xroot)
  1723. cb_ok = None
  1724. data = FIXTURES #master
  1725. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1726. window_manager.new(None,name,wcb=c)
  1727. if libwin.split_window_show(pos_list,_filter=name):
  1728. window_manager.top(name)
  1729. # =======================================================================
  1730. name = "SETUP"
  1731. args = {"title":name +" SHOW:"+master.base.show_name,
  1732. "master":0,"width":445,"height":42,"left":L1+10+W1,"top":TOP,"resize":10}
  1733. args["title"] = "SETUP SHOW:"+master.base.show_name
  1734. geo = libwin.split_window_position(pos_list,name)
  1735. try:
  1736. geo["width"] = args["width"]
  1737. geo["height"] = args["height"]
  1738. except:pass
  1739. if geo:
  1740. args.update(geo)
  1741. cls = draw_setup #(master,w.tk)
  1742. data = []
  1743. cb_ok = None
  1744. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1745. window_manager.new(None,name,wcb=c)
  1746. if libwin.split_window_show(pos_list,_filter=name):
  1747. window_manager.top(name)
  1748. # =======================================================================
  1749. name = "COMMAND"
  1750. args = {"title":name,"master":0,"width":415,"height":130,"left":L1+10+W1,"top":TOP+81,"resize":10}
  1751. geo = libwin.split_window_position(pos_list,name)
  1752. if geo:
  1753. args.update(geo)
  1754. cls = draw_command #(master,w.tk)
  1755. data = []
  1756. cb_ok = None
  1757. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1758. window_manager.new(None,name,wcb=c)
  1759. if libwin.split_window_show(pos_list,_filter=name):
  1760. window_manager.top(name)
  1761. # =======================================================================
  1762. name = "LIVE"
  1763. args = {"title":name,"master":0,"width":415,"height":42,"left":L1+10+W1,"top":TOP+235,"resize":10}
  1764. geo = libwin.split_window_position(pos_list,name)
  1765. if geo:
  1766. args.update(geo)
  1767. cls = draw_live #(master,w.tk)
  1768. data = []
  1769. cb_ok = None
  1770. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1771. window_manager.new(None,name,wcb=c)
  1772. if libwin.split_window_show(pos_list,_filter=name):
  1773. window_manager.top(name)
  1774. # =======================================================================
  1775. name = "CLOCK"
  1776. args = {"title":name,"master":0,"width":335,"height":102,"left":L1+10+W1+80,"top":TOP+H1+HTB+160,"resize":0}
  1777. geo = libwin.split_window_position(pos_list,name)
  1778. if geo:
  1779. args.update(geo)
  1780. cclock = X_CLOCK()
  1781. cls = cclock.draw_clock
  1782. data = []
  1783. cb_ok = None
  1784. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1785. window_manager.new(None,name,wcb=c)
  1786. if libwin.split_window_show(pos_list,_filter=name):
  1787. window_manager.top(name)
  1788. # =======================================================================
  1789. name="FX"
  1790. args = {"title":name,"master":0,"width":415,"height":297+30,"left":L1+10+W1,"top":TOP+302,"resize":1}
  1791. geo = libwin.split_window_position(pos_list,name)
  1792. if geo:
  1793. args.update(geo)
  1794. cls = draw_fx #(master,w.tk)
  1795. data = []
  1796. cb_ok = None
  1797. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1798. window_manager.new(None,name,wcb=c)
  1799. if libwin.split_window_show(pos_list,_filter=name):
  1800. window_manager.top(name)
  1801. # =======================================================================
  1802. name="PATCH"
  1803. args = {"title":name,"master":0,"width":W1,"height":H1,"left":L1,"top":TOP,"foot":1,"head":1}
  1804. geo = libwin.split_window_position(pos_list,name)
  1805. if geo:
  1806. args.update(geo)
  1807. cls = GUI_PATCH
  1808. data = FIXTURES
  1809. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=1)
  1810. window_manager.new(None,name,wcb=c) #,obj)
  1811. if libwin.split_window_show(pos_list,_filter=name):
  1812. window_manager.top(name)
  1813. # =======================================================================
  1814. name="COLORPICKER"
  1815. args = {"title":name,"master":0,"width":600,"height":113,"left":L1+5,"top":TOP+5+HTB*2+H1}
  1816. geo = libwin.split_window_position(pos_list,name)
  1817. if geo:
  1818. args.update(geo)
  1819. cls = draw_colorpicker #(master,w.tk,FIXTURES,master)
  1820. data = [FIXTURES,master]
  1821. cb_ok = None #FIXTURES
  1822. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1823. window_manager.new(None,name,wcb=c)
  1824. if libwin.split_window_show(pos_list,_filter=name):
  1825. window_manager.top(name)
  1826. # =======================================================================
  1827. name="TABLE"
  1828. args = {"title":name,"master":0,"width":600,"height":113,"left":L1+5,"top":TOP+5+HTB*2+H1}
  1829. geo = libwin.split_window_position(pos_list,name)
  1830. if geo:
  1831. args.update(geo)
  1832. #cls = draw_colorpicker #(master,w.tk,FIXTURES,master)
  1833. cls = TableFrame #(root=w.tk)#,left=80,top=620)
  1834. data = [FIXTURES,master]
  1835. cb_ok = None #FIXTURES
  1836. c = libtk.window_create_buffer(args=args,cls=cls,data=data,cb_ok=cb_ok,gui=master,scroll=0)
  1837. window_manager.new(None,name,wcb=c)
  1838. if libwin.split_window_show(pos_list,_filter=name):
  1839. window_manager.top(name)
  1840. def wm_mainloop():
  1841. try:
  1842. window_manager.mainloop()
  1843. finally:
  1844. print()
  1845. print()
  1846. cprint(" - EXIT -",color="red")
  1847. BASE_PATH = "/opt/LibreLight/Xdesk/"
  1848. movewin.process_kill(BASE_PATH+"tksdl/")
  1849. master.exit()
  1850. sys.exit()
  1851. wm_mainloop() #window_manager.mainloop()
  1852. # thread.start_new_thread(wm_mainloop,()) # break TKINTER !!!
  1853. while 1:
  1854. print("loop..")
  1855. time.sleep(1)