RemoteControlV2.py 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547
  1. # module_remote_control_v2
  2. import json
  3. import time, asyncio
  4. import settings
  5. from .SerialIns import SerialIns
  6. from .BaseClass import BaseClass
  7. from sockets.connect_manager import ConnectionManager
  8. from databases import SqlQuery, PhotoRecord, DeviceConfig, CRUD, insert_photo_records
  9. from .capture.module_digicam import DigiCam
  10. from .capture.module_watch_dog import FileEventHandler
  11. # from .BlueToothMode import BlueToothMode
  12. class RemoteControlV2(BaseClass):
  13. # sign_data = Signal(dict)
  14. def __init__(self, bluetooth_ins, websocket_manager: ConnectionManager):
  15. # 遥控设备处理--新版遥控器;硅胶按钮
  16. super().__init__(websocket_manager)
  17. self.msg_type = "blue_tooth"
  18. self.websocket_manager = websocket_manager
  19. # self.windows = windows
  20. self.serial_ins = None
  21. self.bluetooth_ins = bluetooth_ins
  22. self.port_name = ""
  23. self.bluetooth_address = ""
  24. self.connect_state = False
  25. self.is_running = False
  26. self.goods_art_no = None
  27. # 0 闲置;1进行中;2已完成;
  28. self.photo_take_state = 0
  29. def to_connect_com(self, port_name, is_test=False):
  30. if self.connect_state:
  31. return
  32. self.close_connect()
  33. time.sleep(0.5)
  34. try:
  35. # 原值为9600
  36. self.serial_ins = SerialIns(port_name=port_name, baud=115200)
  37. # self.serial_ins = SerialIns(port_name=port_name, baud=9600)
  38. if self.serial_ins.serial_handle:
  39. message = {
  40. "_type": "show_info",
  41. "plugins_mode": "remote_control",
  42. "data": "遥控设备V2 打开串口成功",
  43. }
  44. self.sendSocketMessage(
  45. code=0,
  46. msg="遥控设备V2 打开串口成功",
  47. data=message,
  48. device_status=1,
  49. )
  50. # print(message)
  51. self.connect_state = True
  52. message = {
  53. "_type": "remote_control_connect",
  54. "plugins_mode": "remote_control",
  55. "data": port_name,
  56. }
  57. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  58. print(message)
  59. self.port_name = port_name
  60. self.is_running = True
  61. self.set_voltage_value(0)
  62. self.run()
  63. return True
  64. else:
  65. message = {
  66. "_type": "show_info",
  67. "plugins_mode": "remote_control",
  68. "data": "遥控设备V2 打开串口失败",
  69. }
  70. self.sendSocketMessage(
  71. code=1,
  72. msg="遥控设备V2 打开串口失败",
  73. data=message,
  74. device_status=-1,
  75. )
  76. print(message)
  77. self.serial_ins = None
  78. self.connect_state = False
  79. self.set_voltage_value(None)
  80. except:
  81. message = {
  82. "_type": "show_info",
  83. "plugins_mode": "remote_control",
  84. "data": "遥控设备V2 打开串口失败",
  85. }
  86. print(message)
  87. self.sendSocketMessage(
  88. code=1, msg="遥控设备V2 打开串口失败", data=message, device_status=-1
  89. )
  90. self.serial_ins = None
  91. self.connect_state = False
  92. self.set_voltage_value(None)
  93. return False
  94. def to_connect_bluetooth(self, address, is_test=False):
  95. print("to_connect_bluetooth", self.connect_state)
  96. if self.connect_state:
  97. return
  98. # if self.bluetooth_ins == None:
  99. # print("bluetooth_ins 未初始化", bluetooth_mode)
  100. # self.bluetooth_ins = BlueToothMode()
  101. # else:
  102. # self.bluetooth_ins = bluetooth_mode
  103. self.close_connect()
  104. if self.bluetooth_ins == None:
  105. print("bluetooth_ins 未初始化", self.bluetooth_ins)
  106. # self.bluetooth_ins = self.
  107. self.bluetooth_address = address
  108. message = {
  109. "_type": "show_info",
  110. "plugins_mode": "remote_control",
  111. "data": "遥控设备V2 打开蓝牙成功",
  112. }
  113. print(message)
  114. self.sendSocketMessage(
  115. code=0, msg="遥控设备V2 打开蓝牙成功", data=message, device_status=2
  116. )
  117. self.connect_state = True
  118. self.is_running = True
  119. self.set_voltage_value(0)
  120. if is_test is False:
  121. loop = asyncio.get_event_loop()
  122. loop.create_task(self.run())
  123. def close_bluetooth_connect(self):
  124. if self.bluetooth_address:
  125. print("蓝牙断开")
  126. message = {
  127. "_type": "show_info",
  128. "plugins_mode": "remote_control",
  129. "data": "遥控设备V2 蓝牙断开",
  130. }
  131. print(message)
  132. self.sendSocketMessage(
  133. code=1, msg="遥控设备V2 蓝牙断开", data=message, device_status=-1
  134. )
  135. self.close_connect()
  136. print("关闭蓝牙")
  137. def set_voltage_value(self, voltage_value=None, voltage_text=None):
  138. device_status = 2
  139. if self.is_running:
  140. flag = "接收器已连接 {}".format(
  141. "蓝牙" if self.bluetooth_address else "串口"
  142. )
  143. self.sendSocketMessage(
  144. code=0, msg="遥控设备V2 打开蓝牙成功", data=None, device_status=2
  145. )
  146. self.connect_state = True
  147. self.is_running = True
  148. else:
  149. flag = "接收器未连接"
  150. device_status = -1
  151. if voltage_value is None:
  152. if voltage_text:
  153. print(voltage_text)
  154. # 发送电量剩余消息
  155. self.sendSocketMessage(msg=voltage_text, device_status=device_status)
  156. else:
  157. self.sendSocketMessage(msg=flag, device_status=device_status)
  158. else:
  159. if voltage_value == 0:
  160. print(flag)
  161. self.sendSocketMessage(msg=flag, device_status=device_status)
  162. else:
  163. print("电量:{}%".format(voltage_value))
  164. self.sendSocketMessage(
  165. msg="电量:{}%".format(voltage_value), device_status=device_status
  166. )
  167. # print("打印===>", flag)
  168. def close_connect(self):
  169. self.port_name = ""
  170. self.bluetooth_address = ""
  171. # self.bluetooth_ins = None
  172. if self.serial_ins:
  173. self.serial_ins.close_serial_port()
  174. self.connect_state = False
  175. def __del__(self):
  176. self.close_connect()
  177. def play_sound(self, tip="sound_tips_3"):
  178. self.windows.playsound.tips_type = tip
  179. self.windows.playsound.start()
  180. def handlerAction(self, button_value):
  181. """处理拍照动作按键[左 右]"""
  182. control_program = "执行左脚程序" if button_value == 1 else "执行右脚程序"
  183. if self.goods_art_no == None or self.goods_art_no == "":
  184. input_data = {
  185. "data": {
  186. "action": control_program,
  187. "goods_art_no": "",
  188. },
  189. "type": "run_mcu",
  190. }
  191. self.msg_type = "blue_tooth_scan"
  192. self.sendSocketMessage(
  193. code=0,
  194. msg=f"准备执行[{control_program}]",
  195. data=input_data,
  196. device_status=2,
  197. )
  198. self.msg_type = "blue_tooth"
  199. return
  200. self.photo_take_state = 1
  201. input_data = {
  202. "data": {
  203. "action": control_program,
  204. "goods_art_no": self.goods_art_no,
  205. },
  206. "type": "run_mcu",
  207. }
  208. self.msg_type = "blue_tooth_scan"
  209. self.sendSocketMessage(
  210. code=0,
  211. msg=f"准备执行[{control_program}]",
  212. data=input_data,
  213. device_status=2,
  214. )
  215. self.goods_art_no = None
  216. self.msg_type = "blue_tooth"
  217. self.photo_take_state = 2
  218. async def handlerTakePhoto(self, smart_shooter=None,session=None,record=None):
  219. """处理单独拍照"""
  220. await asyncio.sleep(0.1)
  221. print("开始单拍1")
  222. if record.image_index == 19:
  223. self.msg_type = "photo_take"
  224. self.sendSocketMessage(
  225. code=1,
  226. msg="单拍失败,单个货号最多允许拍摄20张产品图",
  227. data=None,
  228. device_status=2,
  229. )
  230. self.msg_type = "blue_tooth"
  231. return
  232. deviceConfig = CRUD(DeviceConfig)
  233. deviceConfigData = deviceConfig.read(session=session, conditions={"id": record.action_id})
  234. select_tab_id = deviceConfigData.tab_id
  235. AllTabConfig = deviceConfig.read_all(session=session, conditions={"tab_id": select_tab_id})
  236. action_id = 0
  237. if AllTabConfig[len(AllTabConfig) - 1].take_picture == True:
  238. action_id = AllTabConfig[0].id
  239. else:
  240. action_id = AllTabConfig[len(AllTabConfig) - 1].id
  241. image_index = record.image_index + 1
  242. self.photo_take_state = 1
  243. deviceConfig = CRUD(DeviceConfig)
  244. deviceConfigData = deviceConfig.read(
  245. session=session, conditions={"id": record.action_id}
  246. )
  247. if deviceConfigData == None:
  248. self.msg_type = "photo_take"
  249. self.sendSocketMessage(
  250. code=1,
  251. msg="相关配置不存在,请删除当前货号后重新拍摄",
  252. data=None,
  253. device_status=2,
  254. )
  255. self.msg_type = "blue_tooth"
  256. return
  257. select_tab_id = deviceConfigData.tab_id
  258. AllTabConfig = deviceConfig.read_all(
  259. session=session, conditions={"tab_id": select_tab_id}
  260. )
  261. action_id = 0
  262. if AllTabConfig[len(AllTabConfig) - 1].take_picture == True:
  263. action_id = AllTabConfig[0].id
  264. else:
  265. action_id = AllTabConfig[len(AllTabConfig) - 1].id
  266. image_index = record.image_index + 1
  267. self.photo_take_state = 1
  268. state, record_id = await insert_photo_records(
  269. record.image_deal_mode,
  270. record.goods_art_no,
  271. image_index,
  272. action_id,
  273. )
  274. session.close()
  275. print("开始单拍1-插入数据")
  276. try:
  277. if smart_shooter == None:
  278. capture_one = DigiCam()
  279. watch_dog = FileEventHandler()
  280. if watch_dog.observer is None:
  281. captrure_folder_path = capture_one.getCaptureFolderPath()
  282. watch_dog.start_observer(captrure_folder_path)
  283. watch_dog.goods_art_no = record.goods_art_no
  284. watch_dog.image_index = image_index
  285. print("开始单拍1-检查相机")
  286. capture_one.run_capture_action("Capture")
  287. print("开始单拍1-完成拍照")
  288. else:
  289. camera_configs = settings.getSysConfigs(
  290. "camera_configs",
  291. "iso_config",
  292. None,
  293. )
  294. CameraKey = camera_configs[record.point_name].get("CameraKey", None)
  295. loop = asyncio.get_event_loop()
  296. loop.create_task(
  297. smart_shooter.CameraShooter(
  298. msg_type="handler_take_picture",
  299. goods_art_no=record.goods_art_no,
  300. id=record_id,
  301. CameraKey=CameraKey,
  302. ),
  303. name="CameraShooter",
  304. )
  305. await asyncio.sleep(0.1)
  306. # await asyncio.sleep(1)
  307. self.msg_type = "photo_take"
  308. self.sendSocketMessage(
  309. code=0,
  310. msg="{} 执行完成~".format(
  311. "执行右脚程序"
  312. if record.image_deal_mode == 1
  313. else "执行左脚程序"
  314. ),
  315. data={"goods_art_no": record.goods_art_no, "id": record_id},
  316. device_status=2,
  317. )
  318. self.msg_type = "blue_tooth"
  319. except Exception as e:
  320. print(f"错误:{e}")
  321. self.sendSocketMessage(1, "处理失败,请重试", device_status=-1)
  322. self.photo_take_state = 0
  323. async def analysis_received_data(self):
  324. if not self.connect_state:
  325. return
  326. await asyncio.sleep(0.01)
  327. if self.bluetooth_address:
  328. receive_data = self.bluetooth_ins.read_cmd_one(
  329. address=self.bluetooth_address
  330. )
  331. else:
  332. receive_data = self.serial_ins.read_cmd(out_time=1, check=None)
  333. if receive_data is False:
  334. self.connect_state = False
  335. return False
  336. if not receive_data:
  337. return
  338. if self.photo_take_state != 0:
  339. print("正在拍照", self.photo_take_state)
  340. return
  341. receive_data_parser = receive_data[0]
  342. # 数据 结构 command,按命令解析
  343. if receive_data_parser == 1:
  344. # self.play_sound("get_qr_code")
  345. # 扫码数据
  346. bar_code = receive_data[1:].decode()
  347. bar_code = bar_code.replace("\r", "")
  348. bar_code = bar_code.replace("\n", "")
  349. self.goods_art_no = bar_code
  350. message = {"_type": 0, "plugins_mode": "remote_control", "data": bar_code}
  351. print(message)
  352. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  353. return
  354. if receive_data_parser == 9:
  355. # 播放声音
  356. button_value = receive_data[1]
  357. data = {"button_value": button_value}
  358. message = {"_type": 9, "plugins_mode": "remote_control", "data": data}
  359. print(message)
  360. if button_value in [1, 2]:
  361. # 扫描货号
  362. if self.photo_take_state != 0:
  363. self.sendSocketMessage(1, "前置拍照未完成,请稍后", device_status=-1)
  364. return
  365. print("收到货号信息", self.goods_art_no)
  366. self.handlerAction(button_value)
  367. self.photo_take_state = 0
  368. if button_value in [3]:
  369. # 处理遥控器单拍
  370. self.msg_type = "handler_take_picture"
  371. # 0 闲置;1进行中;2已完成;
  372. _data = {"type": self.msg_type,"data":None}
  373. self.sendSocketMessage(0, "处理单拍消息", data=_data, device_status=-1)
  374. self.msg_type = "blue_tooth"
  375. if button_value in [9]:
  376. # 处理停止
  377. self.msg_type = "stop_action"
  378. # 0 闲置;1进行中;2已完成;
  379. _data = {"type": self.msg_type, "data": None}
  380. self.sendSocketMessage(0, "停止执行组合动作", data=_data, device_status=-1)
  381. self.msg_type = "blue_tooth"
  382. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  383. if settings.IS_DEBUG == "true":
  384. print("收到按键", button_value)
  385. return
  386. if receive_data_parser == 10:
  387. voltage_value = receive_data[1]
  388. self.set_voltage_value(voltage_value)
  389. if settings.IS_TEST:
  390. print("遥控器V2电量:{}".format(voltage_value))
  391. return
  392. # 使用Max17048 查看电量
  393. if receive_data_parser == 12:
  394. chg_status = self.get_data_from_receive_data(
  395. receive_data=receive_data, start=1, len_data=1
  396. )
  397. soc_percentage = self.get_data_from_receive_data(
  398. receive_data=receive_data, start=2, len_data=4
  399. )
  400. soc_percentage = soc_percentage / 100
  401. voltage = self.get_data_from_receive_data(
  402. receive_data=receive_data, start=6, len_data=4
  403. )
  404. voltage = voltage / 100
  405. current = self.get_data_from_receive_data(
  406. receive_data=receive_data, start=10, len_data=4
  407. )
  408. current = current / 10000
  409. temperature = self.get_data_from_receive_data(
  410. receive_data=receive_data, start=14, len_data=4
  411. )
  412. temperature = temperature / 100
  413. adjusted_soc = self.get_data_from_receive_data(
  414. receive_data=receive_data, start=18, len_data=4
  415. )
  416. adjusted_soc = adjusted_soc / 100
  417. soft_vision = self.get_data_from_receive_data(
  418. receive_data=receive_data, start=22, len_data=1
  419. )
  420. full_status = self.get_data_from_receive_data(
  421. receive_data=receive_data, start=23, len_data=1
  422. )
  423. # print("is_charging:{}".format(chg_status))
  424. # print("Battery SOC: {:.2f}%".format(soc_percentage))
  425. # print("Battery Voltage: {:.3f}V".format(voltage))
  426. # print("Average Current: {:.3f}A".format(current))
  427. # print("Chip Temperature: {:.1f}°C".format(temperature))
  428. # print("adjusted Battery soc: {:.2f}%".format(adjusted_soc))
  429. # print("soft_vision:{}".format(soft_vision))
  430. # print("chg_status:{} full_status:{}".format(chg_status, full_status))
  431. if chg_status:
  432. t1 = "充电中"
  433. else:
  434. t1 = ""
  435. if full_status:
  436. t2 = "已充满"
  437. else:
  438. t2 = ""
  439. self.set_voltage_value(
  440. voltage_text="遥控器:{:.1f}% {:.2f}V {}{}".format(
  441. min(adjusted_soc / 92.5 * 100, 100), voltage, t1, t2
  442. )
  443. )
  444. return
  445. if receive_data[0] == 111:
  446. value = (
  447. receive_data[1] << 24
  448. | receive_data[2] << 16
  449. | receive_data[3] << 8
  450. | receive_data[4]
  451. )
  452. print("遥控器-测试 value:{}".format(value))
  453. # self.windows.show_label.setText("--------{}".format(value))
  454. if receive_data[0] == 112:
  455. bar_code = receive_data[1:].decode()
  456. bar_code = bar_code.replace("\r", "")
  457. bar_code = bar_code.replace("\n", "")
  458. print("read bar_code {}".format(bar_code))
  459. # 通用串口数据解析器
  460. def get_data_from_receive_data(
  461. self, receive_data, start, len_data, data_magnification=1
  462. ):
  463. # data_magnification 数据放大倍数,或缩小倍数,默认为1
  464. try:
  465. if len_data == 1:
  466. data = receive_data[start]
  467. return data * data_magnification
  468. elif len_data == 2:
  469. data = receive_data[start] << 8 | receive_data[start + 1]
  470. return data * data_magnification
  471. elif len_data == 4:
  472. data = (
  473. receive_data[start] << 24
  474. | receive_data[start + 1] << 16
  475. | receive_data[start + 2] << 8
  476. | receive_data[start + 3]
  477. )
  478. return data * data_magnification
  479. return None
  480. except:
  481. return None
  482. async def run(self):
  483. # self.show_info.emit("未连接")
  484. # self.data_command_sign.emit(data)
  485. self.is_running = True
  486. print("Running")
  487. while 1:
  488. await asyncio.sleep(0.01)
  489. if not self.connect_state:
  490. message = {
  491. "_type": "show_info",
  492. "plugins_mode": "remote_control",
  493. "data": "遥控设备V2 未连接",
  494. }
  495. print(message)
  496. self.sendSocketMessage(
  497. code=1, msg="遥控设备V2 未连接", data=message, device_status=-1
  498. )
  499. break
  500. await self.analysis_received_data()
  501. self.is_running = False
  502. if not self.connect_state:
  503. message = {
  504. "_type": "show_info",
  505. "plugins_mode": "remote_control",
  506. "data": "遥控设备V2 未连接",
  507. }
  508. print(message)
  509. self.sendSocketMessage(
  510. code=1, msg="遥控设备V2 未连接", data=message, device_status=-1
  511. )
  512. self.set_voltage_value(None)