123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488 |
- #include <control/control_status.h>
- #include <QDebug>
- //#if 1
- void iv::control::ControlStatus::set_cmd_checksum(unsigned char cmd_id)
- {
- unsigned int check_sum=0;
- if(cmd_id==0x10)
- {
- for(int i=0;i<7;i++)
- {
- check_sum^=(ServiceControlStatus.command10.byte[i]);
- }
- ServiceControlStatus.command10.byte[7]=check_sum;
- }else if(cmd_id==0x11)
- {
- for(int i=0;i<7;i++)
- {
- check_sum^=(ServiceControlStatus.command11.byte[i]);
- }
- ServiceControlStatus.command11.byte[7]=check_sum;
- }else if(cmd_id==0x12)
- {
- for(int i=0;i<7;i++)
- {
- check_sum^=(ServiceControlStatus.command12.byte[i]);
- }
- ServiceControlStatus.command12.byte[7]=check_sum;
- }
- }
- void iv::control::ControlStatus::set_wheel_angle(float angle)
- {
- int ang =(angle+870)*10;
- ServiceControlStatus.command12.bit.ang_H = (ang) /256;
- ServiceControlStatus.command12.bit.ang_L = (ang) % 256;
- }
- void iv::control::ControlStatus::set_wheel_speed(float speed)
- {
- int angSpeed =speed;
- ServiceControlStatus.command12.bit.ang_speed = angSpeed;
- }
- void iv::control::ControlStatus::set_wheel_enable(bool enable)
- {
- if(enable){
- ServiceControlStatus.command12.bit.ang_enable = 1;
- }else{
- ServiceControlStatus.command12.bit.ang_enable = 0;
- }
- }
- void iv::control::ControlStatus::set_speed_limit(float speed)
- {
- ServiceControlStatus.command11.bit.speed_limit = (unsigned)speed;
- }
- void iv::control::ControlStatus::set_aeb(float aeb)
- {
- int aebBrake =(aeb+16)/0.000488;
- ServiceControlStatus.command11.bit.aeb_H = (aebBrake) /256;
- ServiceControlStatus.command11.bit.aeb_L = (aebBrake) % 256;
- }
- void iv::control::ControlStatus::set_torque(float troque)
- {
- command11.bit.torque=(unsigned)(troque*2.5);
- }
- void iv::control::ControlStatus::set_brake(float brake)
- {
- command11.bit.brake=(unsigned)brake;
- }
- void iv::control::ControlStatus::set_gear(int gear)
- {
- command11.bit.gear = (unsigned)gear;
- }
- void iv::control::ControlStatus::set_handBrake(bool handbrake)
- {
- if(handbrake){
- command11.bit.park = 2;
- }else{
- command11.bit.park = 1;
- }
- }
- void iv::control::ControlStatus::set_driveMode(char driveMode)
- {
- command11.bit.driveMode = (unsigned)driveMode;
- }
- void iv::control::ControlStatus::set_gear_enable(bool enable){
- if (enable == true)
- command11.bit.gear_enable = 1;
- else
- command11.bit.gear_enable = 0;
- }
- void iv::control::ControlStatus::set_acc_enable(bool enable){
- if (enable == true)
- command11.bit.acc_enable = 1;
- else
- command11.bit.acc_enable = 0;
- }
- void iv::control::ControlStatus::set_aeb_enable(bool enable){
- if (enable == true)
- command11.bit.aeb_enable = 1;
- else
- command11.bit.aeb_enable = 0;
- }
- //void iv::control::ControlStatus::set_win_lf(char para)
- //{
- // command10.bit.windowlf = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_win_rf(char para)
- //{
- // command10.bit.windowrf = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_win_lr(char para)
- //{
- // command10.bit.windowlr = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_win_rr(char para)
- //{
- // command10.bit.windowrr = (unsigned)para;
- //}
- //空调控制
- void iv::control::ControlStatus::set_air_on(char para)
- {
- command10.bit.air_on = (unsigned)para;
- }
- //void iv::control::ControlStatus::set_air_cricle(char para)
- //{
- // command10.bit.air_cricle = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_air_auto(char para)
- //{
- // command10.bit.air_auto = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_air_off(char para)
- //{
- // command10.bit.air_off = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_air_temup(char para)
- //{
- // command10.bit.tem_up = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_air_temdown(char para)
- //{
- // command10.bit.tem_down = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_air_powerup(char para)
- //{
- // command10.bit.power_up = (unsigned)para;
- //}
- //void iv::control::ControlStatus::set_air_powerdown(char para)
- //{
- // command10.bit.power_down = (unsigned)para;
- //}
- void iv::control::ControlStatus::set_obligate(char para)
- {
- command10.bit.ignition = (unsigned)para;
- }
- void iv::control::ControlStatus::set_door(char enable)
- {
- command10.bit.door = (unsigned)enable;
- }
- void iv::control::ControlStatus::set_turnsignals_control(bool left, bool right)
- {
- if ( (left == true) && (right == false) )
- {
- command10.bit.turn_light = 0x01;
- }
- else if ( (left == false) && (right == true) )
- {
- command10.bit.turn_light = 0x02;
- }
- else if ((left == false) && (right == false))
- {
- command10.bit.turn_light = 0x00;
- }
- else
- {
- command10.bit.turn_light = 0x03;
- }
- }
- void iv::control::ControlStatus::set_small_light(char para)
- {
- command10.bit.small_light = (unsigned)para;
- }
- void iv::control::ControlStatus::set_near_light(char para)
- {
- command10.bit.near_light = (unsigned)para;
- }
- void iv::control::ControlStatus::set_horn(char para)
- {
- command10.bit.horn = (unsigned)para;
- }
- void iv::control::ControlStatus::set_far_light(char para)
- {
- command10.bit.far_light = (unsigned)para;
- }
- void iv::control::ControlStatus::set_frog_light(char para)
- {
- command10.bit.fog_light = (unsigned)para;
- }
- void iv::control::ControlStatus::set_wiper(char para)
- {
- command10.bit.wiper = (unsigned)para;
- }
- void iv::control::ControlStatus::set_brake_light(char para)
- {
- command10.bit.brake_light = (unsigned)para;
- }
- void iv::control::ControlStatus::set_defrog(char para)
- {
- command10.bit.defrog = (unsigned)para;
- }
- void iv::control::ControlStatus::set_reverse_light(char para)
- {
- command10.bit.revers_light = (unsigned)para;
- }
- void set_air_temp(char para);
- void set_air_mode(char para);
- void set_air_enable(bool enable);
- void set_wind_level(char para);
- void set_roof_light(char para);
- void set_home_light(char para);
- void set_air_worktime(char para);
- void set_air_offtime(char para);
- void iv::control::ControlStatus::set_air_temp(char para)
- {
- command10.bit.air_temp = (unsigned)para+40;
- }
- void iv::control::ControlStatus::set_air_mode(char para)
- {
- command10.bit.air_mode = (unsigned)para;
- }
- void iv::control::ControlStatus::set_air_enable(bool enable)
- {
- if(enable){
- command10.bit.air_enable = 0x01;
- }else{
- command10.bit.air_enable = 0x00;
- }
- }
- void iv::control::ControlStatus::set_wind_level(char para)
- {
- command10.bit.air_wind_level = (unsigned)para;
- }
- void iv::control::ControlStatus::set_roof_light(char para)
- {
- command10.bit.roof_light = (unsigned)para;
- }
- void iv::control::ControlStatus::set_home_light(char para)
- {
- command10.bit.home_light = (unsigned)para;
- }
- void iv::control::ControlStatus::set_air_worktime(char para)
- {
- command10.bit.air_work_time = (unsigned)para;
- }
- void iv::control::ControlStatus::set_air_offtime(char para)
- {
- command10.bit.air_off_time = (unsigned)para;
- }
- //void iv::control::ControlStatus::set_speaker(bool enable){
- // if (enable == true)
- // command.bit.speaker = 1;
- // else
- // command.bit.speaker = 0;
- //}
- //void iv::control::ControlStatus::set_door(char enable){
- // if (enable == true)
- // command.bit.door = 1;
- // else
- // command.bit.door = 0;
- //}
- //void iv::control::ControlStatus::set_doorEnable(bool enable){
- // if (enable == true){
- // command.bit.doorEnable = 1;
- // command.bit.door=1;
- // }
- // else{
- // command.bit.doorEnable = 0;
- // command.bit.door=0;
- // }
- //}
- ////void iv::control::ControlStatus::set_flicker(bool enable){
- //// if (enable == true)
- //// command.bit.flicker = 1;
- //// else
- //// command.bit.flicker = 0;
- ////}
- //void iv::control::ControlStatus::set_light(bool enable){
- // if (enable == true)
- // command.bit.bright = 1;
- // else
- // command.bit.bright = 0;
- //}
- //void iv::control::ControlStatus::set_leftlight(bool enable){
- // if (enable == true)
- // command.bit.left_turn = 1;
- // else
- // command.bit.left_turn = 0;
- //}
- //void iv::control::ControlStatus::set_rightlight(bool enable){
- // if (enable == true)
- // command.bit.right_turn = 1;
- // else
- // command.bit.right_turn = 0;
- //}
- //void iv::control::ControlStatus::set_turnsignals_control(bool left, bool right){
- // if (left == true)
- // {
- // command.bit.left_turn = 1;
- // command.bit.right_turn = 0;
- // }
- // else if (right == true)
- // {
- // command.bit.left_turn = 0;
- // command.bit.right_turn = 1;
- // }
- // else
- // {
- // command.bit.left_turn = 0;
- // command.bit.right_turn = 0;
- // }
- //}
- //#else
- //void iv::control::ControlStatus::set_accelerate(float percent)
- //{
- // command.bit.acce = (unsigned)((percent + 7) * 20);
- //}
- //void iv::control::ControlStatus::set_wheel_angle(float angle)
- //{
- // command.bit.ang_H = angle * 10 >> 8;
- // command.bit.ang_L = angle * 10 % 256;
- //}
- //void iv::control::ControlStatus::set_engine(char enable)
- //{
- // command.bit.engine = enable;
- //}
- //void iv::control::ControlStatus::set_door(char enable){
- // command.bit.door = enable;
- //}
- //void iv::control::ControlStatus::set_speaker(bool enable){
- // if (enable == true)
- // command.bit.speaker = 1;
- // else
- // command.bit.speaker = 0;
- //}
- //void iv::control::ControlStatus::set_flicker(bool enable){
- // if (enable == true)
- // command.bit.flicker = 1;
- // else
- // command.bit.flicker = 0;
- //}
- //void iv::control::ControlStatus::set_light(bool enable){
- // if (enable == true)
- // command.bit.bright = 1;
- // else
- // command.bit.bright = 0;
- //}
- //void iv::control::ControlStatus::set_turnsignals_control(bool left, bool right){
- // if (left == true)
- // {
- // command.bit.left_turn = 1;
- // command.bit.right_turn = 0;
- // }
- // else if (right == true)
- // {
- // command.bit.left_turn = 0;
- // command.bit.right_turn = 1;
- // }
- // else
- // {
- // command.bit.left_turn = 0;
- // command.bit.right_turn = 0;
- // }
- //}
- //#endif
|