message_queue.cpp 34 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145
  1. #include <atomic>
  2. #include <string>
  3. #include "../common/comm.h"
  4. #include "api.h"
  5. #include "../common/iobuffer.h"
  6. #include "../common/sensor_socket.h"
  7. #include "../common/peer_connection.h"
  8. #include "VideoRenderer.h"
  9. #include "../thirdparty/jsoncpp/include/json/json.h"
  10. #include "protocol.pb.h"
  11. #include "radar_sensor.h"
  12. #include "imu_sensor.h"
  13. #include "robot_sensor.h"
  14. #include "Rtk.h"
  15. #include "message_queue.h"
  16. #include <fstream>
  17. #include <iostream>
  18. #include <cstring>
  19. #include "hmacsha256.h"
  20. #include <linux/usbdevice_fs.h>
  21. #include <sys/ioctl.h>
  22. CMessageQueue::CMessageQueue():Head(nullptr),Tail(nullptr)
  23. {
  24. _peerId=-1;
  25. btimeStopedCar = false;
  26. }
  27. CMessageQueue::~CMessageQueue()
  28. {
  29. }
  30. void renableUSB(const char* file)
  31. {
  32. printf("Resetting USB device %s\n", file);
  33. int fd = open(file, O_WRONLY);
  34. if (fd < 0) {
  35. char text[256];
  36. perror(text);
  37. printf("Error opening output file %s", text);
  38. return;
  39. }
  40. int rc = ioctl(fd, USBDEVFS_RESET, 0);
  41. if (rc < 0) {
  42. perror("Error in ioctl");
  43. return;
  44. }
  45. printf("Reset successful\n");
  46. close(fd);
  47. }
  48. void CMessageQueue::Create()
  49. {
  50. Json::Value root;
  51. Json::Reader jsonReader;
  52. std::ifstream ifile("./config.json");
  53. std::string serverip;
  54. int32_t _hostPort;
  55. int32_t _remotePort;
  56. _curTick=0;
  57. bStopedCar=false;
  58. if(jsonReader.parse(ifile,root))
  59. {
  60. std::cout<<"enter config json"<<std::endl;
  61. _serial=root["serial"].asString();
  62. int32_t _Rtkport=root["rtk_port"].asInt();
  63. int32_t _Rtkhost=root["rtk_host"].asInt();
  64. std::string _Rtkip=root["rtk_ip"].asString();
  65. std::cout<<"Rtk ip:"<< _Rtkip <<std::endl;
  66. //_Rtk = std::make_unique<SensorSocket<CRtkSensor>>(this, _Rtkip, _Rtkport, _Rtkhost);
  67. //_Rtk->Start();
  68. int32_t _radarport=root["radar_port"].asInt();
  69. int32_t _radarhost=root["radar_host"].asInt();
  70. std::string _radarip=root["radar_ip"].asString();
  71. std::cout<<"radar ip:"<<_radarip<<std::endl;
  72. //_radar=std::make_unique<SensorSocket<CRadarSensor>>(this,_radarip,_radarport,_radarhost);
  73. //_radar->Start();
  74. int32_t _UdpCanport=root["Udp_Can_port"].asInt();
  75. int32_t _UdpCanhost=root["Udp_Can_host"].asInt();
  76. std::string _UdpCanip=root["Udp_Can_ip"].asString();
  77. std::cout<<"UdpCan ip:"<<_UdpCanip<<std::endl;
  78. _UdpCan = std::make_unique<SensorSocket<CUdpCanSensor>>(this,_UdpCanip,_UdpCanport,_UdpCanhost);
  79. //_UdpCan->Start();
  80. int32_t _UdpStateport=root["Udp_State_port"].asInt();
  81. int32_t _UdpStatehost=root["Udp_State_host"].asInt();
  82. std::string _UdpStateip=root["Udp_State_ip"].asString();
  83. std::cout<<"UdpStateip ip:"<<_UdpStateip<<std::endl;
  84. _UdpState = std::make_unique<SensorSocket<CUdpStateSensor>>(this,_UdpStateip,_UdpStateport,_UdpStatehost);
  85. //_UdpState->Start();
  86. //_robot = std::make_unique<SensorPeakCan<CRobotSensor>>(this);
  87. //_robot->Start();
  88. _GSML = root["GMSL"].asInt();
  89. _UdpMinPort=root["udp_min_port"].asInt();
  90. _UdpMaxPort=root["udp_max_port"].asInt();
  91. //20230417
  92. //const char* serverUrl = "tcp://localhost:1883"; //服务器地址
  93. //const char* userName = ""; //用户名
  94. //const char* password = ""; //密码
  95. std::string serverUrl = root["MqttserverUrl"].asString();
  96. std::string userName = root["Esn"].asString();
  97. std::string password = root["EsnPass"].asString();
  98. std::string clientId = ""; //客户端标识符
  99. bool _Hm256 = false;
  100. unsigned char Source[128];
  101. time_t rawtime;
  102. struct tm* info;
  103. char buffer[80];
  104. time(&rawtime);
  105. info = localtime(&rawtime);
  106. uint8_t secret[32] = { 0 };
  107. //如UTC 时间2018/7/24 17:56:20 则应表示为2018072417。
  108. /*sprintf((char*)secret, "%d%.2d%.2d%.2d", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday,
  109. info->tm_hour);*/
  110. sprintf((char*)secret, "%d%.2d%.2d", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday);
  111. memset(Source, 0, 128);
  112. sprintf((char*)Source, "%s_0_0_%s", userName.c_str(), secret);
  113. clientId.clear();
  114. clientId.append((const char*)Source);
  115. if (password.length() && _Hm256)
  116. {
  117. uint8_t outdata[128] = { 0 };
  118. uint8_t md[SHA256_DIGESTLEN] = { 0 };
  119. int len1 = strlen((char*)secret);
  120. int len2 = strlen((char*)password.c_str());
  121. HMAC_SHA256_CTX hmac;
  122. hmac_sha256_init(&hmac, secret, len1);
  123. hmac_sha256_update(&hmac, (const uint8_t*)password.c_str(), len2);
  124. hmac_sha256_final(&hmac, md);
  125. memcpy(outdata, md, SHA256_DIGESTLEN);
  126. password.clear();
  127. password.append((const char*)outdata);
  128. }
  129. //_Mqtt = std::make_unique<SensorMQTT<CMqttSensor>>(this, serverUrl, userName, password, clientId);
  130. //_Mqtt->Start();
  131. std::string can_port = root["can_bus_vehicle"].asString();
  132. _CanBusVehicle = std::make_unique<SensorCanBus<CCanBusSensor>>(this, can_port);
  133. //_CanBusVehicle->Start();//车辆线控
  134. std::string can_port_radar = root["can_bus_radar"].asString();
  135. //_CanBusRadar->Start();
  136. std::string serial_Articulated = root["serial_Articulated"].asString();
  137. int32_t serial_Articulated_speed = root["serial_Articulated_speed"].asInt();
  138. //_ArticulatedSensor = std::make_unique<SensorSerial<CSerialSensor>>(this, serial_Articulated,serial_Articulated_speed);
  139. //_ArticulatedSensor->Start();//铰接转向姿态编码器
  140. std::string Drivenwheels_modbus_server = root["Drivenwheels_modbus_ip"].asString();
  141. int32_t Drivenwheels_modbus_port = root["Drivenwheels_modbus_port"].asInt();
  142. uint32_t Drivenwheels_modbus_slave[16] = {0};
  143. const Json::Value arrayslave_Drivenwheels=root["Drivenwheels_slave_id"];
  144. int32_t count_slave = arrayslave_Drivenwheels.size();
  145. for(int32_t i = 0; i < count_slave ; i++)
  146. {
  147. const Json::Value& value_id=arrayslave_Drivenwheels[i];
  148. Drivenwheels_modbus_slave[i] = value_id["id"].asInt();
  149. }
  150. //_ModbusTcp_Drivenwheels = std::make_unique<SensorModbusTcp<CModbusTcpSensor>>(this, Drivenwheels_modbus_server,Drivenwheels_modbus_port,Drivenwheels_modbus_slave,0);
  151. //_ModbusTcp_Drivenwheels->Start();//从动轮防撞激光传感器
  152. std::string Outriggers_modbus_server = root["Outriggers_modbus_ip"].asString();
  153. int32_t Outriggers_modbus_port = root["Outriggers_modbus_port"].asInt();
  154. uint32_t Outriggers_modbus_slave[16] = {0};
  155. const Json::Value arrayslave_Outriggers=root["Outriggers_slave_id"];
  156. count_slave = arrayslave_Outriggers.size();
  157. for(int32_t i = 0; i < count_slave ; i++)
  158. {
  159. const Json::Value& value_id = arrayslave_Outriggers[i];
  160. Outriggers_modbus_slave[i] = value_id["id"].asInt();
  161. }
  162. //_ModbusTcp_Outriggers = std::make_unique<SensorModbusTcp<COutriggersSensor>>(this, Outriggers_modbus_server,Outriggers_modbus_port,Outriggers_modbus_slave,0);
  163. //_ModbusTcp_Outriggers->Start();//后车架支腿拉线传感器器
  164. /*
  165. RemoNet::vehicle_QT m_vehicle_QT;
  166. RemoNet::vehicle_data *pdata = m_vehicle_QT.add__vehicle_data();
  167. pdata->set_dlc(1);
  168. */
  169. //std::string _usb_2 = root["usb_2"].asString();
  170. //std::string _usb_1 = root["usb_3"].asString();
  171. //renableUSB("/dev/bus/usb/002/002");
  172. //renableUSB("/dev/bus/usb/001/003");
  173. //renableUSB(_usb_2.c_str());
  174. //renableUSB(_usb_1.c_str());
  175. serverip=root["ip"].asString();
  176. _hostPort=root["TcpHostPort"].asInt();
  177. _remotePort=root["TcpRemotePort"].asInt();
  178. _name=root["name"].asString();
  179. const Json::Value arrayObj=root["camerainfo"];
  180. int32_t count=arrayObj.size();
  181. for(int32_t i=0;i<count;i++)
  182. {
  183. LocalCameraInfo info;
  184. const Json::Value& value=arrayObj[i];
  185. info.index=value["index"].asInt();
  186. info.label=value["label"].asString();
  187. _cameraArray.push_back(info);
  188. }
  189. for(int i=0;i<_cameraArray.size();i++)
  190. {
  191. _peerArray.push_back({nullptr});
  192. }
  193. }
  194. else{
  195. std::string error=jsonReader.getFormattedErrorMessages();
  196. std::cout<<error<<std::endl;
  197. }
  198. _client=std::make_unique<SocketClient>(this);
  199. _client->Start(serverip.c_str(),_remotePort,_hostPort);
  200. std::this_thread::yield();
  201. }
  202. /*
  203. void CMessageQueue::WriteCanMessage(std::unordered_map<int32_t, cannet_frame>& node,bool islidar)
  204. {
  205. if(!bDataChannelCreated) return;
  206. // std::lock_guard<std::mutex> l(_canLock);
  207. RemoNet::CCCanMesage Req;
  208. Req.set_islidar(islidar);
  209. for(auto& p:node)
  210. {
  211. int32_t lidar=p.second.canid;
  212. auto m=Req.add_message();
  213. m->set_head(p.second.dlc);
  214. m->set_canid(lidar);
  215. m->set_data(p.second.data,8);
  216. }
  217. MessageHead Head;
  218. CIOBuffer pBuffer;
  219. Head.Command = RemoNet::CC_CAN;
  220. Head.Length = Req.ByteSizeLong();
  221. Head.Serialize(pBuffer.Buffer);
  222. auto ptr = pBuffer.Buffer + MessageHead::Size();
  223. Req.SerializeToArray(ptr, Head.Length);
  224. pBuffer.Length = MessageHead::Size() + Head.Length;
  225. _peerArray[0]->SendData(&pBuffer);
  226. }
  227. bool CMessageQueue::IsCarId(int32_t value)
  228. {
  229. return std::find(_carArray.begin(),_carArray.end(),value)!=_carArray.end();
  230. }
  231. */
  232. /*
  233. #define QUEUE_ZISE 32//队列长度
  234. typedef struct Queue
  235. {
  236. int qFront;
  237. int qRear;
  238. CIOBuffer *BasicArr[QUEUE_ZISE];
  239. }Queue, * pQueue;
  240. void InitQueue(pQueue queue)
  241. {
  242. queue->qFront = 0;
  243. queue->qRear = 0;
  244. }
  245. bool IsEmptyQueue(pQueue queue)
  246. {
  247. if (queue->qFront == queue->qRear)
  248. return true;
  249. else
  250. return false;
  251. }
  252. bool IsFullQueue(pQueue queue)
  253. {
  254. if (((queue->qRear + 1) % QUEUE_ZISE) == queue->qFront)
  255. return true;
  256. else
  257. return false;
  258. }
  259. void EnterQueue(pQueue queue, CIOBuffer *vale)
  260. {
  261. if (IsFullQueue(queue))
  262. {
  263. return;
  264. }
  265. queue->BasicArr[queue->qRear] = vale;
  266. queue->qRear = (queue->qRear + 1) % QUEUE_ZISE;
  267. }
  268. CIOBuffer * OutQueue(pQueue queue)
  269. {
  270. if (IsEmptyQueue(queue))
  271. {
  272. return nullptr;
  273. }
  274. CIOBuffer * p = queue->BasicArr[queue->qFront];
  275. queue->qFront = (queue->qFront + 1) % QUEUE_ZISE;
  276. return p;
  277. }
  278. Queue queue;
  279. */
  280. void CMessageQueue::EnQueue(CIOBuffer* pBuffer)
  281. {
  282. bool bNullBuffer=false;
  283. //std::unique_lock <std::mutex> lck(_lock);
  284. if(Head==nullptr)
  285. {
  286. Head=Tail=pBuffer;
  287. bNullBuffer=true;
  288. }
  289. else{
  290. Tail->NextBuf=pBuffer;
  291. Tail=Tail->NextBuf;
  292. }
  293. pBuffer->NextBuf=nullptr;
  294. if(bNullBuffer)
  295. {
  296. //_cv.notify_one();
  297. //20231023
  298. _cv.notify_all();
  299. }
  300. }
  301. void CMessageQueue::Process()
  302. {
  303. CIOBuffer * ptr=nullptr;
  304. {
  305. std::unique_lock <std::mutex> lck(_lock);
  306. while(Head==nullptr&&_cv.wait_for(lck,std::chrono::seconds(1))==std::cv_status::timeout)
  307. {
  308. CheckSignal();
  309. //std::cout<<".";
  310. //std::cout.flush();
  311. }
  312. }
  313. while(Head!=nullptr)
  314. {
  315. ptr=Head;
  316. Head=Head->NextBuf;
  317. if(ptr!=nullptr)
  318. {
  319. Message* message=reinterpret_cast<Message *>(ptr->Buffer);
  320. switch (message->cmd)
  321. {
  322. case MessageType::ReqVideo:
  323. OnNotifyReq((int32_t)message->param_l);
  324. break;
  325. case MessageType::RepVideo:
  326. OnNotifyRep((int32_t)message->param_l);
  327. break;
  328. case MessageType::Connected:
  329. OnNotifyConnected((bool)message->param_l);
  330. break;
  331. case MessageType::Leave:
  332. OnNotifyLeave();
  333. break;
  334. case MessageType::AsyncMessage:
  335. OnNotifyMessage();
  336. break;
  337. case MessageType::StopSensor:
  338. OnNotifyStopSensor();
  339. break;
  340. case MessageType::Ping:
  341. OnNotifyPing(message->param_l);
  342. //_curTick = std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  343. break;
  344. }
  345. ptr->Release();
  346. }
  347. }
  348. }
  349. void CMessageQueue::SetTick(long long tick)
  350. {
  351. _curTick=tick;
  352. }
  353. void CMessageQueue::OnNotifyConnected(bool bRet)
  354. {
  355. if(bRet)
  356. {
  357. _client->WriteAddRobot(_serial,_name,static_cast<int32_t>(EgoType::Car));
  358. _updatethread.start(_client.get());
  359. //cs->Analog(0,0,0,0,0);
  360. }
  361. else
  362. {
  363. if(_peerId!=-1)
  364. {
  365. OnVideoLeave(_peerId,EgoType::User);
  366. /* for (size_t i = 0; i < _peerArray.size(); i++)
  367. {
  368. if(_peerArray[i]!=nullptr)
  369. {
  370. _peerArray[i]->Close();
  371. _peerArray[i].reset();
  372. }
  373. }
  374. */
  375. // for (size_t i = 0; i < _windowArray.size(); i++)
  376. // {
  377. /* code */
  378. // if(_windowArray[i]!=nullptr)
  379. // _windowArray[i].reset();
  380. // }
  381. _peerId=-1;
  382. // StopCar();
  383. }
  384. _updatethread.stop();
  385. }
  386. }
  387. void CMessageQueue::OnNotifyReq(int32_t index)
  388. {
  389. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  390. if(_peerId==-1) return;
  391. if(index==0)
  392. {
  393. mrsWebrtcCreateFactory(true);
  394. _curTick=0;
  395. bStopedCar=false;
  396. /*
  397. _CanBusVehicle->Start();//车辆线控
  398. _ArticulatedSensor->Start();//铰接转向姿态编码器
  399. _ModbusTcp_Drivenwheels->Start();//从动轮防撞激光传感器
  400. _ModbusTcp_Outriggers->Start();//后车架支腿拉线传感器器
  401. _radar->Start(); //DYP雷达
  402. _CanBusRadar->Start();//纳雷雷达
  403. _Rtk->Start();
  404. _robot->Start();
  405. _Mqtt->Start();
  406. */
  407. _CanBusVehicle->Start();//车辆线控
  408. _UdpState->Start();
  409. _UdpCan->Start();
  410. }
  411. // PeerConnectionWrapper* peer = nullptr;
  412. // VideoRenderer* window = nullptr;
  413. // _windowArray[temp]=std::make_unique<VideoRenderer>();// .reset(new VideoRenderer());
  414. _peerArray[index]=std::make_unique<CPeerConnection>(static_cast<ChannelType>(index),_client.get());
  415. _client->WriteVideoRep(_peerId, RemoNet::VideoDesc::OK, index);
  416. }
  417. void CMessageQueue::OnNotifyRep(int32_t index)
  418. {
  419. _peerArray[index]=std::make_unique<CPeerConnection>(static_cast<ChannelType>(index), _client.get());
  420. InitPeerConnection(_peerId,index);
  421. _peerArray[index]->CreateOffer();
  422. }
  423. void CMessageQueue::InitPeerConnection(int32_t peer,int32_t index)
  424. {
  425. //bool NeedData=index==RenderPosition::CAR_FRONT;
  426. _peerArray[index]->Initialize(peer,index,_UdpMinPort,_UdpMaxPort);
  427. //_peerArray[index]->AddDataChannel(true, false);
  428. _peerArray[index]->AddLocalVideoTrack(static_cast<RenderPosition>(index),_cameraArray[index].index,_GSML);
  429. if(index==RenderPosition::BACK)
  430. {
  431. void * front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  432. while(front==nullptr)
  433. {
  434. std::cout<<"front==nullptr"<<std::endl;
  435. std::this_thread::sleep_for(std::chrono::microseconds(50));
  436. front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  437. }
  438. void * back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  439. while (back==nullptr)
  440. {
  441. std::cout<<"back==nullptr"<<std::endl;
  442. std::this_thread::sleep_for(std::chrono::microseconds(50));
  443. back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  444. }
  445. _peerArray[RenderPosition::FRONT]->SetOtherCtx(back);
  446. _peerArray[RenderPosition::BACK]->SetOtherCtx(front);
  447. }
  448. /*
  449. if((index+1)==RenderPosition::ALL)
  450. {
  451. void * front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  452. while(front==nullptr)
  453. {
  454. std::cout<<"front==nullptr"<<std::endl;
  455. std::this_thread::sleep_for(std::chrono::microseconds(50));
  456. front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  457. }
  458. void * back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  459. while (back==nullptr)
  460. {
  461. std::cout<<"back==nullptr"<<std::endl;
  462. std::this_thread::sleep_for(std::chrono::microseconds(50));
  463. back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  464. }
  465. _peerArray[RenderPosition::FRONT]->SetOtherCtx(back);
  466. _peerArray[RenderPosition::BACK]->SetOtherCtx(front);
  467. void * left=_peerArray[RenderPosition::LEFT]->GetCurrentCtx();
  468. while(left==nullptr)
  469. {
  470. std::cout<<"left==nullptr"<<std::endl;
  471. std::this_thread::sleep_for(std::chrono::microseconds(50));
  472. left=_peerArray[RenderPosition::LEFT]->GetCurrentCtx();
  473. }
  474. void * right=_peerArray[RenderPosition::RIGHT]->GetCurrentCtx();
  475. while (right==nullptr)
  476. {
  477. std::cout<<"right==nullptr"<<std::endl;
  478. std::this_thread::sleep_for(std::chrono::microseconds(50));
  479. right=_peerArray[RenderPosition::RIGHT]->GetCurrentCtx();
  480. }
  481. _peerArray[RenderPosition::LEFT]->SetOtherCtx(right);
  482. _peerArray[RenderPosition::RIGHT]->SetOtherCtx(left);
  483. }
  484. */
  485. /*
  486. if((index+1)==RenderPosition::ALL)
  487. {
  488. void * front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  489. void * back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  490. void * left=_peerArray[RenderPosition::LEFT]->GetCurrentCtx();
  491. void * right=_peerArray[RenderPosition::RIGHT]->GetCurrentCtx();
  492. void * dash=_peerArray[RenderPosition::DASHBOARD]->GetCurrentCtx();
  493. _peerArray[RenderPosition::FRONT]->SetOtherCtx(back);
  494. _peerArray[RenderPosition::BACK]->SetOtherCtx(front);
  495. _peerArray[RenderPosition::LEFT]->SetOtherCtx(left);
  496. _peerArray[RenderPosition::RIGHT]->SetOtherCtx(right);
  497. _peerArray[RenderPosition::DASHBOARD]->SetOtherCtx(dash);
  498. }
  499. */
  500. if(index==RenderPosition::FRONT)
  501. _peerArray[index]->AddLocalAudioTrack();
  502. }
  503. void CMessageQueue::OnAdd(bool bRet)
  504. {
  505. }
  506. void CMessageQueue::OnConnected(bool bRet)
  507. {
  508. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  509. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  510. message->cmd=MessageType::Connected;
  511. message->param_l=bRet;
  512. EnQueue(pBuffer);
  513. //20240104
  514. //InitQueue(&queue);
  515. //EnterQueue(&queue, pBuffer);
  516. }
  517. void CMessageQueue::OnVideoLeave(int32_t peer,EgoType type)
  518. {
  519. {
  520. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  521. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  522. message->cmd=MessageType::StopSensor;
  523. EnQueue(pBuffer);
  524. //20240104
  525. //EnterQueue(&queue, pBuffer);
  526. }
  527. {
  528. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  529. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  530. message->cmd=MessageType::Leave;
  531. EnQueue(pBuffer);
  532. //20240104
  533. //EnterQueue(&queue, pBuffer);
  534. }
  535. }
  536. #ifdef WIN32
  537. void CMessageQueue::OnVideoRep(int32_t index,RemoNet::VideoDesc desc)
  538. {
  539. if (desc == RemoNet::VideoDesc::OK)
  540. {
  541. assert(_peerId!=-1);
  542. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  543. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  544. message->cmd=MessageType::ReqVideo;
  545. message->param_l=index;
  546. EnQueue(pBuffer);
  547. }
  548. }
  549. #else
  550. void CMessageQueue::OnVideoReq(int32_t video,int32_t peer)
  551. {
  552. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  553. _peerId=peer;
  554. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  555. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  556. message->cmd=MessageType::ReqVideo;
  557. message->param_l=video;
  558. EnQueue(pBuffer);
  559. //20240104
  560. //EnterQueue(&queue, pBuffer);
  561. }
  562. #endif
  563. void CMessageQueue::OnNotifyLeave()
  564. {
  565. std::this_thread::sleep_for(std::chrono::milliseconds(100));
  566. for (size_t i = 0; i < _peerArray.size(); i++)
  567. {
  568. if(_peerArray[i]!=nullptr)
  569. {
  570. _peerArray[i]->Close();
  571. _peerArray[i].reset();
  572. }
  573. /* code */
  574. }
  575. //for (size_t i = 0; i < _windowArray.size(); i++)
  576. // {
  577. /* code */
  578. // _windowArray[i].reset();
  579. // }
  580. _peerId=-1;
  581. //StopCar();
  582. }
  583. void CMessageQueue::OnNotifyStopSensor()
  584. {
  585. _curTick=0;
  586. /*
  587. std::cout<<"vehicle can stop"<<std::endl;
  588. _CanBusVehicle->Stop();//车辆线控
  589. std::cout<<"rs485 _ArticulatedSensor stop"<<std::endl;
  590. _ArticulatedSensor->Stop();//铰接转向姿态编码器
  591. std::cout<<"Drivenwheels modbus tcp stop"<<std::endl;
  592. _ModbusTcp_Drivenwheels->Stop();//从动轮防撞激光传感器
  593. std::cout<<"Outriggers modbus tcp stop"<<std::endl;
  594. _ModbusTcp_Outriggers->Stop();//后车架支腿拉线传感器器
  595. std::cout<<"radar stop"<<std::endl;
  596. _radar->Stop(); //DYP雷达
  597. _CanBusRadar->Stop();//纳雷雷达
  598. _robot->Stop();
  599. std::cout << "RTK stop" << std::endl;
  600. _Rtk->Stop();
  601. std::cout<<"mqtt stop"<<std::endl;
  602. _Mqtt->Stop();
  603. */
  604. std::cout<<"vehicle can stop"<<std::endl;
  605. _CanBusVehicle->Stop();//车辆线控
  606. std::cout<<"vehicle UdpState stop"<<std::endl;
  607. _UdpState->Stop();
  608. std::cout<<"vehicle UdpCan stop"<<std::endl;
  609. _UdpCan->Stop();
  610. RemoNet::StopAck Rep;
  611. CIOBuffer Buffer;
  612. MessageHead Head;
  613. Head.Command = RemoNet::CC_StopACK;
  614. Head.Length = Rep.ByteSizeLong();
  615. Head.Serialize(Buffer.Buffer);
  616. auto ptr = Buffer.Buffer + MessageHead::Size();
  617. Rep.SerializeToArray(ptr, Head.Length);
  618. Buffer.Length = Head.Length + MessageHead::Size();
  619. _peerArray[RenderPosition::FRONT]->SendData(Buffer);
  620. }
  621. void CMessageQueue::OnVideoOffer(int32_t index,const char* type, const char* sdp)
  622. {
  623. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  624. InitPeerConnection(_peerId,index);
  625. _peerArray[index]->SetRemoteDescription(type,sdp);
  626. _peerArray[index]->CreateAnswer();
  627. }
  628. void CMessageQueue::OnVideoAnswer(int32_t index, const char* type, const char* sdp)
  629. {
  630. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  631. _peerArray[index]->SetRemoteDescription(type,sdp);
  632. }
  633. void CMessageQueue::OnVideoCandidate(int32_t index,const char* candidate,
  634. int32_t sdp_mline_index,
  635. const char* sdp_mid)
  636. {
  637. _peerArray[index]->AddIceCandidate(candidate,sdp_mline_index,sdp_mid);
  638. }
  639. /*
  640. void CMessageQueue::SwitchCamera(bool front)
  641. {
  642. _peerArray[RenderPosition::FRONT_BACK]->SwitchCapture(front);
  643. }
  644. */
  645. void CMessageQueue::OnMessageFrameNotify(ChannelType type,int16_t cmd,int16_t length,const void * data)
  646. {
  647. //std::cout<<"cmd:" <<std::hex<<cmd<<std::endl;
  648. if(cmd==RemoNet::CC_Text)
  649. {
  650. RemoNet::TestTextReq Req;
  651. Req.ParseFromArray(data,length);
  652. std::cout<<Req.text()<<std::endl;
  653. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  654. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  655. message->cmd=MessageType::AsyncMessage;
  656. EnQueue(pBuffer);
  657. //20240104
  658. //EnterQueue(&queue, pBuffer);
  659. }
  660. else if(cmd==RemoNet::CC_Switch)
  661. {
  662. RemoNet::CCSwitch Req;
  663. Req.ParseFromArray(data,length);
  664. bool front=Req.front();
  665. _peerArray[RenderPosition::FRONT]->SwitchCapture(front);
  666. }
  667. else if(cmd==RemoNet::CC_Ping)
  668. {
  669. /*
  670. RemoNet::CCPing Req;
  671. Req.ParseFromArray(data,length);
  672. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  673. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  674. message->cmd=MessageType::Ping;
  675. message->param_l=Req.tick();
  676. EnQueue(pBuffer);
  677. */
  678. //20240104
  679. //EnterQueue(&queue, pBuffer);
  680. }
  681. else if(cmd==RemoNet::CC_SensorStop)
  682. {
  683. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  684. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  685. message->cmd=MessageType::StopSensor;
  686. EnQueue(pBuffer);
  687. //20240104
  688. //EnterQueue(&queue, pBuffer);
  689. }
  690. else if (cmd == RemoNet::CC_CANMSG)
  691. {
  692. //_curTick = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  693. /*
  694. RemoNet::CCCanMsg Req;
  695. Req.ParseFromArray(data, length);
  696. cannet_busframe* frames = (cannet_busframe*)alloca(sizeof(cannet_busframe) * Req.frams_size());
  697. for (int32_t i = 0; i < Req.frams_size(); i++)
  698. {
  699. auto& frame = Req.frams(i);
  700. frames[i].canid = frame.canid();
  701. frames[i].dlc = frame.dlc();
  702. memcpy(frames[i].data, frame.data().data(), frame.dlc());
  703. }
  704. _CanBusVehicle->Get()->OnMessage(frames, Req.frams_size());
  705. //_UdpCan->Get()->OnMessage(frames, Req.frams_size());
  706. */
  707. }
  708. }
  709. void CMessageQueue::SetTickLive(long long tick)
  710. {
  711. _curTick = tick;
  712. }
  713. void CMessageQueue::SendNoEmergency()
  714. {
  715. CIOBuffer buffer;
  716. int8_t source[16] = "wobuting";
  717. buffer.Length = strlen((const char *)source);
  718. memcpy(buffer.Buffer, &source, buffer.Length);
  719. _UdpState->Write(&buffer);
  720. }
  721. void CMessageQueue::SendEmergency()
  722. {
  723. CIOBuffer buffer;
  724. int8_t source[16] = "woyaoting";
  725. buffer.Length = strlen((const char *)source);
  726. memcpy(buffer.Buffer, &source, buffer.Length);
  727. _UdpState->Write(&buffer);
  728. }
  729. void CMessageQueue::SetGsmlInfo(int64_t time,int64_t StartRecord,int64_t DeviceId)
  730. {
  731. //if( _peerArray[ChannelType::CHANNEL_IMU]!=nullptr)
  732. // _peerArray[ChannelType::CHANNEL_IMU]->SetGsml(time,StartRecord,DeviceId);
  733. if( _peerArray[DeviceId]!=nullptr)
  734. {
  735. _peerArray[DeviceId]->SetGsml(time,StartRecord,DeviceId);
  736. }
  737. }
  738. void CMessageQueue::Senddirection(int16_t speed)
  739. {
  740. CIOBuffer buffer;
  741. int16_t source[16];
  742. memset(source,0,16);
  743. if(speed < 0)
  744. sprintf((char *)source,"%d",speed);
  745. else
  746. sprintf((char *)source,"+%d",speed);
  747. buffer.Length = strlen((const char *)source);
  748. memcpy(buffer.Buffer, &source, buffer.Length);
  749. //buffer.Length = 1;
  750. //buffer.Buffer[0] = speed;
  751. //printf("%s\r\n",source);
  752. _UdpState->Write(&buffer);
  753. }
  754. void CMessageQueue::StopCar()
  755. {
  756. std::cout<<"Stop Car"<<std::endl;
  757. _CanBusVehicle->Get()->Emergency();
  758. }
  759. void CMessageQueue::OnNotifyMessage()
  760. {
  761. RemoNet::TestTextReq Req;
  762. Req.set_text("ewqewqewqe");
  763. CIOBuffer Buffer;
  764. MessageHead Head;
  765. Head.Command = RemoNet::CC_Text;
  766. Head.Length = Req.ByteSizeLong();
  767. Head.Serialize(Buffer.Buffer);
  768. auto ptr = Buffer.Buffer + MessageHead::Size();
  769. Req.SerializeToArray(ptr, Head.Length);
  770. Buffer.Length = Head.Length + MessageHead::Size();
  771. _peerArray[RenderPosition::FRONT]->SendData(Buffer);
  772. }
  773. void CMessageQueue::OnNotifyPing(int64_t value)
  774. {
  775. RemoNet::CCPing Rep;
  776. Rep.set_tick(value);
  777. CIOBuffer Buffer;
  778. MessageHead Head;
  779. Head.Command = RemoNet::CC_Ping;
  780. Head.Length = Rep.ByteSizeLong();
  781. Head.Serialize(Buffer.Buffer);
  782. auto ptr = Buffer.Buffer + MessageHead::Size();
  783. Rep.SerializeToArray(ptr, Head.Length);
  784. Buffer.Length = Head.Length + MessageHead::Size();
  785. if( _peerArray[RenderPosition::FRONT]!=nullptr && _peerArray[RenderPosition::FRONT]->bReadyChannel)
  786. {
  787. _peerArray[RenderPosition::FRONT]->SendData(Buffer);
  788. }
  789. }
  790. /*
  791. void CMessageQueue::StartCar()
  792. {
  793. _can->SetStartWrite(true);
  794. }
  795. */
  796. void CMessageQueue::CheckSignal()
  797. {
  798. if(!bStopedCar)
  799. {
  800. long long tick=std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  801. if(_curTick!=0&&tick-_curTick > 3)
  802. {
  803. StopCar();
  804. bStopedCar=true;
  805. std::cout<<"_curTick!=0&&tick-_curTick > 3" << std::endl;
  806. _curStopTick = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  807. btimeStopedCar = true;
  808. _curTick = 0;
  809. }
  810. }
  811. }
  812. void CMessageQueue::WriteIMUData(ImuData* data)
  813. {
  814. MessageHead Head;
  815. CIOBuffer Buffer;
  816. RemoNet::IMuMessage Req;
  817. Req.set_rx(data->ry);
  818. Req.set_ry(data->rx);
  819. // Req.set_rz(data->rz);
  820. Head.Command=RemoNet::CC_IMU;
  821. Head.Length=Req.ByteSizeLong();
  822. Head.Serialize(Buffer.Buffer);
  823. auto ptr = Buffer.Buffer + MessageHead::Size();
  824. Req.SerializeToArray(ptr, Head.Length);
  825. Buffer.Length = Head.Length + MessageHead::Size();
  826. if( _peerArray[ChannelType::CHANNEL_IMU]!=nullptr)
  827. _peerArray[ChannelType::CHANNEL_IMU]->SendData(Buffer);
  828. }
  829. void CMessageQueue::SendVehicleStatue()
  830. {
  831. RemoNet::State req;
  832. req.set_work_pressure(_Feeddata.work_pressure);
  833. req.set_brake_pressure(_Feeddata.brake_pressure);
  834. req.set_gearbox_oil_temp(_Feeddata.gearbox_oil_temp);
  835. req.set_gearbox_oil_pressure(_Feeddata.gearbox_oil_pressure);
  836. req.set_engine_rpm(_Feeddata.engine_rpm);//发动机转速
  837. req.set_speed(_Feeddata.speed);//不知道?---可能是后加的传感器---驱动轮增量编码器
  838. req.set_gear(_Feeddata.gear);
  839. req.set_engine_pressure(_Feeddata.engine_pressure);//发动机压力
  840. req.set_cold_water(_Feeddata.cold_water);//冷却液温度-发动机水温
  841. req.set_steer_angle(_Feeddata.steer_angle);//转向角度(原来金川是轮子的现在大冶用铰链位置) 铰接转向姿态编码器
  842. req.set_left_lock(_Feeddata.left_lock);//遥操模式
  843. req.set_right_lock(_Feeddata.right_lock);//人工模式
  844. req.set_engine_time(_Feeddata.engine_time);//发动机运行小时
  845. req.set_wire_sensor_l(_Feeddata.wire_sensor_l);//拉线传感器左侧
  846. req.set_wire_sensor_r(_Feeddata.wire_sensor_r);//拉线传感器右侧
  847. req.set_fuel_level(_Feeddata.fuel_level);//燃油油位
  848. req.set_lock_switch_l(_Feeddata.lock_switch_l);//锁钩到位开关左
  849. req.set_lock_switch_r(_Feeddata.lock_switch_r); //锁钩到位开关右
  850. req.set_tip_limit(_Feeddata.tip_limit);//倾翻限位
  851. req.set_turn_left(_Feeddata.turn_left);//左转
  852. req.set_turn_right(_Feeddata.turn_right);//右转
  853. req.set_hight_beam(_Feeddata.hight_beam);//远光灯
  854. req.set_low_beam(_Feeddata.low_beam);//近光灯
  855. req.set_parking(_Feeddata.parking);//驻车
  856. req.set_brake(_Feeddata.brake);//刹车
  857. req.set_back_car(_Feeddata.back_car);//倒车
  858. req.set_front_work_lamp(_Feeddata.front_work_lamp);//前工作灯
  859. req.set_rear_work_lamp(_Feeddata.rear_work_lamp);//后工作灯
  860. req.set_cargo_weight(_Feeddata.cargo_weight);//渣包重量
  861. req.set_system_vol(_Feeddata.system_vol);//系统电压
  862. req.set_error_buff((char *)_Feeddata.Error_Buff,8);//报警信息
  863. req.set_f_gear(_Feeddata.f_gear);//1F,2R,3N
  864. req.set_gear_1(_Feeddata.gear_1);//1,2,3,4
  865. req.set_outgrigger_l(_Feeddata.outgrigger_l);//左支腿伸到位开关
  866. req.set_outgrigger_r(_Feeddata.outgrigger_r);//右支腿伸到位开关
  867. req.set_tip_pressure(_Feeddata.tip_pressure);//倾翻压力开关
  868. MessageHead Head;
  869. CIOBuffer pBuffer;
  870. Head.Command = RemoNet::CC_STATE;
  871. Head.Length = req.ByteSizeLong();
  872. Head.Serialize(pBuffer.Buffer);
  873. auto ptr = pBuffer.Buffer + MessageHead::Size();
  874. req.SerializeToArray(ptr, Head.Length);
  875. pBuffer.Length = MessageHead::Size() + Head.Length;
  876. //if( _peerArray[ChannelType::CHANNEL_CAR] != nullptr && _peerArray[RenderPosition::FRONT]->bReadyChannel)
  877. // WritePacket(ChannelType::CHANNEL_CAR, pBuffer);
  878. if( _peerArray[ChannelType::CHANNEL_CAR] != nullptr)
  879. _UdpCan->Write(&pBuffer);
  880. }
  881. void CMessageQueue::WritePacket(ChannelType type, CIOBuffer & pBuffer)
  882. {
  883. if( _peerArray[type]!=nullptr)
  884. _peerArray[type]->SendData(pBuffer);
  885. }
  886. void CMessageQueue::WriteRadarData(RadarData& data)
  887. {
  888. MessageHead Head;
  889. CIOBuffer Buffer;
  890. RemoNet::CCRadarMessage Req;
  891. Req.set_radar0(data.r0);
  892. Req.set_radar1(data.r1);
  893. Req.set_radar2(data.r2);
  894. Req.set_radar3(data.r3);
  895. Req.set_radar4(data.r4);
  896. Req.set_radar5(data.r5);
  897. Req.set_radar6(data.r6);
  898. Req.set_radar7(data.r7);
  899. Req.set_radar7(data.r8);
  900. //Head.Command=RemoNet::CC_IMU;
  901. Head.Command = RemoNet::CC_Radar;
  902. Head.Length=Req.ByteSizeLong();
  903. Head.Serialize(Buffer.Buffer);
  904. auto ptr = Buffer.Buffer + MessageHead::Size();
  905. Req.SerializeToArray(ptr, Head.Length);
  906. Buffer.Length = Head.Length + MessageHead::Size();
  907. if( _peerArray[ChannelType::CHANNEL_RADAR]!=nullptr)
  908. _UdpCan->Write(&Buffer);
  909. //_peerArray[ChannelType::CHANNEL_RADAR]->SendData(Buffer);
  910. }
  911. void CMessageQueue::WriteRobotStatus(int32_t ,int32_t )
  912. {
  913. }
  914. #ifdef LIDAR_SENSOR
  915. void CMessageQueue::WriteLidarPoint(const PointCloudMsg<PointXYZI>& msg,ChannelType side)
  916. {
  917. RemoNet::LidarPoint pt;
  918. pt.set_is_left(side==ChannelType::CHANNEL_LEFT_LIDAR);
  919. pt.set_frame_id(msg.frame_id);
  920. pt.set_height(msg.height);
  921. pt.set_width(msg.width);
  922. pt.set_is_dense(msg.is_dense);
  923. pt.set_seq(msg.seq);
  924. pt.set_timestamp(msg.timestamp);
  925. for(int i=0;i<msg.point_cloud_ptr->size();i++)
  926. {
  927. pt.add_data((*msg.point_cloud_ptr)[i].x);
  928. pt.add_data((*msg.point_cloud_ptr)[i].y);
  929. pt.add_data((*msg.point_cloud_ptr)[i].z);
  930. pt.add_data((*msg.point_cloud_ptr)[i].intensity);
  931. }
  932. MessageHead Head;
  933. CIOBuffer Buffer;
  934. Head.Command=RemoNet::CC_LIDARDATA;
  935. Head.Length=pt.ByteSizeLong();
  936. Head.Serialize(Buffer.Buffer);
  937. auto ptr = Buffer.Buffer + MessageHead::Size();
  938. pt.SerializeToArray(ptr, Head.Length);
  939. Buffer.Length = Head.Length + MessageHead::Size();
  940. if( _peerArray[side]!=nullptr)
  941. _peerArray[side]->SendData(&Buffer);
  942. }
  943. #endif
  944. void CMessageQueue::SwitchCamera(bool front)
  945. {
  946. _peerArray[RenderPosition::FRONT]->SwitchCapture(front);
  947. _peerArray[RenderPosition::BACK]->SwitchCapture(front);
  948. }
  949. void CMessageQueue::SendZGJStatus(int status)
  950. {
  951. _Rtk->Get()->Send_ZGJ_status(status);
  952. }