RemoteControlV2.py 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468
  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, 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. def to_connect_com(self, port_name, is_test=False):
  28. if self.connect_state:
  29. return
  30. self.close_connect()
  31. time.sleep(0.5)
  32. try:
  33. # 原值为9600
  34. self.serial_ins = SerialIns(port_name=port_name, baud=115200)
  35. # self.serial_ins = SerialIns(port_name=port_name, baud=9600)
  36. if self.serial_ins.serial_handle:
  37. message = {
  38. "_type": "show_info",
  39. "plugins_mode": "remote_control",
  40. "data": "遥控设备V2 打开串口成功",
  41. }
  42. self.sendSocketMessage(
  43. code=0,
  44. msg="遥控设备V2 打开串口成功",
  45. data=message,
  46. device_status=1,
  47. )
  48. # print(message)
  49. self.connect_state = True
  50. message = {
  51. "_type": "remote_control_connect",
  52. "plugins_mode": "remote_control",
  53. "data": port_name,
  54. }
  55. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  56. print(message)
  57. self.port_name = port_name
  58. self.is_running = True
  59. self.set_voltage_value(0)
  60. self.run()
  61. return True
  62. else:
  63. message = {
  64. "_type": "show_info",
  65. "plugins_mode": "remote_control",
  66. "data": "遥控设备V2 打开串口失败",
  67. }
  68. self.sendSocketMessage(
  69. code=1,
  70. msg="遥控设备V2 打开串口失败",
  71. data=message,
  72. device_status=-1,
  73. )
  74. print(message)
  75. self.serial_ins = None
  76. self.connect_state = False
  77. self.set_voltage_value(None)
  78. except:
  79. message = {
  80. "_type": "show_info",
  81. "plugins_mode": "remote_control",
  82. "data": "遥控设备V2 打开串口失败",
  83. }
  84. print(message)
  85. self.sendSocketMessage(
  86. code=1, msg="遥控设备V2 打开串口失败", data=message, device_status=-1
  87. )
  88. self.serial_ins = None
  89. self.connect_state = False
  90. self.set_voltage_value(None)
  91. return False
  92. def to_connect_bluetooth(self, address, is_test=False):
  93. print("to_connect_bluetooth", self.connect_state)
  94. if self.connect_state:
  95. return
  96. # if self.bluetooth_ins == None:
  97. # print("bluetooth_ins 未初始化", bluetooth_mode)
  98. # self.bluetooth_ins = BlueToothMode()
  99. # else:
  100. # self.bluetooth_ins = bluetooth_mode
  101. self.close_connect()
  102. if self.bluetooth_ins == None:
  103. print("bluetooth_ins 未初始化", self.bluetooth_ins)
  104. # self.bluetooth_ins = self.
  105. self.bluetooth_address = address
  106. message = {
  107. "_type": "show_info",
  108. "plugins_mode": "remote_control",
  109. "data": "遥控设备V2 打开蓝牙成功",
  110. }
  111. print(message)
  112. self.sendSocketMessage(
  113. code=0, msg="遥控设备V2 打开蓝牙成功", data=message, device_status=2
  114. )
  115. self.connect_state = True
  116. self.is_running = True
  117. self.set_voltage_value(0)
  118. if is_test is False:
  119. loop = asyncio.get_event_loop()
  120. loop.create_task(self.run())
  121. def close_bluetooth_connect(self):
  122. if self.bluetooth_address:
  123. print("蓝牙断开")
  124. message = {
  125. "_type": "show_info",
  126. "plugins_mode": "remote_control",
  127. "data": "遥控设备V2 蓝牙断开",
  128. }
  129. print(message)
  130. self.sendSocketMessage(
  131. code=1, msg="遥控设备V2 蓝牙断开", data=message, device_status=-1
  132. )
  133. self.close_connect()
  134. print("关闭蓝牙")
  135. def set_voltage_value(self, voltage_value=None, voltage_text=None):
  136. device_status = 2
  137. if self.is_running:
  138. flag = "接收器已连接 {}".format(
  139. "蓝牙" if self.bluetooth_address else "串口"
  140. )
  141. self.sendSocketMessage(
  142. code=0, msg="遥控设备V2 打开蓝牙成功", data=None, device_status=2
  143. )
  144. self.connect_state = True
  145. self.is_running = True
  146. else:
  147. flag = "接收器未连接"
  148. device_status = -1
  149. if voltage_value is None:
  150. if voltage_text:
  151. print(voltage_text)
  152. # 发送电量剩余消息
  153. self.sendSocketMessage(msg=voltage_text, device_status=device_status)
  154. else:
  155. self.sendSocketMessage(msg=flag, device_status=device_status)
  156. else:
  157. if voltage_value == 0:
  158. print(flag)
  159. self.sendSocketMessage(msg=flag, device_status=device_status)
  160. else:
  161. print("电量:{}%".format(voltage_value))
  162. self.sendSocketMessage(
  163. msg="电量:{}%".format(voltage_value), device_status=device_status
  164. )
  165. # print("打印===>", flag)
  166. def close_connect(self):
  167. self.port_name = ""
  168. self.bluetooth_address = ""
  169. # self.bluetooth_ins = None
  170. if self.serial_ins:
  171. self.serial_ins.close_serial_port()
  172. self.connect_state = False
  173. def __del__(self):
  174. self.close_connect()
  175. def play_sound(self, tip="sound_tips_3"):
  176. self.windows.playsound.tips_type = tip
  177. self.windows.playsound.start()
  178. def handlerAction(self, button_value):
  179. """处理拍照动作按键[左 右]"""
  180. control_program = "执行左脚程序" if button_value == 1 else "执行右脚程序"
  181. if self.goods_art_no == None or self.goods_art_no == "":
  182. input_data = {
  183. "data": {
  184. "action": control_program,
  185. "goods_art_no": "",
  186. },
  187. "type": "run_mcu",
  188. }
  189. self.msg_type = "blue_tooth_scan"
  190. self.sendSocketMessage(
  191. code=0,
  192. msg=f"准备执行[{control_program}]",
  193. data=input_data,
  194. device_status=2,
  195. )
  196. self.msg_type = "blue_tooth"
  197. return
  198. input_data = {
  199. "data": {
  200. "action": control_program,
  201. "goods_art_no": self.goods_art_no,
  202. },
  203. "type": "run_mcu",
  204. }
  205. self.msg_type = "blue_tooth_scan"
  206. self.sendSocketMessage(
  207. code=0,
  208. msg=f"准备执行[{control_program}]",
  209. data=input_data,
  210. device_status=2,
  211. )
  212. self.goods_art_no = None
  213. self.msg_type = "blue_tooth"
  214. def handlerTakePhoto(self):
  215. """处理单独拍照"""
  216. session = SqlQuery()
  217. crud = CRUD(PhotoRecord)
  218. record = crud.read(session=session, order_by="id", ascending=False)
  219. if record == None:
  220. # 发送失败消息
  221. self.sendSocketMessage(
  222. code=1,
  223. msg="单拍失败,请先输入货号或扫码进行组合拍摄",
  224. data=None,
  225. device_status=2,
  226. )
  227. else:
  228. image_index = record.image_index + 1
  229. insert_photo_records(
  230. record.image_deal_mode, record.goods_art_no, image_index
  231. )
  232. capture_one = DigiCam()
  233. try:
  234. captrure_folder_path = capture_one.getCaptureFolderPath()
  235. watch_dog = FileEventHandler()
  236. watch_dog.goods_art_no = record.goods_art_no
  237. watch_dog.image_index = image_index
  238. watch_dog.start_observer(captrure_folder_path)
  239. camera_is_connect = capture_one.checkCameraConnect()
  240. if camera_is_connect is not True:
  241. self.sendSocketMessage(1, "相机未连接,请检查", device_status=-1)
  242. return
  243. capture_one.getCaptureFolderPath()
  244. capture_one.run_capture_action("Capture")
  245. time.sleep(1)
  246. self.msg_type = "photo_take"
  247. self.sendSocketMessage(
  248. code=0,
  249. msg="{} 执行完成~".format(
  250. "执行右脚程序"
  251. if record.image_deal_mode == 1
  252. else "执行左脚程序"
  253. ),
  254. device_status=2,
  255. )
  256. self.msg_type = "blue_tooth"
  257. except Exception as e:
  258. print("错误信息:",e)
  259. self.sendSocketMessage(1, "digicam未初始化,请检查", device_status=-1)
  260. def analysis_received_data(self):
  261. if not self.connect_state:
  262. return
  263. if self.bluetooth_address:
  264. receive_data = self.bluetooth_ins.read_cmd_one(
  265. address=self.bluetooth_address
  266. )
  267. # print("received data", receive_data)
  268. else:
  269. receive_data = self.serial_ins.read_cmd(out_time=1, check=None)
  270. # print("self.bluetooth_ins", receive_data)
  271. if receive_data is False:
  272. self.connect_state = False
  273. return False
  274. if not receive_data:
  275. return
  276. receive_data_parser = receive_data[0]
  277. # 数据 结构 command,按命令解析
  278. if receive_data_parser == 1:
  279. # self.play_sound("get_qr_code")
  280. # 扫码数据
  281. bar_code = receive_data[1:].decode()
  282. bar_code = bar_code.replace("\r", "")
  283. bar_code = bar_code.replace("\n", "")
  284. self.goods_art_no = bar_code
  285. message = {"_type": 0, "plugins_mode": "remote_control", "data": bar_code}
  286. print(message)
  287. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  288. return
  289. if receive_data_parser == 9:
  290. # 播放声音
  291. button_value = receive_data[1]
  292. data = {"button_value": button_value}
  293. message = {"_type": 9, "plugins_mode": "remote_control", "data": data}
  294. print(message)
  295. if button_value in [1, 2]:
  296. # 扫描货号
  297. print("收到货号信息", self.goods_art_no)
  298. self.handlerAction(button_value)
  299. if button_value in [3]:
  300. # 处理遥控器单拍
  301. self.handlerTakePhoto()
  302. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  303. if settings.IS_DEBUG:
  304. print("收到按键", button_value)
  305. return
  306. if receive_data_parser == 10:
  307. voltage_value = receive_data[1]
  308. self.set_voltage_value(voltage_value)
  309. if settings.IS_TEST:
  310. print("遥控器V2电量:{}".format(voltage_value))
  311. return
  312. # 使用Max17048 查看电量
  313. if receive_data_parser == 12:
  314. chg_status = self.get_data_from_receive_data(
  315. receive_data=receive_data, start=1, len_data=1
  316. )
  317. soc_percentage = self.get_data_from_receive_data(
  318. receive_data=receive_data, start=2, len_data=4
  319. )
  320. soc_percentage = soc_percentage / 100
  321. voltage = self.get_data_from_receive_data(
  322. receive_data=receive_data, start=6, len_data=4
  323. )
  324. voltage = voltage / 100
  325. current = self.get_data_from_receive_data(
  326. receive_data=receive_data, start=10, len_data=4
  327. )
  328. current = current / 10000
  329. temperature = self.get_data_from_receive_data(
  330. receive_data=receive_data, start=14, len_data=4
  331. )
  332. temperature = temperature / 100
  333. adjusted_soc = self.get_data_from_receive_data(
  334. receive_data=receive_data, start=18, len_data=4
  335. )
  336. adjusted_soc = adjusted_soc / 100
  337. soft_vision = self.get_data_from_receive_data(
  338. receive_data=receive_data, start=22, len_data=1
  339. )
  340. full_status = self.get_data_from_receive_data(
  341. receive_data=receive_data, start=23, len_data=1
  342. )
  343. # print("is_charging:{}".format(chg_status))
  344. # print("Battery SOC: {:.2f}%".format(soc_percentage))
  345. # print("Battery Voltage: {:.3f}V".format(voltage))
  346. # print("Average Current: {:.3f}A".format(current))
  347. # print("Chip Temperature: {:.1f}°C".format(temperature))
  348. # print("adjusted Battery soc: {:.2f}%".format(adjusted_soc))
  349. # print("soft_vision:{}".format(soft_vision))
  350. # print("chg_status:{} full_status:{}".format(chg_status, full_status))
  351. if chg_status:
  352. t1 = "充电中"
  353. else:
  354. t1 = ""
  355. if full_status:
  356. t2 = "已充满"
  357. else:
  358. t2 = ""
  359. self.set_voltage_value(
  360. voltage_text="遥控器:{:.1f}% {:.2f}V {}{}".format(
  361. min(adjusted_soc / 92.5 * 100, 100), voltage, t1, t2
  362. )
  363. )
  364. return
  365. if receive_data[0] == 111:
  366. value = (
  367. receive_data[1] << 24
  368. | receive_data[2] << 16
  369. | receive_data[3] << 8
  370. | receive_data[4]
  371. )
  372. print("遥控器-测试 value:{}".format(value))
  373. # self.windows.show_label.setText("--------{}".format(value))
  374. if receive_data[0] == 112:
  375. bar_code = receive_data[1:].decode()
  376. bar_code = bar_code.replace("\r", "")
  377. bar_code = bar_code.replace("\n", "")
  378. print("read bar_code {}".format(bar_code))
  379. # 通用串口数据解析器
  380. def get_data_from_receive_data(
  381. self, receive_data, start, len_data, data_magnification=1
  382. ):
  383. # data_magnification 数据放大倍数,或缩小倍数,默认为1
  384. try:
  385. if len_data == 1:
  386. data = receive_data[start]
  387. return data * data_magnification
  388. elif len_data == 2:
  389. data = receive_data[start] << 8 | receive_data[start + 1]
  390. return data * data_magnification
  391. elif len_data == 4:
  392. data = (
  393. receive_data[start] << 24
  394. | receive_data[start + 1] << 16
  395. | receive_data[start + 2] << 8
  396. | receive_data[start + 3]
  397. )
  398. return data * data_magnification
  399. return None
  400. except:
  401. return None
  402. async def run(self):
  403. # self.show_info.emit("未连接")
  404. # self.data_command_sign.emit(data)
  405. self.is_running = True
  406. print("Running")
  407. while 1:
  408. await asyncio.sleep(0.01)
  409. if not self.connect_state:
  410. message = {
  411. "_type": "show_info",
  412. "plugins_mode": "remote_control",
  413. "data": "遥控设备V2 未连接",
  414. }
  415. print(message)
  416. self.sendSocketMessage(
  417. code=1, msg="遥控设备V2 未连接", data=message, device_status=-1
  418. )
  419. break
  420. self.analysis_received_data()
  421. self.is_running = False
  422. if not self.connect_state:
  423. message = {
  424. "_type": "show_info",
  425. "plugins_mode": "remote_control",
  426. "data": "遥控设备V2 未连接",
  427. }
  428. print(message)
  429. self.sendSocketMessage(
  430. code=1, msg="遥控设备V2 未连接", data=message, device_status=-1
  431. )
  432. self.set_voltage_value(None)