DeviceControl.py 79 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983
  1. import asyncio
  2. import datetime
  3. from cv2 import log
  4. import serial.tools.list_ports
  5. import time, json
  6. from .SerialIns import SerialIns
  7. from utils.SingletonType import SingletonType
  8. from utils.utils_func import dynamic_parameter_issuance_get
  9. from .BaseClass import BaseClass
  10. from sockets import ConnectionManager
  11. from collections import defaultdict
  12. import threading
  13. import settings
  14. from .ProgramItem import ProgramItem
  15. from .capture.module_digicam import DigiCam
  16. from databases import insert_photo_records
  17. from .McuDeviationSet import McuDeviationSet
  18. from .OtherSet import OtherSet
  19. from .DebugUart import DebugUart
  20. from .LineControl import LineControl
  21. import copy
  22. import logging
  23. from mcu.capture.smart_shooter_class import SmartShooter
  24. import logging
  25. from conifg_info import ConfigManager
  26. logger = logging.getLogger(__name__)
  27. # mcu命令
  28. class DeviceControl(BaseClass, metaclass=SingletonType):
  29. lock = threading.Lock()
  30. def __init__(
  31. self, websocket_manager: ConnectionManager, smart_shooter: SmartShooter = None
  32. ):
  33. super().__init__(
  34. websocket_manager=websocket_manager, smart_shooter=smart_shooter
  35. )
  36. self.camera_high_motor_deviation_offset = 0
  37. self.camera_height = 400
  38. self.config_manager = None
  39. self.msg_type = "mcu"
  40. self.command = {
  41. "to_device_move": 1, # 设备运动
  42. "to_init_device": 2, # 初始化设备
  43. "to_deal_other_device": 3, # 处理其他设备
  44. "get_all_info": 29, # 获取所有信息
  45. "set_deviation": 40, # 设置偏移量
  46. "get_deviation": 41, # 读取偏移量
  47. "signal_forwarding": 91, # 信号转发处理
  48. "signal_forwarding_return": 92, # 信号转发返回
  49. "get_other_info": 44, # 获取其他信息
  50. "open_rgb_led": 43, ## RGB灯的处理与通讯
  51. "set_other_info": 45, # 设置其他信息
  52. "query_remote_control_battery": 47, # 查询遥控器电量
  53. "set_turntable_mode": 48, # 设置转盘通讯方式 1、串口、2、无线、3 混合
  54. "stop_mcu": 93, # 停止运行mcu
  55. }
  56. self.serial_ins = None
  57. self.mcu_deviation_set = McuDeviationSet(self)
  58. self.mcu_other_set = OtherSet(self)
  59. self.debug_uart = DebugUart(self)
  60. self.line_control = LineControl(websocket_manager)
  61. self.m_t = 1
  62. # 0未开始 1进行中 2已结束 99异常
  63. self.action_state = 2
  64. self._mcu_move_state = 0
  65. self.state_camera_motor = 3
  66. self.state_camera_steering = 3
  67. self.state_turntable_steering = 3
  68. self.state_overturn_steering = 3
  69. self.seed = 0
  70. self.last_camera_height = 0
  71. # 是否实时获取mcu状态信息
  72. self.is_get_mcu_state = True
  73. self.state_move_turntable_steering = 3
  74. self.last_from_mcu_move_respond_data = None
  75. self.camera_motor_speed = 0
  76. self.camera_motor_value = 0
  77. self.init_state = False
  78. self.port_name = ""
  79. self.mcu_exit = False
  80. self.t_n = 0
  81. self.connected_ports_dict = {} # 已连接的ports
  82. self.p_list = []
  83. self.temp_ports_dict = {}
  84. self.is_running = False
  85. self.is_runn_action = False
  86. self.is_stop_action = False
  87. self.connect_state = False
  88. self.is_init_while = False
  89. self.device_name_dict = {
  90. "camera_steering": 0,
  91. "camera_high_motor": 1,
  92. "turntable_steering": 2,
  93. "overturn_steering": 3,
  94. "laser_position": 4,
  95. "buzzer": 5,
  96. "split": 6,
  97. "turntable_position_motor": 7,
  98. "mp3_player": 8,
  99. "mcu": 99,
  100. }
  101. self.last_move_time = time.time()
  102. self.device_name_dict_mapping = {
  103. 0: "相机角度",
  104. 1: "相机高度",
  105. 2: "转盘角度",
  106. 3: "翻板角度",
  107. 4: "激光灯位置",
  108. 5: "蜂鸣器",
  109. 6: "split",
  110. 7: "转盘位置",
  111. 8: "播放音频",
  112. 99: "mcu命令",
  113. }
  114. # 最近的mcu基础信息,用于获取数据状态检查
  115. self.last_mcu_info_data = {
  116. "num": 0,
  117. "time": time.time(),
  118. "data": None,
  119. }
  120. # 最近的mcu的其他配置
  121. self.last_mcu_other_info_data = {
  122. "num": 0,
  123. "time": time.time(),
  124. "data": {},
  125. }
  126. # self.window = window
  127. self.last_push_time = defaultdict(float)
  128. self.is_running = False
  129. self.is_wait_connect = False # 等待链接
  130. self.send_data_queue = [] # 发送队列
  131. # self.lock = Lock()
  132. # 是否是刚进行完初始化;首次初始化,需要运动到指定第一个指定位置
  133. self.is_just_init_time = False
  134. # self.init()
  135. # ===========注册命令函数============
  136. self.deal_code_func_dict = {
  137. 29: self.get_from_mcu_base_info, # 获取基本情况
  138. 32: self.get_from_mcu_button, # 获取按键信息
  139. 42: self.get_from_mcu_deviation_info, # 获取偏移量信息
  140. 44: self.get_from_mcu_other_info, # 获取其他配置参数
  141. 90: self.get_from_mcu_connect_info, # 获取链接电脑信号
  142. 92: self.get_from_mcu_move_respond_data, # 获取MCU响应
  143. 100: self.print_mcu_error_data, # 打印下位机的错误内容
  144. 255: self.print_mcu_noraml_data, # 打印回执
  145. 124: self.read_register_data_by_usb, # 读取某个寄存器数据
  146. 125: self.write_register_data_by_usb, # 写入某个寄存器数据
  147. 126: self.get_all_registers_list_by_usb, # 获取所有寄存器
  148. 150: self.dynamic_parameter_issuance, # 动态参数下发
  149. }
  150. def set_dynamic_config(self, config):
  151. """
  152. 设置动态参数配置
  153. """
  154. print("set_dynamic_config", config)
  155. if not self.init_state:
  156. self.sendSocketMessage(code=1, msg="mcu设备未初始化", device_status=4)
  157. return False
  158. return self.config_manager.set_dynamic_value(config)
  159. def get_dynamic_config(self):
  160. """
  161. 获取动态参数配置
  162. """
  163. if not self.init_state:
  164. self.sendSocketMessage(code=1, msg="mcu设备未初始化", device_status=4)
  165. return False
  166. # 先收集需要删除的键
  167. keys_to_delete = []
  168. for item in list(self.config_manager.CONFIG_METADATA.keys()):
  169. item_value = self.config_manager.get_dynamic_value(self.config_manager.CONFIG_METADATA[item])
  170. if not item_value:
  171. keys_to_delete.append(item)
  172. continue
  173. self.config_manager.CONFIG_METADATA[item]['value'] = item_value
  174. # 遍历结束后再删除
  175. for key in keys_to_delete:
  176. del self.config_manager.CONFIG_METADATA[key]
  177. return self.config_manager.CONFIG_METADATA
  178. def get_device_info(self):
  179. if not self.init_state:
  180. self.sendSocketMessage(code=1, msg="mcu设备未初始化", device_status=4)
  181. return False
  182. cmd = [124]
  183. cmd.extend([0xff & 106 >> 8, 0xff & 106])
  184. # print("get_device_info cmd",cmd)
  185. data = self.get_basic_info_mcu_without_async(data=cmd)
  186. # print("get_device_info====>",data)
  187. if not data:
  188. return False
  189. return_data = self.analysis_data(data[1:])
  190. is_camera_has_focal = self.config_manager.is_camera_has_focal()
  191. # print("return_data", return_data)
  192. # print("camera_high_motor_deviation_offset", self.camera_high_motor_deviation_offset)
  193. if return_data:
  194. camera_height = return_data.get('value', 35)
  195. self.camera_height = camera_height - self.camera_high_motor_deviation_offset
  196. else:
  197. self.camera_height = 400 - self.camera_high_motor_deviation_offset
  198. self.msg_type = 'get_device_info'
  199. self.sendSocketMessage(
  200. code=0,
  201. msg="获取其他设备信息",
  202. device_status=2,
  203. data={"camera_height": self.camera_height, "is_camera_has_focal": is_camera_has_focal}
  204. )
  205. self.msg_type = 'mcu'
  206. return self.camera_height
  207. # 获取异步数据
  208. def analysis_data(self, _data):
  209. _addr = _data[0] << 8 | _data[1]
  210. if _addr not in self.config_manager.CONFIG_METADATA_BY_ADDR:
  211. return False
  212. start = 2
  213. _value = _data[start] << 40 | _data[start + 1] << 32 | _data[start + 2] << 24 | _data[start + 3] << 16 | _data[
  214. start + 4] << 8 | _data[start + 5]
  215. start = start + 5
  216. _read_only = True if _data[start + 1] == 1 else False # 是否只读
  217. _dir = 1 if _data[start + 2] == 1 else -1
  218. _type = "int" if _data[start + 3] == 1 else "float"
  219. _precision = _data[start + 4]
  220. if _dir < 0:
  221. _value = _value * _dir
  222. if _type == "float":
  223. if _precision > 0:
  224. _round_x = _precision
  225. _precision = _precision * -1
  226. _value = _value * 10 ** _precision
  227. _value = round(_value, _round_x)
  228. else:
  229. _value = int(_value)
  230. return_data = {"addr": _addr,
  231. "key_name": self.config_manager.CONFIG_METADATA_BY_ADDR[_addr],
  232. "readonly": _read_only,
  233. "value": _value}
  234. return return_data
  235. # 跳过异步,直接查询某个数据信息
  236. def get_basic_info_mcu_without_async(self, data, fiddler_cmd=0):
  237. """
  238. fiddler_cmd :只接收指定的命令内容
  239. """
  240. try:
  241. # 清空接收数据
  242. self.serial_ins.clearn_flush()
  243. self.serial_ins.write_cmd(data)
  244. time.sleep(0.06)
  245. r_data = self.get_basic_info_mcu()
  246. print("264----------r_data:", r_data)
  247. except BaseException as e:
  248. print("302---e", e)
  249. r_data = []
  250. #
  251. # self.async_lock.release()
  252. return r_data
  253. def dynamic_parameter_issuance(self, receive_data):
  254. print("dynamic_parameter_issuance receive_data", receive_data)
  255. func_code, status_code, out_par_data_list = dynamic_parameter_issuance_get(
  256. receive_data
  257. )
  258. r_data = {
  259. "func_code": func_code,
  260. "status_code": status_code,
  261. "out_par_data_list": out_par_data_list,
  262. }
  263. print(r_data)
  264. return r_data
  265. # 读取某个寄存器数据
  266. def read_register_data_by_usb(self, receive_data):
  267. return receive_data
  268. # 写入某个寄存器数据
  269. def write_register_data_by_usb(self, receive_data):
  270. return receive_data
  271. # 获取所有寄存器
  272. def get_all_registers_list_by_usb(self, receive_data):
  273. byte_list = receive_data[1:]
  274. _r_data = []
  275. for i in range(0, len(byte_list), 2):
  276. if i + 1 < len(byte_list):
  277. first_byte = byte_list[i]
  278. second_byte = byte_list[i + 1]
  279. _addr = first_byte << 8 | second_byte
  280. _r_data.append(_addr)
  281. return _r_data
  282. async def sendCommand(self, command):
  283. await asyncio.sleep(0.01)
  284. loop = asyncio.get_event_loop()
  285. loop.create_task(self.debug_uart.set(command), name="sendCommand2")
  286. async def getMcuOtherInfo(self):
  287. await asyncio.sleep(0.01)
  288. self.get_other_info()
  289. async def setMcuOtherInfo(self, data):
  290. await asyncio.sleep(0.01)
  291. for k, v in data.items():
  292. print("k:{},v:{}".format(k, v))
  293. logger.info("k:{},v:{}".format(k, v))
  294. data[k] = self.setOtherMaxMinValue(k, v)
  295. self.set_to_mcu_other_info(data)
  296. self.msg_type = "set_other_mcu_info"
  297. self.sendSocketMessage(
  298. code=0,
  299. msg="设置mcu其他配置信息完成",
  300. device_status=2,
  301. )
  302. self.msg_type = "mcu"
  303. def setOtherMaxMinValue(self, item, value):
  304. value = int(value)
  305. parameter_limits = {
  306. "is_auto_send_base_info": (0, 10000),
  307. "is_move_retry": (0, 10000),
  308. "is_data_response": (0, 10000),
  309. "low_speed": (0, 10000), # 假设低速范围是0到1000
  310. "is_test": (0, 10000),
  311. "to_init_mode": (0, 10000),
  312. "turntable_move_to_init_mode": (0, 10000), # 假设转盘通讯方式范围是0到3
  313. "led_count": (0, 10000), # 假设LED数量范围是0到10
  314. "turntable_steering_angle_ratio": (0, 10000), # 假设角度比例范围是0到100
  315. "is_manual_check": (0, 10000),
  316. "camera_steering_angle_ratio": (0, 100000), # 假设角度比例范围是0到100
  317. "is_auto_motor_to_disable": (0, 10000),
  318. "diff_dir": (0, 10000),
  319. "is_auto_send_pos_info": (0, 10000),
  320. "is_dog": (0, 10000),
  321. "has_been_set_motor_config": (0, 10000),
  322. }
  323. # 获取参数的最小值和最大值
  324. min_value, max_value = parameter_limits.get(item, (0, 10000))
  325. value = max(min_value, min(max_value, value))
  326. return value
  327. async def initDevice(self, is_force=False):
  328. if not self.is_running:
  329. self.sendSocketMessage(
  330. code=1, msg="mcu设备未连接,请先连接设备", device_status=0
  331. )
  332. return False
  333. if self.init_state == True:
  334. print("已经初始化过,请勿重复初始化")
  335. logger.info("已经初始化过,请勿重复初始化")
  336. self.sendSocketMessage(msg="设备初始化完成", device_status=2)
  337. return False
  338. self.config_manager = ConfigManager(self)
  339. self.serial_ins.clearn_flush()
  340. self.to_init_device_origin_point(device_name="mcu", is_force=is_force)
  341. print("MCU 开始循环~")
  342. logger.info("MCU 开始循环~")
  343. while 1:
  344. await asyncio.sleep(0.05)
  345. if not self.serial_ins or not self.connect_state:
  346. break
  347. try:
  348. self.send_cmd()
  349. if not self.get_basic_info_mcu():
  350. pass
  351. except BaseException as e:
  352. print("121231298908", e)
  353. logger.info(f"121231298908{e}")
  354. break
  355. self.is_running = False
  356. self.connect_state = False
  357. print("MCU 循环退出~")
  358. logger.info("MCU 循环退出~")
  359. print("串口未连接,请检查")
  360. logger.info("串口未连接,请检查")
  361. self.sendSocketMessage(code=1, msg="MCU串口未连接,请检查", device_status=-1)
  362. message = {"_type": "show_info", "plugins_mode": "mcu", "data": "MCU 连接失败"}
  363. self.sendSocketMessage(
  364. code=1, msg="MCU 连接失败", data=message, device_status=-1
  365. )
  366. self.close_connect()
  367. async def initControlLine(self, serial_handle):
  368. """实例化有线控制设备"""
  369. self.line_control.connect_state = True
  370. self.line_control.serial_ins = serial_handle
  371. await self.line_control.run()
  372. def stop_mcu(self):
  373. buf = [self.command["stop_mcu"]]
  374. buf.extend(self.encapsulation_data(data=1, len_data=1))
  375. self.add_send_data_queue(buf)
  376. # 设置转盘通讯方式 1、串口、2、无线、3 混合
  377. def to_set_turntable_mode(self, mode=1):
  378. buf = [self.command["set_turntable_mode"]]
  379. buf.extend(self.encapsulation_data(data=mode, len_data=1))
  380. self.add_send_data_queue(buf)
  381. def query_remote_control_battery(self):
  382. """查询遥控器电量"""
  383. buf = [self.command["query_remote_control_battery"]]
  384. buf.extend(self.encapsulation_data(data=1, len_data=1))
  385. buf.extend(self.encapsulation_data(data=1, len_data=1))
  386. buf.extend(self.encapsulation_data(data=1, len_data=1))
  387. self.add_send_data_queue(buf)
  388. def encapsulation_data(self, data, len_data, data_magnification=1):
  389. # data_magnification 数据放大倍数,或缩小倍数,默认为1
  390. data = int(data * data_magnification)
  391. if len_data == 1:
  392. return [0xFF & data]
  393. elif len_data == 2:
  394. return [0xFF & data >> 8, 0xFF & data]
  395. elif len_data == 4:
  396. return [0xFF & data >> 24, 0xFF & data >> 16, 0xFF & data >> 8, 0xFF & data]
  397. def open_rgb_led(
  398. self,
  399. color_name,
  400. led_command=1,
  401. brightness=80,
  402. enable=True,
  403. mode="loop",
  404. times=2,
  405. interval=0.1,
  406. ):
  407. color_name_value = {
  408. "红色": (156, 6, 3),
  409. "黄色": (255, 206, 25),
  410. "绿色": (0, 128, 0),
  411. "蓝色": (0, 25, 255),
  412. "白色": (255, 250, 227),
  413. }
  414. if color_name in color_name_value:
  415. buf = [self.command["open_rgb_led"]]
  416. buf.append(1 if enable else 0)
  417. buf.append(led_command)
  418. buf.extend(color_name_value[color_name])
  419. buf.extend(
  420. [
  421. brightness,
  422. 1 if mode == "loop" else 2,
  423. times,
  424. int(interval * 10),
  425. ]
  426. )
  427. self.add_send_data_queue(buf)
  428. def getDeviationInfo(self):
  429. # await asyncio.sleep(0.01)
  430. try:
  431. # 发送获取偏移量
  432. data = [self.command["get_deviation"], 1]
  433. self.add_send_data_queue(data)
  434. # if self.serial_ins:
  435. # self.serial_ins.write_cmd(data)
  436. print("发送获取偏移量")
  437. logger.info("发送获取偏移量")
  438. except Exception as e:
  439. print(e)
  440. print("getDeviationInfo", "暂未获取到self.command")
  441. logger.info("getDeviationInfo暂未获取到self.command")
  442. def set_deviation(self, device_name, _type=0, deviation=0):
  443. # turntable----0 angle_ratio 1 turntable_steering_deviation
  444. # overturn ----0 middle 1 high
  445. if device_name == "camera_high_motor":
  446. deviation = deviation / 10 # deviation 原单位为mm
  447. if device_name == "turntable_position_motor":
  448. deviation = deviation / 10 # deviation 原单位为mm
  449. if device_name == "camera_steering":
  450. pass
  451. if device_name == "turntable_steering":
  452. pass
  453. if device_name == "overturn_steering":
  454. pass
  455. device_id = self.device_name_dict[device_name]
  456. _dir = 1 if deviation >= 0 else 0
  457. deviation = int(abs(deviation * 10))
  458. data = [
  459. self.command["set_deviation"],
  460. device_id,
  461. _type,
  462. _dir,
  463. 0xFF & deviation >> 8,
  464. 0xFF & deviation,
  465. ]
  466. self.add_send_data_queue(data)
  467. # self.controlDevice(device_name, deviation)
  468. async def set_deviation_cmd(self, value, action_name, type):
  469. await asyncio.sleep(0.01)
  470. name_sets = [
  471. "相机电机", # min 0 max 400,步长1
  472. "相机舵机", # min -40 max 40,步长0.1
  473. "转盘舵机", # min -720 max 720,步长1
  474. "转盘前后电机", # min 0 max 950,步长1
  475. "翻板舵机中位", # min 0 max 180,步长0.5
  476. "翻板舵机高位", # min 0 max 180,步长0.5
  477. "翻板舵机上升速度", # min 1 max 10,步长1
  478. "翻板舵机下降速度", # min 1 max 10,步长1
  479. ]
  480. if action_name not in name_sets:
  481. self.msg_type = f"{type}_deviation"
  482. self.sendSocketMessage(msg="设置参数有误,请检查", device_status=0, code=1)
  483. self.msg_type = "mcu"
  484. return
  485. # 发送获取偏移量
  486. if type == "move":
  487. self.mcu_deviation_set.change_value(value, action_name)
  488. elif type == "set":
  489. self.mcu_deviation_set.set_deviation(action_name)
  490. self.msg_type = f"{type}_deviation"
  491. self.sendSocketMessage(msg=f"{action_name} 设置成功", device_status=2, code=0)
  492. self.msg_type = "mcu"
  493. def get_other_info(self):
  494. # 发送获取偏移量
  495. data = [self.command["get_other_info"], 1]
  496. self.add_send_data_queue(data)
  497. print("发送获取其他信息")
  498. logger.info("发送获取其他信息")
  499. def add_send_data_queue(self, data):
  500. self.lock.acquire()
  501. if self.serial_ins:
  502. print("send_data_queue append :{}".format(data))
  503. logger.info("send_data_queue append %s", data)
  504. self.send_data_queue.append(data)
  505. self.lock.release()
  506. async def send_all_cmd(self):
  507. # await asyncio.sleep(0.001)
  508. while True:
  509. await asyncio.sleep(0.1)
  510. if self.send_data_queue:
  511. # self.sendSocketMessage(msg="正在发送命令", device_status=1)
  512. data = self.send_data_queue.pop(0)
  513. # print("\033[1;32;40m 正在发送命令 \033[0m",data)
  514. self.serial_ins.write_cmd(data)
  515. # self.sendSocketMessage(msg="命令发送完成", device_status=2)
  516. else:
  517. break
  518. def send_cmd(self):
  519. self.lock.acquire()
  520. if self.send_data_queue:
  521. # self.sendSocketMessage(msg="正在发送命令", device_status=1)
  522. data = self.send_data_queue.pop(0)
  523. self.serial_ins.write_cmd(data)
  524. # self.sendSocketMessage(msg="命令发送完成", device_status=2)
  525. else:
  526. # self.t_n += 1
  527. # 加大发送获取基础数据的时间间隔
  528. # 默认为0.01秒一个循环,每隔1.5秒发送数据
  529. if self.t_n == 150:
  530. # self.t_n = 0
  531. self.send_get_all_info_to_mcu()
  532. self.lock.release()
  533. def send_get_all_info_to_mcu(self):
  534. if self.is_get_mcu_state is False:
  535. return
  536. data = [self.command["get_all_info"], 1]
  537. self.serial_ins.write_cmd(data)
  538. def print_mcu_error_data(self, receive_data):
  539. # 扫码数据
  540. try:
  541. data = receive_data[1:].decode()
  542. if "设备初始化完成" in data:
  543. self.init_state = True
  544. logger.info(f"设备初始化完成:%{data}")
  545. self.sendSocketMessage(msg=data, device_status=2)
  546. else:
  547. # print("设备异常数据打印:", data)
  548. logger.info(f"115 设备异常数据打印:%{data}")
  549. msg_data = {
  550. "message": data
  551. }
  552. self.sendSocketMessage(msg="设备信息打印", data=msg_data, device_status=2,
  553. msg_type="print_mcu_error_data")
  554. except BaseException as e:
  555. print("117 error {}".format(e))
  556. logger.info(f"117 error %{e}")
  557. return
  558. def print_mcu_noraml_data(self, receive_data):
  559. # 扫码数据
  560. print("接收到255数据:", receive_data)
  561. try:
  562. command_mapping = {
  563. 1: "设备运动",
  564. 2: "初始化设备", # 初始化设备
  565. 3: "处理其他设备", # 处理其他设备
  566. 29: "获取所有信息", # 获取所有信息
  567. 40: "设置偏移量", # 设置偏移量
  568. 41: "读取偏移量", # 读取偏移量
  569. 91: "信号转发处理", # 信号转发处理
  570. 92: "信号转发返回", # 信号转发返回
  571. 44: "获取其他信息", # 获取其他信息
  572. 43: "RGB灯的处理与通讯", ## RGB灯的处理与通讯
  573. 45: "设置其他信息", # 设置其他信息
  574. 47: "查询遥控器电量", # 查询遥控器电量
  575. 48: "设置转盘通讯方式 1、串口、2、无线、3 混合", #
  576. 93: "停止运行mcu", # 停止运行mcu
  577. 90: "连接MCU", # 连接MCU
  578. }
  579. # command = int(receive_data[0])
  580. command = int(receive_data[1])
  581. command_text = command_mapping[command]
  582. # receive_data_temp = receive_data[2:]
  583. receive_data_temp_text = " ".join([hex(x) for x in receive_data])
  584. # print("255 command_text:", command_text)
  585. if command_text in ["设备运动", "处理其他设备"]:
  586. device_id = int(receive_data[2])
  587. device_value = int(receive_data[3])
  588. device_name_info = self.device_name_dict_mapping[device_id]
  589. message_info = {"设备名称": device_name_info, "运动值": device_value}
  590. print("【设备运动】消息回执:", message_info)
  591. logger.info(f"设备运动消息回执:{message_info}")
  592. print("接收设备消息回执:", command_text)
  593. logger.info(f"接收设备消息回执:{receive_data_temp_text}")
  594. except BaseException as e:
  595. print(f"255 error {e}")
  596. logger.info(f"255 error {e}")
  597. return
  598. def get_from_mcu_move_respond_data(self, receive_data):
  599. self.last_from_mcu_move_respond_data = receive_data
  600. def get_from_mcu_connect_info(self, receive_data):
  601. connect_flag = receive_data[1]
  602. device_id = receive_data[2]
  603. try:
  604. mcu_has_been_set = receive_data[6] # 设备是否有初始化 ,1 表示已初始化
  605. except:
  606. mcu_has_been_set = 99 # 未知状态
  607. # self.self_sign.emit({"type": "connect_sign", "data": connect_flag})
  608. message = {"type": "connect_sign", "data": connect_flag}
  609. self.sendSocketMessage(msg="接收连接信息", data=message)
  610. print("接收链接信息")
  611. logger.info("接收链接信息")
  612. return
  613. def to_init_device_origin_point(self, device_name, is_force=False):
  614. device_id = self.device_name_dict[device_name]
  615. cmd = 2
  616. data = [cmd, device_id, 0 if is_force is False else 1]
  617. self.open_rgb_led(color_name="红色")
  618. self.add_send_data_queue(data)
  619. if device_name == "mcu":
  620. # 重置初始化标记为 从未初始化
  621. self.is_just_init_time = False
  622. return True
  623. # 设置其他信息
  624. def set_to_mcu_other_info(self, data):
  625. is_auto_send_base_info = data["is_auto_send_base_info"]
  626. is_move_retry = data["is_move_retry"]
  627. is_data_response = data["is_data_response"]
  628. low_speed = data["low_speed"]
  629. is_test = data["is_test"]
  630. to_init_mode = data["to_init_mode"]
  631. turntable_move_to_init_mode = data["turntable_move_to_init_mode"]
  632. led_count = data["led_count"]
  633. turntable_steering_angle_ratio = data["turntable_steering_angle_ratio"]
  634. is_manual_check = data["is_manual_check"]
  635. camera_steering_angle_ratio = data["camera_steering_angle_ratio"]
  636. is_auto_motor_to_disable = data["is_auto_motor_to_disable"]
  637. diff_dir = data["diff_dir"]
  638. is_auto_send_pos_info = data["is_auto_send_pos_info"]
  639. is_dog = data["is_dog"]
  640. has_been_set_motor_config = data["has_been_set_motor_config"]
  641. buf = [self.command["set_other_info"]]
  642. buf.extend(self.encapsulation_data(data=is_auto_send_base_info, len_data=1))
  643. buf.extend(self.encapsulation_data(data=is_move_retry, len_data=1))
  644. buf.extend(self.encapsulation_data(data=is_data_response, len_data=1))
  645. buf.extend(self.encapsulation_data(data=low_speed, len_data=2))
  646. buf.extend(self.encapsulation_data(data=is_test, len_data=1))
  647. buf.extend(self.encapsulation_data(data=to_init_mode, len_data=1))
  648. buf.extend(
  649. self.encapsulation_data(data=turntable_move_to_init_mode, len_data=1)
  650. )
  651. buf.extend(self.encapsulation_data(data=led_count, len_data=2))
  652. buf.extend(
  653. self.encapsulation_data(data=turntable_steering_angle_ratio, len_data=2)
  654. )
  655. buf.extend(self.encapsulation_data(data=is_manual_check, len_data=1))
  656. buf.extend(
  657. self.encapsulation_data(data=camera_steering_angle_ratio, len_data=4)
  658. )
  659. buf.extend(self.encapsulation_data(data=is_auto_motor_to_disable, len_data=1))
  660. buf.extend(self.encapsulation_data(data=diff_dir, len_data=1))
  661. buf.extend(self.encapsulation_data(data=is_auto_send_pos_info, len_data=1))
  662. buf.extend(self.encapsulation_data(data=is_dog, len_data=1))
  663. buf.extend(self.encapsulation_data(data=has_been_set_motor_config, len_data=1))
  664. self.add_send_data_queue(buf)
  665. async def cleanAllReceiveData(self):
  666. while True:
  667. await asyncio.sleep(0.001)
  668. receive_data = self.serial_ins.read_cmd(out_time=1)
  669. if not receive_data:
  670. break
  671. def get_basic_info_mcu(self):
  672. receive_data = self.serial_ins.read_cmd(out_time=1)
  673. if receive_data is False:
  674. logger.info("get_basic_info_mcu,------------------------------------------------4657564654")
  675. self.connect_state = False
  676. return False
  677. if not receive_data:
  678. return False
  679. command = receive_data[0]
  680. print("get_basic_info_mcu", command)
  681. if command in self.deal_code_func_dict:
  682. _data = ' '.join([hex(x) for x in receive_data])
  683. return self.deal_code_func_dict[command](receive_data)
  684. return False
  685. def get_from_mcu_button(self, receive_data):
  686. button_name = receive_data[1]
  687. self.deal_mcu_button(button_name)
  688. def deal_mcu_button(self, button_name):
  689. # 防止重复点击
  690. s = time.time()
  691. if s - self.last_push_time[button_name] > 0.1:
  692. self.last_push_time[button_name] = s
  693. # print("button_name", button_name)
  694. else:
  695. self.last_push_time[button_name] = s
  696. return
  697. if button_name == 1:
  698. # 自动执行全部
  699. # self.sign_data.emit(
  700. # {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_1"}
  701. # )
  702. message = {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_1"}
  703. self.sendSocketMessage(code=0, msg="", data=message)
  704. if button_name == 2:
  705. # self.sign_data.emit(
  706. # {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_2"}
  707. # )
  708. message = {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_2"}
  709. self.sendSocketMessage(code=0, msg="", data=message)
  710. if button_name == 3:
  711. # self.sign_data.emit(
  712. # {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_3"}
  713. # )
  714. message = {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_3"}
  715. self.sendSocketMessage(code=0, msg="", data=message)
  716. # 获取偏移量信息
  717. def get_from_mcu_deviation_info(self, receive_data):
  718. if len(receive_data) == 18:
  719. camera_high_motor_deviation_dir = receive_data[1]
  720. camera_high_motor_deviation = receive_data[2] << 8 | receive_data[3]
  721. camera_high_motor_deviation = (
  722. camera_high_motor_deviation * -1
  723. if camera_high_motor_deviation_dir == 0
  724. else camera_high_motor_deviation
  725. )
  726. camera_steering_deviation_dir = receive_data[4]
  727. camera_steering_deviation = (receive_data[5] << 8 | receive_data[6]) * 0.1
  728. camera_steering_deviation = (
  729. camera_steering_deviation * -1
  730. if camera_steering_deviation_dir == 0
  731. else camera_steering_deviation
  732. )
  733. turntable_steering_deviation_dir = receive_data[7]
  734. turntable_steering_deviation = (
  735. receive_data[8] << 8 | receive_data[9]
  736. ) * 0.1
  737. turntable_steering_deviation = (
  738. turntable_steering_deviation * -1
  739. if turntable_steering_deviation_dir == 0
  740. else turntable_steering_deviation
  741. )
  742. overturn_steering_middle_dir = receive_data[10]
  743. overturn_steering_middle = (receive_data[11] << 8 | receive_data[12]) * 0.1
  744. overturn_steering_middle = (
  745. overturn_steering_middle * -1
  746. if overturn_steering_middle_dir == 0
  747. else overturn_steering_middle
  748. )
  749. overturn_steering_high_dir = receive_data[13]
  750. overturn_steering_high = (receive_data[14] << 8 | receive_data[15]) * 0.1
  751. overturn_steering_high = (
  752. overturn_steering_middle * -1
  753. if overturn_steering_high_dir == 0
  754. else overturn_steering_high
  755. )
  756. overturn_steering_up_speed = receive_data[16]
  757. overturn_steering_down_speed = receive_data[17]
  758. self.camera_high_motor_deviation_offset = camera_high_motor_deviation
  759. get_deviation_data = {
  760. "camera_high_motor_deviation": camera_high_motor_deviation,
  761. "camera_steering_deviation": camera_steering_deviation,
  762. "turntable_steering_deviation": turntable_steering_deviation,
  763. "turntable_front_end_deviation": 300,
  764. "overturn_steering_middle": overturn_steering_middle,
  765. "overturn_steering_high": overturn_steering_high,
  766. "overturn_steering_up_speed": overturn_steering_up_speed,
  767. "overturn_steering_down_speed": overturn_steering_down_speed,
  768. }
  769. self.initDeviationInfo(get_deviation_data)
  770. self.msg_type = "get_deviation_data"
  771. self.sendSocketMessage(msg="接收偏移量信息", data=get_deviation_data)
  772. self.msg_type = "mcu"
  773. print("接收偏移量信息", get_deviation_data)
  774. logger.info("接收偏移量信息")
  775. return
  776. def initDeviationInfo(self, get_deviation_data):
  777. # 初始化偏移量信息
  778. camera_high_motor_deviation = get_deviation_data["camera_high_motor_deviation"]
  779. camera_steering_deviation = get_deviation_data["camera_steering_deviation"]
  780. turntable_steering_deviation = get_deviation_data[
  781. "turntable_steering_deviation"
  782. ]
  783. overturn_steering_middle = get_deviation_data["overturn_steering_middle"]
  784. overturn_steering_high = get_deviation_data["overturn_steering_high"]
  785. overturn_steering_up_speed = get_deviation_data["overturn_steering_up_speed"]
  786. overturn_steering_down_speed = get_deviation_data[
  787. "overturn_steering_down_speed"
  788. ]
  789. self.mcu_deviation_set.last_value["相机电机"] = camera_high_motor_deviation
  790. self.mcu_deviation_set.last_value["相机舵机"] = camera_steering_deviation
  791. self.mcu_deviation_set.last_value["转盘舵机"] = turntable_steering_deviation
  792. self.mcu_deviation_set.last_value["翻板舵机中位"] = overturn_steering_middle
  793. self.mcu_deviation_set.last_value["翻板舵机高位"] = overturn_steering_high
  794. self.mcu_deviation_set.last_value["翻板舵机上升速度"] = (
  795. overturn_steering_up_speed
  796. )
  797. self.mcu_deviation_set.last_value["翻板舵机下降速度"] = (
  798. overturn_steering_down_speed
  799. )
  800. # 获取其他信息
  801. def get_from_mcu_other_info(self, receive_data):
  802. # TODO 已完成设置
  803. is_auto_send_base_info = self.get_data_from_receive_data(
  804. receive_data=receive_data, start=1, len_data=1
  805. )
  806. is_move_retry = self.get_data_from_receive_data(
  807. receive_data=receive_data, start=2, len_data=1
  808. )
  809. is_data_response = self.get_data_from_receive_data(
  810. receive_data=receive_data, start=3, len_data=1
  811. )
  812. low_speed = self.get_data_from_receive_data(
  813. receive_data=receive_data, start=4, len_data=2
  814. )
  815. is_test = self.get_data_from_receive_data(
  816. receive_data=receive_data, start=6, len_data=1
  817. )
  818. to_init_mode = self.get_data_from_receive_data(
  819. receive_data=receive_data, start=7, len_data=1
  820. )
  821. turntable_move_to_init_mode = self.get_data_from_receive_data(
  822. receive_data=receive_data, start=8, len_data=1
  823. )
  824. led_count = self.get_data_from_receive_data(
  825. receive_data=receive_data, start=9, len_data=2
  826. )
  827. turntable_steering_angle_ratio = self.get_data_from_receive_data(
  828. receive_data=receive_data, start=11, len_data=2
  829. )
  830. is_manual_check = self.get_data_from_receive_data(
  831. receive_data=receive_data, start=13, len_data=1
  832. )
  833. camera_steering_angle_ratio = self.get_data_from_receive_data(
  834. receive_data=receive_data, start=14, len_data=4
  835. )
  836. is_auto_motor_to_disable = self.get_data_from_receive_data(
  837. receive_data=receive_data, start=18, len_data=1
  838. )
  839. diff_dir = self.get_data_from_receive_data(
  840. receive_data=receive_data, start=19, len_data=1
  841. )
  842. is_auto_send_pos_info = self.get_data_from_receive_data(
  843. receive_data=receive_data, start=20, len_data=1
  844. )
  845. is_dog = self.get_data_from_receive_data(
  846. receive_data=receive_data, start=21, len_data=1
  847. )
  848. has_been_set_motor_config = self.get_data_from_receive_data(
  849. receive_data=receive_data, start=22, len_data=1
  850. )
  851. self.last_mcu_other_info_data["data"] = {
  852. "is_auto_send_base_info": is_auto_send_base_info,
  853. "is_move_retry": is_move_retry,
  854. "is_data_response": is_data_response,
  855. "low_speed": low_speed,
  856. "is_test": is_test,
  857. "to_init_mode": to_init_mode,
  858. "turntable_move_to_init_mode": turntable_move_to_init_mode,
  859. "led_count": led_count,
  860. "turntable_steering_angle_ratio": turntable_steering_angle_ratio,
  861. "is_manual_check": is_manual_check,
  862. "camera_steering_angle_ratio": camera_steering_angle_ratio,
  863. "is_auto_motor_to_disable": is_auto_motor_to_disable,
  864. "diff_dir": diff_dir,
  865. "is_auto_send_pos_info": is_auto_send_pos_info,
  866. "is_dog": is_dog,
  867. "has_been_set_motor_config": has_been_set_motor_config,
  868. }
  869. self.last_mcu_other_info_data["time"] = time.time()
  870. self.last_mcu_other_info_data["num"] += 1
  871. for k, v in self.last_mcu_other_info_data["data"].items():
  872. print("k:{},v:{}".format(k, v))
  873. logger.info("k:%s,v:%s", k, v)
  874. self.msg_type = "get_mcu_other_info"
  875. self.sendSocketMessage(
  876. code=0,
  877. msg="获取mcu其他配置信息",
  878. device_status=2,
  879. data=self.last_mcu_other_info_data["data"],
  880. )
  881. self.msg_type = "mcu"
  882. def get_data_from_receive_data(
  883. self, receive_data, start, len_data, data_magnification=1
  884. ):
  885. # data_magnification 数据放大倍数,或缩小倍数,默认为1
  886. try:
  887. if len_data == 1:
  888. data = receive_data[start]
  889. return data * data_magnification
  890. elif len_data == 2:
  891. data = receive_data[start] << 8 | receive_data[start + 1]
  892. return data * data_magnification
  893. elif len_data == 4:
  894. data = (
  895. receive_data[start] << 24
  896. | receive_data[start + 1] << 16
  897. | receive_data[start + 2] << 8
  898. | receive_data[start + 3]
  899. )
  900. return data * data_magnification
  901. return None
  902. except:
  903. return None
  904. def get_from_mcu_base_info(self, receive_data):
  905. # 数据缓存
  906. self.last_mcu_info_data["time"] = time.time()
  907. self.last_mcu_info_data["num"] += 1
  908. # print("last_mcu_info_data:{}".format(self.last_mcu_info_data["time"]))
  909. self.state_camera_motor = 3
  910. self.state_camera_steering = 3
  911. self.state_turntable_steering = 3
  912. self.state_overturn_steering = 3
  913. self.state_move_turntable_steering = 3
  914. if len(receive_data) == 7:
  915. self.m_t = 1
  916. laser_state = receive_data[1]
  917. self.state_camera_motor = receive_data[2]
  918. self.state_camera_steering = receive_data[3]
  919. self.state_turntable_steering = receive_data[4]
  920. self.state_overturn_steering = receive_data[5]
  921. flag = receive_data[6]
  922. message = {
  923. "_type": "show_mcu_info",
  924. "plugins_mode": "mcu",
  925. "data": "激光状态;{laser_state},相机高度状态:{state_camera_motor},相机角度状态:{state_camera_steering},转盘状态:{state_turntable_steering},翻板状态:{state_overturn_steering},flag:{flag}".format(
  926. laser_state=laser_state,
  927. state_camera_motor=self.state_camera_motor,
  928. state_camera_steering=self.state_camera_steering,
  929. state_turntable_steering=self.state_turntable_steering,
  930. state_overturn_steering=self.state_overturn_steering,
  931. flag=flag,
  932. ),
  933. "data_state": {
  934. "state_camera_motor": self.state_camera_motor,
  935. "state_camera_steering": self.state_camera_steering,
  936. "state_turntable_steering": self.state_turntable_steering,
  937. "state_overturn_steering": self.state_overturn_steering,
  938. },
  939. }
  940. self.msg_type = "get_mcu_info"
  941. self.sendSocketMessage(msg="获取mcu设备运行状态信息", data=message)
  942. self.msg_type = "mcu"
  943. # print("转盘:{},时间:{}".format(self.state_turntable_steering, time.time()))
  944. if len(receive_data) == 8:
  945. self.m_t = 2
  946. laser_state = receive_data[1]
  947. self.state_camera_motor = receive_data[2]
  948. self.state_camera_steering = receive_data[3]
  949. self.state_turntable_steering = receive_data[4]
  950. self.state_overturn_steering = receive_data[5]
  951. self.state_move_turntable_steering = receive_data[6]
  952. flag = receive_data[7]
  953. message = {
  954. "_type": "show_mcu_info",
  955. "plugins_mode": "mcu",
  956. "data": "激光状态;{laser_state},相机高度状态:{state_camera_motor},相机角度状态:{state_camera_steering},转盘状态:{state_turntable_steering},转盘前后移动状态:{state_move_turntable_steering},翻板状态:{state_overturn_steering},flag:{flag}".format(
  957. laser_state=laser_state,
  958. state_camera_motor=self.state_camera_motor,
  959. state_camera_steering=self.state_camera_steering,
  960. state_turntable_steering=self.state_turntable_steering,
  961. state_overturn_steering=self.state_overturn_steering,
  962. state_move_turntable_steering=self.state_move_turntable_steering,
  963. flag=flag,
  964. ),
  965. "data_state": {
  966. "state_camera_motor": self.state_camera_motor,
  967. "state_camera_steering": self.state_camera_steering,
  968. "state_turntable_steering": self.state_turntable_steering,
  969. "state_overturn_steering": self.state_overturn_steering,
  970. "state_move_turntable_steering": self.state_move_turntable_steering,
  971. },
  972. }
  973. # if self.state_camera_motor
  974. if all(
  975. value == 2
  976. for value in [
  977. self.state_camera_motor,
  978. self.state_camera_steering,
  979. self.state_turntable_steering,
  980. self.state_overturn_steering,
  981. ]
  982. ):
  983. self.init_state = True
  984. self.sendSocketMessage(msg="设备初始化完成", device_status=2)
  985. self.msg_type = "get_mcu_info"
  986. self.sendSocketMessage(msg="获取mcu设备运行状态信息", data=message)
  987. self.msg_type = "mcu"
  988. # 检查是否成功初始化
  989. if self.is_just_init_time is False:
  990. if self.mcu_move_state == 2:
  991. self.is_just_init_time = True
  992. print("is_just_init_time")
  993. logger.info("设备初始化完成")
  994. message = {
  995. "_type": "is_just_init_time",
  996. "plugins_mode": "mcu",
  997. "data": "",
  998. }
  999. self.sendSocketMessage(msg="检查设备初始化", data=message)
  1000. return
  1001. def scan_serial_port(self) -> dict:
  1002. # 获取所有可用串口列表
  1003. ports_dict = {}
  1004. ports = serial.tools.list_ports.comports()
  1005. # 遍历所有端口并打印信息
  1006. for port in ports:
  1007. # logger.info("扫描到的串口信息:{}".format(port.description))
  1008. if "CH34" in port.description:
  1009. ports_dict[port.name] = {
  1010. "name": port.name,
  1011. "device": port.device,
  1012. "description": port.description,
  1013. "hwid": port.hwid,
  1014. "manufacturer": port.manufacturer,
  1015. "product": port.product,
  1016. "serial_number": port.serial_number,
  1017. }
  1018. if len(ports_dict) <= 0:
  1019. return {}
  1020. return ports_dict
  1021. def remove_port(self, port_name):
  1022. """移除串口"""
  1023. print("remove", port_name)
  1024. logger.info("串口被移除")
  1025. data = {
  1026. "_type": "remove_port",
  1027. "plugins_mode": "auto_select_com",
  1028. "data": {"port_name": port_name},
  1029. }
  1030. self.sendSocketMessage(1, "串口被移除", data)
  1031. def is_serial_available(self, port):
  1032. try:
  1033. ser = serial.Serial(port)
  1034. ser.close()
  1035. return True
  1036. except serial.serialException:
  1037. return False
  1038. async def add_port_by_linkage(self, port_name):
  1039. # port_value :串口基础信息
  1040. # todo 根据prot_value 信息自动进行连接
  1041. print("add port_name", port_name)
  1042. logger.info("add port_name %s", port_name)
  1043. print("self.port_name", self.port_name)
  1044. logger.info("self.port_name %s", self.port_name)
  1045. if self.port_name == port_name:
  1046. self.port_name = ""
  1047. # 对没有连接的设备进行尝试连接
  1048. # 如果存在串口被占用则进行断开
  1049. self.is_serial_available(port_name)
  1050. return False
  1051. message_data = {
  1052. "_type": "show_info",
  1053. "plugins_mode": "auto_select_com",
  1054. "data": {"text": "开始识别接口:{}".format(port_name)},
  1055. }
  1056. self.sendSocketMessage(
  1057. msg="开始识别接口:{}".format(port_name), data=message_data, device_status=1
  1058. )
  1059. await asyncio.sleep(1)
  1060. """
  1061. 步骤:
  1062. 1、进行临时连接,并发送命令,成功后,自动连接对应设备
  1063. """
  1064. try:
  1065. # 尝试使用115200波特率链接
  1066. serial_handle = serial.Serial(port=port_name, baudrate=115200, timeout=0.5)
  1067. except Exception as e:
  1068. message_data = {
  1069. "_type": "show_info",
  1070. "plugins_mode": "auto_select_com",
  1071. "data": {"text": "串口:{} 被占用,或无法识别".format(port_name)},
  1072. }
  1073. self.sendSocketMessage(
  1074. 1,
  1075. msg="串口:{} 被占用,或无法识别".format(port_name).format(port_name),
  1076. data=message_data,
  1077. device_status=-1,
  1078. )
  1079. print("串口:{} 被占用".format(port_name))
  1080. logger.info("串口:%s 被占用", port_name)
  1081. if self.serial_ins.serial_handle is not None:
  1082. self.serial_ins.serial_handle.close()
  1083. return False
  1084. await asyncio.sleep(2)
  1085. print("开始发送命令")
  1086. logger.info("开始发送命令")
  1087. data = [90, 1]
  1088. try:
  1089. serial_handle.flushInput() # 尝试重置输入缓冲区
  1090. except serial.SerialTimeoutException:
  1091. print("超时错误:无法在规定时间内重置输入缓冲区。")
  1092. logger.info("超时错误:无法在规定时间内重置输入缓冲区。")
  1093. self.sendSocketMessage(
  1094. 1,
  1095. msg="超时错误:无法在规定时间内重置输入缓冲区。",
  1096. data=None,
  1097. )
  1098. serial_handle.close()
  1099. return False
  1100. print("尝试写入数据")
  1101. logger.info("尝试写入数据")
  1102. buf = bytearray(b"")
  1103. buf.extend([0x55, 0x55, (0xFF & len(data))])
  1104. buf.extend(data)
  1105. buf.extend([0xFF & ~sum(data)])
  1106. try:
  1107. self.receive_data = b""
  1108. serial_handle.write(buf)
  1109. except serial.SerialTimeoutException:
  1110. print("写入数据错误")
  1111. logger.info("写入数据错误")
  1112. serial_handle.close()
  1113. return False
  1114. await asyncio.sleep(0.3)
  1115. receive_data = self.read_cmd(serial_handle)
  1116. # print("尝试接收命令", receive_data)
  1117. # logger.info("尝试接收命令,%s", receive_data)
  1118. device_id = 0
  1119. if receive_data:
  1120. print("receive_data", receive_data)
  1121. logger.info("receive_data %s", receive_data)
  1122. if receive_data[0] == 90:
  1123. connect_flag = receive_data[1]
  1124. device_id = receive_data[2]
  1125. else:
  1126. logger.info("串口数据未监听到,继续等待...%s", port_name)
  1127. return False
  1128. print("关闭串口:{}".format(port_name))
  1129. logger.info("关闭串口:%s", port_name)
  1130. serial_handle.close()
  1131. loop = asyncio.get_event_loop()
  1132. print("device_id============>>>", device_id)
  1133. logger.info("device_id============>>>%s", device_id)
  1134. if device_id > 0:
  1135. if device_id == settings.MCU_CODE:
  1136. state, _ = self.to_connect_com(port_name)
  1137. if not state:
  1138. return False
  1139. message_data = {
  1140. "_type": "show_info",
  1141. "plugins_mode": "auto_select_com",
  1142. "data": {"text": "MCU开始连接"},
  1143. }
  1144. self.sendSocketMessage(
  1145. msg="MCU开始连接", data=message_data, device_status=1
  1146. )
  1147. self.connected_ports_dict[port_name] = "MCU"
  1148. message_data = {
  1149. "_type": "select_port_name",
  1150. "plugins_mode": "auto_select_com",
  1151. "data": {
  1152. "device_name": "mcu" if device_id == 1 else "remote_control",
  1153. "port_name": port_name,
  1154. },
  1155. }
  1156. return True
  1157. elif device_id == 2:
  1158. # 有线接收器
  1159. self.connected_ports_dict[port_name] = "Line_Control"
  1160. # print("device_id", device_id)
  1161. # logger.info("device_id %s", device_id)
  1162. state = await self.line_control.to_connect_com(port_name)
  1163. if not state:
  1164. return False
  1165. self.line_control.connect_state = True
  1166. return True
  1167. else:
  1168. print("串口无法识别")
  1169. logger.info("串口无法识别")
  1170. self.sendSocketMessage(
  1171. code=1,
  1172. msg="串口无法识别,请重新插拔拍照机USB",
  1173. data=message_data,
  1174. device_status=-1,
  1175. )
  1176. return False
  1177. # 走其他途径处理
  1178. def clearMyInstance(self):
  1179. SingletonType.clear_instance()
  1180. def to_connect_com(self, port_name):
  1181. # 关闭串口
  1182. print("to_connect_com", port_name)
  1183. logger.info("to_connect_com %s", port_name)
  1184. self.close_connect()
  1185. time.sleep(0.3)
  1186. self.connect_state = False
  1187. try:
  1188. self.serial_ins = SerialIns(port_name=port_name, baud=115200, timeout=0.1)
  1189. if not self.serial_ins.serial_handle:
  1190. message_data = {
  1191. "_type": "show_info",
  1192. "plugins_mode": "mcu",
  1193. "data": "MCU 打开串口失败",
  1194. }
  1195. self.sendSocketMessage(
  1196. msg="MCU 打开串口失败", data=message_data, device_status=-1
  1197. )
  1198. self.serial_ins = None
  1199. self.connect_state = False
  1200. return False, None
  1201. except:
  1202. message_data = {
  1203. "_type": "show_info",
  1204. "plugins_mode": "mcu",
  1205. "data": "MCU 打开串口失败",
  1206. }
  1207. self.sendSocketMessage(
  1208. msg="MCU 打开串口失败", data=message_data, device_status=-1
  1209. )
  1210. self.serial_ins = None
  1211. self.connect_state = False
  1212. return False, None
  1213. message_data = {
  1214. "_type": "show_info",
  1215. "plugins_mode": "mcu",
  1216. "data": "MCU 开始连接",
  1217. }
  1218. self.sendSocketMessage(msg="MCU 开始连接", data=message_data, device_status=1)
  1219. # =======================发送连接请求=================================
  1220. cmd = 90
  1221. data = [cmd, 1]
  1222. print("405 发送 连接请求 -----------------------------------------")
  1223. logger.info("405 发送 连接请求 -----------------------------------------")
  1224. print(self.serial_ins)
  1225. logger.info(self.serial_ins)
  1226. # self.serial_ins.clearn_flush()
  1227. self.serial_ins.write_cmd(data)
  1228. # 延迟接收数据
  1229. time.sleep(0.3)
  1230. receive_data = self.serial_ins.read_cmd(out_time=1)
  1231. if receive_data:
  1232. print(
  1233. "409 receive_data--90:{}".format(self.change_hex_to_int(receive_data))
  1234. )
  1235. logger.info(
  1236. "409 receive_data--90:%s", str(self.change_hex_to_int(receive_data))
  1237. )
  1238. else:
  1239. return False, None
  1240. if receive_data:
  1241. # receive_data[2]=1 表示为MCU设备编号
  1242. if receive_data[0] == 90 and receive_data[2] == settings.MCU_CODE:
  1243. connect_flag = receive_data[1]
  1244. # 是否有初始化
  1245. try:
  1246. mcu_has_been_set = receive_data[
  1247. 6
  1248. ] # 设备是否有初始化 ,1 表示已初始化
  1249. except:
  1250. mcu_has_been_set = 99 # 未知状态
  1251. print("MCU初始化信息{}".format(mcu_has_been_set))
  1252. logger.info("MCU初始化信息%s", str(mcu_has_been_set))
  1253. message_data = {
  1254. "_type": "show_info",
  1255. "plugins_mode": "mcu",
  1256. "data": "MCU 已连接",
  1257. }
  1258. self.sendSocketMessage(
  1259. msg="MCU 已连接", data=message_data, device_status=1
  1260. )
  1261. self.connect_state = True
  1262. self.is_running = True
  1263. print("MCU 已连接")
  1264. logger.info("MCU 已连接")
  1265. self.port_name = port_name
  1266. # time.sleep(2)
  1267. loop = asyncio.get_event_loop()
  1268. # # 异步处理
  1269. loop.create_task(self.initDevice(), name="initDevice")
  1270. return True, None
  1271. print("MCU 连接失败")
  1272. logger.info("MCU 连接失败")
  1273. # for port in self.p_list:
  1274. # logger.info(
  1275. # "MCU 连接失败处理list移除操作,self port name %s,p_list:%s",
  1276. # port_name,
  1277. # self.p_list,
  1278. # )
  1279. # if port == port_name:
  1280. # logger.info("MCU 连接失败处理list移除操作,移除 %s", port_name)
  1281. # self.p_list.remove(port)
  1282. # self.remove_port(port)
  1283. message_data = {
  1284. "_type": "show_info",
  1285. "plugins_mode": "mcu",
  1286. "data": "MCU 连接失败",
  1287. }
  1288. self.sendSocketMessage(msg="MCU 连接失败", data=message_data, device_status=-1)
  1289. self.close_connect()
  1290. return False, None
  1291. def close_connect(self):
  1292. self.port_name = ""
  1293. if self.serial_ins:
  1294. self.serial_ins.close_serial_port()
  1295. self.is_running = False
  1296. self.connect_state = False
  1297. self.connected_ports_dict = {} # 已连接的ports
  1298. # self.p_list = []
  1299. # self.temp_ports_dict = {}
  1300. self.init_state = False
  1301. print("关闭MCU")
  1302. logger.info("关闭MCU")
  1303. def close_lineConnect(self):
  1304. """'关闭有线遥控器连接"""
  1305. self.line_control.port_name = ""
  1306. self.line_control.close_connect()
  1307. print("关闭有线遥控器")
  1308. logger.info("关闭有线遥控器")
  1309. @property
  1310. def mcu_move_state(self):
  1311. if self.is_get_mcu_state is False:
  1312. self._mcu_move_state = 2
  1313. # self.action_state = 2
  1314. else:
  1315. if self.m_t == 1:
  1316. if (
  1317. self.state_camera_motor == 2
  1318. and self.state_camera_steering == 2
  1319. and self.state_turntable_steering == 2
  1320. and self.state_overturn_steering == 2
  1321. ):
  1322. self._mcu_move_state = 2
  1323. else:
  1324. self._mcu_move_state = 1
  1325. else:
  1326. if (
  1327. self.state_camera_motor == 2
  1328. and self.state_camera_steering == 2
  1329. and self.state_turntable_steering == 2
  1330. and self.state_overturn_steering == 2
  1331. and self.state_move_turntable_steering == 2
  1332. ):
  1333. self._mcu_move_state = 2
  1334. else:
  1335. self._mcu_move_state = 1
  1336. # self._mcu_move_state = 2
  1337. return self._mcu_move_state
  1338. def to_deal_device(self, device_name, value=1, _type=0, times=1, delay=0):
  1339. """
  1340. value 激光0关 1开
  1341. mp3_player value 表示0表示关,1表示开,_type 表示歌曲切换到指定歌曲
  1342. delay:延迟处理,单位为0.1秒,即delay=100时,表示延迟10秒
  1343. """
  1344. device_id = self.device_name_dict[device_name]
  1345. if device_name == "buzzer":
  1346. value = int(value)
  1347. cmd = 3
  1348. data = [
  1349. cmd,
  1350. device_id,
  1351. value,
  1352. _type,
  1353. times,
  1354. delay,
  1355. ]
  1356. self.add_send_data_queue(data)
  1357. # if self.serial_ins:
  1358. # self.serial_ins.write_cmd(data)
  1359. return True
  1360. def to_device_move(
  1361. self,
  1362. device_name,
  1363. value=0,
  1364. max_speed=None,
  1365. up_speed=None,
  1366. down_speed=None,
  1367. _is_debug=0,
  1368. is_relative=0,
  1369. is_deviation=1,
  1370. times=2, is_response=False
  1371. ):
  1372. """
  1373. 此处输入单位为 毫米,以及度 需要先缩小,再放大
  1374. """
  1375. self.seed += 1
  1376. if self.seed > 9000:
  1377. self.seed = 1
  1378. print("移动", time.time())
  1379. logger.info("移动,%s", time.time())
  1380. speed = settings.moveSpeed()
  1381. cmd = 1
  1382. device_id = self.device_name_dict[device_name]
  1383. # if device_id != 1:
  1384. # print("F非MCU设备,禁止处理")
  1385. # return
  1386. print("正在执行", device_name)
  1387. logger.info("正在执行 %s", device_name)
  1388. match device_name:
  1389. case "camera_high_motor":
  1390. # value 单位毫米
  1391. # max_speed = 10000 if max_speed is None else max_speed
  1392. # up_speed = 800 if up_speed is None else up_speed
  1393. # down_speed = 700 if down_speed is None else down_speed
  1394. max_speed = (
  1395. speed[device_name]["max_speed"] if max_speed is None else max_speed
  1396. )
  1397. up_speed = (
  1398. speed[device_name]["up_speed"] if up_speed is None else up_speed
  1399. )
  1400. down_speed = (
  1401. speed[device_name]["down_speed"]
  1402. if down_speed is None
  1403. else down_speed
  1404. )
  1405. value = value / 10 # value 单位毫米
  1406. max_camera_hight = self.camera_height / 10
  1407. # print("高度位置",max_camera_hight)
  1408. if value > max_camera_hight:
  1409. value = max_camera_hight
  1410. assert 0 <= value <= max_camera_hight
  1411. assert 0 <= max_speed <= 10000
  1412. case "camera_steering":
  1413. # 角度为度 未放大 精确到0.1度
  1414. max_speed = 6000 if max_speed is None else max_speed
  1415. up_speed = 500 if up_speed is None else up_speed
  1416. down_speed = 500 if down_speed is None else down_speed
  1417. assert -360 <= value <= 360
  1418. case "turntable_steering":
  1419. # 角度为度 未放大 精确到0.1度
  1420. # max_speed = 6000 if max_speed is None else max_speed
  1421. # up_speed = 500 if up_speed is None else up_speed
  1422. # down_speed = 400 if down_speed is None else down_speed
  1423. max_speed = (
  1424. speed[device_name]["max_speed"] if max_speed is None else max_speed
  1425. )
  1426. up_speed = (
  1427. speed[device_name]["up_speed"] if up_speed is None else up_speed
  1428. )
  1429. down_speed = (
  1430. speed[device_name]["down_speed"]
  1431. if down_speed is None
  1432. else down_speed
  1433. )
  1434. assert -720 <= value <= 720
  1435. case "overturn_steering":
  1436. # 角度为度 未放大 精确到0.1度
  1437. max_speed = 2 if max_speed is None else max_speed
  1438. up_speed = 1 if up_speed is None else up_speed
  1439. down_speed = 1 if down_speed is None else down_speed
  1440. assert 0 <= value <= 360
  1441. case "turntable_position_motor":
  1442. # value 单位毫米
  1443. max_speed = 11000 if max_speed is None else max_speed
  1444. up_speed = 900 if up_speed is None else up_speed
  1445. down_speed = 900 if down_speed is None else down_speed
  1446. value = value / 10 # value 单位毫米
  1447. assert 0 <= value <= 900
  1448. assert 0 <= max_speed <= 15000
  1449. _dir = True if value >= 0 else False
  1450. value = int(abs(value * 10)) # 此处value赋值后,单位为mm以及0.1度
  1451. print("准备执行", device_name, value)
  1452. logger.info("准备执行,%s %s", device_name, value)
  1453. data = [
  1454. cmd,
  1455. device_id,
  1456. 1 if _dir else 0,
  1457. 0xFF & value >> 8,
  1458. 0xFF & value,
  1459. 0xFF & max_speed >> 8,
  1460. 0xFF & max_speed,
  1461. 0xFF & up_speed >> 8,
  1462. 0xFF & up_speed,
  1463. 0xFF & down_speed >> 8,
  1464. 0xFF & down_speed,
  1465. _is_debug,
  1466. is_deviation,
  1467. is_relative,
  1468. times, # 重试次数
  1469. 0xff & self.seed >> 8, # 随机种子
  1470. 0xff & self.seed, # 随机种子
  1471. 1 if is_response is True else 0, # 是否返回内容
  1472. ]
  1473. self.add_send_data_queue(data)
  1474. current_time = time.time()
  1475. self.last_move_time = current_time
  1476. def to_get_mcu_base_info(self):
  1477. if self.connect_state:
  1478. self.lock.acquire()
  1479. # print('==========================>1111')
  1480. print("-------------------to_get_mcu_base_info--------------------------")
  1481. data = [self.command["get_all_info"], 1]
  1482. f = True
  1483. try:
  1484. self.serial_ins.write_cmd(data)
  1485. except:
  1486. f = False
  1487. pass
  1488. self.lock.release()
  1489. if not f:
  1490. self.connect_state = False
  1491. return False
  1492. else:
  1493. return True
  1494. def check_before_action(self):
  1495. if self.state != 2:
  1496. print("check_before_action 设备正在运行中~")
  1497. logger.info("check_before_action 设备正在运行中~")
  1498. self.sendSocketMessage(code=1, msg="设备正在运行中", device_status=1)
  1499. return False
  1500. if self.mcu_move_state != 2:
  1501. if settings.IS_LIN_SHI_TEST:
  1502. return True
  1503. # self.show_info("mcu 非停止状态")
  1504. self.sendSocketMessage(code=1, msg="mcu 非停止状态", device_status=1)
  1505. return True
  1506. async def controlDevice(self, device_name, value):
  1507. """控制设备移动等"""
  1508. await asyncio.sleep(0.01)
  1509. if not self.is_running:
  1510. self.sendSocketMessage(
  1511. code=1, msg="mcu设备未连接,请先连接设备", device_status=0
  1512. )
  1513. return False
  1514. if not self.init_state:
  1515. self.sendSocketMessage(code=1, msg="mcu设备未初始化", device_status=4)
  1516. return False
  1517. _is_debug = 1 if settings.IS_DEBUG == "true" else 0
  1518. is_deviation = 0 if settings.IS_DEBUG == "true" else 1
  1519. print("控制设备==>_is_debug", _is_debug)
  1520. logger.info("控制设备==>_is_debug %s", _is_debug)
  1521. match device_name:
  1522. case "camera_high_motor":
  1523. # 相机电机
  1524. print(device_name, value)
  1525. self.to_device_move(
  1526. device_name=device_name,
  1527. value=float(value),
  1528. )
  1529. self.to_device_move(
  1530. device_name=device_name,
  1531. value=float(value),
  1532. )
  1533. case "camera_steering":
  1534. print(device_name, value)
  1535. # 相机舵机
  1536. self.to_device_move(
  1537. device_name=device_name,
  1538. value=float(value),
  1539. )
  1540. self.to_device_move(
  1541. device_name=device_name,
  1542. value=float(value),
  1543. )
  1544. case "turntable_steering":
  1545. # 转盘舵机
  1546. self.to_device_move(
  1547. device_name=device_name,
  1548. value=float(value),
  1549. )
  1550. self.to_device_move(
  1551. device_name=device_name,
  1552. value=float(value),
  1553. )
  1554. case "turntable_position_motor":
  1555. # 转盘舵机
  1556. self.to_device_move(
  1557. device_name=device_name,
  1558. value=float(value),
  1559. )
  1560. self.to_device_move(
  1561. device_name=device_name,
  1562. value=float(value),
  1563. )
  1564. case "overturn_steering":
  1565. # 翻板舵机中位
  1566. self.to_deal_device(
  1567. device_name="overturn_steering",
  1568. )
  1569. case "laser_position":
  1570. self.to_deal_device(
  1571. device_name="laser_position", value=0 if int(value) <= 0 else 1
  1572. )
  1573. case "take_picture":
  1574. # loop = asyncio.get_event_loop()
  1575. # if value>0:
  1576. # # 指定自动对焦
  1577. # loop.create_task(
  1578. # self.smart_shooter.CameraAutofocus(),
  1579. # name="CameraAutofocus",
  1580. # )
  1581. # 拍照
  1582. await self.smart_shooter.CameraShooter(msg_type="run_mcu")
  1583. case "to_deal_device":
  1584. self.to_deal_device(device_name, value=value, _type=0, times=1)
  1585. case _:
  1586. pass
  1587. def checkDevice(self):
  1588. print("检查设备是否运行中")
  1589. logger.info("检查设备是否运行中")
  1590. if not self.is_running:
  1591. self.sendSocketMessage(
  1592. code=1, msg="mcu设备未连接,请先连接设备", device_status=0
  1593. )
  1594. return False
  1595. if self.init_state is not True:
  1596. self.sendSocketMessage(code=1, msg="mcu设备未初始化", device_status=4)
  1597. return False
  1598. if self.action_state != 2:
  1599. self.sendSocketMessage(
  1600. code=1,
  1601. msg="当前有未完成的任务,请稍后再试",
  1602. device_status=0,
  1603. )
  1604. return False
  1605. async def run_mcu_config(
  1606. self, config_list, goods_art_no, action_info, smart_shooter
  1607. ):
  1608. if self.checkDevice() == False:
  1609. return
  1610. image_counts = 0
  1611. if config_list:
  1612. action_names = []
  1613. record_ids = []
  1614. if len(config_list) > 1:
  1615. if config_list[-1]["take_picture"] is True:
  1616. new_init_config = copy.copy(config_list[0])
  1617. new_init_config["action_name"] = "移动到初始位"
  1618. new_init_config["number_focus"] = 0
  1619. new_init_config["take_picture"] = False
  1620. new_init_config["shoe_upturn"] = False
  1621. new_init_config["pre_delay"] = 0.0
  1622. new_init_config["after_delay"] = 0.0
  1623. # new_init_config["point_name"] = "A"
  1624. new_init_config["is_move_device"] = True
  1625. new_init_config["led_switch"] = True
  1626. new_init_config["turntable_angle"] = 0.0
  1627. new_init_config["is_wait"] = False
  1628. new_init_config["is_need_confirm"] = False
  1629. config_list.append(new_init_config)
  1630. for idx, item in enumerate(config_list):
  1631. is_take_picture = item["take_picture"]
  1632. action_id = item["id"]
  1633. record_id = -1
  1634. if is_take_picture:
  1635. image_counts += 1
  1636. # 批量插入
  1637. image_deal_mode = 0 if action_info == "执行左脚程序" else 1
  1638. state, record_id = await insert_photo_records(
  1639. image_deal_mode=image_deal_mode,
  1640. goods_art_no=goods_art_no,
  1641. image_index=idx,
  1642. action_id=action_id,
  1643. )
  1644. config_list[idx]["record_id"] = record_id
  1645. total_len = len(config_list)
  1646. self.action_state = 1
  1647. self.msg_type = "image_process"
  1648. self.sendSocketMessage(
  1649. code=0,
  1650. msg="MCU 命令已发送完成",
  1651. device_status=2,
  1652. data={
  1653. "goods_art_no": goods_art_no,
  1654. "image_counts": image_counts,
  1655. "action_names": action_names,
  1656. "current_time": datetime.datetime.now(settings.TIME_ZONE).strftime(
  1657. "%Y-%m-%d %H:%M:%S"
  1658. ),
  1659. },
  1660. )
  1661. await self.controlDevice("laser_position", 0)
  1662. # await smart_shooter.EnableCameraPreview(
  1663. # enable_status=True, msg_type="smart_shooter_enable_preview"
  1664. # )
  1665. self.msg_type = "mcu"
  1666. self.is_runn_action = True
  1667. for index, action in enumerate(config_list):
  1668. # await asyncio.sleep(0.01)
  1669. if self.is_stop_action == True:
  1670. print("停止命令接收,立即终止")
  1671. logger.info("停止命令接收,立即终止")
  1672. break
  1673. # action_is_take_picture = action["take_picture"]
  1674. record_id = action["record_id"]
  1675. image_index = -1
  1676. if record_id == -1:
  1677. image_index = -1
  1678. else:
  1679. image_index = index
  1680. program_item = ProgramItem(
  1681. websocket_manager=self.websocket_manager,
  1682. action_data=action,
  1683. mcu=self,
  1684. goods_art_no=goods_art_no,
  1685. image_index=image_index,
  1686. smart_shooter=smart_shooter,
  1687. record_id=record_id,
  1688. is_get_mcu_state=True,
  1689. )
  1690. program_item.last_move_time = self.last_move_time
  1691. if self.action_state != 1:
  1692. # 异常终止
  1693. print("action异常终止")
  1694. logger.info("action异常终止")
  1695. break
  1696. self.msg_type = "photo_take"
  1697. if not await program_item.run(total_len):
  1698. self.sendSocketMessage(
  1699. code=1,
  1700. msg="{} 执行失败~".format(program_item.action_name),
  1701. data={"goods_art_no": goods_art_no, "id": action_id},
  1702. device_status=0,
  1703. )
  1704. self.to_deal_device(device_name="buzzer", times=3)
  1705. break
  1706. else:
  1707. if program_item.action_name == "移动到初始位":
  1708. self.msg_type = "mcu"
  1709. break
  1710. self.sendSocketMessage(
  1711. code=0,
  1712. msg="{} 执行完成~".format(program_item.action_name),
  1713. data={"goods_art_no": goods_art_no, "id": record_id},
  1714. device_status=2,
  1715. )
  1716. self.msg_type = "mcu"
  1717. if index == total_len - 1:
  1718. pass
  1719. if self.is_stop_action == True:
  1720. self.msg_type = "run_mcu_stop"
  1721. self.sendSocketMessage(
  1722. code=0,
  1723. msg=f"货号:{goods_art_no},执行终止",
  1724. device_status=2,
  1725. )
  1726. self.is_stop_action = False
  1727. self.action_state = 2
  1728. self.is_runn_action = False
  1729. self.msg_type = "photo_take_finish"
  1730. self.sendSocketMessage(
  1731. code=0,
  1732. msg=f"货号:{goods_art_no},执行完成",
  1733. device_status=2,
  1734. )
  1735. self.msg_type = "mcu"
  1736. await self.controlDevice("laser_position", 1)
  1737. self.action_state = 2
  1738. # await smart_shooter.EnableCameraPreview(
  1739. # enable_status=False, msg_type="smart_shooter_enable_preview"
  1740. # )
  1741. async def run_mcu_config_single(
  1742. self,
  1743. config_info,
  1744. goods_art_no,
  1745. msg_type="run_mcu_single_finish",
  1746. image_index=-1,
  1747. smart_shooter=None,
  1748. action_id=-1,
  1749. ):
  1750. """独立拍照 仅作测试用"""
  1751. await asyncio.sleep(0.01)
  1752. if self.checkDevice() == False:
  1753. return
  1754. print("检查完成", config_info)
  1755. logger.info("检查完成 %s", config_info)
  1756. if config_info:
  1757. self.action_state = 1
  1758. self.msg_type = "mcu"
  1759. program_item = ProgramItem(
  1760. websocket_manager=self.websocket_manager,
  1761. action_data=config_info,
  1762. mcu=self,
  1763. goods_art_no=goods_art_no,
  1764. image_index=image_index,
  1765. smart_shooter=smart_shooter,
  1766. record_id=action_id,
  1767. is_get_mcu_state=False,
  1768. )
  1769. program_item.last_move_time = self.last_move_time
  1770. if self.action_state != 1:
  1771. # 异常终止
  1772. print("action异常终止")
  1773. logger.info("action异常终止")
  1774. return
  1775. program_item.smart_shooter = smart_shooter
  1776. await program_item.run(3)
  1777. self.msg_type = "mcu"
  1778. logger.info(
  1779. "发送 run_mcu_signle消息,{} 执行完成~".format(program_item.action_name)
  1780. )
  1781. self.sendSocketMessage(
  1782. code=0,
  1783. msg="{} 执行完成~".format(program_item.action_name),
  1784. data={"goods_art_no": goods_art_no, "id": action_id},
  1785. device_status=2,
  1786. )
  1787. self.action_state = 2
  1788. self.msg_type = "run_mcu_single"
  1789. logger.info("发送 run_mcu_signle消息执行完成")
  1790. self.sendSocketMessage(
  1791. code=0,
  1792. msg=f"执行完成",
  1793. device_status=2,
  1794. )
  1795. self.msg_type = "mcu"
  1796. else:
  1797. self.sendSocketMessage(
  1798. code=1, msg="未查询到重拍记录得配置信息,请确认", device_status=0
  1799. )
  1800. self.action_state = 2
  1801. async def only_take_photo(self, goods_art_no, image_index, record_id):
  1802. await asyncio.sleep(0.1)
  1803. print("only_take_photo=====>", goods_art_no, image_index, record_id)
  1804. logger.info(
  1805. f"only_take_photo=====> {goods_art_no} {image_index} {record_id}"
  1806. )
  1807. if goods_art_no == "":
  1808. print("only_take_photo 数据查询异常")
  1809. logger.info("only_take_photo 数据查询异常")
  1810. return
  1811. # 关闭led
  1812. self.controlDevice("laser_position", 0)
  1813. program_item = ProgramItem(
  1814. websocket_manager=self.websocket_manager,
  1815. action_data={},
  1816. mcu=self,
  1817. goods_art_no=goods_art_no,
  1818. image_index=image_index,
  1819. record_id=record_id,
  1820. )
  1821. program_item.digicam_take_picture()
  1822. # 打开led
  1823. self.controlDevice("laser_position", 1)
  1824. async def checkMcuConnection(device_ctrl: DeviceControl):
  1825. if device_ctrl.is_running == True:
  1826. message = {
  1827. "_type": "select_port_name",
  1828. "plugins_mode": "auto_select_com",
  1829. "data": device_ctrl.temp_ports_dict,
  1830. }
  1831. device_ctrl.device_status = 2
  1832. device_ctrl.sendSocketMessage(code=0, msg="MCU连接成功", data=message)
  1833. return
  1834. if device_ctrl.is_init_while == True:
  1835. logger.info("mcu 初始化循环已创建,请勿重复创建")
  1836. device_ctrl.sendSocketMessage(
  1837. code=0, msg="mcu 初始化循环已创建,请勿重复创建", data={}
  1838. )
  1839. return
  1840. device_ctrl.is_init_while = True
  1841. """实时检测串口是否连接"""
  1842. while True:
  1843. await asyncio.sleep(1)
  1844. if device_ctrl.mcu_exit:
  1845. break
  1846. ports_dict = device_ctrl.scan_serial_port()
  1847. device_ctrl.temp_ports_dict = ports_dict
  1848. # print("device_ctrl.p_list", device_ctrl.p_list)
  1849. # logger.info("device_ctrl.p_list %s", device_ctrl.p_list)
  1850. if not ports_dict:
  1851. # 全部清空 移除所有串口
  1852. if device_ctrl.p_list:
  1853. _p = device_ctrl.p_list.pop()
  1854. device_ctrl.remove_port(_p)
  1855. continue
  1856. if ports_dict:
  1857. for index, _i in enumerate(device_ctrl.p_list):
  1858. if _i not in ports_dict:
  1859. _p = device_ctrl.p_list.pop(index)
  1860. device_ctrl.remove_port(_p)
  1861. for _port_name, _port_value in ports_dict.items():
  1862. if _port_name not in device_ctrl.p_list:
  1863. try:
  1864. flag = await device_ctrl.add_port_by_linkage(_port_name)
  1865. if not flag:
  1866. continue
  1867. device_ctrl.p_list.append(_port_name)
  1868. except BaseException as e:
  1869. print("串口不存在{} {}".format(_port_name, e))
  1870. logger.info("串口不存在{} {}".format(_port_name, e))
  1871. device_ctrl.is_init_while = False
  1872. print("MCU断开连接,已释放")
  1873. logger.info("MCU断开连接,已释放")