DeviceControl.py 80 KB

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