DeviceControl.py 79 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969
  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. logger = logging.getLogger(__name__)
  26. # mcu命令
  27. class DeviceControl(BaseClass, metaclass=SingletonType):
  28. lock = threading.Lock()
  29. def __init__(
  30. self, websocket_manager: ConnectionManager, smart_shooter: SmartShooter = None
  31. ):
  32. super().__init__(
  33. websocket_manager=websocket_manager, smart_shooter=smart_shooter
  34. )
  35. self.msg_type = "mcu"
  36. self.mcu_deviation_set = McuDeviationSet(self)
  37. self.mcu_other_set = OtherSet(self)
  38. self.debug_uart = DebugUart(self)
  39. self.line_control = LineControl(websocket_manager)
  40. self.m_t = 1
  41. # 0未开始 1进行中 2已结束 99异常
  42. self.action_state = 2
  43. self._mcu_move_state = 0
  44. self.state_camera_motor = 3
  45. self.state_camera_steering = 3
  46. self.state_turntable_steering = 3
  47. self.state_overturn_steering = 3
  48. self.seed = 0
  49. self.last_camera_height = 0
  50. # 是否实时获取mcu状态信息
  51. self.is_get_mcu_state = True
  52. self.state_move_turntable_steering = 3
  53. self.last_from_mcu_move_respond_data = None
  54. self.camera_motor_speed = 0
  55. self.camera_motor_value = 0
  56. self.init_state = False
  57. self.port_name = ""
  58. self.mcu_exit = False
  59. self.t_n = 0
  60. self.serial_ins = None
  61. self.connected_ports_dict = {} # 已连接的ports
  62. self.p_list = []
  63. self.temp_ports_dict = {}
  64. self.is_running = False
  65. self.is_runn_action = False
  66. self.is_stop_action = False
  67. self.connect_state = False
  68. self.is_init_while = False
  69. self.device_name_dict = {
  70. "camera_steering": 0,
  71. "camera_high_motor": 1,
  72. "turntable_steering": 2,
  73. "overturn_steering": 3,
  74. "laser_position": 4,
  75. "buzzer": 5,
  76. "split": 6,
  77. "turntable_position_motor": 7,
  78. "mp3_player": 8,
  79. "mcu": 99,
  80. }
  81. self.last_move_time = time.time()
  82. self.device_name_dict_mapping = {
  83. 0:"相机角度",
  84. 1:"相机高度",
  85. 2:"转盘角度",
  86. 3:"翻板角度",
  87. 4:"激光灯位置",
  88. 5:"蜂鸣器",
  89. 6:"split",
  90. 7:"转盘位置",
  91. 8:"播放音频",
  92. 99:"mcu命令",
  93. }
  94. # 最近的mcu基础信息,用于获取数据状态检查
  95. self.last_mcu_info_data = {
  96. "num": 0,
  97. "time": time.time(),
  98. "data": None,
  99. }
  100. # 最近的mcu的其他配置
  101. self.last_mcu_other_info_data = {
  102. "num": 0,
  103. "time": time.time(),
  104. "data": {},
  105. }
  106. self.command = {
  107. "to_device_move": 1, # 设备运动
  108. "to_init_device": 2, # 初始化设备
  109. "to_deal_other_device": 3, # 处理其他设备
  110. "get_all_info": 29, # 获取所有信息
  111. "set_deviation": 40, # 设置偏移量
  112. "get_deviation": 41, # 读取偏移量
  113. "signal_forwarding": 91, # 信号转发处理
  114. "signal_forwarding_return": 92, # 信号转发返回
  115. "get_other_info": 44, # 获取其他信息
  116. "open_rgb_led": 43, ## RGB灯的处理与通讯
  117. "set_other_info": 45, # 设置其他信息
  118. "query_remote_control_battery": 47, # 查询遥控器电量
  119. "set_turntable_mode": 48, # 设置转盘通讯方式 1、串口、2、无线、3 混合
  120. "stop_mcu": 93, # 停止运行mcu
  121. }
  122. # self.window = window
  123. self.last_push_time = defaultdict(float)
  124. self.is_running = False
  125. self.is_wait_connect = False # 等待链接
  126. self.send_data_queue = [] # 发送队列
  127. # self.lock = Lock()
  128. # 是否是刚进行完初始化;首次初始化,需要运动到指定第一个指定位置
  129. self.is_just_init_time = False
  130. # self.init()
  131. # ===========注册命令函数============
  132. self.deal_code_func_dict = {
  133. 29: self.get_from_mcu_base_info, # 获取基本情况
  134. 32: self.get_from_mcu_button, # 获取按键信息
  135. 42: self.get_from_mcu_deviation_info, # 获取偏移量信息
  136. 44: self.get_from_mcu_other_info, # 获取其他配置参数
  137. 90: self.get_from_mcu_connect_info, # 获取链接电脑信号
  138. 92: self.get_from_mcu_move_respond_data, # 获取MCU响应
  139. 100: self.print_mcu_error_data, # 打印下位机的错误内容
  140. 255: self.print_mcu_noraml_data, # 打印回执
  141. 124: self.read_register_data_by_usb, # 读取某个寄存器数据
  142. 125: self.write_register_data_by_usb, # 写入某个寄存器数据
  143. 126: self.get_all_registers_list_by_usb, # 获取所有寄存器
  144. 150: self.dynamic_parameter_issuance, # 动态参数下发
  145. }
  146. def get_all_ids(self):
  147. cmd = [124]
  148. cmd.extend([0xff & 106 >> 8, 0xff & 106])
  149. data = self.get_basic_info_mcu_without_async(data=cmd)
  150. if not data:
  151. return False
  152. return_data = self.analysis_data(data[1:])
  153. if return_data:
  154. print(return_data)
  155. # 获取异步数据
  156. def analysis_data(self, _data):
  157. _addr = _data[0] << 8 | _data[1]
  158. if _addr not in CONFIG_METADATA_BY_ADDR:
  159. return False
  160. start = 2
  161. _value = _data[start] << 40 | _data[start + 1] << 32 | _data[start + 2] << 24 | _data[start + 3] << 16 | _data[start + 4] << 8 | _data[start + 5]
  162. start = start + 5
  163. _read_only = True if _data[start + 1] == 1 else False # 是否只读
  164. _dir = 1 if _data[start + 2] == 1 else -1
  165. _type = "int" if _data[start + 3] == 1 else "float"
  166. _precision = _data[start + 4]
  167. if _dir < 0:
  168. _value = _value * _dir
  169. if _type == "float":
  170. if _precision > 0:
  171. _round_x = _precision
  172. _precision = _precision * -1
  173. _value = _value * 10 ** _precision
  174. _value = round(_value, _round_x)
  175. else:
  176. _value = int(_value)
  177. return_data = {"addr": _addr,
  178. "key_name": CONFIG_METADATA_BY_ADDR[_addr],
  179. "readonly": _read_only,
  180. "value": _value}
  181. return return_data
  182. # 跳过异步,直接查询某个数据信息
  183. def get_basic_info_mcu_without_async(self, data,fiddler_cmd=0):
  184. """
  185. fiddler_cmd :只接收指定的命令内容
  186. """
  187. try:
  188. # 清空接收数据
  189. self.serial_ins.clearn_flush()
  190. self.serial_ins.write_cmd(data, is_print=True)
  191. time.sleep(0.06)
  192. r_data = self.get_basic_info_mcu(max_retries=1,fiddler_cmd=fiddler_cmd)
  193. # print("264----------r_data:", r_data)
  194. except BaseException as e:
  195. print("302---e",e)
  196. r_data = []
  197. self.async_lock.release()
  198. return r_data
  199. def dynamic_parameter_issuance(self, receive_data):
  200. print("dynamic_parameter_issuance receive_data", receive_data)
  201. func_code, status_code, out_par_data_list = dynamic_parameter_issuance_get(
  202. receive_data
  203. )
  204. r_data = {
  205. "func_code": func_code,
  206. "status_code": status_code,
  207. "out_par_data_list": out_par_data_list,
  208. }
  209. print(r_data)
  210. return r_data
  211. # 读取某个寄存器数据
  212. def read_register_data_by_usb(self, receive_data):
  213. return receive_data
  214. # 写入某个寄存器数据
  215. def write_register_data_by_usb(self, receive_data):
  216. return receive_data
  217. # 获取所有寄存器
  218. def get_all_registers_list_by_usb(self, receive_data):
  219. byte_list = receive_data[1:]
  220. _r_data = []
  221. for i in range(0, len(byte_list), 2):
  222. if i + 1 < len(byte_list):
  223. first_byte = byte_list[i]
  224. second_byte = byte_list[i + 1]
  225. _addr = first_byte << 8 | second_byte
  226. _r_data.append(_addr)
  227. return _r_data
  228. async def sendCommand(self, command):
  229. await asyncio.sleep(0.01)
  230. loop = asyncio.get_event_loop()
  231. loop.create_task(self.debug_uart.set(command), name="sendCommand2")
  232. async def getMcuOtherInfo(self):
  233. await asyncio.sleep(0.01)
  234. self.get_other_info()
  235. async def setMcuOtherInfo(self, data):
  236. await asyncio.sleep(0.01)
  237. for k, v in data.items():
  238. print("k:{},v:{}".format(k, v))
  239. logger.info("k:{},v:{}".format(k, v))
  240. data[k] = self.setOtherMaxMinValue(k, v)
  241. self.set_to_mcu_other_info(data)
  242. self.msg_type = "set_other_mcu_info"
  243. self.sendSocketMessage(
  244. code=0,
  245. msg="设置mcu其他配置信息完成",
  246. device_status=2,
  247. )
  248. self.msg_type = "mcu"
  249. def setOtherMaxMinValue(self, item, value):
  250. value = int(value)
  251. parameter_limits = {
  252. "is_auto_send_base_info": (0, 10000),
  253. "is_move_retry": (0, 10000),
  254. "is_data_response": (0, 10000),
  255. "low_speed": (0, 10000), # 假设低速范围是0到1000
  256. "is_test": (0, 10000),
  257. "to_init_mode": (0, 10000),
  258. "turntable_move_to_init_mode": (0, 10000), # 假设转盘通讯方式范围是0到3
  259. "led_count": (0, 10000), # 假设LED数量范围是0到10
  260. "turntable_steering_angle_ratio": (0, 10000), # 假设角度比例范围是0到100
  261. "is_manual_check": (0, 10000),
  262. "camera_steering_angle_ratio": (0, 100000), # 假设角度比例范围是0到100
  263. "is_auto_motor_to_disable": (0, 10000),
  264. "diff_dir": (0, 10000),
  265. "is_auto_send_pos_info": (0, 10000),
  266. "is_dog": (0, 10000),
  267. "has_been_set_motor_config": (0, 10000),
  268. }
  269. # 获取参数的最小值和最大值
  270. min_value, max_value = parameter_limits.get(item, (0, 10000))
  271. value = max(min_value, min(max_value, value))
  272. return value
  273. async def initDevice(self, is_force=False):
  274. if not self.is_running:
  275. self.sendSocketMessage(
  276. code=1, msg="mcu设备未连接,请先连接设备", device_status=0
  277. )
  278. return False
  279. if self.init_state == True:
  280. print("已经初始化过,请勿重复初始化")
  281. logger.info("已经初始化过,请勿重复初始化")
  282. self.sendSocketMessage(msg="设备初始化完成", device_status=2)
  283. return False
  284. self.serial_ins.clearn_flush()
  285. self.to_init_device_origin_point(device_name="mcu", is_force=is_force)
  286. print("MCU 开始循环~")
  287. logger.info("MCU 开始循环~")
  288. while 1:
  289. await asyncio.sleep(0.05)
  290. if not self.serial_ins or not self.connect_state:
  291. break
  292. try:
  293. self.send_cmd()
  294. if not self.get_basic_info_mcu():
  295. pass
  296. except BaseException as e:
  297. print("121231298908", e)
  298. logger.info(f"121231298908{e}")
  299. break
  300. self.is_running = False
  301. self.connect_state = False
  302. print("MCU 循环退出~")
  303. logger.info("MCU 循环退出~")
  304. print("串口未连接,请检查")
  305. logger.info("串口未连接,请检查")
  306. self.sendSocketMessage(code=1, msg="MCU串口未连接,请检查", device_status=-1)
  307. message = {"_type": "show_info", "plugins_mode": "mcu", "data": "MCU 连接失败"}
  308. self.sendSocketMessage(
  309. code=1, msg="MCU 连接失败", data=message, device_status=-1
  310. )
  311. self.close_connect()
  312. async def initControlLine(self, serial_handle):
  313. """实例化有线控制设备"""
  314. self.line_control.connect_state = True
  315. self.line_control.serial_ins = serial_handle
  316. await self.line_control.run()
  317. # if self.init_state == True:
  318. # print("已经初始化过,请勿重复初始化")
  319. # self.sendSocketMessage(msg="设备初始化完成", device_status=2)
  320. # return False
  321. # self.serial_ins.clearn_flush()
  322. # self.to_init_device_origin_point(device_name="mcu", is_force=is_force)
  323. # print("MCU 开始循环~")
  324. # while 1:
  325. # await asyncio.sleep(0.01)
  326. # if not self.serial_ins or not self.connect_state:
  327. # break
  328. # try:
  329. # # print("mcu send_cmd")
  330. # self.send_cmd()
  331. # # time.sleep(0.01)
  332. # self.get_basic_info_mcu()
  333. # # self.close_other_window()
  334. # except BaseException as e:
  335. # print("121231298908", e)
  336. # break
  337. # self.is_running = False
  338. # self.connect_state = False
  339. # print("MCU 循环退出~")
  340. # # self.sign_data.emit(
  341. # # {"_type": "show_info", "plugins_mode": "mcu", "data": "MCU 连接失败"}
  342. # # )
  343. # message = {"_type": "show_info", "plugins_mode": "mcu", "data": "MCU 连接失败"}
  344. # self.sendSocketMessage(
  345. # code=1, msg="MCU 连接失败", data=message, device_status=-1
  346. # )
  347. # self.close_connect()
  348. def stop_mcu(self):
  349. buf = [self.command["stop_mcu"]]
  350. buf.extend(self.encapsulation_data(data=1, len_data=1))
  351. self.add_send_data_queue(buf)
  352. # 设置转盘通讯方式 1、串口、2、无线、3 混合
  353. def to_set_turntable_mode(self, mode=1):
  354. buf = [self.command["set_turntable_mode"]]
  355. buf.extend(self.encapsulation_data(data=mode, len_data=1))
  356. self.add_send_data_queue(buf)
  357. def query_remote_control_battery(self):
  358. """查询遥控器电量"""
  359. buf = [self.command["query_remote_control_battery"]]
  360. buf.extend(self.encapsulation_data(data=1, len_data=1))
  361. buf.extend(self.encapsulation_data(data=1, len_data=1))
  362. buf.extend(self.encapsulation_data(data=1, len_data=1))
  363. self.add_send_data_queue(buf)
  364. def encapsulation_data(self, data, len_data, data_magnification=1):
  365. # data_magnification 数据放大倍数,或缩小倍数,默认为1
  366. data = int(data * data_magnification)
  367. if len_data == 1:
  368. return [0xFF & data]
  369. elif len_data == 2:
  370. return [0xFF & data >> 8, 0xFF & data]
  371. elif len_data == 4:
  372. return [0xFF & data >> 24, 0xFF & data >> 16, 0xFF & data >> 8, 0xFF & data]
  373. def open_rgb_led(
  374. self,
  375. color_name,
  376. led_command=1,
  377. brightness=80,
  378. enable=True,
  379. mode="loop",
  380. times=2,
  381. interval=0.1,
  382. ):
  383. color_name_value = {
  384. "红色": (156, 6, 3),
  385. "黄色": (255, 206, 25),
  386. "绿色": (0, 128, 0),
  387. "蓝色": (0, 25, 255),
  388. "白色": (255, 250, 227),
  389. }
  390. if color_name in color_name_value:
  391. buf = [self.command["open_rgb_led"]]
  392. buf.append(1 if enable else 0)
  393. buf.append(led_command)
  394. buf.extend(color_name_value[color_name])
  395. buf.extend(
  396. [
  397. brightness,
  398. 1 if mode == "loop" else 2,
  399. times,
  400. int(interval * 10),
  401. ]
  402. )
  403. self.add_send_data_queue(buf)
  404. async def getDeviationInfo(self):
  405. await asyncio.sleep(0.01)
  406. try:
  407. # 发送获取偏移量
  408. data = [self.command["get_deviation"], 1]
  409. self.add_send_data_queue(data)
  410. # if self.serial_ins:
  411. # self.serial_ins.write_cmd(data)
  412. print("发送获取偏移量")
  413. logger.info("发送获取偏移量")
  414. except Exception as e:
  415. print(e)
  416. print("getDeviationInfo", "暂未获取到self.command")
  417. logger.info("getDeviationInfo暂未获取到self.command")
  418. def set_deviation(self, device_name, _type=0, deviation=0):
  419. # turntable----0 angle_ratio 1 turntable_steering_deviation
  420. # overturn ----0 middle 1 high
  421. if device_name == "camera_high_motor":
  422. deviation = deviation / 10 # deviation 原单位为mm
  423. if device_name == "turntable_position_motor":
  424. deviation = deviation / 10 # deviation 原单位为mm
  425. if device_name == "camera_steering":
  426. pass
  427. if device_name == "turntable_steering":
  428. pass
  429. if device_name == "overturn_steering":
  430. pass
  431. device_id = self.device_name_dict[device_name]
  432. _dir = 1 if deviation >= 0 else 0
  433. deviation = int(abs(deviation * 10))
  434. data = [
  435. self.command["set_deviation"],
  436. device_id,
  437. _type,
  438. _dir,
  439. 0xFF & deviation >> 8,
  440. 0xFF & deviation,
  441. ]
  442. self.add_send_data_queue(data)
  443. # self.controlDevice(device_name, deviation)
  444. async def set_deviation_cmd(self, value, action_name, type):
  445. await asyncio.sleep(0.01)
  446. name_sets = [
  447. "相机电机", # min 0 max 400,步长1
  448. "相机舵机", # min -40 max 40,步长0.1
  449. "转盘舵机", # min -720 max 720,步长1
  450. "转盘前后电机", # min 0 max 950,步长1
  451. "翻板舵机中位", # min 0 max 180,步长0.5
  452. "翻板舵机高位", # min 0 max 180,步长0.5
  453. "翻板舵机上升速度", # min 1 max 10,步长1
  454. "翻板舵机下降速度", # min 1 max 10,步长1
  455. ]
  456. if action_name not in name_sets:
  457. self.msg_type = f"{type}_deviation"
  458. self.sendSocketMessage(msg="设置参数有误,请检查", device_status=0, code=1)
  459. self.msg_type = "mcu"
  460. return
  461. # 发送获取偏移量
  462. if type == "move":
  463. self.mcu_deviation_set.change_value(value, action_name)
  464. elif type == "set":
  465. self.mcu_deviation_set.set_deviation(action_name)
  466. self.msg_type = f"{type}_deviation"
  467. self.sendSocketMessage(msg=f"{action_name} 设置成功", device_status=2, code=0)
  468. self.msg_type = "mcu"
  469. def get_other_info(self):
  470. # 发送获取偏移量
  471. data = [self.command["get_other_info"], 1]
  472. self.add_send_data_queue(data)
  473. print("发送获取其他信息")
  474. logger.info("发送获取其他信息")
  475. def add_send_data_queue(self, data):
  476. self.lock.acquire()
  477. if self.serial_ins:
  478. print("send_data_queue append :{}".format(data))
  479. logger.info("send_data_queue append %s", data)
  480. self.send_data_queue.append(data)
  481. self.lock.release()
  482. async def send_all_cmd(self):
  483. # await asyncio.sleep(0.001)
  484. while True:
  485. await asyncio.sleep(0.1)
  486. if self.send_data_queue:
  487. # self.sendSocketMessage(msg="正在发送命令", device_status=1)
  488. data = self.send_data_queue.pop(0)
  489. # print("\033[1;32;40m 正在发送命令 \033[0m",data)
  490. self.serial_ins.write_cmd(data)
  491. # self.sendSocketMessage(msg="命令发送完成", device_status=2)
  492. else:
  493. break
  494. def send_cmd(self):
  495. self.lock.acquire()
  496. if self.send_data_queue:
  497. # self.sendSocketMessage(msg="正在发送命令", device_status=1)
  498. data = self.send_data_queue.pop(0)
  499. self.serial_ins.write_cmd(data)
  500. # self.sendSocketMessage(msg="命令发送完成", device_status=2)
  501. else:
  502. # self.t_n += 1
  503. # 加大发送获取基础数据的时间间隔
  504. # 默认为0.01秒一个循环,每隔1.5秒发送数据
  505. if self.t_n == 150:
  506. # self.t_n = 0
  507. self.send_get_all_info_to_mcu()
  508. self.lock.release()
  509. def send_get_all_info_to_mcu(self):
  510. if self.is_get_mcu_state is False:
  511. return
  512. data = [self.command["get_all_info"], 1]
  513. self.serial_ins.write_cmd(data)
  514. def print_mcu_error_data(self, receive_data):
  515. # 扫码数据
  516. try:
  517. data = receive_data[1:].decode()
  518. if "设备初始化完成" in data:
  519. self.init_state = True
  520. logger.info(f"设备初始化完成:%{data}")
  521. self.sendSocketMessage(msg=data, device_status=2)
  522. else:
  523. print("设备异常数据打印:", data)
  524. logger.info(f"115 设备异常数据打印:%{data}")
  525. except BaseException as e:
  526. print("117 error {}".format(e))
  527. logger.info(f"117 error %{e}")
  528. return
  529. def print_mcu_noraml_data(self, receive_data):
  530. # 扫码数据
  531. print("接收到255数据:", receive_data)
  532. try:
  533. command_mapping = {
  534. 1:"设备运动",
  535. 2:"初始化设备", # 初始化设备
  536. 3:"处理其他设备", # 处理其他设备
  537. 29:"获取所有信息", # 获取所有信息
  538. 40:"设置偏移量", # 设置偏移量
  539. 41:"读取偏移量", # 读取偏移量
  540. 91:"信号转发处理", # 信号转发处理
  541. 92:"信号转发返回", # 信号转发返回
  542. 44:"获取其他信息", # 获取其他信息
  543. 43:"RGB灯的处理与通讯", ## RGB灯的处理与通讯
  544. 45:"设置其他信息", # 设置其他信息
  545. 47:"查询遥控器电量", # 查询遥控器电量
  546. 48:"设置转盘通讯方式 1、串口、2、无线、3 混合", #
  547. 93:"停止运行mcu", # 停止运行mcu
  548. 90:"连接MCU",# 连接MCU
  549. }
  550. # command = int(receive_data[0])
  551. command = int(receive_data[1])
  552. command_text = command_mapping[command]
  553. # receive_data_temp = receive_data[2:]
  554. receive_data_temp_text = " ".join([hex(x) for x in receive_data])
  555. # print("255 command_text:", command_text)
  556. if command_text in ["设备运动","处理其他设备"]:
  557. device_id = int(receive_data[2])
  558. device_value = int(receive_data[3])
  559. device_name_info = self.device_name_dict_mapping[device_id]
  560. message_info = {"设备名称":device_name_info,"运动值":device_value}
  561. print("【设备运动】消息回执:", message_info)
  562. logger.info(f"设备运动消息回执:{message_info}")
  563. print("接收设备消息回执:", command_text)
  564. logger.info(f"接收设备消息回执:{receive_data_temp_text}")
  565. except BaseException as e:
  566. print(f"255 error {e}")
  567. logger.info(f"255 error {e}")
  568. return
  569. def get_from_mcu_move_respond_data(self, receive_data):
  570. self.last_from_mcu_move_respond_data = receive_data
  571. def get_from_mcu_connect_info(self, receive_data):
  572. connect_flag = receive_data[1]
  573. device_id = receive_data[2]
  574. try:
  575. mcu_has_been_set = receive_data[6] # 设备是否有初始化 ,1 表示已初始化
  576. except:
  577. mcu_has_been_set = 99 # 未知状态
  578. # self.self_sign.emit({"type": "connect_sign", "data": connect_flag})
  579. message = {"type": "connect_sign", "data": connect_flag}
  580. self.sendSocketMessage(msg="接收连接信息", data=message)
  581. print("接收链接信息")
  582. logger.info("接收链接信息")
  583. return
  584. def to_init_device_origin_point(self, device_name, is_force=False):
  585. device_id = self.device_name_dict[device_name]
  586. cmd = 2
  587. data = [cmd, device_id, 0 if is_force is False else 1]
  588. self.open_rgb_led(color_name="红色")
  589. self.add_send_data_queue(data)
  590. if device_name == "mcu":
  591. # 重置初始化标记为 从未初始化
  592. self.is_just_init_time = False
  593. return True
  594. # 设置其他信息
  595. def set_to_mcu_other_info(self, data):
  596. is_auto_send_base_info = data["is_auto_send_base_info"]
  597. is_move_retry = data["is_move_retry"]
  598. is_data_response = data["is_data_response"]
  599. low_speed = data["low_speed"]
  600. is_test = data["is_test"]
  601. to_init_mode = data["to_init_mode"]
  602. turntable_move_to_init_mode = data["turntable_move_to_init_mode"]
  603. led_count = data["led_count"]
  604. turntable_steering_angle_ratio = data["turntable_steering_angle_ratio"]
  605. is_manual_check = data["is_manual_check"]
  606. camera_steering_angle_ratio = data["camera_steering_angle_ratio"]
  607. is_auto_motor_to_disable = data["is_auto_motor_to_disable"]
  608. diff_dir = data["diff_dir"]
  609. is_auto_send_pos_info = data["is_auto_send_pos_info"]
  610. is_dog = data["is_dog"]
  611. has_been_set_motor_config = data["has_been_set_motor_config"]
  612. buf = [self.command["set_other_info"]]
  613. buf.extend(self.encapsulation_data(data=is_auto_send_base_info, len_data=1))
  614. buf.extend(self.encapsulation_data(data=is_move_retry, len_data=1))
  615. buf.extend(self.encapsulation_data(data=is_data_response, len_data=1))
  616. buf.extend(self.encapsulation_data(data=low_speed, len_data=2))
  617. buf.extend(self.encapsulation_data(data=is_test, len_data=1))
  618. buf.extend(self.encapsulation_data(data=to_init_mode, len_data=1))
  619. buf.extend(
  620. self.encapsulation_data(data=turntable_move_to_init_mode, len_data=1)
  621. )
  622. buf.extend(self.encapsulation_data(data=led_count, len_data=2))
  623. buf.extend(
  624. self.encapsulation_data(data=turntable_steering_angle_ratio, len_data=2)
  625. )
  626. buf.extend(self.encapsulation_data(data=is_manual_check, len_data=1))
  627. buf.extend(
  628. self.encapsulation_data(data=camera_steering_angle_ratio, len_data=4)
  629. )
  630. buf.extend(self.encapsulation_data(data=is_auto_motor_to_disable, len_data=1))
  631. buf.extend(self.encapsulation_data(data=diff_dir, len_data=1))
  632. buf.extend(self.encapsulation_data(data=is_auto_send_pos_info, len_data=1))
  633. buf.extend(self.encapsulation_data(data=is_dog, len_data=1))
  634. buf.extend(self.encapsulation_data(data=has_been_set_motor_config, len_data=1))
  635. self.add_send_data_queue(buf)
  636. async def cleanAllReceiveData(self):
  637. while True:
  638. await asyncio.sleep(0.001)
  639. receive_data = self.serial_ins.read_cmd(out_time=1)
  640. if not receive_data:
  641. break
  642. def get_basic_info_mcu(self):
  643. receive_data = self.serial_ins.read_cmd(out_time=1)
  644. if receive_data is False:
  645. print("------------------------------------------------4657564654")
  646. print(
  647. "------------------------------------------------get_basic_info_mcu------------------"
  648. )
  649. logger.info("------------------------------------------------4657564654")
  650. self.connect_state = False
  651. return False
  652. if not receive_data:
  653. return False
  654. command = receive_data[0]
  655. print("get_basic_info_mcu",command)
  656. if command in self.deal_code_func_dict:
  657. self.deal_code_func_dict[command](receive_data)
  658. def get_from_mcu_button(self, receive_data):
  659. button_name = receive_data[1]
  660. self.deal_mcu_button(button_name)
  661. def deal_mcu_button(self, button_name):
  662. # 防止重复点击
  663. s = time.time()
  664. if s - self.last_push_time[button_name] > 0.1:
  665. self.last_push_time[button_name] = s
  666. # print("button_name", button_name)
  667. else:
  668. self.last_push_time[button_name] = s
  669. return
  670. if button_name == 1:
  671. # 自动执行全部
  672. # self.sign_data.emit(
  673. # {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_1"}
  674. # )
  675. message = {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_1"}
  676. self.sendSocketMessage(code=0, msg="", data=message)
  677. if button_name == 2:
  678. # self.sign_data.emit(
  679. # {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_2"}
  680. # )
  681. message = {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_2"}
  682. self.sendSocketMessage(code=0, msg="", data=message)
  683. if button_name == 3:
  684. # self.sign_data.emit(
  685. # {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_3"}
  686. # )
  687. message = {"_type": "mcu_button", "plugins_mode": "mcu", "data": "todo_3"}
  688. self.sendSocketMessage(code=0, msg="", data=message)
  689. # 获取偏移量信息
  690. def get_from_mcu_deviation_info(self, receive_data):
  691. if len(receive_data) == 18:
  692. camera_high_motor_deviation_dir = receive_data[1]
  693. camera_high_motor_deviation = receive_data[2] << 8 | receive_data[3]
  694. camera_high_motor_deviation = (
  695. camera_high_motor_deviation * -1
  696. if camera_high_motor_deviation_dir == 0
  697. else camera_high_motor_deviation
  698. )
  699. camera_steering_deviation_dir = receive_data[4]
  700. camera_steering_deviation = (receive_data[5] << 8 | receive_data[6]) * 0.1
  701. camera_steering_deviation = (
  702. camera_steering_deviation * -1
  703. if camera_steering_deviation_dir == 0
  704. else camera_steering_deviation
  705. )
  706. turntable_steering_deviation_dir = receive_data[7]
  707. turntable_steering_deviation = (
  708. receive_data[8] << 8 | receive_data[9]
  709. ) * 0.1
  710. turntable_steering_deviation = (
  711. turntable_steering_deviation * -1
  712. if turntable_steering_deviation_dir == 0
  713. else turntable_steering_deviation
  714. )
  715. overturn_steering_middle_dir = receive_data[10]
  716. overturn_steering_middle = (receive_data[11] << 8 | receive_data[12]) * 0.1
  717. overturn_steering_middle = (
  718. overturn_steering_middle * -1
  719. if overturn_steering_middle_dir == 0
  720. else overturn_steering_middle
  721. )
  722. overturn_steering_high_dir = receive_data[13]
  723. overturn_steering_high = (receive_data[14] << 8 | receive_data[15]) * 0.1
  724. overturn_steering_high = (
  725. overturn_steering_middle * -1
  726. if overturn_steering_high_dir == 0
  727. else overturn_steering_high
  728. )
  729. overturn_steering_up_speed = receive_data[16]
  730. overturn_steering_down_speed = receive_data[17]
  731. # self.sign_data.emit(
  732. # {
  733. # "_type": "get_deviation_data",
  734. # "plugins_mode": "mcu",
  735. # "data": {
  736. # "camera_high_motor_deviation": camera_high_motor_deviation,
  737. # "camera_steering_deviation": camera_steering_deviation,
  738. # "turntable_steering_deviation": turntable_steering_deviation,
  739. # "overturn_steering_middle": overturn_steering_middle,
  740. # "overturn_steering_high": overturn_steering_high,
  741. # "overturn_steering_up_speed": overturn_steering_up_speed,
  742. # "overturn_steering_down_speed": overturn_steering_down_speed,
  743. # },
  744. # }
  745. # )
  746. # message = {
  747. # "_type": "get_deviation_data",
  748. # "plugins_mode": "mcu",
  749. # "data": {
  750. # "camera_high_motor_deviation": camera_high_motor_deviation,
  751. # "camera_steering_deviation": camera_steering_deviation,
  752. # "turntable_steering_deviation": turntable_steering_deviation,
  753. # "overturn_steering_middle": overturn_steering_middle,
  754. # "overturn_steering_high": overturn_steering_high,
  755. # "overturn_steering_up_speed": overturn_steering_up_speed,
  756. # "overturn_steering_down_speed": overturn_steering_down_speed,
  757. # },
  758. # }
  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("接收偏移量信息")
  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. assert 0 <= value <= 40
  1407. assert 0 <= max_speed <= 10000
  1408. case "camera_steering":
  1409. # 角度为度 未放大 精确到0.1度
  1410. max_speed = 6000 if max_speed is None else max_speed
  1411. up_speed = 500 if up_speed is None else up_speed
  1412. down_speed = 500 if down_speed is None else down_speed
  1413. assert -360 <= value <= 360
  1414. case "turntable_steering":
  1415. # 角度为度 未放大 精确到0.1度
  1416. # max_speed = 6000 if max_speed is None else max_speed
  1417. # up_speed = 500 if up_speed is None else up_speed
  1418. # down_speed = 400 if down_speed is None else down_speed
  1419. max_speed = (
  1420. speed[device_name]["max_speed"] if max_speed is None else max_speed
  1421. )
  1422. up_speed = (
  1423. speed[device_name]["up_speed"] if up_speed is None else up_speed
  1424. )
  1425. down_speed = (
  1426. speed[device_name]["down_speed"]
  1427. if down_speed is None
  1428. else down_speed
  1429. )
  1430. assert -720 <= value <= 720
  1431. case "overturn_steering":
  1432. # 角度为度 未放大 精确到0.1度
  1433. max_speed = 2 if max_speed is None else max_speed
  1434. up_speed = 1 if up_speed is None else up_speed
  1435. down_speed = 1 if down_speed is None else down_speed
  1436. assert 0 <= value <= 360
  1437. case "turntable_position_motor":
  1438. # value 单位毫米
  1439. max_speed = 11000 if max_speed is None else max_speed
  1440. up_speed = 900 if up_speed is None else up_speed
  1441. down_speed = 900 if down_speed is None else down_speed
  1442. value = value / 10 # value 单位毫米
  1443. assert 0 <= value <= 900
  1444. assert 0 <= max_speed <= 15000
  1445. _dir = True if value >= 0 else False
  1446. value = int(abs(value * 10)) # 此处value赋值后,单位为mm以及0.1度
  1447. print("准备执行", device_name, value)
  1448. logger.info("准备执行,%s %s", device_name, value)
  1449. data = [
  1450. cmd,
  1451. device_id,
  1452. 1 if _dir else 0,
  1453. 0xFF & value >> 8,
  1454. 0xFF & value,
  1455. 0xFF & max_speed >> 8,
  1456. 0xFF & max_speed,
  1457. 0xFF & up_speed >> 8,
  1458. 0xFF & up_speed,
  1459. 0xFF & down_speed >> 8,
  1460. 0xFF & down_speed,
  1461. _is_debug,
  1462. is_deviation,
  1463. is_relative,
  1464. times, # 重试次数
  1465. 0xff & self.seed >> 8, # 随机种子
  1466. 0xff & self.seed, # 随机种子
  1467. 1 if is_response is True else 0, # 是否返回内容
  1468. ]
  1469. self.add_send_data_queue(data)
  1470. current_time = time.time()
  1471. self.last_move_time = current_time
  1472. def to_get_mcu_base_info(self):
  1473. if self.connect_state:
  1474. self.lock.acquire()
  1475. # print('==========================>1111')
  1476. print("-------------------to_get_mcu_base_info--------------------------")
  1477. data = [self.command["get_all_info"], 1]
  1478. f = True
  1479. try:
  1480. self.serial_ins.write_cmd(data)
  1481. except:
  1482. f = False
  1483. pass
  1484. self.lock.release()
  1485. if not f:
  1486. self.connect_state = False
  1487. return False
  1488. else:
  1489. return True
  1490. def check_before_action(self):
  1491. if self.state != 2:
  1492. print("check_before_action 设备正在运行中~")
  1493. logger.info("check_before_action 设备正在运行中~")
  1494. self.sendSocketMessage(code=1, msg="设备正在运行中", device_status=1)
  1495. return False
  1496. if self.mcu_move_state != 2:
  1497. if settings.IS_LIN_SHI_TEST:
  1498. return True
  1499. # self.show_info("mcu 非停止状态")
  1500. self.sendSocketMessage(code=1, msg="mcu 非停止状态", device_status=1)
  1501. return True
  1502. async def controlDevice(self, device_name, value):
  1503. """控制设备移动等"""
  1504. await asyncio.sleep(0.01)
  1505. if not self.is_running:
  1506. self.sendSocketMessage(
  1507. code=1, msg="mcu设备未连接,请先连接设备", device_status=0
  1508. )
  1509. return False
  1510. if not self.init_state:
  1511. self.sendSocketMessage(code=1, msg="mcu设备未初始化", device_status=4)
  1512. return False
  1513. _is_debug = 1 if settings.IS_DEBUG == "true" else 0
  1514. is_deviation = 0 if settings.IS_DEBUG == "true" else 1
  1515. print("控制设备==>_is_debug", _is_debug)
  1516. logger.info("控制设备==>_is_debug %s", _is_debug)
  1517. match device_name:
  1518. case "camera_high_motor":
  1519. # 相机电机
  1520. print(device_name, value)
  1521. self.to_device_move(
  1522. device_name=device_name,
  1523. value=float(value),
  1524. )
  1525. self.to_device_move(
  1526. device_name=device_name,
  1527. value=float(value),
  1528. )
  1529. case "camera_steering":
  1530. print(device_name, value)
  1531. # 相机舵机
  1532. self.to_device_move(
  1533. device_name=device_name,
  1534. value=float(value),
  1535. )
  1536. self.to_device_move(
  1537. device_name=device_name,
  1538. value=float(value),
  1539. )
  1540. case "turntable_steering":
  1541. # 转盘舵机
  1542. self.to_device_move(
  1543. device_name=device_name,
  1544. value=float(value),
  1545. )
  1546. self.to_device_move(
  1547. device_name=device_name,
  1548. value=float(value),
  1549. )
  1550. case "turntable_position_motor":
  1551. # 转盘舵机
  1552. self.to_device_move(
  1553. device_name=device_name,
  1554. value=float(value),
  1555. )
  1556. self.to_device_move(
  1557. device_name=device_name,
  1558. value=float(value),
  1559. )
  1560. case "overturn_steering":
  1561. # 翻板舵机中位
  1562. self.to_deal_device(
  1563. device_name="overturn_steering",
  1564. )
  1565. case "laser_position":
  1566. self.to_deal_device(
  1567. device_name="laser_position", value=0 if int(value) <= 0 else 1
  1568. )
  1569. case "take_picture":
  1570. # loop = asyncio.get_event_loop()
  1571. # if value>0:
  1572. # # 指定自动对焦
  1573. # loop.create_task(
  1574. # self.smart_shooter.CameraAutofocus(),
  1575. # name="CameraAutofocus",
  1576. # )
  1577. # 拍照
  1578. await self.smart_shooter.CameraShooter(msg_type="run_mcu")
  1579. case "to_deal_device":
  1580. self.to_deal_device(device_name, value=value, _type=0, times=1)
  1581. case _:
  1582. pass
  1583. def checkDevice(self):
  1584. print("检查设备是否运行中")
  1585. logger.info("检查设备是否运行中")
  1586. if not self.is_running:
  1587. self.sendSocketMessage(
  1588. code=1, msg="mcu设备未连接,请先连接设备", device_status=0
  1589. )
  1590. return False
  1591. if self.init_state is not True:
  1592. self.sendSocketMessage(code=1, msg="mcu设备未初始化", device_status=4)
  1593. return False
  1594. if self.action_state != 2:
  1595. self.sendSocketMessage(
  1596. code=1,
  1597. msg="当前有未完成的任务,请稍后再试",
  1598. device_status=0,
  1599. )
  1600. return False
  1601. async def run_mcu_config(
  1602. self, config_list, goods_art_no, action_info, smart_shooter
  1603. ):
  1604. if self.checkDevice() == False:
  1605. return
  1606. image_counts = 0
  1607. if config_list:
  1608. action_names = []
  1609. record_ids = []
  1610. if len(config_list) > 1:
  1611. if config_list[-1]["take_picture"] is True:
  1612. new_init_config = copy.copy(config_list[0])
  1613. new_init_config["action_name"] = "移动到初始位"
  1614. new_init_config["number_focus"] = 0
  1615. new_init_config["take_picture"] = False
  1616. new_init_config["shoe_upturn"] = False
  1617. new_init_config["pre_delay"] = 0.0
  1618. new_init_config["after_delay"] = 0.0
  1619. # new_init_config["point_name"] = "A"
  1620. new_init_config["is_move_device"] = True
  1621. new_init_config["led_switch"] = True
  1622. new_init_config["turntable_angle"] = 0.0
  1623. new_init_config["is_wait"] = False
  1624. new_init_config["is_need_confirm"] = False
  1625. config_list.append(new_init_config)
  1626. for idx, item in enumerate(config_list):
  1627. is_take_picture = item["take_picture"]
  1628. action_id = item["id"]
  1629. record_id = -1
  1630. if is_take_picture:
  1631. image_counts += 1
  1632. # 批量插入
  1633. image_deal_mode = 0 if action_info == "执行左脚程序" else 1
  1634. state, record_id = await insert_photo_records(
  1635. image_deal_mode=image_deal_mode,
  1636. goods_art_no=goods_art_no,
  1637. image_index=idx,
  1638. action_id=action_id,
  1639. )
  1640. config_list[idx]["record_id"] = record_id
  1641. total_len = len(config_list)
  1642. self.action_state = 1
  1643. self.msg_type = "image_process"
  1644. self.sendSocketMessage(
  1645. code=0,
  1646. msg="MCU 命令已发送完成",
  1647. device_status=2,
  1648. data={
  1649. "goods_art_no": goods_art_no,
  1650. "image_counts": image_counts,
  1651. "action_names": action_names,
  1652. "current_time": datetime.datetime.now(settings.TIME_ZONE).strftime(
  1653. "%Y-%m-%d %H:%M:%S"
  1654. ),
  1655. },
  1656. )
  1657. await self.controlDevice("laser_position", 0)
  1658. # await smart_shooter.EnableCameraPreview(
  1659. # enable_status=True, msg_type="smart_shooter_enable_preview"
  1660. # )
  1661. self.msg_type = "mcu"
  1662. self.is_runn_action = True
  1663. for index, action in enumerate(config_list):
  1664. # await asyncio.sleep(0.01)
  1665. if self.is_stop_action == True:
  1666. print("停止命令接收,立即终止")
  1667. logger.info("停止命令接收,立即终止")
  1668. break
  1669. # action_is_take_picture = action["take_picture"]
  1670. record_id = action["record_id"]
  1671. image_index = -1
  1672. if record_id == -1:
  1673. image_index = -1
  1674. else:
  1675. image_index = index
  1676. program_item = ProgramItem(
  1677. websocket_manager=self.websocket_manager,
  1678. action_data=action,
  1679. mcu=self,
  1680. goods_art_no=goods_art_no,
  1681. image_index=image_index,
  1682. smart_shooter=smart_shooter,
  1683. record_id=record_id,
  1684. is_get_mcu_state=True,
  1685. )
  1686. program_item.last_move_time = self.last_move_time
  1687. if self.action_state != 1:
  1688. # 异常终止
  1689. print("action异常终止")
  1690. logger.info("action异常终止")
  1691. break
  1692. self.msg_type = "photo_take"
  1693. if not await program_item.run(total_len):
  1694. self.sendSocketMessage(
  1695. code=1,
  1696. msg="{} 执行失败~".format(program_item.action_name),
  1697. data={"goods_art_no": goods_art_no, "id": action_id},
  1698. device_status=0,
  1699. )
  1700. self.to_deal_device(device_name="buzzer", times=3)
  1701. break
  1702. else:
  1703. if program_item.action_name == "移动到初始位":
  1704. self.msg_type = "mcu"
  1705. break
  1706. self.sendSocketMessage(
  1707. code=0,
  1708. msg="{} 执行完成~".format(program_item.action_name),
  1709. data={"goods_art_no": goods_art_no, "id": record_id},
  1710. device_status=2,
  1711. )
  1712. self.msg_type = "mcu"
  1713. if index == total_len - 1:
  1714. pass
  1715. if self.is_stop_action == True:
  1716. self.msg_type = "run_mcu_stop"
  1717. self.sendSocketMessage(
  1718. code=0,
  1719. msg=f"货号:{goods_art_no},执行终止",
  1720. device_status=2,
  1721. )
  1722. self.is_stop_action = False
  1723. self.action_state = 2
  1724. self.is_runn_action = False
  1725. self.msg_type = "photo_take_finish"
  1726. self.sendSocketMessage(
  1727. code=0,
  1728. msg=f"货号:{goods_art_no},执行完成",
  1729. device_status=2,
  1730. )
  1731. self.msg_type = "mcu"
  1732. await self.controlDevice("laser_position", 1)
  1733. self.action_state = 2
  1734. # await smart_shooter.EnableCameraPreview(
  1735. # enable_status=False, msg_type="smart_shooter_enable_preview"
  1736. # )
  1737. async def run_mcu_config_single(
  1738. self,
  1739. config_info,
  1740. goods_art_no,
  1741. msg_type="run_mcu_single_finish",
  1742. image_index=-1,
  1743. smart_shooter=None,
  1744. action_id=-1,
  1745. ):
  1746. """独立拍照 仅作测试用"""
  1747. await asyncio.sleep(0.01)
  1748. if self.checkDevice() == False:
  1749. return
  1750. print("检查完成", config_info)
  1751. logger.info("检查完成 %s", config_info)
  1752. if config_info:
  1753. self.action_state = 1
  1754. self.msg_type = "mcu"
  1755. program_item = ProgramItem(
  1756. websocket_manager=self.websocket_manager,
  1757. action_data=config_info,
  1758. mcu=self,
  1759. goods_art_no=goods_art_no,
  1760. image_index=image_index,
  1761. smart_shooter=smart_shooter,
  1762. record_id=action_id,
  1763. is_get_mcu_state=False,
  1764. )
  1765. program_item.last_move_time = self.last_move_time
  1766. if self.action_state != 1:
  1767. # 异常终止
  1768. print("action异常终止")
  1769. logger.info("action异常终止")
  1770. return
  1771. program_item.smart_shooter = smart_shooter
  1772. await program_item.run(3)
  1773. self.msg_type = "mcu"
  1774. logger.info(
  1775. "发送 run_mcu_signle消息,{} 执行完成~".format(program_item.action_name)
  1776. )
  1777. self.sendSocketMessage(
  1778. code=0,
  1779. msg="{} 执行完成~".format(program_item.action_name),
  1780. data={"goods_art_no": goods_art_no, "id": action_id},
  1781. device_status=2,
  1782. )
  1783. self.action_state = 2
  1784. self.msg_type = "run_mcu_single"
  1785. logger.info("发送 run_mcu_signle消息执行完成")
  1786. self.sendSocketMessage(
  1787. code=0,
  1788. msg=f"执行完成",
  1789. device_status=2,
  1790. )
  1791. self.msg_type = "mcu"
  1792. else:
  1793. self.sendSocketMessage(
  1794. code=1, msg="未查询到重拍记录得配置信息,请确认", device_status=0
  1795. )
  1796. self.action_state = 2
  1797. async def only_take_photo(self, goods_art_no, image_index, record_id):
  1798. await asyncio.sleep(0.1)
  1799. print("only_take_photo=====>", goods_art_no, image_index, record_id)
  1800. logger.info(
  1801. f"only_take_photo=====> {goods_art_no} {image_index} {record_id}"
  1802. )
  1803. if goods_art_no == "":
  1804. print("only_take_photo 数据查询异常")
  1805. logger.info("only_take_photo 数据查询异常")
  1806. return
  1807. # 关闭led
  1808. self.controlDevice("laser_position", 0)
  1809. program_item = ProgramItem(
  1810. websocket_manager=self.websocket_manager,
  1811. action_data={},
  1812. mcu=self,
  1813. goods_art_no=goods_art_no,
  1814. image_index=image_index,
  1815. record_id=record_id,
  1816. )
  1817. program_item.digicam_take_picture()
  1818. # 打开led
  1819. self.controlDevice("laser_position", 1)
  1820. async def checkMcuConnection(device_ctrl: DeviceControl):
  1821. if device_ctrl.is_running == True:
  1822. message = {
  1823. "_type": "select_port_name",
  1824. "plugins_mode": "auto_select_com",
  1825. "data": device_ctrl.temp_ports_dict,
  1826. }
  1827. device_ctrl.device_status = 2
  1828. device_ctrl.sendSocketMessage(code=0, msg="MCU连接成功", data=message)
  1829. return
  1830. if device_ctrl.is_init_while == True:
  1831. logger.info("mcu 初始化循环已创建,请勿重复创建")
  1832. device_ctrl.sendSocketMessage(
  1833. code=0, msg="mcu 初始化循环已创建,请勿重复创建", data={}
  1834. )
  1835. return
  1836. device_ctrl.is_init_while = True
  1837. """实时检测串口是否连接"""
  1838. while True:
  1839. await asyncio.sleep(1)
  1840. if device_ctrl.mcu_exit:
  1841. break
  1842. ports_dict = device_ctrl.scan_serial_port()
  1843. device_ctrl.temp_ports_dict = ports_dict
  1844. # print("device_ctrl.p_list", device_ctrl.p_list)
  1845. # logger.info("device_ctrl.p_list %s", device_ctrl.p_list)
  1846. if not ports_dict:
  1847. # 全部清空 移除所有串口
  1848. if device_ctrl.p_list:
  1849. _p = device_ctrl.p_list.pop()
  1850. device_ctrl.remove_port(_p)
  1851. continue
  1852. if ports_dict:
  1853. for index, _i in enumerate(device_ctrl.p_list):
  1854. if _i not in ports_dict:
  1855. _p = device_ctrl.p_list.pop(index)
  1856. device_ctrl.remove_port(_p)
  1857. for _port_name, _port_value in ports_dict.items():
  1858. if _port_name not in device_ctrl.p_list:
  1859. try:
  1860. flag = await device_ctrl.add_port_by_linkage(_port_name)
  1861. if not flag:
  1862. continue
  1863. device_ctrl.p_list.append(_port_name)
  1864. except BaseException as e:
  1865. print("串口不存在{} {}".format(_port_name, e))
  1866. logger.info("串口不存在{} {}".format(_port_name, e))
  1867. device_ctrl.is_init_while = False
  1868. print("MCU断开连接,已释放")
  1869. logger.info("MCU断开连接,已释放")