RemoteControlV2.py 20 KB

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