LineControl.py 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301
  1. import time
  2. # from import_qt_mode import *
  3. import asyncio
  4. from .SerialIns import SerialIns
  5. from .BaseClass import BaseClass
  6. from utils.SingletonType import SingletonType
  7. from databases import SqlQuery, PhotoRecord, DeviceConfig, CRUD, insert_photo_records
  8. from .capture.module_digicam import DigiCam
  9. from .capture.module_watch_dog import FileEventHandler
  10. from sockets.connect_manager import ConnectionManager
  11. import settings,os
  12. import logging
  13. logger = logging.getLogger(__name__)
  14. class LineControl(BaseClass):
  15. # sign_data = Signal(dict)
  16. def __init__(self, websocket_manager: ConnectionManager):
  17. super().__init__(websocket_manager)
  18. self.serial_ins = None
  19. self.connect_state = False
  20. self.is_running = False
  21. self.msg_type = "blue_tooth"
  22. self.port_name = None
  23. self.goods_art_no = None
  24. # 0 闲置;1进行中;2已完成;
  25. self.photo_take_state = 0
  26. async def to_connect_com(self, port_name):
  27. self.port_name = port_name
  28. self.close_connect()
  29. await asyncio.sleep(0.5)
  30. try:
  31. # 原值为9600
  32. self.serial_ins = SerialIns(port_name=port_name, baud=115200)
  33. if self.serial_ins.serial_handle:
  34. self.connect_state = True
  35. message = {
  36. "_type": "show_info",
  37. "plugins_mode": "remote_control",
  38. "data": {"msg": "有线遥控器 打开串口成功", "port_name": port_name},
  39. }
  40. self.sendSocketMessage(
  41. code=0,
  42. msg="有线遥控器 打开串口成功",
  43. data=message,
  44. device_status=2,
  45. )
  46. # 循环监听消息
  47. loop = asyncio.get_event_loop()
  48. loop.create_task(self.run())
  49. return True
  50. else:
  51. message = {
  52. "_type": "show_info",
  53. "plugins_mode": "remote_control",
  54. "data": {"msg": "有线遥控器 打开串口失败"},
  55. }
  56. self.sendSocketMessage(
  57. code=1,
  58. msg="有线遥控器 打开串口失败",
  59. data=message,
  60. device_status=-1,
  61. )
  62. self.serial_ins = None
  63. self.connect_state = False
  64. return False
  65. except:
  66. message = {
  67. "_type": "show_info",
  68. "plugins_mode": "remote_control",
  69. "data": {"msg": "有线遥控器 打开串口失败"},
  70. }
  71. self.sendSocketMessage(
  72. code=1,
  73. msg="有线遥控器 打开串口失败",
  74. data=message,
  75. device_status=-1,
  76. )
  77. self.serial_ins = None
  78. self.connect_state = False
  79. return False
  80. def close_connect(self):
  81. if self.connect_state:
  82. self.serial_ins.close_serial_port()
  83. self.connect_state = False
  84. def __del__(self):
  85. self.close_connect()
  86. async def to_connect_linecontrol(self):
  87. """连接有线控制器"""
  88. print("to_connect_linecontrol 连接有线控制器,连接状态", self.connect_state)
  89. if self.connect_state:
  90. return
  91. message = {
  92. "_type": "show_info",
  93. "plugins_mode": "remote_control",
  94. "data": "有线遥控器 打开成功",
  95. }
  96. self.close_connect()
  97. print(message)
  98. self.sendSocketMessage(
  99. code=0, msg="有线遥控器 打开蓝牙成功", data=message, device_status=2
  100. )
  101. self.connect_state = True
  102. self.is_running = True
  103. await self.run()
  104. def handlerAction(self, button_value):
  105. """处理拍照动作按键[左 右]"""
  106. control_program = "执行左脚程序" if button_value == 1 else "执行右脚程序"
  107. match button_value:
  108. case 1:
  109. control_program = "执行左脚程序"
  110. case 2:
  111. control_program = "执行右脚程序"
  112. if self.goods_art_no == None or self.goods_art_no == "":
  113. input_data = {
  114. "data": {
  115. "action": control_program,
  116. "goods_art_no": "",
  117. },
  118. "type": "run_mcu",
  119. }
  120. self.msg_type = "blue_tooth_scan"
  121. self.sendSocketMessage(
  122. code=0,
  123. msg=f"准备执行[{control_program}]",
  124. data=input_data,
  125. device_status=2,
  126. )
  127. self.msg_type = "blue_tooth"
  128. return
  129. self.photo_take_state = 1
  130. input_data = {
  131. "data": {
  132. "action": control_program,
  133. "goods_art_no": self.goods_art_no,
  134. },
  135. "type": "run_mcu",
  136. }
  137. self.msg_type = "blue_tooth_scan"
  138. self.sendSocketMessage(
  139. code=0,
  140. msg=f"准备执行[{control_program}]",
  141. data=input_data,
  142. device_status=2,
  143. )
  144. self.goods_art_no = None
  145. self.msg_type = "blue_tooth"
  146. self.photo_take_state = 2
  147. async def analysis_received_data(self,):
  148. await asyncio.sleep(0.01)
  149. if not self.connect_state:
  150. return
  151. receive_data = self.serial_ins.read_cmd(out_time=1, check=0x6B)
  152. if receive_data is False:
  153. self.connect_state = False
  154. return False
  155. if not receive_data:
  156. return
  157. else:
  158. print("有线控制器receive_data", receive_data)
  159. # print(
  160. # "有线控制器 read receive_data {}".format(
  161. # self.serial_ins.change_hex_to_int(receive_data)
  162. # )
  163. # )
  164. pass
  165. # 数据 结构 command,按命令解析
  166. if receive_data[0] == 1:
  167. # 扫码数据
  168. bar_code = receive_data[1:].decode()
  169. bar_code = bar_code.replace("\r", "")
  170. bar_code = bar_code.replace("\n", "")
  171. # self.sign_data.emit(
  172. # {"_type": 0, "plugins_mode": "remote_control", "data": bar_code}
  173. # )
  174. message = {"_type": 0, "plugins_mode": "remote_control", "data": bar_code}
  175. print("有线控制器 扫码数据1", message)
  176. self.goods_art_no = bar_code
  177. self.saveScanData(self.goods_art_no)
  178. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  179. return
  180. if receive_data[0] == 9:
  181. button_value = receive_data[1]
  182. data = {"button_value": button_value}
  183. message = {"_type": 9, "plugins_mode": "remote_control", "data": data}
  184. if button_value in [1, 2]:
  185. # 扫描货号
  186. if self.photo_take_state != 0:
  187. self.sendSocketMessage(1, "前置拍照未完成,请稍后", device_status=-1)
  188. return
  189. print("收到货号信息", self.goods_art_no)
  190. # self.saveScanData(self.goods_art_no)
  191. self.handlerAction(button_value)
  192. self.photo_take_state = 0
  193. if button_value in [3]:
  194. # 处理遥控器单拍
  195. self.msg_type = "handler_take_picture"
  196. # 0 闲置;1进行中;2已完成;
  197. _data = {"type": self.msg_type, "data": None}
  198. self.sendSocketMessage(0, "处理单拍消息", data=_data, device_status=-1)
  199. self.msg_type = "blue_tooth"
  200. if button_value in [9]:
  201. # 处理停止
  202. self.msg_type = "stop_action"
  203. # 0 闲置;1进行中;2已完成;
  204. _data = {"type": self.msg_type, "data": None}
  205. self.sendSocketMessage(
  206. 0, "停止执行组合动作", data=_data, device_status=-1
  207. )
  208. self.msg_type = "blue_tooth"
  209. self.sendSocketMessage(code=0, msg="", data=message, device_status=2)
  210. return
  211. pass
  212. def saveScanData(self, scan_data):
  213. """保存扫码数据"""
  214. if scan_data == None or scan_data == "":
  215. return
  216. scan_path = settings.SCAN_DIR
  217. if scan_path ==None or scan_path == "":
  218. return
  219. try:
  220. # 验证文件名的有效性
  221. # 替换可能导致问题的字符
  222. invalid_chars = '<>:"/\\|?*'
  223. safe_scan_data = scan_data
  224. for char in invalid_chars:
  225. safe_scan_data = safe_scan_data.replace(char, '_')
  226. # 确保文件名不为空
  227. if not safe_scan_data.strip():
  228. logger.info(f"扫码文件,无效的文件名")
  229. return
  230. # 获取目录下所有txt文件
  231. txt_files = [f for f in os.listdir(scan_path) if f.lower().endswith('.txt')]
  232. txt_filename = safe_scan_data + ".txt"
  233. new_txt_path = os.path.join(scan_path, txt_filename)
  234. # 如果只有一个txt文件,则重命名并覆盖内容
  235. if len(txt_files) == 1:
  236. try:
  237. old_txt_path = os.path.join(scan_path, txt_files[0])
  238. os.rename(old_txt_path, new_txt_path)
  239. # 覆盖文件内容
  240. with open(new_txt_path, 'w', encoding='utf-8') as f:
  241. f.write(scan_data)
  242. except Exception as e:
  243. logger.info(f"扫码文件,重命名或写入文件失败: {e}")
  244. # 如果重命名失败,创建新文件
  245. with open(new_txt_path, 'w', encoding='utf-8') as f:
  246. f.write(scan_data)
  247. # 如果有多个txt文件,删除它们并创建新文件
  248. elif len(txt_files) > 1:
  249. for txt_file in txt_files:
  250. try:
  251. txt_file_path = os.path.join(scan_path, txt_file)
  252. os.remove(txt_file_path)
  253. except Exception as e:
  254. logger.info(f"扫码文件,删除文件失败 {txt_file}: {e}")
  255. # 创建新的txt文件
  256. with open(new_txt_path, 'w', encoding='utf-8') as f:
  257. f.write(scan_data)
  258. # 如果没有txt文件,直接创建新文件
  259. else:
  260. with open(new_txt_path, 'w', encoding='utf-8') as f:
  261. f.write(scan_data)
  262. except Exception as e:
  263. logger.info(f"扫码文件,保存文件时发生错误: {e}")
  264. async def run(self):
  265. self.is_running = True
  266. while True:
  267. await asyncio.sleep(0.06)
  268. if not self.connect_state:
  269. message = {
  270. "_type": "show_info",
  271. "plugins_mode": "remote_control",
  272. "data": {"msg": "有线遥控器 未连接"},
  273. }
  274. self.sendSocketMessage(
  275. code=1,
  276. msg="有线遥控器 未连接",
  277. data=message,
  278. device_status=-1,
  279. )
  280. break
  281. await self.analysis_received_data()
  282. self.is_running = False
  283. self.close_connect()