message_queue.cpp 32 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100
  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 "imu_sensor.h"
  12. #include "Rtk.h"
  13. #include "message_queue.h"
  14. #include <fstream>
  15. #include <iostream>
  16. #include <cstring>
  17. #include "hmacsha256.h"
  18. #include <linux/usbdevice_fs.h>
  19. #include <sys/ioctl.h>
  20. #include <sys/statfs.h>
  21. #include <stdlib.h>
  22. #include <unistd.h>
  23. #include <sys/vfs.h>
  24. #include <dirent.h>
  25. #include <sys/stat.h>
  26. CMessageQueue::CMessageQueue():Head(nullptr),Tail(nullptr)
  27. {
  28. _peerId=-1;
  29. btimeStopedCar = false;
  30. File_fd = NULL;
  31. _Version = 1;
  32. }
  33. CMessageQueue::~CMessageQueue()
  34. {
  35. }
  36. void renableUSB(const char* file)
  37. {
  38. printf("Resetting USB device %s\n", file);
  39. int fd = open(file, O_WRONLY);
  40. if (fd < 0) {
  41. char text[256];
  42. perror(text);
  43. printf("Error opening output file %s", text);
  44. return;
  45. }
  46. int rc = ioctl(fd, USBDEVFS_RESET, 0);
  47. if (rc < 0) {
  48. perror("Error in ioctl");
  49. return;
  50. }
  51. printf("Reset successful\n");
  52. close(fd);
  53. }
  54. void CMessageQueue::Create()
  55. {
  56. Json::Value root;
  57. Json::Reader jsonReader;
  58. std::ifstream ifile("./config.json");
  59. std::string serverip;
  60. int32_t _hostPort;
  61. int32_t _remotePort;
  62. _curTick=0;
  63. bStopedCar=false;
  64. if(jsonReader.parse(ifile,root))
  65. {
  66. std::cout<<"enter config json"<<std::endl;
  67. _serial=root["serial"].asString();
  68. int32_t _Rtkport=root["rtk_port"].asInt();
  69. int32_t _Rtkhost=root["rtk_host"].asInt();
  70. std::string _Rtkip=root["rtk_ip"].asString();
  71. std::cout<<"Rtk ip:"<< _Rtkip <<std::endl;
  72. _Rtk = std::make_unique<SensorSocket<CRtkSensor>>(this, _Rtkip, _Rtkport, _Rtkhost);
  73. //_Rtk->Start();
  74. _Version = root["Version"].asInt();
  75. if(_Version)//AD10
  76. {
  77. std::string can_port_radar = root["can_bus_radar"].asString();
  78. _CanBusRadar = std::make_unique<SensorCanBus<CCanRadarSensor>>(this, can_port_radar);
  79. //_CanBusRadar->Start();
  80. }
  81. else
  82. {
  83. //_RadarIp
  84. int32_t _radarport=root["radar_port"].asInt();
  85. int32_t _radarhost=root["radar_host"].asInt();
  86. std::string _radarip=root["radar_ip"].asString();
  87. std::cout<<"radar ip:"<<_radarip<<std::endl;
  88. _RadarIp = std::make_unique<SensorSocket<CRadarSensor>>(this,_radarip,_radarport,_radarhost);
  89. //_RadarIp->Start();
  90. }
  91. if(_Version)//AD10
  92. {
  93. std::string can_port = root["can_bus_vehicle"].asString();
  94. _CanBusVehicle = std::make_unique<SensorCanBus<CCanBusSensor>>(this, can_port);
  95. //_CanBusVehicle->Start();
  96. }
  97. else
  98. {
  99. _PcanBusVehicle = std::make_unique<SensorPeakCan<CPcanSensor>>(this);
  100. //_PcanBusVehicle->Start();
  101. }
  102. _UdpMinPort=root["udp_min_port"].asInt();
  103. _UdpMaxPort=root["udp_max_port"].asInt();
  104. //20230417
  105. //const char* serverUrl = "tcp://localhost:1883"; //服务器地址
  106. //const char* userName = ""; //用户名
  107. //const char* password = ""; //密码
  108. std::string serverUrl = root["MqttserverUrl"].asString();
  109. std::string userName = root["Esn"].asString();
  110. std::string password = root["EsnPass"].asString();
  111. std::string clientId = ""; //客户端标识符
  112. bool _Hm256 = false;
  113. unsigned char Source[128];
  114. time_t rawtime;
  115. struct tm* info;
  116. char buffer[80];
  117. time(&rawtime);
  118. info = localtime(&rawtime);
  119. uint8_t secret[32] = { 0 };
  120. //如UTC 时间2018/7/24 17:56:20 则应表示为2018072417。
  121. /*sprintf((char*)secret, "%d%.2d%.2d%.2d", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday,
  122. info->tm_hour);*/
  123. sprintf((char*)secret, "%d%.2d%.2d", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday);
  124. memset(Source, 0, 128);
  125. sprintf((char*)Source, "%s_0_0_%s", userName.c_str(), secret);
  126. clientId.clear();
  127. clientId.append((const char*)Source);
  128. if (password.length() && _Hm256)
  129. {
  130. uint8_t outdata[128] = { 0 };
  131. uint8_t md[SHA256_DIGESTLEN] = { 0 };
  132. int len1 = strlen((char*)secret);
  133. int len2 = strlen((char*)password.c_str());
  134. HMAC_SHA256_CTX hmac;
  135. hmac_sha256_init(&hmac, secret, len1);
  136. hmac_sha256_update(&hmac, (const uint8_t*)password.c_str(), len2);
  137. hmac_sha256_final(&hmac, md);
  138. memcpy(outdata, md, SHA256_DIGESTLEN);
  139. password.clear();
  140. password.append((const char*)outdata);
  141. }
  142. _Mqtt_ZR = std::make_unique<SensorMQTT<CMqttSensor>>(this, serverUrl, userName, password, clientId);
  143. std::string DataServerUrl = root["DataServerUrl"].asString();
  144. std::string DatauserName = root["DataEsn"].asString();
  145. std::string Datapassword = root["DataEsnPass"].asString();
  146. std::string DataclientId = root["DataClientId"].asString();
  147. _Mqtt_SE = std::make_unique<SensorMQTT<CDataMqttSensor>>(this, DataServerUrl, DatauserName, Datapassword, DataclientId);
  148. //_Mqtt_SE->Start();
  149. //std::string _usb_1 = root["usb_3"].asString();
  150. //renableUSB("/dev/bus/usb/002/002");
  151. //renableUSB("/dev/bus/usb/001/003");
  152. //renableUSB(_usb_2.c_str());
  153. //renableUSB(_usb_1.c_str());
  154. serverip=root["ip"].asString();
  155. _hostPort=root["TcpHostPort"].asInt();
  156. _remotePort=root["TcpRemotePort"].asInt();
  157. _name=root["name"].asString();
  158. const Json::Value arrayObj=root["camerainfo"];
  159. int32_t count=arrayObj.size();
  160. for(int32_t i=0;i<count;i++)
  161. {
  162. LocalCameraInfo info;
  163. const Json::Value& value=arrayObj[i];
  164. info.index=value["index"].asInt();
  165. info.label=value["label"].asString();
  166. _cameraArray.push_back(info);
  167. }
  168. for(int i=0;i<_cameraArray.size();i++)
  169. {
  170. _peerArray.push_back({nullptr});
  171. }
  172. }
  173. else{
  174. std::string error=jsonReader.getFormattedErrorMessages();
  175. std::cout<<error<<std::endl;
  176. }
  177. _client=std::make_unique<SocketClient>(this);
  178. _client->Start(serverip.c_str(),_remotePort,_hostPort);
  179. //20230412
  180. //_Mqtt_ZR = std::make_unique<CMqtt>(this);
  181. //_Mqtt_ZR->start();
  182. //_can=std::make_unique<SocketCan>(this);
  183. //_can->Start(_canip,_canport,_hostport);
  184. std::this_thread::yield();
  185. // OnNotifyReq(0);
  186. }
  187. /*
  188. void CMessageQueue::WriteCanMessage(std::unordered_map<int32_t, cannet_frame>& node,bool islidar)
  189. {
  190. if(!bDataChannelCreated) return;
  191. // std::lock_guard<std::mutex> l(_canLock);
  192. RemoNet::CCCanMesage Req;
  193. Req.set_islidar(islidar);
  194. for(auto& p:node)
  195. {
  196. int32_t lidar=p.second.canid;
  197. auto m=Req.add_message();
  198. m->set_head(p.second.dlc);
  199. m->set_canid(lidar);
  200. m->set_data(p.second.data,8);
  201. }
  202. MessageHead Head;
  203. CIOBuffer pBuffer;
  204. Head.Command = RemoNet::CC_CAN;
  205. Head.Length = Req.ByteSizeLong();
  206. Head.Serialize(pBuffer.Buffer);
  207. auto ptr = pBuffer.Buffer + MessageHead::Size();
  208. Req.SerializeToArray(ptr, Head.Length);
  209. pBuffer.Length = MessageHead::Size() + Head.Length;
  210. _peerArray[0]->SendData(&pBuffer);
  211. }
  212. bool CMessageQueue::IsCarId(int32_t value)
  213. {
  214. return std::find(_carArray.begin(),_carArray.end(),value)!=_carArray.end();
  215. }
  216. */
  217. void CMessageQueue::EnQueue(CIOBuffer* pBuffer)
  218. {
  219. bool bNullBuffer=false;
  220. std::unique_lock <std::mutex> lck(_lock);
  221. if(Head==nullptr)
  222. {
  223. Head=Tail=pBuffer;
  224. bNullBuffer=true;
  225. }
  226. else{
  227. Tail->NextBuf=pBuffer;
  228. Tail=Tail->NextBuf;
  229. }
  230. pBuffer->NextBuf=nullptr;
  231. if(bNullBuffer)
  232. {
  233. //_cv.notify_one();
  234. //20231023
  235. _cv.notify_all();
  236. }
  237. }
  238. void CMessageQueue::Process()
  239. {
  240. // printf("-----process-----\n");
  241. CIOBuffer * ptr=nullptr;
  242. {
  243. std::unique_lock <std::mutex> lck(_lock);
  244. /*
  245. while(Head==nullptr)
  246. {
  247. _cv.wait(lck);
  248. }
  249. */
  250. while(Head==nullptr&&_cv.wait_for(lck,std::chrono::seconds(1))==std::cv_status::timeout)
  251. {
  252. CheckSignal();
  253. //std::cout<<".";
  254. //std::cout.flush();
  255. }
  256. }
  257. while(Head!=nullptr)
  258. {
  259. // printf("head-------\n");
  260. ptr=Head;
  261. Head=Head->NextBuf;
  262. if(ptr!=nullptr)
  263. {
  264. Message* message=reinterpret_cast<Message *>(ptr->Buffer);
  265. switch (message->cmd)
  266. {
  267. case MessageType::ReqVideo:
  268. // printf("ReqVideo\n");
  269. // printf("ReqVideo message param_l : %d\n", message->param_l);
  270. OnNotifyReq((int32_t)message->param_l);
  271. break;
  272. case MessageType::RepVideo:
  273. // printf("RepVideo\n");
  274. // printf("RepVideo message param_l : %d\n", message->param_l);
  275. OnNotifyRep((int32_t)message->param_l);
  276. break;
  277. case MessageType::Connected:
  278. // printf("Connected\n");
  279. // printf("Connected message param_l : %d\n", message->param_l);
  280. OnNotifyConnected((bool)message->param_l);
  281. break;
  282. case MessageType::Leave:
  283. // printf("Leave\n");
  284. OnNotifyLeave();
  285. break;
  286. case MessageType::AsyncMessage:
  287. // printf("AsyncMessage\n");
  288. OnNotifyMessage();
  289. break;
  290. case MessageType::StopSensor:
  291. // printf("StopSensor\n");
  292. OnNotifyStopSensor();
  293. break;
  294. case MessageType::Ping:
  295. // printf("Ping \n");
  296. OnNotifyPing(message->param_l);
  297. break;
  298. }
  299. ptr->Release();
  300. }
  301. // printf("8888888-------------head-------\n");
  302. }
  303. }
  304. void CMessageQueue::SetTick(long long tick)
  305. {
  306. _curTick=tick;
  307. }
  308. void CMessageQueue::OnNotifyConnected(bool bRet)
  309. {
  310. if(bRet)
  311. {
  312. std::cout << _serial << " " << _name << std::endl;
  313. _client->WriteAddRobot(_serial,_name,static_cast<int32_t>(EgoType::Car));
  314. _updatethread.start(_client.get());
  315. //cs->Analog(0,0,0,0,0);
  316. }
  317. else
  318. {
  319. if(_peerId!=-1)
  320. {
  321. OnVideoLeave(_peerId,EgoType::User);
  322. _peerId=-1;
  323. }
  324. _updatethread.stop();
  325. }
  326. }
  327. // int day_diffient(int year_start, int month_start, int day_start,char *Dst)
  328. // {
  329. // //2024-03-11
  330. // int year_end = strtol(Dst,NULL,10);
  331. // char Temp = '-',*p = NULL,*p1 = NULL;
  332. // p = strchr(Dst,Temp);
  333. // int month_end = strtol(p + 1,NULL,10);
  334. // p1 = strchr(p + 1,Temp);
  335. // int day_end = strtol(p1 + 1,NULL,10);
  336. // int y2, m2, d2;
  337. // int y1, m1, d1;
  338. // m1 = (month_start + 9) % 12;
  339. // y1 = year_start - m1/10;
  340. // d1 = 365*y1 + y1/4 - y1/100 + y1/400 + (m1*306 + 5)/10 + (day_start - 1);
  341. // m2 = (month_end + 9) % 12;
  342. // y2 = year_end - m2/10;
  343. // d2 = 365*y2 + y2/4 - y2/100 + y2/400 + (m2*306 + 5)/10 + (day_end - 1);
  344. // return (d1 - d2);
  345. // }
  346. // void delete_days(const char *path)
  347. // {
  348. // DIR *dir;
  349. // struct dirent *entry;
  350. // struct stat statbuf;
  351. // time_t rawtime;
  352. // struct tm* info;
  353. // time(&rawtime);
  354. // info = localtime(&rawtime);
  355. // uint8_t secret[64] = { 0 };
  356. // sprintf((char*)secret, "%d-%.2d-%.2d.log", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday);
  357. // printf("%s\r\n",secret);
  358. // dir = opendir(path);
  359. // if (dir == NULL)
  360. // {
  361. // printf("无法打开目录\n");
  362. // return;
  363. // }
  364. // while ((entry = readdir(dir)) != NULL)
  365. // {
  366. // if(entry->d_name[0]=='.')
  367. // continue;
  368. // //printf("%s\n",entry->d_name);
  369. // if(day_diffient(info->tm_year + 1900, info->tm_mon + 1, info->tm_mday,entry->d_name) > 15)
  370. // {
  371. // char Dst[128];
  372. // memset(Dst,0,128);
  373. // sprintf(Dst,"rm -rf /home/nvidia/devdata/ZJ_PRO_test/EgoSystem/build/log/%s",entry->d_name);
  374. // system(Dst);
  375. // }
  376. // }
  377. // closedir(dir);
  378. // }
  379. // void CMessageQueue::SerichFile(char *filename)
  380. // {
  381. // DIR *directory_pointer;
  382. // struct dirent *entry;
  383. // int exist = 0;
  384. // char Dst[128];
  385. // memset(Dst,0,128);
  386. // sprintf(Dst,"/home/nvidia/devdata/ZJ_PRO_test/EgoSystem/build/log/%s",filename);
  387. // if((directory_pointer=opendir("/home/nvidia/devdata/ZJ_PRO_test/EgoSystem/build/log/")) == NULL)
  388. // printf("Error open\n");
  389. // else
  390. // {
  391. // while((entry=readdir(directory_pointer)) != NULL)
  392. // {
  393. // if(entry->d_name[0]=='.') continue;
  394. // printf("%s\n",entry->d_name);
  395. // if(!strcmp(entry->d_name,filename))
  396. // {
  397. // File_fd = fopen(Dst, "a");
  398. // exist = 1;
  399. // break;
  400. // }
  401. // }
  402. // }
  403. // if(!exist)
  404. // File_fd = fopen(Dst, "w+");
  405. // closedir(directory_pointer);
  406. // }
  407. void CMessageQueue::OnNotifyReq(int32_t index)
  408. {
  409. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  410. // printf("index:%d\n",index);
  411. // printf ("000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000\n");
  412. if(_peerId==-1) return;
  413. if(index==0)
  414. {
  415. mrsWebrtcCreateFactory(true);
  416. _curTick=0;
  417. bStopedCar=false;
  418. _Rtk->Start();
  419. if(_Version)//AD10
  420. {
  421. _CanBusVehicle->Start();
  422. _CanBusRadar->Start();
  423. }
  424. else
  425. {
  426. _PcanBusVehicle->Start();
  427. _RadarIp->Start();
  428. }
  429. _Mqtt_ZR->Start();
  430. _Mqtt_SE->Start();
  431. // printf("8999----------------------------------------------------------------\n");
  432. // File_fd = NULL;
  433. // struct statfs diskInfo;
  434. // statfs("/dev/mmcblk0p1", &diskInfo);
  435. // unsigned long long freeDisk = diskInfo.f_bfree * diskInfo.f_bsize;
  436. // time_t rawtime;
  437. // struct tm* info;
  438. // time(&rawtime);
  439. // info = localtime(&rawtime);
  440. // uint8_t secret[64] = { 0 };
  441. // sprintf((char*)secret, "%d-%.2d-%.2d.log", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday);
  442. // if((freeDisk >> 30) < 15)
  443. // {
  444. // system("rm -rf /home/nvidia/devdata/ZJ_PRO_test/EgoSystem/build/log");
  445. // system("mkdir /home/nvidia/devdata/ZJ_PRO_test/EgoSystem/build/log/");
  446. // }
  447. // else
  448. // delete_days("/home/nvidia/devdata/ZJ_PRO_test/EgoSystem/build/log");
  449. // SerichFile((char *)secret);
  450. }
  451. _peerArray[index]=std::make_unique<CPeerConnection>(static_cast<ChannelType>(index),_client.get());
  452. _client->WriteVideoRep(_peerId, RemoNet::VideoDesc::OK, index);
  453. }
  454. void CMessageQueue::OnNotifyRep(int32_t index)
  455. {
  456. _peerArray[index]=std::make_unique<CPeerConnection>(static_cast<ChannelType>(index), _client.get());
  457. InitPeerConnection(_peerId,index);
  458. _peerArray[index]->CreateOffer();
  459. }
  460. void CMessageQueue::InitPeerConnection(int32_t peer,int32_t index)
  461. {
  462. _peerArray[index]->Initialize(peer,index,_UdpMinPort,_UdpMaxPort);
  463. _peerArray[index]->AddDataChannel(true, false);
  464. _peerArray[index]->AddLocalVideoTrack(static_cast<RenderPosition>(index),_cameraArray[index].index);
  465. if(index==RenderPosition::BACK)
  466. {
  467. void * front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  468. while(front==nullptr)
  469. {
  470. std::cout<<"front==nullptr"<<std::endl;
  471. std::this_thread::sleep_for(std::chrono::microseconds(50));
  472. front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  473. }
  474. void * back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  475. while (back==nullptr)
  476. {
  477. std::cout<<"back==nullptr"<<std::endl;
  478. std::this_thread::sleep_for(std::chrono::microseconds(50));
  479. back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  480. }
  481. _peerArray[RenderPosition::FRONT]->SetOtherCtx(back);
  482. _peerArray[RenderPosition::BACK]->SetOtherCtx(front);
  483. }
  484. /*
  485. if((index+1)==RenderPosition::ALL)
  486. {
  487. void * front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  488. while(front==nullptr)
  489. {
  490. std::cout<<"front==nullptr"<<std::endl;
  491. std::this_thread::sleep_for(std::chrono::microseconds(50));
  492. front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  493. }
  494. void * back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  495. while (back==nullptr)
  496. {
  497. std::cout<<"back==nullptr"<<std::endl;
  498. std::this_thread::sleep_for(std::chrono::microseconds(50));
  499. back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  500. }
  501. _peerArray[RenderPosition::FRONT]->SetOtherCtx(back);
  502. _peerArray[RenderPosition::BACK]->SetOtherCtx(front);
  503. void * left=_peerArray[RenderPosition::LEFT]->GetCurrentCtx();
  504. while(left==nullptr)
  505. {
  506. std::cout<<"left==nullptr"<<std::endl;
  507. std::this_thread::sleep_for(std::chrono::microseconds(50));
  508. front=_peerArray[RenderPosition::LEFT]->GetCurrentCtx();
  509. }
  510. void * right=_peerArray[RenderPosition::RIGHT]->GetCurrentCtx();
  511. while (right==nullptr)
  512. {
  513. std::cout<<"right==nullptr"<<std::endl;
  514. std::this_thread::sleep_for(std::chrono::microseconds(50));
  515. back=_peerArray[RenderPosition::RIGHT]->GetCurrentCtx();
  516. }
  517. _peerArray[RenderPosition::LEFT]->SetOtherCtx(right);
  518. _peerArray[RenderPosition::RIGHT]->SetOtherCtx(left);
  519. }
  520. */
  521. /*
  522. if((index+1)==RenderPosition::ALL)
  523. {
  524. void * front=_peerArray[RenderPosition::FRONT]->GetCurrentCtx();
  525. void * back=_peerArray[RenderPosition::BACK]->GetCurrentCtx();
  526. void * left=_peerArray[RenderPosition::LEFT]->GetCurrentCtx();
  527. void * right=_peerArray[RenderPosition::RIGHT]->GetCurrentCtx();
  528. void * dash=_peerArray[RenderPosition::DASHBOARD]->GetCurrentCtx();
  529. _peerArray[RenderPosition::FRONT]->SetOtherCtx(back);
  530. _peerArray[RenderPosition::BACK]->SetOtherCtx(front);
  531. _peerArray[RenderPosition::LEFT]->SetOtherCtx(left);
  532. _peerArray[RenderPosition::RIGHT]->SetOtherCtx(right);
  533. _peerArray[RenderPosition::DASHBOARD]->SetOtherCtx(dash);
  534. }
  535. */
  536. if(index==RenderPosition::FRONT)
  537. _peerArray[index]->AddLocalAudioTrack();
  538. }
  539. void CMessageQueue::OnAdd(bool bRet)
  540. {
  541. }
  542. void CMessageQueue::OnConnected(bool bRet)
  543. {
  544. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  545. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  546. message->cmd=MessageType::Connected;
  547. message->param_l=bRet;
  548. EnQueue(pBuffer);
  549. }
  550. void CMessageQueue::OnVideoLeave(int32_t peer,EgoType type)
  551. {
  552. {
  553. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  554. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  555. message->cmd=MessageType::StopSensor;
  556. EnQueue(pBuffer);
  557. }
  558. {
  559. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  560. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  561. message->cmd=MessageType::Leave;
  562. EnQueue(pBuffer);
  563. }
  564. }
  565. #ifdef WIN32
  566. void CMessageQueue::OnVideoRep(int32_t index,RemoNet::VideoDesc desc)
  567. {
  568. if (desc == RemoNet::VideoDesc::OK)
  569. {
  570. assert(_peerId!=-1);
  571. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  572. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  573. message->cmd=MessageType::ReqVideo;
  574. message->param_l=index;
  575. EnQueue(pBuffer);
  576. }
  577. }
  578. #else
  579. void CMessageQueue::OnVideoReq(int32_t video,int32_t peer)
  580. {
  581. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  582. _peerId=peer;
  583. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  584. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  585. message->cmd=MessageType::ReqVideo;
  586. message->param_l=video;
  587. EnQueue(pBuffer);
  588. }
  589. #endif
  590. void CMessageQueue::OnNotifyLeave()
  591. {
  592. std::this_thread::sleep_for(std::chrono::milliseconds(100));
  593. for (size_t i = 0; i < _peerArray.size(); i++)
  594. {
  595. if(_peerArray[i]!=nullptr)
  596. {
  597. _peerArray[i]->Close();
  598. _peerArray[i].reset();
  599. }
  600. /* code */
  601. }
  602. _peerId=-1;
  603. }
  604. void CMessageQueue::OnNotifyStopSensor()
  605. {
  606. _curTick=0;
  607. if(_Version)//AD10
  608. {
  609. std::cout<<"_CanBusVehicle Stop"<<std::endl;
  610. _CanBusVehicle->Stop();
  611. std::cout<<"_CanBusRadar Stop"<<std::endl;
  612. _CanBusRadar->Stop();
  613. }
  614. else
  615. {
  616. std::cout<<"_PcanBusVehicle Stop"<<std::endl;
  617. _PcanBusVehicle->Stop();
  618. std::cout<<"_RadarIp Stop"<<std::endl;
  619. _RadarIp->Stop();
  620. }
  621. std::cout << "RTK Stop" << std::endl;
  622. _Rtk->Stop();
  623. std::cout<<"mqtt Stop"<<std::endl;
  624. _Mqtt_ZR->Stop();
  625. std::cout<<"data mqtt Stop"<<std::endl;
  626. _Mqtt_SE->Stop();
  627. // if(!File_fd)
  628. // {
  629. // fclose(File_fd);
  630. // File_fd = NULL;
  631. // }
  632. RemoNet::StopAck Rep;
  633. CIOBuffer Buffer;
  634. MessageHead Head;
  635. Head.Command = RemoNet::CC_StopACK;
  636. Head.Length = Rep.ByteSizeLong();
  637. Head.Serialize(Buffer.Buffer);
  638. auto ptr = Buffer.Buffer + MessageHead::Size();
  639. Rep.SerializeToArray(ptr, Head.Length);
  640. Buffer.Length = Head.Length + MessageHead::Size();
  641. _peerArray[RenderPosition::FRONT]->SendData(Buffer);
  642. }
  643. void CMessageQueue::OnVideoOffer(int32_t index,const char* type, const char* sdp)
  644. {
  645. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  646. // printf ("onvideo offer9999999999999999999999999999999999999999999999999999999999999999999999999999\n");
  647. InitPeerConnection(_peerId,index);
  648. _peerArray[index]->SetRemoteDescription(type,sdp);
  649. _peerArray[index]->CreateAnswer();
  650. }
  651. void CMessageQueue::OnVideoAnswer(int32_t index, const char* type, const char* sdp)
  652. {
  653. // std::cout<<__FUNCTION__<<","<<__LINE__<<std::endl;
  654. _peerArray[index]->SetRemoteDescription(type,sdp);
  655. }
  656. void CMessageQueue::OnVideoCandidate(int32_t index,const char* candidate,
  657. int32_t sdp_mline_index,
  658. const char* sdp_mid)
  659. {
  660. _peerArray[index]->AddIceCandidate(candidate,sdp_mline_index,sdp_mid);
  661. }
  662. /*
  663. void CMessageQueue::SwitchCamera(bool front)
  664. {
  665. _peerArray[RenderPosition::FRONT_BACK]->SwitchCapture(front);
  666. }
  667. */
  668. void CMessageQueue::OnMessageFrameNotify(ChannelType type,int16_t cmd,int16_t length,const void * data)
  669. {
  670. // std::cout<<"cmd:" <<std::hex<<cmd<<std::endl;
  671. if(cmd==RemoNet::CC_Text)
  672. {
  673. RemoNet::TestTextReq Req;
  674. Req.ParseFromArray(data,length);
  675. std::cout<<Req.text()<<std::endl;
  676. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  677. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  678. message->cmd=MessageType::AsyncMessage;
  679. EnQueue(pBuffer);
  680. }
  681. else if(cmd==RemoNet::CC_Switch)
  682. {
  683. RemoNet::CCSwitch Req;
  684. Req.ParseFromArray(data,length);
  685. bool front=Req.front();
  686. _peerArray[RenderPosition::FRONT]->SwitchCapture(front);
  687. }
  688. else if(cmd==RemoNet::CC_Ping)
  689. {
  690. RemoNet::CCPing Req;
  691. Req.ParseFromArray(data,length);
  692. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  693. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  694. message->cmd=MessageType::Ping;
  695. message->param_l=Req.tick();
  696. EnQueue(pBuffer);
  697. }
  698. else if(cmd==RemoNet::CC_SensorStop)
  699. {
  700. CIOBuffer * pBuffer=CIOBuffer::Alloc();
  701. Message* message=reinterpret_cast<Message *>(pBuffer->Buffer);
  702. message->cmd=MessageType::StopSensor;
  703. EnQueue(pBuffer);
  704. }
  705. else if (cmd == RemoNet::CC_CANMSG)
  706. {
  707. _source = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  708. _curTick = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  709. RemoNet::CCCanMsg Req;
  710. Req.ParseFromArray(data, length);
  711. cannet_frame* frames = (cannet_frame*)alloca(sizeof(cannet_frame) * Req.frams_size());
  712. for (int32_t i = 0; i < Req.frams_size(); i++)
  713. {
  714. auto& frame = Req.frams(i);
  715. frames[i].canid = frame.canid();
  716. frames[i].dlc = frame.dlc();
  717. memcpy(frames[i].data, frame.data().data(), frame.dlc());
  718. }
  719. //_robot->Get()->OnMessage(frames, Req.frams_size());
  720. if(_Version)//AD10
  721. _CanBusVehicle->Get()->OnMessage(frames, Req.frams_size());
  722. else
  723. _PcanBusVehicle->Get()->OnMessage(frames, Req.frams_size());
  724. }
  725. }
  726. void CMessageQueue::StopCar()
  727. {
  728. std::cout<<"Stop Car"<<std::endl;
  729. if(_Version)//AD10
  730. _CanBusVehicle->Get()->Emergency();
  731. else
  732. _PcanBusVehicle->Get()->Emergency();
  733. }
  734. void CMessageQueue::OnNotifyMessage()
  735. {
  736. RemoNet::TestTextReq Req;
  737. Req.set_text("ewqewqewqe");
  738. CIOBuffer Buffer;
  739. MessageHead Head;
  740. Head.Command = RemoNet::CC_Text;
  741. Head.Length = Req.ByteSizeLong();
  742. Head.Serialize(Buffer.Buffer);
  743. auto ptr = Buffer.Buffer + MessageHead::Size();
  744. Req.SerializeToArray(ptr, Head.Length);
  745. Buffer.Length = Head.Length + MessageHead::Size();
  746. _peerArray[RenderPosition::FRONT]->SendData(Buffer);
  747. }
  748. void CMessageQueue::OnNotifyPing(int64_t value)
  749. {
  750. RemoNet::CCPing Rep;
  751. Rep.set_tick(value);
  752. CIOBuffer Buffer;
  753. MessageHead Head;
  754. Head.Command = RemoNet::CC_Ping;
  755. Head.Length = Rep.ByteSizeLong();
  756. Head.Serialize(Buffer.Buffer);
  757. auto ptr = Buffer.Buffer + MessageHead::Size();
  758. Rep.SerializeToArray(ptr, Head.Length);
  759. Buffer.Length = Head.Length + MessageHead::Size();
  760. //std::cout << "ping" << std::endl;
  761. if( _peerArray[RenderPosition::FRONT]!=nullptr && _peerArray[RenderPosition::FRONT]->bReadyChannel)
  762. _peerArray[RenderPosition::FRONT]->SendData(Buffer);
  763. }
  764. /*
  765. void CMessageQueue::StartCar()
  766. {
  767. _can->SetStartWrite(true);
  768. }
  769. */
  770. void CMessageQueue::CheckSignal()
  771. {
  772. if(!bStopedCar)
  773. {
  774. long long tick=std::chrono::duration_cast<std::chrono::seconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  775. if(_curTick!=0&&tick-_curTick > 3)
  776. {
  777. StopCar();
  778. bStopedCar=true;
  779. std::cout<<"_curTick!=0&&tick-_curTick > 3" << std::endl;
  780. _curStopTick = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  781. btimeStopedCar = true;
  782. _curTick = 0;
  783. }
  784. }
  785. }
  786. void CMessageQueue::WriteIMUData(ImuData* data)
  787. {
  788. MessageHead Head;
  789. CIOBuffer Buffer;
  790. RemoNet::IMuMessage Req;
  791. Req.set_rx(data->ry);
  792. Req.set_ry(data->rx);
  793. // Req.set_rz(data->rz);
  794. Head.Command=RemoNet::CC_IMU;
  795. Head.Length=Req.ByteSizeLong();
  796. Head.Serialize(Buffer.Buffer);
  797. auto ptr = Buffer.Buffer + MessageHead::Size();
  798. Req.SerializeToArray(ptr, Head.Length);
  799. Buffer.Length = Head.Length + MessageHead::Size();
  800. if( _peerArray[ChannelType::CHANNEL_IMU]!=nullptr)
  801. _peerArray[ChannelType::CHANNEL_IMU]->SendData(Buffer);
  802. }
  803. void CMessageQueue::WritePacket(ChannelType type, CIOBuffer & pBuffer)
  804. {
  805. if( _peerArray[type]!=nullptr)
  806. _peerArray[type]->SendData(pBuffer);
  807. }
  808. void CMessageQueue::WriteRadarData(RadarData& data)
  809. {
  810. MessageHead Head;
  811. CIOBuffer Buffer;
  812. RemoNet::CCRadarMessage Req;
  813. Req.set_radar0(data.r0);
  814. Req.set_radar1(data.r1);
  815. Req.set_radar2(data.r2);
  816. Req.set_radar3(data.r3);
  817. Req.set_radar4(data.r4);
  818. Req.set_radar5(data.r5);
  819. Req.set_radar6(data.r6);
  820. Req.set_radar7(data.r7);
  821. //Head.Command=RemoNet::CC_IMU;
  822. Head.Command = RemoNet::CC_Radar;
  823. Head.Length=Req.ByteSizeLong();
  824. Head.Serialize(Buffer.Buffer);
  825. auto ptr = Buffer.Buffer + MessageHead::Size();
  826. Req.SerializeToArray(ptr, Head.Length);
  827. Buffer.Length = Head.Length + MessageHead::Size();
  828. if( _peerArray[ChannelType::CHANNEL_RADAR]!=nullptr)
  829. _peerArray[ChannelType::CHANNEL_RADAR]->SendData(Buffer);
  830. }
  831. void CMessageQueue::WriteRobotStatus(int32_t ,int32_t )
  832. {
  833. }
  834. #ifdef LIDAR_SENSOR
  835. void CMessageQueue::WriteLidarPoint(const PointCloudMsg<PointXYZI>& msg,ChannelType side)
  836. {
  837. RemoNet::LidarPoint pt;
  838. pt.set_is_left(side==ChannelType::CHANNEL_LEFT_LIDAR);
  839. pt.set_frame_id(msg.frame_id);
  840. pt.set_height(msg.height);
  841. pt.set_width(msg.width);
  842. pt.set_is_dense(msg.is_dense);
  843. pt.set_seq(msg.seq);
  844. pt.set_timestamp(msg.timestamp);
  845. for(int i=0;i<msg.point_cloud_ptr->size();i++)
  846. {
  847. pt.add_data((*msg.point_cloud_ptr)[i].x);
  848. pt.add_data((*msg.point_cloud_ptr)[i].y);
  849. pt.add_data((*msg.point_cloud_ptr)[i].z);
  850. pt.add_data((*msg.point_cloud_ptr)[i].intensity);
  851. }
  852. MessageHead Head;
  853. CIOBuffer Buffer;
  854. Head.Command=RemoNet::CC_LIDARDATA;
  855. Head.Length=pt.ByteSizeLong();
  856. Head.Serialize(Buffer.Buffer);
  857. auto ptr = Buffer.Buffer + MessageHead::Size();
  858. pt.SerializeToArray(ptr, Head.Length);
  859. Buffer.Length = Head.Length + MessageHead::Size();
  860. if( _peerArray[side]!=nullptr)
  861. _peerArray[side]->SendData(&Buffer);
  862. }
  863. #endif
  864. void CMessageQueue::SwitchCamera(bool front)
  865. {
  866. _peerArray[RenderPosition::FRONT]->SwitchCapture(front);
  867. _peerArray[RenderPosition::BACK]->SwitchCapture(front);
  868. }
  869. void CMessageQueue::SendZGJStatus(int status)
  870. {
  871. _Rtk->Get()->Send_ZGJ_status(status);
  872. }
  873. void CMessageQueue::SendVehicleStatus(int16_t Direction,int16_t Hand_Throttle,int16_t Foot_Throttle,int16_t Brake)
  874. {
  875. //CDataMqttSensor::sendMessage()
  876. if (CDataMqttSensor::_run)
  877. {
  878. time_t rawtime;
  879. struct tm* info;
  880. time(&rawtime);
  881. info = localtime(&rawtime);
  882. char secret[64] = { 0 };
  883. sprintf((char*)secret, "%d-%.2d-%.2d %.2d:%.2d:%.2d", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday,info->tm_hour,info->tm_min,info->tm_sec);
  884. printf("%s\r\n",secret);
  885. char WriteLocalDat[128];
  886. memset(WriteLocalDat,0,128);
  887. sprintf(WriteLocalDat, "%d-%.2d-%.2d %.2d:%.2d:%.2d 方向值:%d 手油门值:%d 脚油门值:%d 刹车值:%d\n", info->tm_year + 1900, info->tm_mon + 1, info->tm_mday,info->tm_hour,info->tm_min,info->tm_sec,
  888. Direction,Hand_Throttle,Foot_Throttle,Brake);
  889. fwrite(WriteLocalDat, strlen(WriteLocalDat) , 1, File_fd);
  890. Json::Value root;
  891. Json::Value Source;
  892. Json::FastWriter writer;
  893. std::string SendTime;
  894. Source["1"] = SendTime.assign(secret,strlen(secret));//发送时间
  895. Source["2"] = Direction;//方向值
  896. Source["3"] = Hand_Throttle;//手油门值
  897. Source["4"] = Foot_Throttle;//脚油门值
  898. Source["5"] = Brake;//刹车值
  899. Json::StyledWriter sw;
  900. //std::cout << sw.write(Source) << std::endl << std::endl;
  901. if (!DataMqtt_SendDate)
  902. {
  903. DataMqtt_curTick = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  904. DataMqtt_SendDate = true;
  905. }
  906. else
  907. {
  908. long long tick = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
  909. if (DataMqtt_curTick != 0 && tick - DataMqtt_curTick > 10000)
  910. {
  911. if (CDataMqttSensor::_run && (CDataMqttSensor::m_mqttClient != NULL))
  912. CDataMqttSensor::sendMessage((char*)sw.write(Source).c_str(), 0, (char*)"bg/log");
  913. DataMqtt_SendDate = false;
  914. }
  915. }
  916. }
  917. }