123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611 |
- #include "can_bus.h"
- #include <thread>
- #include "message_queue.h"
- #define GET_BIT(x, bit) ((x & (1 << bit)) >> bit)
- int16_t make_int16(unsigned char h,unsigned char l)
- {
- int16_t hi=(int16_t)(h&0x00FF);
- int16_t low= (int16_t)(l&0x00FF);
- return (hi<<8)|low;
- }
- CCanBusSensor::CCanBusSensor(CMessageQueue* q) :_message(q)
- {
- _run = false;
- _front_view = true;
- for (int32_t i = 0; i < sizeof(Sendframe)/sizeof(can_frame); i++)
- memset(&Sendframe[i], 0, sizeof(can_frame));
- }
- void CCanBusSensor::SetCanBusSensor(SensorCanBus<CCanBusSensor>* can)
- {
- _canbus = can;
- halfautomatic = true;
- _message->_Feeddata.right_lock = 1;
- }
- void CCanBusSensor::CanSendProc()
- {
- while (_run)
- {
-
-
- for(int32_t i=0;i<sizeof(Sendframe)/sizeof(can_frame);i++)
- {
- if(Sendframe[i].can_id != 0)
- {
- if(!_message->_Feeddata.right_lock)
- {
- _canbus->Write(&Sendframe[i]);
-
- }
- Sendframe[i].can_id = 0;
- }
- }
- std::this_thread::sleep_for(std::chrono::milliseconds(5));
- }
-
-
- }
- void CCanBusSensor::Start()
- {
-
- _run = true;
- _can_thread = std::thread(&CCanBusSensor::CanSendProc, this);
- halfautomatic = true;
- Gear_position_Set = 0;
- Gear_position_now = 1;
- count = 0;
- _message->_Feeddata.right_lock = 1;
- }
- void CCanBusSensor::Run()
- {
-
- }
-
- void CCanBusSensor::Stop()
- {
-
- if (_run)
- {
- _run = false;
- _can_thread.join();
- }
- for (int32_t i = 0; i < sizeof(Sendframe)/sizeof(can_frame); i++)
- memset(&Sendframe[i], 0, sizeof(can_frame));
- halfautomatic = false;
- Gear_position_Set = 0;
- Gear_position_now = 1;
- count = 0;
- _message->_Feeddata.right_lock = 1;
- }
- void CCanBusSensor::GetGearCurrent(uint8_t data)
- {
-
- if((GET_BIT(data,0) == 1) && (GET_BIT(data,1) == 0))
- {
- Gear_direction = 'F';
- _message->_Feeddata.f_gear = 1;
- }
- else if((GET_BIT(data,0) == 0) && (GET_BIT(data,1) == 1))
- {
- Gear_direction = 'R';
- _message->_Feeddata.f_gear = 2;
- }
- else
- {
- Gear_direction = 'N';
- _message->_Feeddata.f_gear = 3;
- }
-
- if((GET_BIT(data,4) == 0) && (GET_BIT(data,5) == 1) && (GET_BIT(data,6) == 0))
- {
- Gear_position_now = 2;
- _message->_Feeddata.gear_1 = 2;
- }
- else if((GET_BIT(data,4) == 1) && (GET_BIT(data,5) == 1) && (GET_BIT(data,6) == 0))
- {
- Gear_position_now = 3;
- _message->_Feeddata.gear_1 = 3;
- }
- else if((GET_BIT(data,4) == 0) && (GET_BIT(data,5) == 0) && (GET_BIT(data,6) == 1))
- {
- Gear_position_now = 4;
- _message->_Feeddata.gear_1 = 4;
- }
- else
- {
- Gear_position_now = 1;
- _message->_Feeddata.gear_1 = 1;
- }
- }
- void CCanBusSensor::SetGear_FR_Current(uint8_t data,uint8_t type)
- {
- if(!type)
- {
- if((GET_BIT(data,3) == 1))
- Gear_position_Set = 1;
- if((GET_BIT(data,2) == 1))
- Gear_position_Set = 2;
- if((GET_BIT(data,1) == 1))
- Gear_position_Set = 3;
- if((GET_BIT(data,0) == 1))
- Gear_position_Set = 4;
-
- }
- else
- {
- if((GET_BIT(data,4) == 1))
- Gear_position_Set = 1;
- if((GET_BIT(data,5) == 1))
- Gear_position_Set = 2;
- if((GET_BIT(data,6) == 1))
- Gear_position_Set = 3;
- if((GET_BIT(data,7) == 1))
- Gear_position_Set = 4;
- }
- }
- void CCanBusSensor::Notify(struct can_frame *date)
- {
-
-
-
- if(_run)
- {
-
- switch (date->can_id)
- {
- case 0x8CFF2303:
- GetGearCurrent(date->data[0]);
- _message->_Feeddata.gearbox_oil_temp = (int32_t)(date->data[4] - 50);
-
- break;
- case 0x98FEEE00:
- _message->_Feeddata.cold_water = (int32_t)(date->data[0] -40);
-
- break;
- case 0x98FEEF00:
- _message->_Feeddata.engine_pressure = (int32_t)(date->data[3] * 4);
-
- break;
- case 0x8CF00400:
- _message->_Feeddata.engine_rpm = make_int16(date->data[4],date->data[3]) / 8 ;
-
- count++;
- if( _message->btimeStopedCar && _message->_Feeddata.engine_rpm > 700)
- printf("----%d-----\r\n",count);
-
- break;
- case 0x98FEE500:
- {
- int16_t dh = make_int16(date->data[3],date->data[2]);
- int16_t dl = make_int16(date->data[1],date->data[0]);
- int32_t ddd = (((dh & 0x0000ffff) << 16) | (dl & 0x0000ffff));
-
- _message->_Feeddata.engine_time = ddd / 20;
-
- }
- break;
- case 0x180 + 0x71:
- _message->_Feeddata.brake_pressure = make_int16(date->data[5],date->data[4]);
-
- break;
- case 0x180 + 0x74:
- _message->_Feeddata.gearbox_oil_pressure = (int32_t)(date->data[2]);
-
- break;
- case 0x180 + 0x76:
- memcpy(_message->_Feeddata.Error_Buff,date->data,date->can_dlc);
-
- _message->SendVehicleStatue();
- break;
- case 0x280 + 0x72:
- _message->_Feeddata.fuel_level = make_int16(date->data[1],date->data[0]);
-
- break;
- case 0x380 + 0x72:
- _message->_Feeddata.lock_switch_l = ((date->data[3] & 0x02) == 0x02) ? 1 : 0;
- _message->_Feeddata.lock_switch_r = ((date->data[3] & 0x04) == 0x04) ? 1 : 0;
- _message->_Feeddata.tip_limit = ((date->data[2] & 0x20) == 0x20) ? 1 : 0;
-
- break;
- case 0x480 + 0x72:
- _message->_Feeddata.parking = ((date->data[0] & 0x02) == 0x02) ? 1 : 0;
- _message->_Feeddata.outgrigger_l = ((date->data[0] & 0x04) == 0x04) ? 1 : 0;
- _message->_Feeddata.outgrigger_r = ((date->data[0] & 0x08) == 0x08) ? 1 : 0;
- _message->_Feeddata.tip_pressure = ((date->data[0] & 0x20) == 0x20) ? 1 : 0;
-
- _message->_Feeddata.turn_left = ((date->data[4] & 0x01) == 0x01) ? 1 : 0;
- _message->_Feeddata.turn_right = ((date->data[4] & 0x02) == 0x02) ? 1 : 0;
-
-
- _message->_Feeddata.low_beam = ((date->data[4] & 0x08) == 0x08) ? 1 : 0;
- _message->_Feeddata.hight_beam = ((date->data[4] & 0x04) == 0x04) ? 1 : 0;
- _message->_Feeddata.front_work_lamp = ((date->data[4] & 0x10) == 0x10) ? 1 : 0;
- _message->_Feeddata.rear_work_lamp = ((date->data[4] & 0x20) == 0x20) ? 1 : 0;
- _message->_Feeddata.brake = ((date->data[6] & 0x01) == 0x01) ? 1 : 0;
- _message->_Feeddata.back_car = ((date->data[6] & 0x02) == 0x02) ? 1 : 0;
- _message->_Feeddata.left_lock = ((date->data[7] & 0x01) == 0x01) ? 1 : 0;
- _message->_Feeddata.right_lock = ((date->data[7] & 0x02) == 0x02) ? 1 : 0;
-
-
-
- break;
- case 0x480 + 0x74:
- _message->_Feeddata.system_vol = make_int16(date->data[1],date->data[0]);
- _message->_Feeddata.cargo_weight = make_int16(date->data[3],date->data[2]);
- break;
-
-
- default:
- break;
- }
- }
- }
- void CCanBusSensor::OnMessage(cannet_busframe* frames, int32_t count)
- {
-
- _last_can_uptime = std::chrono::duration_cast<std::chrono::milliseconds>(std::chrono::system_clock::now().time_since_epoch()).count();
-
- for (int32_t i = 0; i < count; i++)
- {
- cannet_busframe& frame = frames[i];
- int32_t canid = frame.canid;
-
-
- switch (canid)
- {
- case 0x181:
- Sendframe[0].can_id = 0x186;
- Sendframe[0].can_dlc = frame.dlc;
-
-
- _front_view = (frame.data[1] & 0x01) == 0x01 ? false: true;
-
- _message->SwitchCamera(_front_view);
- memcpy(Sendframe[0].data, frame.data, frame.dlc);
-
- break;
- case 0x281:
- Sendframe[1].can_id = 0x286;
- Sendframe[1].can_dlc = frame.dlc;
-
- halfautomatic = (frame.data[1] & 0x20) == 0x20 ? false: true;
- if((frame.data[1] & 0x0f) != 0)
- {
- if(halfautomatic)
- {
- Sendframe[1].data[0] = 0x00;
- Gear_position_Set = 1;
- }
- else
- Sendframe[1].data[0] = 0x10;
-
- }
- else
- {
- if((frame.data[0] & 0x0f) != 0)
- {
-
- SetGear_FR_Current(frame.data[0],0);
- if(Gear_position_now != Gear_position_Set)
- {
- if(Gear_position_now < Gear_position_Set)
- {
- if(halfautomatic)
- Sendframe[1].data[0] = 0x05;
- else
- Sendframe[1].data[0] = 0x15;
- }
- else
- {
- if(halfautomatic)
- Sendframe[1].data[0] = 0x09;
- else
- Sendframe[1].data[0] = 0x19;
- }
- }
- else
- {
- if(halfautomatic)
- Sendframe[1].data[0] = 0x01;
- else
- Sendframe[1].data[0] = 0x11;
- }
- }
- if(((frame.data[0] & 0xf0) >> 4) != 0)
- {
- SetGear_FR_Current(frame.data[0],1);
- if(Gear_position_now != Gear_position_Set)
- {
- if(Gear_position_now < Gear_position_Set)
- {
- if(halfautomatic)
- Sendframe[1].data[0] = 0x06;
- else
- Sendframe[1].data[0] = 0x16;
- }
- else
- {
- if(halfautomatic)
- Sendframe[1].data[0] = 0x0A;
- else
- Sendframe[1].data[0] = 0x1A;
- }
- }
- else
- {
- if(halfautomatic)
- Sendframe[1].data[0] = 0x02;
- else
- Sendframe[1].data[0] = 0x12;
- }
- }
- }
-
- if(((unsigned char)frame.data[7] == (unsigned char)0xff) && !_message->btimeStopedCar)
- {
- Emergency();
- std::cout<< "现在是急停"<<((unsigned char)frame.data[7] == (unsigned char)0xff)<<std::endl;
- }
- else if((frame.data[7] == 0x00) && _message->btimeStopedCar)
- {
- NoEmergency();
- std::cout<< "没有急停"<<((frame.data[7] == 0x00))<<std::endl;
- }
-
-
-
- if(!_message->btimeStopedCar)
- {
- memcpy(Sendframe[1].data + 1, frame.data + 1, frame.dlc - 1);
- }
- else
- {
-
- }
-
- break;
- case 0x381:
- Sendframe[2].can_id = 0x386;
- Sendframe[2].can_dlc = frame.dlc;
- memcpy(Sendframe[2].data, frame.data, frame.dlc);
-
- break;
- case 0x481:
-
- Sendframe[3].can_id = 0x486;
- Sendframe[3].can_dlc = frame.dlc;
- memcpy(Sendframe[3].data, frame.data, frame.dlc);
-
- break;
- case 0x1A0:
-
-
-
- _message->Senddirection(make_int16(frame.data[2],frame.data[3]));
-
- break;
- }
- }
- }
- void CCanBusSensor::SendStatusToMSG()
- {
- RemoNet::State req;
-
- req.set_work_pressure(_message->_Feeddata.work_pressure);
- req.set_brake_pressure(_message->_Feeddata.brake_pressure);
- req.set_gearbox_oil_temp(_message->_Feeddata.gearbox_oil_temp);
- req.set_gearbox_oil_pressure(_message->_Feeddata.gearbox_oil_pressure);
- req.set_engine_rpm(_message->_Feeddata.engine_rpm);
- req.set_speed(_message->_Feeddata.speed);
- req.set_gear(_message->_Feeddata.gear);
- req.set_engine_pressure(_message->_Feeddata.engine_pressure);
- req.set_cold_water(_message->_Feeddata.cold_water);
- req.set_steer_angle(_message->_Feeddata.steer_angle);
- req.set_left_lock(_message->_Feeddata.left_lock);
- req.set_right_lock(_message->_Feeddata.right_lock);
- req.set_engine_time(_message->_Feeddata.engine_time);
- req.set_wire_sensor_l(_message->_Feeddata.wire_sensor_l);
- req.set_wire_sensor_r(_message->_Feeddata.wire_sensor_r);
- req.set_fuel_level(_message->_Feeddata.fuel_level);
- req.set_lock_switch_l(_message->_Feeddata.lock_switch_l);
- req.set_lock_switch_r(_message->_Feeddata.lock_switch_r);
- req.set_tip_limit(_message->_Feeddata.tip_limit);
- req.set_turn_left(_message->_Feeddata.turn_left);
- req.set_turn_right(_message->_Feeddata.turn_right);
- req.set_hight_beam(_message->_Feeddata.hight_beam);
- req.set_low_beam(_message->_Feeddata.low_beam);
- req.set_parking(_message->_Feeddata.parking);
- req.set_brake(_message->_Feeddata.brake);
- req.set_back_car(_message->_Feeddata.back_car);
- req.set_front_work_lamp(_message->_Feeddata.front_work_lamp);
- req.set_rear_work_lamp(_message->_Feeddata.rear_work_lamp);
- req.set_cargo_weight(_message->_Feeddata.cargo_weight);
- req.set_system_vol(_message->_Feeddata.system_vol);
- req.set_error_buff((char *)_message->_Feeddata.Error_Buff,8);
- req.set_f_gear(_message->_Feeddata.f_gear);
- req.set_gear_1(_message->_Feeddata.gear_1);
- req.set_outgrigger_l(_message->_Feeddata.outgrigger_l);
- req.set_outgrigger_r(_message->_Feeddata.outgrigger_r);
- req.set_tip_pressure(_message->_Feeddata.tip_pressure);
-
- MessageHead Head;
- CIOBuffer pBuffer;
- Head.Command = RemoNet::CC_STATE;
- Head.Length = req.ByteSizeLong();
- Head.Serialize(pBuffer.Buffer);
- auto ptr = pBuffer.Buffer + MessageHead::Size();
- req.SerializeToArray(ptr, Head.Length);
- pBuffer.Length = MessageHead::Size() + Head.Length;
- _message->WritePacket(ChannelType::CHANNEL_CAR, pBuffer);
- }
- void CCanBusSensor::Emergency()
- {
-
-
- _message->btimeStopedCar = true;
-
- _message->SendEmergency();
- }
- void CCanBusSensor::NoEmergency()
- {
-
-
- _message->btimeStopedCar = false;
- _message->SendNoEmergency();
- }
|