fix.py 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849
  1. #from pyray import *
  2. import pyray
  3. import sys
  4. import _thread as thread
  5. sys.path.insert(0,"/opt/LibreLight/Xdesk/")
  6. CAPTION = 'RAY-FIX-LIST'
  7. import tool.movewin as movewin
  8. import pathlib
  9. _file_path=pathlib.Path(__file__)
  10. print("file:",_file_path)
  11. movewin.check_is_started(CAPTION,_file_path)
  12. win_title =CAPTION.strip().split()[-1]
  13. store = movewin.load_all_sdl(win_title)
  14. print(store)
  15. POS=[10,10]
  16. W=760
  17. H=450
  18. if store:
  19. POS[0] += 5 #frame kompensation
  20. POS[1] += 29 #frame kompensation
  21. POS=[store[-2],store[-1]]
  22. RUN = 1
  23. pyray.set_config_flags(pyray.FLAG_WINDOW_RESIZABLE)
  24. pyray.init_window(W, H, CAPTION) #"RAY-DMX")#,10,10,10,10)
  25. pyray.set_window_min_size(200,200)
  26. pyray.set_window_max_size(1000,1000)
  27. pyray.set_exit_key(-1)
  28. #pyray.set_captur_key(-1)
  29. pyray.begin_drawing()
  30. pyray.clear_background(pyray.BLACK)
  31. pyray.Color(255,0,0,0)
  32. pyray.end_drawing()
  33. pyray.set_target_fps(60)
  34. import json
  35. import lib.zchat as chat
  36. cmd_client = chat.Client(port=30003)
  37. win_con = movewin.Control()
  38. win_con.title = win_title
  39. win_con.winfo()
  40. if POS:
  41. win_con.move(POS[0],POS[1])
  42. print(POS,win_con.title)
  43. #exit()
  44. import sys
  45. sys.path.insert(0,"/opt/LibreLight/Xdesk/")
  46. import tool.tk_elm as tk_elm
  47. #import tool.sdl_elm as sdl_elm
  48. img = "/opt/LibreLight/Xdesk/icon/scribble.png"
  49. IMG = pyray.load_image(img)
  50. print(pyray.set_window_icon(IMG))
  51. import time
  52. import memcache
  53. mc = memcache.Client(['127.0.0.1:11211'], debug=0)
  54. #x=mc.get(k)
  55. old_x = -10
  56. old_y = -10
  57. start = time.time()
  58. frame_count = 0
  59. fps_count = 0
  60. a = "/usr/share/fonts/truetype/freefont/FreeSans.ttf"
  61. a = "/usr/share/fonts/truetype/freefont/FreeSansBold.ttf"
  62. k=200
  63. a = "/usr/share/fonts/truetype/freefont/FreeSans.ttf"
  64. font_l_10 = pyray.load_font_ex(a, 10, None, 0);
  65. a = "/usr/share/fonts/truetype/freefont/FreeSansBold.ttf"
  66. font10 = pyray.load_font_ex(a, 10, None, 0);
  67. font12 = pyray.load_font_ex(a, 12, None, 0);
  68. font14 = pyray.load_font_ex(a, 14, None, 0);
  69. font16 = pyray.load_font_ex(a, 16, None, 0);
  70. font20 = pyray.load_font_ex(a, 20, None, 0);
  71. font22 = pyray.load_font_ex(a, 22, None, 0);
  72. font24 = pyray.load_font_ex(a, 24, None, 0);
  73. a = "/usr/share/fonts/truetype/freefont/FreeSans.ttf"
  74. font_l_22 = pyray.load_font_ex(a, 22, None, 0);
  75. a = "/usr/share/fonts/truetype/freefont/FreeMono.ttf"
  76. a = "/usr/share/fonts/truetype/freefont/FreeSansBold.ttf"
  77. a = "/usr/share/fonts/truetype/freefont/FreeSans.ttf"
  78. font25 = pyray.load_font_ex(a, 25, None, 0);
  79. pyray.TextureFilter(3)
  80. class EVENT():
  81. def __init__(self):
  82. self.dict = {}
  83. self.type = 0
  84. self.button=10
  85. self.buttons=[0,0,0,0]
  86. xevent=EVENT()
  87. class BUTTON():
  88. def __init__(self,master=None,txt="<BUTTON>",pos=[10,10,20,90]):
  89. #self.btn = tk_elm.Button(None,pos=[390,12,20,90])
  90. self.btn = tk_elm.Button(master,pos=pos)
  91. self.btn.btn1.color = [127,127,127,255]
  92. #self.btn.btn1.type = "toggle"
  93. #self.btn.btn2.type = "toggle"
  94. #self.btn.btn3.type = "toggle"
  95. #btn.btn1.color_on = [155,155,155,255]
  96. #btn.btn2.color = [155,55,155,255]
  97. #btn.btn2.color_on = [155,155,155,255]
  98. self.btn.btn3.color = [55,155,155,255]
  99. self.btn.btn3.color_on = [55,255,255,255]
  100. self.btn.btn2.color_on = [55,255,255,255]
  101. self.font = font14
  102. self.val = 0
  103. self.btn.btn1.name=txt
  104. #x=btn.btn1.name
  105. def __repr__(self):
  106. return "<BUTTON {} {} {}>".format(id(self),str(self.btn.pos),self.btn.btn1.name)
  107. def draw(self,event=None):
  108. pos=self.btn.pos
  109. c=[122,122,122,122] #btn.btn2.get_color()
  110. pyray.draw_rectangle(pos[1],pos[0],pos[3],pos[2],c)
  111. c=self.btn.btn1.get_color()
  112. pyray.draw_rectangle(pos[1]+2,pos[0]+2,pos[3]-4,pos[2]-4,c)
  113. c=self.btn.btn4.color # color bar
  114. pyray.draw_rectangle(pos[1]+2,pos[0]+2,1+int((pos[3]-4)*self.val/255),3,c)
  115. c=self.btn.btn3.get_color()
  116. #pyray.draw_rectangle(pos[1]+1,pos[0]+1,pos[3]-2,pos[2]-2,c)
  117. pyray.draw_rectangle_lines_ex([pos[1]+1,pos[0]+1,pos[3]-2,pos[2]-2],1,c)
  118. x=self.btn.btn1.name
  119. font_size = self.font.baseSize
  120. pyray.draw_text_ex(self.font,str(x), [pos[1]+4,pos[0]+4], font_size, 0, [0,0,0,255])#pyray.YELLOW)#[0,255,0,255]) #pyray.YELLOW)
  121. def event(self,x,y,mouse):
  122. try:
  123. buttons = [0,0,0]
  124. button = 0
  125. PRESS=5 #1025
  126. RELEASE=6 #1026
  127. _type=0
  128. for i in range(3):#2,0,-1):
  129. #print(i,mouse)
  130. if mouse[i] == "press":
  131. _type=PRESS
  132. if mouse[i] == "release":
  133. _type=RELEASE
  134. if mouse[i]:
  135. buttons[i] = 1
  136. button = i+1
  137. xevent.dict={"pos":[y,x],"button":button,"buttons":buttons,"type":_type}
  138. #print(xevent.dict)
  139. pos=self.btn.pos
  140. if check_area(pos,[y,x]):
  141. #print("POS:",x,y,mouse,xevent.type)
  142. for i,v in enumerate(mouse):
  143. if i==0:
  144. #if v == "release": # or v == "click":
  145. if v == "click": #"press" or v == "click": # or v == "release":
  146. self.btn.btn1.type = "toggle"
  147. self.btn.btn1.press()
  148. #xevent.type=5
  149. #xevent.dict["button"] = 1
  150. #self.btn.btn1.val.set(0)
  151. #xevent.dict["buttons"] = mouse
  152. #print(xevent.dict,xevent.type,xevent.button)
  153. self.btn.event(xevent)
  154. except Exception as e:
  155. import traceback
  156. print(traceback.format_exc())
  157. raise e
  158. mouse_box_on = 0
  159. mouse_box_on_pos = [0,0]
  160. def draw_mouse_box(window,pos1,mouse=[None,None,None],color=[128,128,128],text=1):
  161. global mouse_box_on_pos
  162. global mouse_box_on
  163. if mouse[0]=="click":#"press":
  164. if mouse_box_on == 0:
  165. pos2 = pos1[:]
  166. mouse_box_on_pos = pos2
  167. mouse_box_on = 1
  168. else:
  169. mouse_box_on = 0
  170. if mouse[0]=="press":
  171. pos2 = mouse_box_on_pos[:]
  172. w=pos1[0]-pos2[0]
  173. h=pos1[1]-pos2[1]
  174. pos = pos2[:]
  175. #print(pos1,pos2,h,w)
  176. wd=1
  177. hd=1
  178. if w < 0:
  179. pos[0] = pos1[0]
  180. w*=-1
  181. wd=-1
  182. if h < 0:
  183. pos[1] = pos1[1]
  184. h*=-1
  185. hd=-1
  186. if w > 10 or h > 10:
  187. c=[255,255,255,255]
  188. pyray.draw_rectangle_lines_ex([pos[0],pos[1],w,h],1,c)
  189. font_size = font_l_10.baseSize
  190. pyray.draw_text_ex(font_l_10,str(pos1[0])+" "+str(pos1[1]), [pos1[0],pos1[1]-10], font_size, 0, pyray.WHITE)
  191. pyray.draw_text_ex(font_l_10,str(pos2[0])+" "+str(pos2[1]), [pos2[0]+5,pos2[1]+10], font_size, 0, pyray.WHITE)
  192. pyray.draw_text_ex(font_l_10,str(w), [pos2[0]+5+w/2*wd,pos2[1]], font_size, 0, pyray.WHITE)
  193. pyray.draw_text_ex(font_l_10,str(h), [pos2[0]+5,pos2[1]+h/2*hd], font_size, 0, pyray.WHITE)
  194. return pos1,pos2
  195. mouse_old=[None,None,None]
  196. def check_area_v(v1,v2,event_v):#elm_pos,event_pos):
  197. if event_v < v1+1:
  198. return 0
  199. if event_v > v2-1:
  200. return 0
  201. return 1
  202. def check_area(pos,event_pos):
  203. v2 = pos[0]+pos[2]
  204. x = check_area_v(pos[0],v2,event_pos[0])
  205. v2 = pos[1]+pos[3]
  206. y = check_area_v(pos[1],v2,event_pos[1])
  207. if x and y:
  208. return 1
  209. def is_hidden_attr(attr_name):
  210. if attr_name.endswith("-FINE"):
  211. return 1
  212. if attr_name == "END":
  213. return 1
  214. if attr_name.startswith("_"):
  215. return 1
  216. return 0
  217. def read_dmx():
  218. dmx = {} #univ
  219. iii = 0
  220. y=mc.get("index")
  221. if y:
  222. key=y.keys()
  223. key = list(key)
  224. key.sort()
  225. for k in key:
  226. if k.startswith("ltp-out"):
  227. #v = y[k]
  228. u = k.split(":")[-1]
  229. x=mc.get(k)
  230. dmx[u] = x
  231. return dmx
  232. def read_fix(dmx):
  233. global mc
  234. y=mc.get("fix")#cmd)
  235. if y is None:
  236. print("==== "*10)
  237. print("error -- read_fix(dmx) mc.get('fix') return",y)
  238. print()
  239. mc = memcache.Client(['127.0.0.1:11211'], debug=0)
  240. return {}
  241. key=y.keys()
  242. key = list(key)
  243. key.sort()
  244. for k in key:#y.items():
  245. v = y[k]
  246. #print(k,v)
  247. x=mc.get(k)
  248. dmx_start = 0
  249. if "DMX" in v:
  250. dmx_start = v["DMX"]
  251. univ_start = 0
  252. if "UNIVERS" in v:
  253. univ_start = v["UNIVERS"]
  254. if "ATTRIBUT" in v: # and 10:
  255. ATTR = v["ATTRIBUT"]
  256. for k2 in ATTR:
  257. k2_ATTR = ATTR[k2]
  258. k2_ATTR["VALUE2"] = -2
  259. if is_hidden_attr(k2):
  260. #if k2.startswith("_"):
  261. continue
  262. k3 = k+"-"+k2
  263. dmx_nr = 0
  264. if "NR" in k2_ATTR:
  265. if k2_ATTR["NR"] >= 1:
  266. dmx_nr = k2_ATTR["NR"]+1
  267. val2 = ""
  268. if "VALUE" in k2_ATTR:
  269. val2 = k2_ATTR["VALUE"]
  270. dmx_val=-1
  271. dmx_x=-1
  272. if dmx_nr > 0 and dmx_start > 0:
  273. try:
  274. dmx_x = dmx_start-1+dmx_nr-1
  275. dmx_val = dmx[str(univ_start)][dmx_x-1]
  276. except:pass
  277. if type(dmx_val) in [int,float]:
  278. k2_ATTR["VALUE2"] = dmx_val
  279. else:
  280. k2_ATTR["VALUE2"] = 0
  281. return y
  282. _load_fix_DATA = {}
  283. _load_fix_fix_list = {}
  284. _load_fix_last = time.time()
  285. _load_fix_keys = 0
  286. _load_fix_init = 0
  287. _load_fix_keys = []
  288. lock = thread.allocate_lock()
  289. #lock.acquire()
  290. #lock.release()
  291. def get_fix():
  292. lock.acquire()
  293. a=_load_fix_keys #= keys.copy()
  294. b=_load_fix_fix_list #= fix_list.copy()
  295. #a,b = _load_fix_keys.copy(), _load_fix_fix_list.copy()
  296. lock.release()
  297. return a,b
  298. def load_fix():
  299. global _load_fix_DATA
  300. global _load_fix_fix_list
  301. global _load_fix_keys
  302. global _load_fix_init
  303. global _load_fix_last
  304. if not _load_fix_init:
  305. pass
  306. elif _load_fix_last+1 > time.time():
  307. pass
  308. #lock.acquire()
  309. #a,b = _load_fix_keys.copy(), _load_fix_fix_list.copy()
  310. #lock.release()
  311. #return a,b
  312. #return _load_fix_keys.copy(), _load_fix_fix_list.copy()
  313. print("load_fix update")
  314. _load_fix_last = time.time()
  315. _load_fix_init = 1
  316. DATA=mc.get("fix")#cmd)
  317. keys = []
  318. fix_list = {}
  319. if not DATA:
  320. DATA = {}
  321. print("mc.get ist NONE")
  322. #continue
  323. for k in DATA:
  324. keys.append(k)
  325. fix_list[k] = DATA[k] #[0]).ljust(" ",18) #,0,"=",0]
  326. keys.sort()
  327. lock.acquire()
  328. _load_fix_keys = keys.copy()
  329. _load_fix_fix_list = fix_list.copy()
  330. #a,b = _load_fix_keys.copy(), _load_fix_fix_list.copy()
  331. lock.release()
  332. #return a,b
  333. def loop_load_fix():
  334. global RUN
  335. while RUN:
  336. try:
  337. load_fix()
  338. time.sleep(1)
  339. except Exception as e:
  340. print("EXC loop_load_fix:",e)
  341. load_fix()
  342. thread.start_new_thread(loop_load_fix,())
  343. def check_buttons(buttons,fix_list):
  344. #raylib.enable_event_waiting()
  345. #pyray.disable_event_waiting() # not working , fast clickinb button or key
  346. _x=20
  347. _y=30
  348. H = 22
  349. W = 100
  350. W2 = W+20
  351. _last_v = {}
  352. for i,k in enumerate(fix_list): #.items():
  353. _x=20
  354. key = str(i)
  355. on_color = [255,255,0,255]
  356. on_color = [200,200,50,255] # gold
  357. if key not in buttons: # insert
  358. v=fix_list[k]
  359. _last_v = v
  360. txt="ID:"+str(v["ID"])
  361. btn=BUTTON(None,txt,[_y,_x,H,60])
  362. btn.btn.btn1.color_on = on_color
  363. buttons[key+".ID"] = btn
  364. #print("ADD",key,btn)
  365. _x+=60+2
  366. txt=v["NAME"]
  367. btn=BUTTON(None,txt,[_y,_x,H,W])
  368. btn.btn.btn1.color_on = on_color
  369. buttons[key] = btn
  370. #print("ADD",key,btn)
  371. _x+=W+5
  372. key = str(i)+":dim"
  373. txt = ""
  374. btn=BUTTON(None,txt,[_y,_x,H,10])
  375. btn.btn.btn1.color = [0,0,0,255]
  376. btn.btn.btn1.color_on = on_color
  377. buttons[key] = btn
  378. _x+=10+1
  379. key = str(i)+":rgb"
  380. txt = ""
  381. btn=BUTTON(None,txt,[_y,_x,H,20])
  382. btn.btn.btn1.color = [0,0,0,255]
  383. btn.btn.btn1.color_on = on_color
  384. buttons[key] = btn
  385. _x+=20+5
  386. if "ATTRIBUT" in v:
  387. #print(txt)
  388. ATTR = v["ATTRIBUT"]
  389. if 1:
  390. ay2=_y
  391. ax2=_x
  392. for kk,vv in v["ATTRIBUT"].items():
  393. if "-FINE" in kk or kk.startswith("_"):
  394. continue
  395. key = str(i)+":" +kk
  396. VAL = vv["VALUE"]
  397. #print("-",kk,vv)
  398. txt = kk+" "+str(VAL)
  399. btn=BUTTON(None,txt,[ay2,ax2,H,W2])
  400. btn.btn.btn1.color_on = on_color
  401. #self.btn4.increment = 4.4
  402. #self.btn4.type = "fader"
  403. #self.btn4.nr_on = [4]
  404. #self.btn4.nr_off = [5]
  405. RGB = [255,255,255,255]
  406. if kk == "RED":
  407. RGB = [255,0,0,255]
  408. elif kk == "GREEN":
  409. RGB = [0,255,0,255]
  410. elif kk == "BLUE":
  411. RGB = [0,0,255,255]
  412. btn.btn.btn4.color = RGB
  413. #btn.btn.btn4.val._max = 100
  414. btn.val = 100
  415. #btn.btn.btn4.val.set(50)
  416. buttons[key] = btn
  417. add=1
  418. ax2+=W2+3
  419. _y+=23
  420. for i,k in enumerate(fix_list): #.items():
  421. key = str(i)
  422. v=fix_list[k]
  423. txt=v["NAME"]
  424. btn = buttons[key]
  425. btn1 = buttons[key+".ID"]
  426. if v["ATTRIBUT"]["_ACTIVE"]["ACTIVE"]:
  427. btn.btn.btn1.val.set(1)
  428. btn1.btn.btn1.val.set(1)
  429. else:
  430. btn.btn.btn1.val.set(0)
  431. btn1.btn.btn1.val.set(0)
  432. if key in buttons: # insert
  433. #print(v)
  434. txt="ID:"+str(v["ID"])
  435. btn = buttons[key+".ID"]
  436. key = str(i)+":rgb"
  437. txt = ""
  438. btn = buttons[key]
  439. if "ATTRIBUT" in v:
  440. ATTR = v["ATTRIBUT"]
  441. for kk,vv in v["ATTRIBUT"].items():
  442. if "-FINE" in kk or kk.startswith("_"):
  443. continue
  444. key = str(i)+":" +kk
  445. VAL = vv["VALUE"]
  446. txt = kk+" "+str(VAL)
  447. btn = buttons[key]
  448. btn.val = VAL
  449. if kk in ["RED","GREEN","BLUE"]:
  450. _key = str(i)+":rgb"
  451. if kk == "RED":
  452. buttons[_key].btn.btn1.color[0] = VAL
  453. if kk == "GREEN":
  454. buttons[_key].btn.btn1.color[1] = VAL
  455. if kk == "BLUE":
  456. buttons[_key].btn.btn1.color[2] = VAL
  457. if kk in ["DIM"]:
  458. _key = str(i)+":dim"
  459. _VAL = VAL
  460. if _VAL > 255:
  461. _VAL=255
  462. if _VAL < 0:
  463. _VAL = 0
  464. buttons[_key].btn.btn1.color = [_VAL,_VAL,_VAL,255] #_VAL]
  465. btn.btn.btn1.name = txt
  466. if vv["ACTIVE"]:
  467. btn.btn.btn1.val.set(1)
  468. else:
  469. btn.btn.btn1.val.set(0)
  470. if _last_v:
  471. print("init.button.ok",_last_v)
  472. def draw_buttons(buttons):
  473. mh = pyray.get_screen_height()
  474. for k,btn in buttons.items():
  475. btn.event(old_x,old_y,mouse_old)
  476. #print(btn)
  477. pos = btn.btn.pos
  478. if pos[0] > (mh-40):
  479. continue
  480. btn.draw()
  481. def event_loop():
  482. global RUN
  483. while RUN:
  484. try:
  485. _event_loop()
  486. time.sleep(0.0001)
  487. except Exception as e:
  488. print("EXC event:",e)
  489. #thread.start_new_thread(event_loop,())
  490. old_x = 0
  491. old_y = 0
  492. wheel = 0
  493. class _M():
  494. def __init__(self):
  495. self.x =0
  496. self.y=0
  497. m = _M() # {"x":0,"y":0}
  498. MOUSE_BTN = [0,0,0]
  499. def _event_loop():
  500. global RUN
  501. global old_x
  502. global old_y
  503. global wheel
  504. global mouse_old
  505. global m
  506. wheel = pyray.get_mouse_wheel_move()
  507. if wheel:
  508. print("wheel",wheel)
  509. m=pyray.get_mouse_position()
  510. #print(m)
  511. if m.x != old_x or m.y != old_y:
  512. old_x = m.x
  513. old_y = m.y
  514. mouse=[None,None,None]
  515. mouse_change=0
  516. #for i in dir(pyray):
  517. # if "gfwl_" not in i.lower():
  518. # print(i)
  519. #print(pyray.exit_window_requested())
  520. if pyray.window_should_close():
  521. print("sending QUIT ...")
  522. pyray.close_window()
  523. RUN=0
  524. time.sleep(1.3)
  525. exit()
  526. for i in range(3):
  527. #v=pyray.is_mouse_button_down(i)
  528. for ii in range(10):
  529. v=pyray.is_mouse_button_pressed(i)
  530. #print(v)
  531. if v:
  532. if not MOUSE_BTN[i]:
  533. MOUSE_BTN[i] = 1
  534. mouse_change=1
  535. #print("mouse",i,v)
  536. print(time.time(),"mouse",i,MOUSE_BTN)#i,v)
  537. for i in range(3):
  538. v=pyray.is_mouse_button_down(i)
  539. if not v:
  540. if MOUSE_BTN[i]:
  541. MOUSE_BTN[i] = 0
  542. mouse_change=1
  543. #print("mouse",i,v)
  544. print(time.time(),"mouse",i,MOUSE_BTN)#i,v)
  545. # KEYBOARD INPUT =========================
  546. _key_del = []
  547. for k in KEY_BUF:
  548. if not pyray.is_key_down(k):
  549. KEY_BUF[k] = [0,1] # release [val,change]
  550. _key_del.append(k)
  551. while RUN:
  552. x = pyray.get_key_pressed()
  553. if x:
  554. if x not in KEY_BUF:
  555. KEY_BUF[x] = [1,1] # press [val,change]
  556. else:
  557. break
  558. for i,k in enumerate(KEY_BUF):
  559. x = k
  560. val,change = KEY_BUF[k]
  561. KEY_BUF[k][1] = 0
  562. if not change:
  563. continue
  564. if x == 256:
  565. if val:
  566. msg=json.dumps([{"event":"ESC"}]).encode("utf-8")
  567. print("ESC",msg)
  568. cmd_client.send(msg)
  569. elif x == 269:
  570. if val:
  571. msg=json.dumps([{"event":"FX-OFF"}]).encode("utf-8")
  572. print("FX-OFF",msg)
  573. cmd_client.send(msg)
  574. elif x >= 290 and x <= 300:
  575. btn_nr = 290-x+81
  576. btn_nr_raw = 81
  577. msg=json.dumps([{"event":"EXEC","EXEC":btn_nr,"VAL":val,"NR-KEY":btn_nr_raw}]).encode("utf-8")
  578. print("SPCIAL-KEY",msg)
  579. cmd_client.send(msg)
  580. else:
  581. print("key",x)
  582. for d in _key_del:
  583. del KEY_BUF[d] # clear KEY BUFFER
  584. # ================================================
  585. if mouse != mouse_old and mouse != [None,None,None]:
  586. #print(mouse)
  587. mouse_old = mouse[:]
  588. check_scrollbar()
  589. MMM = 1
  590. def event_mouse_click():
  591. global MMM
  592. #{'event': 'FIXTURES', 'TYPE': 'ENCODERS', 'FIX': '13', 'VAL': 'click', 'ATTR': 'GREEN'}
  593. # jsbc.remote-key: {'event': 'FIXTURES', 'TYPE': 'ENCODERS', 'FIX': '12', 'VAL': 'click', 'ATTR': '_ACTIVE'}
  594. msg = json.dumps( {'event': 'FIXTURES', 'TYPE': 'ENCODERS', 'FIX': '13', 'VAL': 'click', 'ATTR': 'GREEN'} )
  595. cmd_client.send(msg)
  596. buttons={} #[]
  597. cur = None
  598. history = []
  599. KEY_BUF={}
  600. MOUSE_BUF={}
  601. FIRST_RUN = 1
  602. add=0
  603. core_tick_t = time.time()
  604. dmx_last = time.time()
  605. w = pyray.get_screen_width()
  606. h = pyray.get_screen_height()
  607. mw = w
  608. mh = h
  609. def check_scrollbar():
  610. w = pyray.get_screen_width()
  611. h = pyray.get_screen_height()
  612. mw = w
  613. mh = h
  614. key="scroll-bar"
  615. if key not in buttons:
  616. txt=""
  617. btn=BUTTON(None,txt,[30,mw-35,mh-75,30])
  618. #btn.btn.btn1.color_on = [255,255,0,255]
  619. buttons[key] = btn
  620. btn.btn.btn4.val.set(btn.btn.btn4.val._max*0.4)
  621. try:
  622. key="scroll-bar"
  623. buttons[key].btn.pos[1] = mw-35
  624. buttons[key].btn.pos[2] = mh-75
  625. except:pass
  626. while not pyray.window_should_close():
  627. if pyray.is_window_resized():
  628. print( "RESIZE WINDOW OK")
  629. #check_scrollbar()
  630. if dmx_last+1 < time.time():
  631. #print("dmx")
  632. dmx_last = time.time()
  633. dmx = read_dmx()
  634. read_fix(dmx)
  635. font_size = font12.baseSize
  636. try:
  637. #keys,fix_list = load_fix()
  638. keys,fix_list = get_fix()
  639. check_buttons(buttons,fix_list)
  640. for i in range(3): # hack fast event polling button and key
  641. pyray.begin_drawing()
  642. pyray.clear_background(pyray.BLACK)
  643. pyray.Color(255,0,0,0)
  644. pyray.rl_enable_smooth_lines()
  645. GREY = [122,122,122,255]
  646. k=keys[0]
  647. if cur is None:
  648. cur = k #k[3] #"xx123" # k
  649. #check_buttons(buttons,fix_list)
  650. pyray.draw_text_ex(font_l_22,"FIXTURE LIST",[20,2], 22, 0, pyray.GRAY)
  651. pyray.draw_text_ex(font12,"ACTIVE:{:0.1f} {:0.1f}".format(0,0),[220,5], 12, 0, pyray.YELLOW)
  652. pyray.draw_text_ex(font12,"ENCODER:{:0.2f}".format(5),[315,5], 12, 0, pyray.YELLOW)
  653. pyray.draw_text_ex(font12,"FPS:{}".format(fps_count) ,[420,5], 12, 0, pyray.BLUE)
  654. pyray.draw_text_ex(font12,"BTN:{}".format(len(buttons)) ,[460,5], 12, 0, pyray.BLUE)
  655. pyray.draw_text_ex(font12,"FIX:{}".format(len(fix_list)),[520,5], 12, 0, pyray.BLUE)
  656. txt="HELP"
  657. key="HELP"
  658. btn=BUTTON(None,txt,[4,160,16,40])
  659. btn.font = font10
  660. buttons[key] = btn
  661. draw_buttons(buttons)
  662. pyray.draw_text_ex(font12,"X:{}".format(int(m.x)),[590,5], 12, 0, pyray.VIOLET)
  663. pyray.draw_text_ex(font12,"Y:{}".format(int(m.y)),[620,5], 12, 0, pyray.VIOLET)
  664. pyray.draw_rectangle(int(old_x-10),int(old_y-1),20,2,[255,0,255,255])
  665. pyray.draw_rectangle(int(old_x-1),int(old_y-10),2,20,[255,0,255,255])
  666. aapos = draw_mouse_box(None,[old_x,old_y],mouse_old,color=[128,128,128],text=1)
  667. pyray.end_drawing()
  668. # frame tick speed, CPU LOAD. ------
  669. delta = 1/5
  670. if delta > (time.time()-core_tick_t):
  671. delta -= (time.time()-core_tick_t)
  672. #print(delta)
  673. for t in range(8):
  674. time.sleep(delta/8)
  675. _event_loop()
  676. pyray.begin_drawing()
  677. pyray.end_drawing()
  678. core_tick_t = time.time()
  679. # --------------------------------
  680. frame_count += 1
  681. if time.time()-start > 1:
  682. start = time.time()
  683. fps_count = frame_count
  684. frame_count = 0
  685. FIRST_RUN = 0
  686. except KeyboardInterrupt as e:
  687. raise e
  688. except Exception as e:# KeyInterupt
  689. print("err",e)
  690. import traceback
  691. print(traceback.format_exc())
  692. time.sleep(1)
  693. pyray.close_window()