123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- #include <stdint.h>
- #include "../common/comm.h"
- #include "Protocol.pb.h"
- #include "car_sim.h"
- #include "EgoClient.h"
- #include "car_sim.h"
- #include <random>
- #include "control_sensor.h"
- #include <chrono>
- #include <iomanip>
- #include <windows.h>
- #include <iomanip>
- #include <sstream>
- CCarSim::CCarSim(CEgoClient* car) :_car(car)
- {
- }
- void CCarSim::Start()
- {
- }
- void CCarSim::Stop()
- {
- }
- void CCarSim::OnPeerMessage(int16_t cmd, int16_t length, const void* data)
- {
- switch (cmd)
- {
- case RemoNet::CC_Ping:
- {
- RemoNet::CCPing Req;
- Req.ParseFromArray(data, length);
- int64_t tick = GetTickCount64();
- int32_t diff = tick - Req.tick();
- double temp = Req.temp();
- testPing= Req.tick();
- //增加打印日志文件内容
- /*
- auto now = std::chrono::system_clock::now();
- auto time = std::chrono::system_clock::to_time_t(now);
- auto localtime = std::localtime(&time);
- // 格式化当前系统时间作为文件名
- std::ostringstream filenameStream;
- filenameStream << "E:\\DY\\EgoDY\\Run\\log_" << std::put_time(localtime, "%Y%m%d_%H%M%S") << ".txt";
- filename = filenameStream.str();
- // 添加日志记录
- std::ofstream logFile("E:\\DY\\EgoDY\\Run\\log.txt", std::ios::app);
- //std::ofstream logFile(filename, std::ios::app);
- if (logFile.is_open()) {
- logFile << "System Time: " << std::put_time(localtime, "%Y-%m-%d %H:%M:%S") << std::endl;
- logFile << "Diff: " << diff << " Temp: " << temp << std::endl;
- //logFile.close();
- }
- */
- _car->OnPingValue(diff, temp);
- }
- break;
- case RemoNet::CC_StopACK:
- {
- _car->OnStopAck();
- }
- case RemoNet::CC_STATE:
- {
- //创建一个RemoNet::State
- RemoNet::State msg;
- //用ParseFromArray(data, length)将从data中解析的数据填充到msg对象中
- msg.ParseFromArray(data, length);
- //_control_sensor->_automous = (msg.left_lock()!=0) ? true:false;//left_lock为1时,切换为遥操,发送报文给下位机
- //创建了FeedData类型的数据结构,用于存储从msg中提取的不同数据字段
- FeedData data;
- data.brake_pressure = msg.brake_pressure();//制动气压
- data.engine_rpm = msg.engine_rpm();//发动机转速
- data.engine_pressure = msg.engine_pressure();//发动机压力
- data.gearbox_oil_pressure = msg.gearbox_oil_pressure();//变速箱油压
- data.gearbox_oil_temp = msg.gearbox_oil_temp();//变速箱油温
- data.speed = msg.speed();//行驶速度
- data.cold_water = msg.cold_water();//发动机水温
- data.steer_angle = msg.steer_angle();//车辆姿态???原来是轮子现在定义为铰链
- data.left_lock_status = msg.left_lock();
- data.right_lock_status = msg.right_lock();
- data.work_pressure = msg.work_pressure();
- //data.gear = msg.gear();
- //发送给qt的信息以下是大冶增加的:
- data.engine_time = msg.engine_time();//发动机工作小时
- data.wire_sensor_l = msg.wire_sensor_l();//左支腿高度
- data.wire_sensor_r = msg.wire_sensor_r();//右支腿高度
- //OutputDebugStringA(("===================打印左支腿高度 " + std::to_string(data.wire_sensor_l) + "============\n").c_str());
- //OutputDebugStringA(("===================打印右支腿高度 " + std::to_string(data.wire_sensor_r) + "============\n").c_str());
- data.fuel_level = msg.fuel_level();//燃油油位油量
- //data.lock_switch_l = msg.lock_switch_l();//锁钩到位开关L
- //data.lock_switch_r = msg.lock_switch_r();//锁钩到位开关R
- //data.tip_limit = msg.tip_limit();//倾翻限位
- data.lock_switch_l = msg.outgrigger_l();//左支腿伸到位开关
- data.lock_switch_r = msg.outgrigger_r();//右支腿伸到位开关
- data.tip_limit = msg.tip_pressure();//倾翻压力开关
- data.turn_left = msg.turn_left();//左转
- data.turn_right = msg.turn_right();//右转
- data.hight_beam = msg.hight_beam();//远光灯
- data.low_beam = msg.low_beam();//近光灯
- data.parking = msg.parking();//驻车
- data.brake = msg.brake();//刹车
- data.back_car = msg.back_car();//倒车
- data.front_work_lamp = msg.front_work_lamp();//前工作灯
- data.rear_work_lamp = msg.rear_work_lamp();//后工作灯
- data.cargo_weight = msg.cargo_weight();//渣包重量
- data.system_vol = msg.system_vol();//系统电压
- data.f_gear = msg.f_gear();//档位信息1=F 2=R 3=N
- data.gear_1 = msg.gear_1();//档位1234
- //发送信息给PCAN(下位机传的0x280透传)
- TPCANMsg* CANMsg = (TPCANMsg*)malloc(sizeof(TPCANMsg));
- CANMsg->ID = 0x280;
- CANMsg->MSGTYPE = PCAN_MESSAGE_STANDARD;
- CANMsg->LEN = msg.error_buff().size();
- memcpy(CANMsg->DATA, data.warningData, CANMsg->LEN);
- //SendCANMessage(CANMsg);
- _car->SendCanDate(CANMsg);
- free(CANMsg);
- for (int i = 0; i < msg.error_buff().size(); ++i)//报警信息
- {
- data.warningData[i] = msg.error_buff()[i];
- }
- //将报警信息解读出来赋值给data中的变量
- data.low_oil_pressure_alarm = (data.warningData[0] & 0x1) == 0x1 ? 1 : 0;//机油压力低报警
- data.engine_water_temperature_alarm = (data.warningData[0] & 0x2) == 0x2 ? 1 : 0;//发动机水温高报警
- data.high_engine_oil_temperature_alarm = (data.warningData[0] & 0x4) == 0x4 ? 1 : 0;//发动机油温高报警
- data.engine_water_level_low_alarm = (data.warningData[0] & 0x8) == 0x8 ? 1 : 0;//发动机水位低报警
- data.low_fuel_oil_alarm = (data.warningData[0] & 0x10) == 0x10 ? 1 : 0;//燃油油位低报警
- data.return_oil_filter_blocked_alarm = (data.warningData[0] & 0x20) == 0x20 ? 1 : 0;//回油滤网堵塞报警
- data.oil_filter_blocked_alarm = (data.warningData[0] & 0x40) == 0x40 ? 1 : 0;//吸油滤网堵塞报警
- data.control_screen_blockage_alarm = (data.warningData[0] & 0x80) == 0x80 ? 1 : 0;//控制滤网堵塞报警
- data.emergency_filter_blocking_alarm = (data.warningData[1] & 0x1) == 0x1 ? 1 : 0;//应急滤网堵塞报警
- data.cooling_filter_blocked_alarm = (data.warningData[1] & 0x2) == 0x2 ? 1 : 0;//冷却滤网堵塞报警
- data.electric_pump_screen_blocked_alarm = (data.warningData[1] & 0x4) == 0x4 ? 1 : 0;//电泵滤网堵塞报警
- data.brake_filter_blocked_alarm = (data.warningData[1] & 0x8) == 0x8 ? 1 : 0;//制动滤网堵塞报警
- data.variable_speed_filter_blocked_alarm = (data.warningData[1] & 0x10) == 0x10 ? 1 : 0;//变速滤网堵塞报警
- data.low_voltage_alarm = (data.warningData[1] & 0x20) == 0x20 ? 1 : 0;//电压低报警
- data.high_transmission_oil_temperature = (data.warningData[2] & 0x1) == 0x1 ? 1 : 0;//变速箱油温高
- data.transmission_oil_pressure_is_low = (data.warningData[2] & 0x2) == 0x2 ? 1 : 0;//变速箱油压低
- data.oil_temperature_sensor_1_is_faulty = (data.warningData[2] & 0x4) == 0x4 ? 1 : 0; //油温传感器1故障
- data.oil_temperature_sensor_2_is_faulty = (data.warningData[2] & 0x8) == 0x8 ? 1 : 0;//油温传感器2故障
- data.oil_level_sensor_is_faulty = (data.warningData[2] & 0x10) == 0x10 ? 1 : 0;//油位传感器故障
- data.front_throttle_fault = (data.warningData[2] & 0x20) == 0x20 ? 1 : 0;//前油门故障
- data.rear_throttle_fault = (data.warningData[2] & 0x40) == 0x40 ? 1 : 0;//后油门故障
- data.handle_of_the_upper_arm_is_faulty = (data.warningData[2] & 0x80) == 0x80 ? 1 : 0;//大臂手柄故障
- data.left_leg_handle_is_faulty = (data.warningData[3] & 0x8) == 0x8 ? 1 : 0;//左支腿手柄故障
- data.right_leg_handle_is_faulty = (data.warningData[3] & 0x10) == 0x10 ? 1 : 0;//右支腿手柄故障
- data.engine_bus_fault = (data.warningData[3] & 0x20) == 0x20 ? 1 : 0;//发动机总线故障
- data.transmission_bus_fault = (data.warningData[3] & 0x40) == 0x40 ? 1 : 0;//变速箱总线故障
- data.remote_control_bus_fault = (data.warningData[3] & 0x80) == 0x80 ? 1 : 0;//遥控器总线故
- data.rod_chamber_pressure_sensor_is_faulty = (data.warningData[4] & 0x1) == 0x1 ? 1 : 0;//有杆腔压力传感器故障
- data.no_rod_chamber_pressure_sensor_is_faulty = (data.warningData[4] & 0x2) == 0x2 ? 1 : 0;//无杆腔压力传感器故障
- data.brake_pressure_sensor_is_faulty = (data.warningData[4] & 0x4) == 0x4 ? 1 : 0;//制动压力传感器故障
- data.system_pressure_sensor_is_faulty = (data.warningData[4] & 0x8) == 0x8 ? 1 : 0;//系统压力传感器故障
- data.control_pressure_sensor_is_faulty = (data.warningData[4] & 0x10) == 0x10 ? 1 : 0;//控制压力传感器故障
- data.steering_pressure_sensor_is_faulty = (data.warningData[4] & 0x20) == 0x20 ? 1 : 0;//转向压力传感器故障
- data.pressure_sensor_of_the_lower_arm_is_faulty = (data.warningData[4] & 0x40) == 0x40 ? 1 : 0;//小臂压力传感器故障
- data.locking_pin_displacement_sensor_L_is_faulty = (data.warningData[5] & 0x1) == 0x1 ? 1 : 0;//锁销位移传感器L故障
- data.locking_pin_displacement_sensor_R_is_faulty = (data.warningData[5] & 0x2) == 0x2 ? 1 : 0;//锁销位移传感器R故障
- data.leg_displacement_sensor_L_is_faulty = (data.warningData[5] & 0x4) == 0x4 ? 1 : 0;//支腿位移传感器L故障
- data.leg_displacement_sensor_R_is_faulty = (data.warningData[5] & 0x8) == 0x8 ? 1 : 0;//支腿位移传感器R故障
- data.steering_encoder_failure = (data.warningData[5] & 0x10) == 0x10 ? 1 : 0;//转向编码器故障
- //qqq 发送给QT
- _car->OnFeedPage(data);
- }
- break;
- case RemoNet::CC_NDTPOS:
- {
- RemoNet::NDTPos Req;
- Req.ParseFromArray(data, length);
- Position pos;
- pos.x = Req.x();
- pos.y = Req.y();
- pos.z = Req.z();
- pos.rx = Req.rx();
- pos.ry = Req.ry();
- pos.rz = Req.rz();
- pos.rw = Req.rw();
- _car->OnNDTPos(&pos);
- }
- break;
- }
- }
-
|