日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

pixhawk commander.cpp的飞行模式切换解读

發布時間:2024/4/18 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 pixhawk commander.cpp的飞行模式切换解读 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

commander.cpp邏輯性太強了,涉及整個系統的運作,所以分別拆分成小塊看

另此篇blog大部分是參考(Pixhawk原生固件解讀)飛行模式,控制模式的思路,筆者重新整理一下

此部分探究是因為進入不了光流定點模式,于是查看commander.cpp飛行模式切換部分

流程是:

(1)sensors.cpp發布ORB_ID(manual_control_setpoint)

(2)commander.cpp里set_main_state_rc()函數里的main_state_transition()函數根據遙控信息和飛行器狀態status_flags決定是否能更變internal_state->main_state

(3)commander.cpp里set_nav_state()函數根據internal_state->main_state和飛行器狀態status_flags(傳感器等硬件正常否)確定能否完成internal_state->main_state所指定的模式,若飛行器狀態不行,則將模式跟新為status->nav_state

(4)commander.cpp里set_control_mode()函數根據status.nav_state確定control_mode.flag_xxx


1.?遙控器端

Firmware/src/modules/sensors/sensors.cpp發布ORB_ID(manual_control_setpoint)

[cpp] view plaincopy
  • /*?only?publish?manual?control?if?the?signal?is?still?present?*/??
  • if?(!signal_lost)?{??
  • ??
  • ????/*?initialize?manual?setpoint?*/??
  • ????struct?manual_control_setpoint_s?manual?=?{};??
  • ????/*?set?mode?slot?to?unassigned?*/??
  • ????manual.mode_slot?=?manual_control_setpoint_s::MODE_SLOT_NONE;??
  • ????/*?set?the?timestamp?to?the?last?signal?time?*/??
  • ????manual.timestamp?=?rc_input.timestamp_last_signal;??
  • ??
  • ????/*?limit?controls?*/??
  • ????manual.y?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_ROLL,?-1.0,?1.0);??
  • ????manual.x?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_PITCH,?-1.0,?1.0);??
  • ????manual.r?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_YAW,?-1.0,?1.0);??
  • ????manual.z?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_THROTTLE,?0.0,?1.0);??
  • ????manual.flaps?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_FLAPS,?-1.0,?1.0);??
  • ????manual.aux1?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_AUX_1,?-1.0,?1.0);??
  • ????manual.aux2?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_AUX_2,?-1.0,?1.0);??
  • ????manual.aux3?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_AUX_3,?-1.0,?1.0);??
  • ????manual.aux4?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_AUX_4,?-1.0,?1.0);??
  • ????manual.aux5?=?get_rc_value(rc_channels_s::RC_CHANNELS_FUNCTION_AUX_5,?-1.0,?1.0);??
  • ??
  • ????if?(_parameters.rc_map_flightmode?>?0)?{??
  • ??
  • ????????/*?the?number?of?valid?slots?equals?the?index?of?the?max?marker?minus?one?*/??
  • ????????const?int?num_slots?=?manual_control_setpoint_s::MODE_SLOT_MAX;??
  • ??
  • ????????/*?the?half?width?of?the?range?of?a?slot?is?the?total?range?
  • ?????????*?divided?by?the?number?of?slots,?again?divided?by?two?
  • ?????????*/??
  • ????????const?float?slot_width_half?=?2.0f?/?num_slots?/?2.0f;??
  • ??
  • ????????/*?min?is?-1,?max?is?+1,?range?is?2.?We?offset?below?min?and?max?*/??
  • ????????const?float?slot_min?=?-1.0f?-?0.05f;??
  • ????????const?float?slot_max?=?1.0f?+?0.05f;??
  • ??
  • ????????/*?the?slot?gets?mapped?by?first?normalizing?into?a?0..1?interval?using?min?
  • ?????????*?and?max.?Then?the?right?slot?is?obtained?by?multiplying?with?the?number?of?
  • ?????????*?slots.?And?finally?we?add?half?a?slot?width?to?ensure?that?integer?rounding?
  • ?????????*?will?take?us?to?the?correct?final?index.?
  • ?????????*/??
  • ????????manual.mode_slot?=?(((((_rc.channels[_parameters.rc_map_flightmode?-?1]?-?slot_min)?*?num_slots)?+?slot_width_half)?/??
  • ?????????????????????(slot_max?-?slot_min))?+?(1.0f?/?num_slots));??
  • ??
  • ????????if?(manual.mode_slot?>=?num_slots)?{??
  • ????????????manual.mode_slot?=?num_slots?-?1;??
  • ????????}??
  • ????}??
  • ??
  • ????/*?mode?switches?*/??
  • ????manual.mode_switch?=?get_rc_sw3pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_MODE,?_parameters.rc_auto_th,??
  • ?????????????????_parameters.rc_auto_inv,?_parameters.rc_assist_th,?_parameters.rc_assist_inv);??
  • ????manual.rattitude_switch?=?get_rc_sw2pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_RATTITUDE,??
  • ??????????????????_parameters.rc_rattitude_th,??
  • ??????????????????_parameters.rc_rattitude_inv);??
  • ????manual.posctl_switch?=?get_rc_sw2pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_POSCTL,?_parameters.rc_posctl_th,??
  • ???????????????????_parameters.rc_posctl_inv);??
  • ????manual.return_switch?=?get_rc_sw2pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_RETURN,?_parameters.rc_return_th,??
  • ???????????????????_parameters.rc_return_inv);??
  • ????manual.loiter_switch?=?get_rc_sw2pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_LOITER,?_parameters.rc_loiter_th,??
  • ???????????????????_parameters.rc_loiter_inv);??
  • ????manual.acro_switch?=?get_rc_sw2pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_ACRO,?_parameters.rc_acro_th,??
  • ?????????????????_parameters.rc_acro_inv);??
  • ????manual.offboard_switch?=?get_rc_sw2pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_OFFBOARD,??
  • ?????????????????_parameters.rc_offboard_th,?_parameters.rc_offboard_inv);??
  • ????manual.kill_switch?=?get_rc_sw2pos_position(rc_channels_s::RC_CHANNELS_FUNCTION_KILLSWITCH,??
  • ?????????????????_parameters.rc_killswitch_th,?_parameters.rc_killswitch_inv);??
  • ??
  • ????/*?publish?manual_control_setpoint?topic?*/??
  • ????if?(_manual_control_pub?!=?nullptr)?{??
  • ????????orb_publish(ORB_ID(manual_control_setpoint),?_manual_control_pub,?&manual);??
  • ??
  • ????}?else?{??
  • ????????_manual_control_pub?=?orb_advertise(ORB_ID(manual_control_setpoint),?&manual);??
  • ????}??
  • commander的主程序中

    [cpp] view plaincopy
  • /*?RC?input?check?*/??
  • if?(!status_flags.rc_input_blocked?&&?sp_man.timestamp?!=?0?&&??
  • ????(hrt_absolute_time()?<?sp_man.timestamp?+?(uint64_t)(rc_loss_timeout?*?1e6f)))?{??
  • ????/*?handle?the?case?where?RC?signal?was?regained?*/??
  • ????/*?處理信號失而復得的情況?*/??
  • ????if?(!status_flags.rc_signal_found_once)?{??
  • ????????status_flags.rc_signal_found_once?=?true;??
  • ????????status_changed?=?true;??
  • ??
  • ????}?else?{??
  • ????????if?(status.rc_signal_lost)?{??
  • ????????????mavlink_log_info(&mavlink_log_pub,?"MANUAL?CONTROL?REGAINED?after?%llums",??
  • ?????????????????????????(hrt_absolute_time()?-?rc_signal_lost_timestamp)?/?1000);??
  • ????????????status_changed?=?true;??
  • ????????}??
  • ????}??
  • ??
  • ????status.rc_signal_lost?=?false;??
  • ??
  • ????/*?check?if?left?stick?is?in?lower?left?position?and?we?are?in?MANUAL,?Rattitude,?or?AUTO_READY?mode?or?(ASSIST?mode?and?landed)?->?disarm?
  • ?????*?do?it?only?for?rotary?wings?in?manual?mode?or?fixed?wing?if?landed?*/??
  • ????/*?檢查油門桿在左下角的位置&&在手動&&(Rattitude||AUTO_READY?mode||ASSIST?mode?and?landed,如果是,則上鎖?
  • ????if?((status.is_rotary_wing?||?(!status.is_rotary_wing?&&?land_detector.landed))?&&?status.rc_input_mode?!=?vehicle_status_s::RC_IN_MODE_OFF?&&?
  • ????????(status.arming_state?==?vehicle_status_s::ARMING_STATE_ARMED?||?status.arming_state?==?vehicle_status_s::ARMING_STATE_ARMED_ERROR)?&&?
  • ????????(internal_state.main_state?==?commander_state_s::MAIN_STATE_MANUAL?||?
  • ????????????internal_state.main_state?==?commander_state_s::MAIN_STATE_ACRO?||?
  • ????????????internal_state.main_state?==?commander_state_s::MAIN_STATE_STAB?||?
  • ????????????internal_state.main_state?==?commander_state_s::MAIN_STATE_RATTITUDE?||?
  • ????????????land_detector.landed)?&&?
  • ????????sp_man.r?<?-STICK_ON_OFF_LIMIT?&&?sp_man.z?<?0.1f)?{?
  • ?
  • ????????if?(stick_off_counter?>?rc_arm_hyst)?{?
  • ????????????/*?disarm?to?STANDBY?if?ARMED?or?to?STANDBY_ERROR?if?ARMED_ERROR?*/??
  • ????????????arming_state_t?new_arming_state?=?(status.arming_state?==?vehicle_status_s::ARMING_STATE_ARMED???vehicle_status_s::ARMING_STATE_STANDBY?:??
  • ???????????????????????????????vehicle_status_s::ARMING_STATE_STANDBY_ERROR);??
  • ????????????arming_ret?=?arming_state_transition(&status,??
  • ?????????????????????????????????&battery,??
  • ?????????????????????????????????&safety,??
  • ?????????????????????????????????new_arming_state,??
  • ?????????????????????????????????&armed,??
  • ?????????????????????????????????true?/*?fRunPreArmChecks?*/,??
  • ?????????????????????????????????&mavlink_log_pub,??
  • ?????????????????????????????????&status_flags,??
  • ?????????????????????????????????avionics_power_rail_voltage);??
  • ??
  • ????????????if?(arming_ret?==?TRANSITION_CHANGED)?{??
  • ????????????????arming_state_changed?=?true;??
  • ????????????}??
  • ??
  • ????????????stick_off_counter?=?0;??
  • ??
  • ????????}?else?{??
  • ????????????stick_off_counter++;??
  • ????????}??
  • ??
  • ????}?else?{??
  • ????????stick_off_counter?=?0;??
  • ????}??
  • ??
  • ????/*?check?if?left?stick?is?in?lower?right?position?and?we're?in?MANUAL?mode?->?arm?*/??
  • ????/*?檢查油門桿在右下角的位置&&手動模式,如果是,則解鎖?*/??
  • ????if?(sp_man.r?>?STICK_ON_OFF_LIMIT?&&?sp_man.z?<?0.1f?&&?status.rc_input_mode?!=?vehicle_status_s::RC_IN_MODE_OFF?)?{??
  • ????????if?(stick_on_counter?>?rc_arm_hyst)?{??
  • ??
  • ????????????/*?we?check?outside?of?the?transition?function?here?because?the?requirement?
  • ?????????????*?for?being?in?manual?mode?only?applies?to?manual?arming?actions.?
  • ?????????????*?the?system?can?be?armed?in?auto?if?armed?via?the?GCS.?
  • ?????????????*/??
  • ??
  • ????????????if?((internal_state.main_state?!=?commander_state_s::MAIN_STATE_MANUAL)??
  • ????????????????&&?(internal_state.main_state?!=?commander_state_s::MAIN_STATE_ACRO)??
  • ????????????????&&?(internal_state.main_state?!=?commander_state_s::MAIN_STATE_STAB)??
  • ????????????????&&?(internal_state.main_state?!=?commander_state_s::MAIN_STATE_ALTCTL)??
  • ????????????????&&?(internal_state.main_state?!=?commander_state_s::MAIN_STATE_POSCTL)??
  • ????????????????&&?(internal_state.main_state?!=?commander_state_s::MAIN_STATE_RATTITUDE)??
  • ????????????????)?{??
  • ????????????????print_reject_arm("NOT?ARMING:?Switch?to?a?manual?mode?first.");??
  • ??
  • ????????????}?else?if?(!status_flags.condition_home_position_valid?&&??
  • ????????????????????????geofence_action?==?geofence_result_s::GF_ACTION_RTL)?{??
  • ????????????????print_reject_arm("NOT?ARMING:?Geofence?RTL?requires?valid?home");??
  • ??
  • ????????????}?else?if?(status.arming_state?==?vehicle_status_s::ARMING_STATE_STANDBY)?{??
  • ????????????????arming_ret?=?arming_state_transition(&status,??
  • ?????????????????????????????????????&battery,??
  • ?????????????????????????????????????&safety,??
  • ?????????????????????????????????????vehicle_status_s::ARMING_STATE_ARMED,??
  • ?????????????????????????????????????&armed,??
  • ?????????????????????????????????????true?/*?fRunPreArmChecks?*/,??
  • ?????????????????????????????????????&mavlink_log_pub,??
  • ?????????????????????????????????????&status_flags,??
  • ?????????????????????????????????????avionics_power_rail_voltage);??
  • ??
  • ????????????????if?(arming_ret?==?TRANSITION_CHANGED)?{??
  • ????????????????????arming_state_changed?=?true;??
  • ????????????????}?else?{??
  • ????????????????????usleep(100000);??
  • ????????????????????print_reject_arm("NOT?ARMING:?Preflight?checks?failed");??
  • ????????????????}??
  • ????????????}??
  • ????????????stick_on_counter?=?0;??
  • ??
  • ????????}?else?{??
  • ????????????stick_on_counter++;??
  • ????????}??
  • ??
  • ????}?else?{??
  • ????????stick_on_counter?=?0;??
  • ????}??
  • ??
  • ????if?(arming_ret?==?TRANSITION_CHANGED)?{??
  • ????????if?(status.arming_state?==?vehicle_status_s::ARMING_STATE_ARMED)?{??
  • ????????????mavlink_log_info(&mavlink_log_pub,?"ARMED?by?RC");??
  • ??
  • ????????}?else?{??
  • ????????????mavlink_log_info(&mavlink_log_pub,?"DISARMED?by?RC");??
  • ????????}??
  • ??
  • ????????arming_state_changed?=?true;??
  • ??
  • ????}?else?if?(arming_ret?==?TRANSITION_DENIED)?{??
  • ????????/*?
  • ?????????*?the?arming?transition?can?be?denied?to?a?number?of?reasons:?
  • ?????????*??-?pre-flight?check?failed?(sensors?not?ok?or?not?calibrated)?
  • ?????????*??-?safety?not?disabled?
  • ?????????*??-?system?not?in?manual?mode?
  • ?????????*/??
  • ????????tune_negative(true);??
  • ????}??
  • ??
  • ????/*?evaluate?the?main?state?machine?according?to?mode?switches?*/??
  • ????bool?first_rc_eval?=?(_last_sp_man.timestamp?==?0)?&&?(sp_man.timestamp?>?0);??
  • ????transition_result_t?main_res?=?set_main_state_rc(&status);??
  • ??
  • ????/*?play?tune?on?mode?change?only?if?armed,?blink?LED?always?*/??
  • ????if?(main_res?==?TRANSITION_CHANGED?||?first_rc_eval)?{??
  • ????????tune_positive(armed.armed);??
  • ????????main_state_changed?=?true;??
  • ??
  • ????}?else?if?(main_res?==?TRANSITION_DENIED)?{??
  • ????????/*?DENIED?here?indicates?bug?in?the?commander?*/??
  • ????????mavlink_log_critical(&mavlink_log_pub,?"main?state?transition?denied");??
  • ????}??
  • ??
  • ????/*?check?throttle?kill?switch?*/??
  • ????if?(sp_man.kill_switch?==?manual_control_setpoint_s::SWITCH_POS_ON)?{??
  • ????????/*?set?lockdown?flag?*/??
  • ????????/*?設置鎖定標志?*/??
  • ????????if?(!armed.lockdown)?{??
  • ????????????mavlink_log_emergency(&mavlink_log_pub,?"MANUAL?KILL?SWITCH?ENGAGED");??
  • ????????}??
  • ????????armed.lockdown?=?true;??
  • ????}?else?if?(sp_man.kill_switch?==?manual_control_setpoint_s::SWITCH_POS_OFF)?{??
  • ????????if?(armed.lockdown)?{??
  • ????????????mavlink_log_emergency(&mavlink_log_pub,?"MANUAL?KILL?SWITCH?OFF");??
  • ????????}??
  • ????????armed.lockdown?=?false;??
  • ????}??
  • ????/*?no?else?case:?do?not?change?lockdown?flag?in?unconfigured?case?*/??
  • ??
  • }?else?{??
  • ????if?(!status_flags.rc_input_blocked?&&?!status.rc_signal_lost)?{??
  • ????????mavlink_log_critical(&mavlink_log_pub,?"MANUAL?CONTROL?LOST?(at?t=%llums)",?hrt_absolute_time()?/?1000);??
  • ????????status.rc_signal_lost?=?true;??
  • ????????rc_signal_lost_timestamp?=?sp_man.timestamp;??
  • ????????status_changed?=?true;??
  • ????}??
  • }??
  • 2.set_main_state_rc();函數內

    2.1

    orb_check(sp_man_sub, &updated);

    if (updated) {

    ???????? orb_copy(ORB_ID(manual_control_setpoint),sp_man_sub, &sp_man);

    }

    sp_man.offboard_switch、sp_man.return_switch、sp_man.mode_slot、sp_man.mode_switch都會改變

    2.2

    [cpp] view plaincopy
  • int?new_mode?=_flight_mode_slots[sp_man.mode_slot];??
  • _flight_mode_slots的定義:

    [cpp] view plaincopy
  • static?int32_t_flight_mode_slots[manual_control_setpoint_s::MODE_SLOT_MAX];??
  • [cpp] view plaincopy
  • static?const?int8_t?MODE_SLOT_MAX?=?6;??
  • 也就是說_flight_mode_slots[]數組有6個元素,有6種模式可以選

    賦值語句:

    [cpp] view plaincopy
  • param_get(_param_fmode_1,&_flight_mode_slots[0]);??
  • param_get(_param_fmode_2,&_flight_mode_slots[1]);??
  • param_get(_param_fmode_3,&_flight_mode_slots[2]);??
  • param_get(_param_fmode_4,&_flight_mode_slots[3]);??
  • param_get(_param_fmode_5,&_flight_mode_slots[4]);??
  • param_get(_param_fmode_6,&_flight_mode_slots[5]);??
  • 來源是用戶上位機配置

    mode_slot的定義:

    int8_t mode_slot;

    mode_slot的賦值:

    以上都是遙控信息的來源(先上位機用戶定義哪個開關對應哪個模式,再直接切開關轉變到相應的模式)通過這段程序還沒看懂。

    2.3

    main_state_transition();根據遙控信息和飛行器狀態status_flags決定是否能更變internal_state->main_state

    [cpp] view plaincopy
  • transition_result_t??
  • main_state_transition(struct?vehicle_status_s?*status,?main_state_t?new_main_state,?uint8_t?&main_state_prev,??
  • ??????????????status_flags_s?*status_flags,?struct?commander_state_s?*internal_state)??
  • {??
  • ????transition_result_t?ret?=?TRANSITION_DENIED;??
  • ????/*?transition?may?be?denied?even?if?the?same?state?is?requested?because?conditions?may?have?changed?*/??
  • ????switch?(new_main_state)?{??
  • ????case?commander_state_s::MAIN_STATE_MANUAL:??
  • ????case?commander_state_s::MAIN_STATE_ACRO:??
  • ????case?commander_state_s::MAIN_STATE_RATTITUDE:??
  • ????case?commander_state_s::MAIN_STATE_STAB:??
  • ????????ret?=?TRANSITION_CHANGED;??
  • ????????break;??
  • ????case?commander_state_s::MAIN_STATE_ALTCTL:??
  • ????????/*?need?at?minimum?altitude?estimate?*/??
  • ????????/*?TODO:?add?this?for?fixedwing?as?well?*/??
  • ????????if?(!status->is_rotary_wing?||??
  • ????????????(status_flags->condition_local_altitude_valid?||??
  • ?????????????status_flags->condition_global_position_valid))?{??
  • ????????????ret?=?TRANSITION_CHANGED;??
  • ????????}??
  • ????????break;??
  • ????case?commander_state_s::MAIN_STATE_POSCTL:??
  • ????????/*?need?at?minimum?local?position?estimate?*/??
  • ????????if?(status_flags->condition_local_position_valid?||??
  • ????????????status_flags->condition_global_position_valid)?{??
  • ????????????ret?=?TRANSITION_CHANGED;??
  • ????????}??
  • ????????break;??
  • ????case?commander_state_s::MAIN_STATE_AUTO_LOITER:??
  • ????????/*?need?global?position?estimate?*/??
  • ????????if?(status_flags->condition_global_position_valid)?{??
  • ????????????ret?=?TRANSITION_CHANGED;??
  • ????????}??
  • ????????break;??
  • ????case?commander_state_s::MAIN_STATE_AUTO_FOLLOW_TARGET:??
  • ????case?commander_state_s::MAIN_STATE_AUTO_MISSION:??
  • ????case?commander_state_s::MAIN_STATE_AUTO_RTL:??
  • ????case?commander_state_s::MAIN_STATE_AUTO_TAKEOFF:??
  • ????case?commander_state_s::MAIN_STATE_AUTO_LAND:??
  • ????????/*?need?global?position?and?home?position?*/??
  • ????????if?(status_flags->condition_global_position_valid?&&?status_flags->condition_home_position_valid)?{??
  • ????????????ret?=?TRANSITION_CHANGED;??
  • ????????}??
  • ????????break;??
  • ????case?commander_state_s::MAIN_STATE_OFFBOARD:??
  • ????????/*?need?offboard?signal?*/??
  • ????????if?(!status_flags->offboard_control_signal_lost)?{??
  • ????????????ret?=?TRANSITION_CHANGED;??
  • ????????}??
  • ????????break;??
  • ????case?commander_state_s::MAIN_STATE_MAX:??
  • ????default:??
  • ????????break;??
  • ????}??
  • ????if?(ret?==?TRANSITION_CHANGED)?{??
  • ????????if?(internal_state->main_state?!=?new_main_state)?{??
  • ????????????main_state_prev?=?internal_state->main_state;??
  • ????????????internal_state->main_state?=?new_main_state;??
  • ????????}?else?{??
  • ????????????ret?=?TRANSITION_NOT_CHANGED;??
  • ????????}??
  • ????}??
  • ????return?ret;??
  • }??
  • [cpp] view plaincopy
  • transition_result_t??
  • set_main_state_rc(struct?vehicle_status_s?*status_local)??
  • {??
  • ????/*?set?main?state?according?to?RC?switches?*/??
  • ????transition_result_t?res?=?TRANSITION_DENIED;??
  • ??
  • ????//?XXX?this?should?not?be?necessary?any?more,?we?should?be?able?to??
  • ????//?just?delete?this?and?respond?to?mode?switches??
  • ????/*?if?offboard?is?set?already?by?a?mavlink?command,?abort?*/??
  • ????if?(status_flags.offboard_control_set_by_command)?{??
  • ????????return?main_state_transition(status_local,?commander_state_s::MAIN_STATE_OFFBOARD,?main_state_prev,?&status_flags,?&internal_state);??
  • ????}??
  • ??
  • ????/*?manual?setpoint?has?not?updated,?do?not?re-evaluate?it?*/??
  • ????if?(((_last_sp_man.timestamp?!=?0)?&&?(_last_sp_man.timestamp?==?sp_man.timestamp))?||??
  • ????????((_last_sp_man.offboard_switch?==?sp_man.offboard_switch)?&&??
  • ?????????(_last_sp_man.return_switch?==?sp_man.return_switch)?&&??
  • ?????????(_last_sp_man.mode_switch?==?sp_man.mode_switch)?&&??
  • ?????????(_last_sp_man.acro_switch?==?sp_man.acro_switch)?&&??
  • ?????????(_last_sp_man.rattitude_switch?==?sp_man.rattitude_switch)?&&??
  • ?????????(_last_sp_man.posctl_switch?==?sp_man.posctl_switch)?&&??
  • ?????????(_last_sp_man.loiter_switch?==?sp_man.loiter_switch)?&&??
  • ?????????(_last_sp_man.mode_slot?==?sp_man.mode_slot)))?{??
  • ??
  • ????????//?update?these?fields?for?the?geofence?system??
  • ??
  • ????????if?(!rtl_on)?{??
  • ????????????_last_sp_man.timestamp?=?sp_man.timestamp;??
  • ????????????_last_sp_man.x?=?sp_man.x;??
  • ????????????_last_sp_man.y?=?sp_man.y;??
  • ????????????_last_sp_man.z?=?sp_man.z;??
  • ????????????_last_sp_man.r?=?sp_man.r;??
  • ????????}??
  • ??
  • ????????/*?no?timestamp?change?or?no?switch?change?->?nothing?changed?*/??
  • ????????return?TRANSITION_NOT_CHANGED;??
  • ????}??
  • ??
  • ????_last_sp_man?=?sp_man;??
  • /***********************第一個判斷***********************/??
  • ????/*?offboard?switch?overrides?main?switch?*/??
  • ????if?(sp_man.offboard_switch?==?manual_control_setpoint_s::SWITCH_POS_ON)?{??
  • ????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_OFFBOARD,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????if?(res?==?TRANSITION_DENIED)?{??
  • ????????????print_reject_mode(status_local,?"OFFBOARD");??
  • ????????????/*?mode?rejected,?continue?to?evaluate?the?main?system?mode?*/??
  • ??
  • ????????}?else?{??
  • ????????????/*?changed?successfully?or?already?in?this?state?*/??
  • ????????????return?res;??
  • ????????}??
  • ????}??
  • /***********************第二個判斷***********************/??
  • ????/*?RTL?switch?overrides?main?switch?*/??
  • ????if?(sp_man.return_switch?==?manual_control_setpoint_s::SWITCH_POS_ON)?{??
  • ????????warnx("RTL?switch?changed?and?ON!");??
  • ????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_AUTO_RTL,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????if?(res?==?TRANSITION_DENIED)?{??
  • ????????????print_reject_mode(status_local,?"AUTO?RTL");??
  • ??
  • ????????????/*?fallback?to?LOITER?if?home?position?not?set?*/??
  • ????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_AUTO_LOITER,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????}??
  • ??
  • ????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????/*?changed?successfully?or?already?in?this?state?*/??
  • ????????????return?res;??
  • ????????}??
  • ??
  • ????????/*?if?we?get?here?mode?was?rejected,?continue?to?evaluate?the?main?system?mode?*/??
  • ????}??
  • /***********************第三個判斷***********************/??
  • ????/*?we?know?something?has?changed?-?check?if?we?are?in?mode?slot?operation?*/??
  • ????if?(sp_man.mode_slot?!=?manual_control_setpoint_s::MODE_SLOT_NONE)?{??
  • ??
  • ????????if?(sp_man.mode_slot?>=?sizeof(_flight_mode_slots)?/?sizeof(_flight_mode_slots[0]))?{??
  • ????????????warnx("m?slot?overflow");??
  • ????????????return?TRANSITION_DENIED;??
  • ????????}??
  • ??
  • ????????int?new_mode?=?_flight_mode_slots[sp_man.mode_slot];??
  • ??
  • ????????if?(new_mode?<?0)?{??
  • ????????????/*?slot?is?unused?*/??
  • ????????????res?=?TRANSITION_NOT_CHANGED;??
  • ??
  • ????????}?else?{??
  • ????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????/*?ensure?that?the?mode?selection?does?not?get?stuck?here?*/??
  • ????????????int?maxcount?=?5;??
  • ??
  • ????????????/*?enable?the?use?of?break?*/??
  • ????????????/*?fallback?strategies,?give?the?user?the?closest?mode?to?what?he?wanted?*/??
  • ????????????while?(res?==?TRANSITION_DENIED?&&?maxcount?>?0)?{??
  • ??
  • ????????????????maxcount--;??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_AUTO_MISSION)?{??
  • ??
  • ????????????????????/*?fall?back?to?loiter?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_AUTO_LOITER;??
  • ????????????????????print_reject_mode(status_local,?"AUTO?MISSION");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_AUTO_RTL)?{??
  • ??
  • ????????????????????/*?fall?back?to?position?control?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_AUTO_LOITER;??
  • ????????????????????print_reject_mode(status_local,?"AUTO?RTL");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_AUTO_LAND)?{??
  • ??
  • ????????????????????/*?fall?back?to?position?control?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_AUTO_LOITER;??
  • ????????????????????print_reject_mode(status_local,?"AUTO?LAND");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_AUTO_TAKEOFF)?{??
  • ??
  • ????????????????????/*?fall?back?to?position?control?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_AUTO_LOITER;??
  • ????????????????????print_reject_mode(status_local,?"AUTO?TAKEOFF");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_AUTO_FOLLOW_TARGET)?{??
  • ??
  • ????????????????????/*?fall?back?to?position?control?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_AUTO_LOITER;??
  • ????????????????????print_reject_mode(status_local,?"AUTO?FOLLOW");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_AUTO_LOITER)?{??
  • ??
  • ????????????????????/*?fall?back?to?position?control?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_POSCTL;??
  • ????????????????????print_reject_mode(status_local,?"AUTO?HOLD");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_POSCTL)?{??
  • ??
  • ????????????????????/*?fall?back?to?altitude?control?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_ALTCTL;??
  • ????????????????????print_reject_mode(status_local,?"POSITION?CONTROL");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_ALTCTL)?{??
  • ??
  • ????????????????????/*?fall?back?to?stabilized?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_STAB;??
  • ????????????????????print_reject_mode(status_local,?"ALTITUDE?CONTROL");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ??
  • ????????????????if?(new_mode?==?commander_state_s::MAIN_STATE_STAB)?{??
  • ??
  • ????????????????????/*?fall?back?to?manual?*/??
  • ????????????????????new_mode?=?commander_state_s::MAIN_STATE_MANUAL;??
  • ????????????????????print_reject_mode(status_local,?"STABILIZED");??
  • ????????????????????res?=?main_state_transition(status_local,?new_mode,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????????????break;??
  • ????????????????????}??
  • ????????????????}??
  • ????????????}??
  • ????????}??
  • ??
  • ????????return?res;??
  • ????}??
  • /***********************第四個判斷***********************/??
  • ????/*?offboard?and?RTL?switches?off?or?denied,?check?main?mode?switch?*/??
  • ????switch?(sp_man.mode_switch)?{??
  • ????case?manual_control_setpoint_s::SWITCH_POS_NONE:??
  • ????????res?=?TRANSITION_NOT_CHANGED;??
  • ????????break;??
  • ??
  • ????case?manual_control_setpoint_s::SWITCH_POS_OFF:?????//?MANUAL??
  • ????????if?(sp_man.acro_switch?==?manual_control_setpoint_s::SWITCH_POS_ON)?{??
  • ??
  • ????????????/*?manual?mode?is?stabilized?already?for?multirotors,?so?switch?to?acro?
  • ?????????????*?for?any?non-manual?mode?
  • ?????????????*/??
  • ????????????//?XXX:?put?ACRO?and?STAB?on?separate?switches??
  • ????????????if?(status.is_rotary_wing?&&?!status.is_vtol)?{??
  • ????????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_ACRO,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????????}?else?if?(!status.is_rotary_wing)?{??
  • ????????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_STAB,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????????}?else?{??
  • ????????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_MANUAL,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????????}??
  • ??
  • ????????}??
  • ????????else?if(sp_man.rattitude_switch?==?manual_control_setpoint_s::SWITCH_POS_ON){??
  • ????????????/*?Similar?to?acro?transitions?for?multirotors.??FW?aircraft?don't?need?a?
  • ?????????????*?rattitude?mode.*/??
  • ????????????if?(status.is_rotary_wing)?{??
  • ????????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_RATTITUDE,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????????}?else?{??
  • ????????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_STAB,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????????}??
  • ????????}else?{??
  • ????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_MANUAL,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????}??
  • ??
  • ????????//?TRANSITION_DENIED?is?not?possible?here??
  • ????????break;??
  • ??
  • ????case?manual_control_setpoint_s::SWITCH_POS_MIDDLE:??????//?ASSIST??
  • ????????if?(sp_man.posctl_switch?==?manual_control_setpoint_s::SWITCH_POS_ON)?{??
  • ????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_POSCTL,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????break;??//?changed?successfully?or?already?in?this?state??
  • ????????????}??
  • ??
  • ????????????print_reject_mode(status_local,?"POSITION?CONTROL");??
  • ????????}??
  • ??
  • ????????//?fallback?to?ALTCTL??
  • ????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_ALTCTL,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????break;??//?changed?successfully?or?already?in?this?mode??
  • ????????}??
  • ??
  • ????????if?(sp_man.posctl_switch?!=?manual_control_setpoint_s::SWITCH_POS_ON)?{??
  • ????????????print_reject_mode(status_local,?"ALTITUDE?CONTROL");??
  • ????????}??
  • ??
  • ????????//?fallback?to?MANUAL??
  • ????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_MANUAL,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????//?TRANSITION_DENIED?is?not?possible?here??
  • ????????break;??
  • ??
  • ????case?manual_control_setpoint_s::SWITCH_POS_ON:??????????//?AUTO??
  • ????????if?(sp_man.loiter_switch?==?manual_control_setpoint_s::SWITCH_POS_ON)?{??
  • ????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_AUTO_LOITER,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????break;??//?changed?successfully?or?already?in?this?state??
  • ????????????}??
  • ??
  • ????????????print_reject_mode(status_local,?"AUTO?PAUSE");??
  • ??
  • ????????}?else?{??
  • ????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_AUTO_MISSION,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????break;??//?changed?successfully?or?already?in?this?state??
  • ????????????}??
  • ??
  • ????????????print_reject_mode(status_local,?"AUTO?MISSION");??
  • ??
  • ????????????//?fallback?to?LOITER?if?home?position?not?set??
  • ????????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_AUTO_LOITER,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????????break;??//?changed?successfully?or?already?in?this?state??
  • ????????????}??
  • ????????}??
  • ??
  • ????????//?fallback?to?POSCTL??
  • ????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_POSCTL,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????break;??//?changed?successfully?or?already?in?this?state??
  • ????????}??
  • ??
  • ????????//?fallback?to?ALTCTL??
  • ????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_ALTCTL,?main_state_prev,?&status_flags,?&internal_state);??
  • ??
  • ????????if?(res?!=?TRANSITION_DENIED)?{??
  • ????????????break;??//?changed?successfully?or?already?in?this?state??
  • ????????}??
  • ??
  • ????????//?fallback?to?MANUAL??
  • ????????res?=?main_state_transition(status_local,?commander_state_s::MAIN_STATE_MANUAL,?main_state_prev,?&status_flags,?&internal_state);??
  • ????????//?TRANSITION_DENIED?is?not?possible?here??
  • ????????break;??
  • ??
  • ????default:??
  • ????????break;??
  • ????}??
  • ??
  • ????return?res;??
  • }??
  • 3.set_nav_state();根據internal_state->main_state和飛行器狀態status_flags(傳感器等硬件正常否)確定能否完成internal_state->main_state所指定的模式,若飛行器狀態不行,則將模式跟新為status->nav_state。

    internal_state->main_state包含下面14種:

    [cpp] view plaincopy
  • #define?MAIN_STATE_MANUAL?0??
  • #define?MAIN_STATE_ALTCTL?1??
  • #define?MAIN_STATE_POSCTL?2??
  • #define?MAIN_STATE_AUTO_MISSION?3??
  • #define?MAIN_STATE_AUTO_LOITER?4??
  • #define?MAIN_STATE_AUTO_RTL?5??
  • #define?MAIN_STATE_ACRO?6??
  • #define?MAIN_STATE_OFFBOARD?7??
  • #define?MAIN_STATE_STAB?8??
  • #define?MAIN_STATE_RATTITUDE?9??
  • #define?MAIN_STATE_AUTO_TAKEOFF?10??
  • #define?MAIN_STATE_AUTO_LAND?11??
  • #define?MAIN_STATE_AUTO_FOLLOW_TARGET?12??
  • #define?MAIN_STATE_MAX?13???
  • [cpp] view plaincopy
  • <pre?name="code"?class="cpp">command.cpp中main函數??
  • [cpp] view plaincopy
  • <pre?name="code"?class="cpp">/*?now?set?navigation?state?according?to?failsafe?and?main?state?*/??
  • bool?nav_state_changed?=?set_nav_state(&status,??
  • ???????????????????????&internal_state,??
  • ???????????????????????(datalink_loss_enabled?>?0),??
  • ???????????????????????mission_result.finished,??
  • ???????????????????????mission_result.stay_in_failsafe,??
  • ???????????????????????&status_flags,??
  • ???????????????????????land_detector.landed,??
  • ???????????????????????(rc_loss_enabled?>?0));??
  • [cpp] view plaincopy
  • /**?
  • ?*?Check?failsafe?and?main?status?and?set?navigation?status?for?navigator?accordingly?
  • ?*/??
  • bool?set_nav_state(struct?vehicle_status_s?*status,?struct?commander_state_s?*internal_state,??
  • ???????????const?bool?data_link_loss_enabled,?const?bool?mission_finished,??
  • ???????????const?bool?stay_in_failsafe,?status_flags_s?*status_flags,?bool?landed,?const?bool?rc_loss_enabled)??
  • {??
  • ????navigation_state_t?nav_state_old?=?status->nav_state;??
  • ??
  • ????bool?armed?=?(status->arming_state?==?vehicle_status_s::ARMING_STATE_ARMED?||?status->arming_state?==?vehicle_status_s::ARMING_STATE_ARMED_ERROR);??
  • ????status->failsafe?=?false;??
  • ??
  • ????/*?evaluate?main?state?to?decide?in?normal?(non-failsafe)?mode?*/??
  • ????switch?(internal_state->main_state)?{??
  • ????case?commander_state_s::MAIN_STATE_ACRO:??
  • ????case?commander_state_s::MAIN_STATE_MANUAL:??
  • ????case?commander_state_s::MAIN_STATE_RATTITUDE:??
  • ????case?commander_state_s::MAIN_STATE_STAB:??
  • ????case?commander_state_s::MAIN_STATE_ALTCTL:??
  • ????case?commander_state_s::MAIN_STATE_POSCTL:??
  • ????????/*?require?RC?for?all?manual?modes?*/??
  • ????????if?(rc_loss_enabled?&&?(status->rc_signal_lost?||?status_flags->rc_signal_lost_cmd)?&&?armed?&&?!landed)?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_global_position_valid?&&?status_flags->condition_home_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RCRECOVER;??
  • ????????????}?else?if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ??
  • ????????}?else?{??
  • ????????????switch?(internal_state->main_state)?{??
  • ????????????case?commander_state_s::MAIN_STATE_ACRO:??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_ACRO;??
  • ????????????????break;??
  • ??
  • ????????????case?commander_state_s::MAIN_STATE_MANUAL:??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_MANUAL;??
  • ????????????????break;??
  • ??
  • ????????????case?commander_state_s::MAIN_STATE_RATTITUDE:??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_RATTITUDE;??
  • ????????????????break;??
  • ??
  • ????????????case?commander_state_s::MAIN_STATE_STAB:??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_STAB;??
  • ????????????????break;??
  • ??
  • ????????????case?commander_state_s::MAIN_STATE_ALTCTL:??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_ALTCTL;??
  • ????????????????break;??
  • ??
  • ????????????case?commander_state_s::MAIN_STATE_POSCTL:??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_POSCTL;??
  • ????????????????break;??
  • ??
  • ????????????default:??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_MANUAL;??
  • ????????????????break;??
  • ????????????}??
  • ????????}??
  • ????????break;??
  • ??
  • ????case?commander_state_s::MAIN_STATE_AUTO_MISSION:??
  • ??
  • ????????/*?go?into?failsafe?
  • ?????????*?-?if?commanded?to?do?so?
  • ?????????*?-?if?we?have?an?engine?failure?
  • ?????????*?-?if?we?have?vtol?transition?failure?
  • ?????????*?-?depending?on?datalink,?RC?and?if?the?mission?is?finished?*/??
  • ??
  • ????????/*?first?look?at?the?commands?*/??
  • ????????if?(status->engine_failure_cmd)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL;??
  • ????????}?else?if?(status_flags->data_link_lost_cmd)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTGS;??
  • ????????}?else?if?(status_flags->gps_failure_cmd)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDGPSFAIL;??
  • ????????}?else?if?(status_flags->rc_signal_lost_cmd)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RCRECOVER;??
  • ????????}?else?if?(status_flags->vtol_transition_failure_cmd)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTL;??
  • ??
  • ????????/*?finished?handling?commands?which?have?priority,?now?handle?failures?*/??
  • ????????}?else?if?(status_flags->gps_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDGPSFAIL;??
  • ????????}?else?if?(status->engine_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL;??
  • ????????}?else?if?(status_flags->vtol_transition_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTL;??
  • ????????}?else?if?(status->mission_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTL;??
  • ??
  • ????????/*?datalink?loss?enabled:?
  • ?????????*?check?for?datalink?lost:?this?should?always?trigger?RTGS?*/??
  • ????????}?else?if?(data_link_loss_enabled?&&?status->data_link_lost)?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_global_position_valid?&&?status_flags->condition_home_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTGS;??
  • ????????????}?else?if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ??
  • ????????/*?datalink?loss?disabled:?
  • ?????????*?check?if?both,?RC?and?datalink?are?lost?during?the?mission?
  • ?????????*?or?RC?is?lost?after?the?mission?is?finished:?this?should?always?trigger?RCRECOVER?*/??
  • ????????}?else?if?(!data_link_loss_enabled?&&?((status->rc_signal_lost?&&?status->data_link_lost)?||??
  • ???????????????????????????????(status->rc_signal_lost?&&?mission_finished)))?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_global_position_valid?&&?status_flags->condition_home_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RCRECOVER;??
  • ????????????}?else?if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ??
  • ????????/*?stay?where?you?are?if?you?should?stay?in?failsafe,?otherwise?everything?is?perfect?*/??
  • ????????}?else?if?(!stay_in_failsafe){??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_MISSION;??
  • ????????}??
  • ????????break;??
  • ??
  • ????case?commander_state_s::MAIN_STATE_AUTO_LOITER:??
  • ????????/*?go?into?failsafe?on?a?engine?failure?*/??
  • ????????if?(status->engine_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL;??
  • ????????/*?also?go?into?failsafe?if?just?datalink?is?lost?*/??
  • ????????}?else?if?(status->data_link_lost?&&?data_link_loss_enabled)?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_global_position_valid?&&?status_flags->condition_home_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTGS;??
  • ????????????}?else?if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ??
  • ????????/*?go?into?failsafe?if?RC?is?lost?and?datalink?loss?is?not?set?up?*/??
  • ????????}?else?if?(status->rc_signal_lost?&&?!data_link_loss_enabled)?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_global_position_valid?&&?status_flags->condition_home_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTGS;??
  • ????????????}?else?if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ??
  • ????????/*?don't?bother?if?RC?is?lost?if?datalink?is?connected?*/??
  • ????????}?else?if?(status->rc_signal_lost)?{??
  • ??
  • ????????????/*?this?mode?is?ok,?we?don't?need?RC?for?loitering?*/??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LOITER;??
  • ????????}?else?{??
  • ????????????/*?everything?is?perfect?*/??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LOITER;??
  • ????????}??
  • ????????break;??
  • ??
  • ????case?commander_state_s::MAIN_STATE_AUTO_RTL:??
  • ????????/*?require?global?position?and?home,?also?go?into?failsafe?on?an?engine?failure?*/??
  • ??
  • ????????if?(status->engine_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL;??
  • ????????}?else?if?((!status_flags->condition_global_position_valid?||??
  • ????????????????????!status_flags->condition_home_position_valid))?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ????????}?else?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_RTL;??
  • ????????}??
  • ????????break;??
  • ??
  • ????case?commander_state_s::MAIN_STATE_AUTO_FOLLOW_TARGET:??
  • ????????/*?require?global?position?and?home?*/??
  • ??
  • ????????if?(status->engine_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL;??
  • ????????}?else?if?(!status_flags->condition_global_position_valid)?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ????????}?else?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_FOLLOW_TARGET;??
  • ????????}??
  • ????????break;??
  • ??
  • ????case?commander_state_s::MAIN_STATE_AUTO_TAKEOFF:??
  • ????????/*?require?global?position?and?home?*/??
  • ??
  • ????????if?(status->engine_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL;??
  • ????????}?else?if?((!status_flags->condition_global_position_valid?||??
  • ????????????????????!status_flags->condition_home_position_valid))?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ????????}?else?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_TAKEOFF;??
  • ????????}??
  • ????????break;??
  • ??
  • ????case?commander_state_s::MAIN_STATE_AUTO_LAND:??
  • ????????/*?require?global?position?and?home?*/??
  • ??
  • ????????if?(status->engine_failure)?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL;??
  • ????????}?else?if?((!status_flags->condition_global_position_valid?||??
  • ????????????????????!status_flags->condition_home_position_valid))?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ????????}?else?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????}??
  • ????????break;??
  • ??
  • ????case?commander_state_s::MAIN_STATE_OFFBOARD:??
  • ????????/*?require?offboard?control,?otherwise?stay?where?you?are?*/??
  • ????????if?(status_flags->offboard_control_signal_lost?&&?!status->rc_signal_lost)?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_POSCTL;??
  • ????????}?else?if?(status_flags->offboard_control_signal_lost?&&?status->rc_signal_lost)?{??
  • ????????????status->failsafe?=?true;??
  • ??
  • ????????????if?(status_flags->condition_local_position_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND;??
  • ????????????}?else?if?(status_flags->condition_local_altitude_valid)?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_DESCEND;??
  • ????????????}?else?{??
  • ????????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_TERMINATION;??
  • ????????????}??
  • ????????}?else?{??
  • ????????????status->nav_state?=?vehicle_status_s::NAVIGATION_STATE_OFFBOARD;??
  • ????????}??
  • ????default:??
  • ????????break;??
  • ????}??
  • ??
  • ????return?status->nav_state?!=?nav_state_old;??
  • }??
  • 4.set_control_mode();根據status.nav_state確定control_mode.flag_xxx

    command.cpp的main函數中

    [cpp] view plaincopy
  • /*?publish?states?(armed,?control?mode,?vehicle?status)?at?least?with?5?Hz?*/??
  • ????if?(counter?%?(200000?/?COMMANDER_MONITORING_INTERVAL)?==?0?||?status_changed)?{??
  • ????set_control_mode();??
  • ????control_mode.timestamp?=?now;??
  • ????orb_publish(ORB_ID(vehicle_control_mode),?control_mode_pub,?&control_mode);??
  • ????status.timestamp?=?now;??
  • ????orb_publish(ORB_ID(vehicle_status),?status_pub,?&status);??
  • ????armed.timestamp?=?now;??
  • ????/*?set?prearmed?state?if?safety?is?off,?or?safety?is?not?present?and?5?seconds?passed?*/??
  • ????if?(safety.safety_switch_available)?{??
  • ????????/*?safety?is?off,?go?into?prearmed?*/??
  • ????????armed.prearmed?=?safety.safety_off;??
  • ????????}?else?{??
  • ????????/*?safety?is?not?present,?go?into?prearmed?
  • ?????????*?(all?output?drivers?should?be?started?/?unlocked?last?in?the?boot?process?
  • ?????????*?when?the?rest?of?the?system?is?fully?initialized)?
  • ?????????*/??
  • ????????armed.prearmed?=?(hrt_elapsed_time(&commander_boot_timestamp)?>?5?*?1000?*?1000);??
  • ????}??
  • ????orb_publish(ORB_ID(actuator_armed),?armed_pub,?&armed);??
  • }??
  • status.nav_state可分為

    [cpp] view plaincopy
  • static?const?uint8_t?NAVIGATION_STATE_MANUAL?=?0;??
  • static?const?uint8_t?NAVIGATION_STATE_ALTCTL?=?1;??
  • static?const?uint8_t?NAVIGATION_STATE_POSCTL?=?2;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_MISSION?=?3;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_LOITER?=?4;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_RTL?=?5;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_RCRECOVER?=?6;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_RTGS?=?7;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_LANDENGFAIL?=?8;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_LANDGPSFAIL?=?9;??
  • static?const?uint8_t?NAVIGATION_STATE_ACRO?=?10;??
  • static?const?uint8_t?NAVIGATION_STATE_UNUSED?=?11;??
  • static?const?uint8_t?NAVIGATION_STATE_DESCEND?=?12;??
  • static?const?uint8_t?NAVIGATION_STATE_TERMINATION?=?13;??
  • static?const?uint8_t?NAVIGATION_STATE_OFFBOARD?=?14;??
  • 序只寫到了這??
  • static?const?uint8_t?NAVIGATION_STATE_STAB?=?15;??
  • static?const?uint8_t?NAVIGATION_STATE_RATTITUDE?=?16;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_TAKEOFF?=?17;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_LAND?=?18;??
  • static?const?uint8_t?NAVIGATION_STATE_AUTO_FOLLOW_TARGET?=?19;??
  • static?const?uint8_t?NAVIGATION_STATE_MAX?=?20;??
  • 需要確定的有

    [cpp] view plaincopy
  • control_mode.flag_control_manual_enabled?=?true;??
  • control_mode.flag_control_auto_enabled?=?false;??
  • control_mode.flag_control_rates_enabled?=?stabilization_required();??
  • control_mode.flag_control_attitude_enabled?=?stabilization_required();??
  • control_mode.flag_control_rattitude_enabled?=?false;??
  • control_mode.flag_control_altitude_enabled?=?false;??
  • control_mode.flag_control_climb_rate_enabled?=?false;??
  • control_mode.flag_control_position_enabled?=?false;??
  • control_mode.flag_control_velocity_enabled?=?false;??
  • control_mode.flag_control_acceleration_enabled?=?false;??
  • control_mode.flag_control_termination_enabled?=?false;??
  • [cpp] view plaincopy
  • set_control_mode()??
  • {??
  • ????/*?set?vehicle_control_mode?according?to?set_navigation_state?*/??
  • ????control_mode.flag_armed?=?armed.armed;??
  • ????control_mode.flag_external_manual_override_ok?=?(!status.is_rotary_wing?&&?!status.is_vtol);??
  • ????control_mode.flag_system_hil_enabled?=?status.hil_state?==?vehicle_status_s::HIL_STATE_ON;??
  • ????control_mode.flag_control_offboard_enabled?=?false;??
  • ??
  • ????switch?(status.nav_state)?{??
  • ????case?vehicle_status_s::NAVIGATION_STATE_MANUAL:??
  • ????????control_mode.flag_control_manual_enabled?=?true;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?stabilization_required();??
  • ????????control_mode.flag_control_attitude_enabled?=?stabilization_required();??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?false;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?false;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_STAB:??
  • ????????control_mode.flag_control_manual_enabled?=?true;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?true;??
  • ????????control_mode.flag_control_rattitude_enabled?=?true;??
  • ????????control_mode.flag_control_altitude_enabled?=?false;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?false;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????/*?override?is?not?ok?in?stabilized?mode?*/??
  • ????????control_mode.flag_external_manual_override_ok?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_RATTITUDE:??
  • ????????control_mode.flag_control_manual_enabled?=?true;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?true;??
  • ????????control_mode.flag_control_rattitude_enabled?=?true;??
  • ????????control_mode.flag_control_altitude_enabled?=?false;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?false;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_ALTCTL:??
  • ????????control_mode.flag_control_manual_enabled?=?true;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?true;??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?true;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?true;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_POSCTL:??
  • ????????control_mode.flag_control_manual_enabled?=?true;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?true;??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?true;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?true;??
  • ????????control_mode.flag_control_position_enabled?=?!status.in_transition_mode;??
  • ????????control_mode.flag_control_velocity_enabled?=?!status.in_transition_mode;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_RTL:??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_RCRECOVER:??
  • ????????/*?override?is?not?ok?for?the?RTL?and?recovery?mode?*/??
  • ????????control_mode.flag_external_manual_override_ok?=?false;??
  • ????????/*?fallthrough?*/??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_FOLLOW_TARGET:??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_RTGS:??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_LAND:??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDENGFAIL:??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_MISSION:??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_LOITER:??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_TAKEOFF:??
  • ????????control_mode.flag_control_manual_enabled?=?false;??
  • ????????control_mode.flag_control_auto_enabled?=?true;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?true;??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?true;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?true;??
  • ????????control_mode.flag_control_position_enabled?=?!status.in_transition_mode;??
  • ????????control_mode.flag_control_velocity_enabled?=?!status.in_transition_mode;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_AUTO_LANDGPSFAIL:??
  • ????????control_mode.flag_control_manual_enabled?=?false;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?true;??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?false;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?true;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_ACRO:??
  • ????????control_mode.flag_control_manual_enabled?=?true;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?false;??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?false;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?false;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_DESCEND:??
  • ????????/*?TODO:?check?if?this?makes?sense?*/??
  • ????????control_mode.flag_control_manual_enabled?=?false;??
  • ????????control_mode.flag_control_auto_enabled?=?true;??
  • ????????control_mode.flag_control_rates_enabled?=?true;??
  • ????????control_mode.flag_control_attitude_enabled?=?true;??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?false;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?true;??
  • ????????control_mode.flag_control_termination_enabled?=?false;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_TERMINATION:??
  • ????????/*?disable?all?controllers?on?termination?*/??
  • ????????control_mode.flag_control_manual_enabled?=?false;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_rates_enabled?=?false;??
  • ????????control_mode.flag_control_attitude_enabled?=?false;??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ????????control_mode.flag_control_position_enabled?=?false;??
  • ????????control_mode.flag_control_velocity_enabled?=?false;??
  • ????????control_mode.flag_control_acceleration_enabled?=?false;??
  • ????????control_mode.flag_control_altitude_enabled?=?false;??
  • ????????control_mode.flag_control_climb_rate_enabled?=?false;??
  • ????????control_mode.flag_control_termination_enabled?=?true;??
  • ????????break;??
  • ??
  • ????case?vehicle_status_s::NAVIGATION_STATE_OFFBOARD:??
  • ????????control_mode.flag_control_manual_enabled?=?false;??
  • ????????control_mode.flag_control_auto_enabled?=?false;??
  • ????????control_mode.flag_control_offboard_enabled?=?true;??
  • ??
  • ????????/*?
  • ?????????*?The?control?flags?depend?on?what?is?ignored?according?to?the?offboard?control?mode?topic?
  • ?????????*?Inner?loop?flags?(e.g.?attitude)?also?depend?on?outer?loop?ignore?flags?(e.g.?position)?
  • ?????????*/??
  • ????????control_mode.flag_control_rates_enabled?=?!offboard_control_mode.ignore_bodyrate?||??
  • ????????????!offboard_control_mode.ignore_attitude?||??
  • ????????????!offboard_control_mode.ignore_position?||??
  • ????????????!offboard_control_mode.ignore_velocity?||??
  • ????????????!offboard_control_mode.ignore_acceleration_force;??
  • ??
  • ????????control_mode.flag_control_attitude_enabled?=?!offboard_control_mode.ignore_attitude?||??
  • ????????????!offboard_control_mode.ignore_position?||??
  • ????????????!offboard_control_mode.ignore_velocity?||??
  • ????????????!offboard_control_mode.ignore_acceleration_force;??
  • ??
  • ????????control_mode.flag_control_rattitude_enabled?=?false;??
  • ??
  • ????????control_mode.flag_control_acceleration_enabled?=?!offboard_control_mode.ignore_acceleration_force?&&??
  • ??????????!status.in_transition_mode;??
  • ??
  • ????????control_mode.flag_control_velocity_enabled?=?(!offboard_control_mode.ignore_velocity?||??
  • ????????????!offboard_control_mode.ignore_position)?&&?!status.in_transition_mode?&&??
  • ????????????!control_mode.flag_control_acceleration_enabled;??
  • ??
  • ????????control_mode.flag_control_climb_rate_enabled?=?(!offboard_control_mode.ignore_velocity?||??
  • ????????????!offboard_control_mode.ignore_position)?&&?!control_mode.flag_control_acceleration_enabled;??
  • ??
  • ????????control_mode.flag_control_position_enabled?=?!offboard_control_mode.ignore_position?&&?!status.in_transition_mode?&&??
  • ??????????!control_mode.flag_control_acceleration_enabled;??
  • ??
  • ????????control_mode.flag_control_altitude_enabled?=?(!offboard_control_mode.ignore_velocity?||??
  • ????????????!offboard_control_mode.ignore_position)?&&?!control_mode.flag_control_acceleration_enabled;??
  • ??
  • ????????break;??
  • ??
  • ????default:??
  • ????????break;??
  • ????}??
  • }??
  • 問題是不能切光流定點模式,按以上流程分析:

    main_state_transition();里面

    [cpp] view plaincopy
  • case?commander_state_s::MAIN_STATE_POSCTL:??
  • ????/*?need?at?minimum?local?position?estimate?*/??
  • ????if?(status_flags->condition_local_position_valid?||??
  • ????????status_flags->condition_global_position_valid)?{??
  • ????????ret?=?TRANSITION_CHANGED;??
  • ????}??
  • ????break;??
  • 要想切換模式status_flags->condition_local_position_valid或者status_flags->condition_global_position_valid要為1

    [cpp] view plaincopy
  • /*?update?global?position?estimate?*/??
  • orb_check(global_position_sub,?&updated);??
  • if?(updated)?{??
  • ????/*?position?changed?*/??
  • ????vehicle_global_position_s?gpos;??
  • ????orb_copy(ORB_ID(vehicle_global_position),?global_position_sub,?&gpos);??
  • ????/*?copy?to?global?struct?if?valid,?with?hysteresis?*/??
  • ????//?XXX?consolidate?this?with?local?position?handling?and?timeouts?after?release??
  • ????//?but?we?want?a?low-risk?change?now.??
  • ????if?(status_flags.condition_global_position_valid)?{??
  • ????????if?(gpos.eph?<?eph_threshold?*?2.5f)?{??
  • ????????????orb_copy(ORB_ID(vehicle_global_position),?global_position_sub,?&global_position);??
  • ????????}??
  • ????}?else?{??
  • ????????if?(gpos.eph?<?eph_threshold)?{??
  • ????????????orb_copy(ORB_ID(vehicle_global_position),?global_position_sub,?&global_position);??
  • ????????}??
  • ????}??
  • }??
  • /*?update?local?position?estimate?*/??
  • orb_check(local_position_sub,?&updated);??
  • if?(updated)?{??
  • ????/*?position?changed?*/??
  • ????orb_copy(ORB_ID(vehicle_local_position),?local_position_sub,?&local_position);??
  • }??
  • /*?update?attitude?estimate?*/??
  • orb_check(attitude_sub,?&updated);??
  • if?(updated)?{??
  • ????/*?position?changed?*/??
  • ????orb_copy(ORB_ID(vehicle_attitude),?attitude_sub,?&attitude);??
  • }??
  • //update?condition_global_position_valid??
  • //Global?positions?are?only?published?by?the?estimators?if?they?are?valid??
  • if?(hrt_absolute_time()?-?global_position.timestamp?>?POSITION_TIMEOUT)?{??
  • ????//We?have?had?no?good?fix?for?POSITION_TIMEOUT?amount?of?time??
  • ????if?(status_flags.condition_global_position_valid)?{??
  • ????????set_tune_override(TONE_GPS_WARNING_TUNE);??
  • ????????status_changed?=?true;??
  • ????????status_flags.condition_global_position_valid?=?false;??
  • ????}??
  • }?else?if?(global_position.timestamp?!=?0)?{??
  • ????//?Got?good?global?position?estimate??
  • ????if?(!status_flags.condition_global_position_valid)?{??
  • ????????status_changed?=?true;??
  • ????????status_flags.condition_global_position_valid?=?true;??
  • ????}??
  • }??
  • /*?update?condition_local_position_valid?and?condition_local_altitude_valid?*/??
  • /*?hysteresis?for?EPH?*/??
  • bool?local_eph_good;??
  • if?(status_flags.condition_local_position_valid)?{??
  • ????if?(local_position.eph?>?eph_threshold?*?2.5f)?{??
  • ????????local_eph_good?=?false;??
  • ????}?else?{??
  • ????????local_eph_good?=?true;??
  • ????}??
  • }?else?{??
  • ????if?(local_position.eph?<?eph_threshold)?{??
  • ????????local_eph_good?=?true;??
  • ????}?else?{??
  • ????????local_eph_good?=?false;??
  • ????}??
  • }??
  • check_valid(local_position.timestamp,?POSITION_TIMEOUT,?local_position.xy_valid??
  • ????????&&?local_eph_good,?&(status_flags.condition_local_position_valid),?&status_changed);??
  • check_valid(local_position.timestamp,?POSITION_TIMEOUT,?local_position.z_valid,??
  • ????????&(status_flags.condition_local_altitude_valid),?&status_changed);??
  • 其中void check_valid()原函數為

    [cpp] view plaincopy
  • check_valid(hrt_abstime?timestamp,?hrt_abstime?timeout,?bool?valid_in,?bool?*valid_out,?bool?*changed)??
  • {??
  • ????hrt_abstime?t?=?hrt_absolute_time();??
  • ????bool?valid_new?=?(t?<?timestamp?+?timeout?&&?t?>?timeout?&&?valid_in);??
  • ????if?(*valid_out?!=?valid_new)?{??
  • ????????*valid_out?=?valid_new;??
  • ????????*changed?=?true;??
  • ????}??
  • }??
  • 由此可知

    status_flags.condition_global_position_valid和POSITION_TIMEOUT,global_position.timestamp有關

    #definePOSITION_TIMEOUT? (1 * 1000 * 1000)// 考慮local或global的位置估計在1000毫秒無效

    global_position.timestamp來自orb_copy(ORB_ID(vehicle_global_position),global_position_sub, &global_position);

    ORB_ID(vehicle_global_position)來自位置估計


    status_flags.condition_local_position_valid和local_position.timestamp,POSITION_TIMEOUT, local_position.xy_valid有關

    #definePOSITION_TIMEOUT? (1 * 1000 * 1000)// 考慮local或global的位置估計在1000毫秒無效

    local_position.timestamp, local_position.xy_valid來自orb_copy(ORB_ID(vehicle_local_position),local_position_sub, &local_position);

    ORB_ID(vehicle_local_position)來自位置估計

    總結

    以上是生活随笔為你收集整理的pixhawk commander.cpp的飞行模式切换解读的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

    久草在线久 | 国产视频 亚洲精品 | 成人黄色免费观看 | 国产精品精| www.福利视频 | 懂色av一区二区三区蜜臀 | 天天干中文字幕 | 99国产一区二区三精品乱码 | 欧美午夜视频在线 | 懂色av一区二区在线播放 | 精品在线观看一区二区 | 欧美一区日韩一区 | 成人亚洲网 | 在线电影播放 | 日韩精品免费一区二区在线观看 | 天天综合人人 | 成年人看片网站 | 天天干天天射天天插 | 日韩免费av网址 | 国产永久免费 | 国产精品18久久久久久久久久久久 | 日韩手机在线 | 日韩免费电影在线观看 | 精品欧美一区二区在线观看 | 国产成a人亚洲精v品在线观看 | 亚洲人精品午夜 | 国产中文字幕三区 | 色婷婷丁香 | 操操操操网 | 国产在线观看一区 | 激情深爱.com | 国产精品久久久一区二区三区网站 | 色综合天天综合网国产成人网 | 亚洲国产三级在线观看 | 色av婷婷| 精品一区二区亚洲 | 99国产精品免费网站 | 中文字幕在线成人 | 日韩a欧美 | 黄色高清视频在线观看 | aaa黄色毛片 | 亚洲综合涩| 久久国产精品免费一区二区三区 | 亚洲无毛专区 | 91夫妻视频| 激情综合六月 | av亚洲产国偷v产偷v自拍小说 | 性色av香蕉一区二区 | 蜜臀av麻豆 | 亚洲欧洲中文日韩久久av乱码 | 一级黄色片在线播放 | 视频一区在线免费观看 | 国产超碰97| 亚州精品成人 | 五月婷婷在线综合 | 在线有码中文 | 毛片精品免费在线观看 | 欧美福利片在线观看 | 午夜精品三区 | 日韩中文字幕在线观看 | 黄网站免费大全入口 | 五月婷婷色丁香 | 97超碰人人澡人人 | 一区二区 不卡 | 国产精品久久久久久久久久ktv | 日韩欧美在线观看一区二区三区 | 91麻豆精品国产自产在线游戏 | 久草香蕉在线视频 | 国产精品mv | 视频国产一区二区三区 | 天天射天天干天天 | 91传媒在线播放 | 美女精品久久久 | 九九激情视频 | 99精品久久99久久久久 | 日韩69av| 顶级bbw搡bbbb搡bbbb | 在线电影 你懂得 | 久久影院午夜论 | 五月婷婷激情五月 | 奇米先锋 | 国产精品久久久久久久7电影 | 欧美三级高清 | 亚洲专区在线视频 | 一区二区av | 开心激情网五月天 | 国产精品片 | 国产系列 在线观看 | av电影免费观看 | 深夜福利视频一区二区 | 96久久精品 | www亚洲国产 | 色在线亚洲 | 91黄色小视频 | av免费观看网站 | 亚洲五月六月 | 一本一本久久a久久精品牛牛影视 | 免费观看黄色av | 久久成人视屏 | 99热在 | 国产美女免费观看 | 中文字幕av最新更新 | 日本少妇视频 | 免费看污污视频的网站 | 日韩美女免费线视频 | 国产在线探花 | 99精品国产高清在线观看 | 国产自制av | 日韩高清在线一区二区三区 | 国产精品成人国产乱一区 | 国产96在线 | 国产精品初高中精品久久 | 欧美在线a视频 | 四虎永久国产精品 | 超碰人人在线观看 | 视频在线观看一区 | 久久亚洲私人国产精品 | 国产中文字幕第一页 | 99精品观看 | 国产欧美日韩一区 | 国产精品观看在线亚洲人成网 | 国产精品一区二区三区四区在线观看 | 日本最大色倩网站www | 国产精品一区二区免费视频 | av片免费播放| 91九色视频网站 | 天天狠狠 | 一区二区中文字幕在线观看 | 国产精品免费久久久久久久久久中文 | 天天操天天射天天 | 欧美在线一二 | 国产色妞影院wwwxxx | 视频成人永久免费视频 | 日韩高清网站 | 亚洲三级在线免费观看 | 精品国产免费观看 | 国产精品综合av一区二区国产馆 | 插婷婷| 日韩中文字幕免费在线观看 | 天天射天天射天天射 | 国产精品久免费的黄网站 | 高潮久久久久久 | 久久精国产| 国产成人久久精品亚洲 | 欧美一区免费在线观看 | 久久任你操 | 日韩 在线| 国产成人香蕉 | 国产视频在线观看一区 | 国产黄在线免费观看 | 精品国产123 | 婷婷丁香导航 | 欧美成年人在线视频 | 免费黄色av片 | 久久视了| 成人99免费视频 | 黄色在线观看免费网站 | av一区二区在线观看中文字幕 | 欧美中文字幕久久 | 在线看毛片网站 | 五月婷婷在线视频 | 国产蜜臀av | 久久久久一区 | 欧美日韩精品在线一区二区 | 2022中文字幕在线观看 | 亚洲a在线观看 | 日本中文字幕高清 | 亚洲人成在线观看 | 久久国产亚洲 | 中文字幕无吗 | 午夜精品三区 | 婷婷丁香六月天 | 免费又黄又爽 | 射综合网| 国产伦精品一区二区三区在线 | 国际精品久久久久 | 精品视频网站 | 国产成人三级三级三级97 | 国产精品午夜在线 | av网址aaa | 久久视频99 | 国产精品白浆视频 | 久久视频免费 | 久久久国产影视 | 久久久久久久影视 | 中文字幕欲求不满 | 亚洲午夜久久久久久久久电影网 | 免费看麻豆 | 精品久久久久久亚洲综合网站 | 狠狠干狠狠色 | 亚洲视频 一区 | 三上悠亚在线免费 | 毛片视频电影 | 久久精品永久免费 | 免费视频97| 91精品国自产在线观看欧美 | 日韩视频在线一区 | 精品毛片一区二区免费看 | 亚洲欧美在线观看视频 | 久久综合五月婷婷 | 免费黄色网址网站 | 粉嫩aⅴ一区二区三区 | 免费在线色电影 | 亚洲高清视频在线 | 成年性视频| 日韩精品一区二区三区免费视频观看 | 免费a现在观看 | 麻豆国产在线播放 | 久要激情网| 久久精品99久久久久久2456 | 免费看黄在线网站 | 色在线最新 | 在线观看av国产 | 日本美女xx| 国产经典av | 亚洲精品午夜久久久久久久久久久 | 精品国产自在精品国产精野外直播 | 国产亚州精品视频 | 91干干干 | 天天操天| 免费视频一级片 | 91精品在线观看入口 | 99久久99久久| 在线免费观看的av网站 | 久热av | www.天天成人国产电影 | 久久久久久久久久伊人 | 成人午夜电影久久影院 | 久草视频2| 在线国产欧美 | 一区二区三区精品在线 | 日本最新一区二区三区 | 欧美性色黄大片在线观看 | 久久综合天天 | 亚洲精品99久久久久久 | 日韩试看 | 99视频一区| 亚洲精品视频久久 | 精品国产欧美 | 九九热精品国产 | 国产精品1000 | av综合 日韩| 911av视频 | 在线v片| 亚洲v欧美v国产v在线观看 | 成人小视频在线观看免费 | 日韩欧美xx| 国产一级一片免费播放放a 一区二区三区国产欧美 | 91久久国产精品 | 免费a级黄色毛片 | 最新国产精品拍自在线播放 | 亚洲深爱激情 | 欧美日韩亚洲第一 | 成人动图| 久久久国产精品电影 | 一级免费看视频 | 国产精品一区在线 | 国产精品久久久久久久午夜 | 国产精品欧美久久久久三级 | 国产一级在线免费观看 | 综合五月婷婷 | 亚洲婷婷在线视频 | 国内成人综合 | 日本精品中文字幕 | 婷婷开心久久网 | 午夜三级理论 | 久草在线免费新视频 | 视频三区| 国产精品18久久久久久久久久久久 | 午夜10000| 免费观看性生活大片3 | 中文字幕亚洲欧美日韩2019 | 日韩一区在线播放 | 永久免费的av电影 | 黄色a在线 | 日本最新一区二区三区 | 国产最新在线 | 国产欧美中文字幕 | 日韩高清免费无专码区 | 97在线播放 | 亚洲精品免费在线 | 亚洲激情 | 成人h视频 | 欧美精品你懂的 | 色综合 久久精品 | 日韩精品一区二区三区中文字幕 | 国产精品99久久久久人中文网介绍 | 亚洲另类久久 | 天天干,天天干 | 亚洲国产成人在线观看 | 天天干夜夜 | 又黄又爽又色无遮挡免费 | 婷婷六月综合亚洲 | 国产另类xxxxhd高清 | 免费精品人在线二线三线 | 久久99精品一区二区三区三区 | 亚洲精品乱码久久久一二三 | 国产在线视频不卡 | 69热国产视频 | 国产九色视频在线观看 | 日本三级吹潮在线 | 韩国av一区二区三区 | 尤物九九久久国产精品的分类 | 在线播放 亚洲 | 国产五十路毛片 | 99精品欧美一区二区三区黑人哦 | 亚洲精品国产麻豆 | 黄色软件视频大全免费下载 | 日韩天堂在线观看 | 九九热在线视频 | 美女精品久久久 | 伊人色播| 欧美久久久久久久久久久久久 | 麻豆国产在线播放 | 日韩在线精品一区 | 樱空桃av| 最近中文国产在线视频 | 国产精品wwwwww | 97精品在线观看 | 日韩欧美69 | 毛片网免费 | 中文字幕观看在线 | 久久999精品| 激情婷婷| 黄色亚洲大片免费在线观看 | 中文字幕乱偷在线 | 国产超碰在线观看 | 欧美黄色成人 | 在线观看视频免费播放 | 色之综合网 | 97超碰在线播放 | 欧美韩国日本在线 | 在线观看视频免费大全 | 欧美一区二区日韩一区二区 | 久草在线视频资源 | 久久另类小说 | 精品99视频 | 天天干夜夜爱 | 免费在线观看av | 在线激情电影 | av不卡中文字幕 | 日韩欧美精品在线视频 | 免费特级黄毛片 | 免费在线观看视频一区 | 99r在线播放 | 91激情视频在线 | 中文字幕之中文字幕 | 欧美精品中文在线免费观看 | 91视频91蝌蚪 | 天天插天天操天天干 | 韩国av免费在线观看 | www.国产高清 | 欧美日bb | 波多野结衣在线播放一区 | 九九九九九精品 | 91在线入口| 亚洲国产日韩一区 | 在线视频观看你懂的 | 亚洲成人网av | 有码中文字幕在线观看 | 久久精品99精品国产香蕉 | 91日韩在线视频 | 香蕉视频最新网址 | 美女久久网站 | 91视频在线自拍 | 91福利在线观看 | 国产色综合天天综合网 | 日本精品一二区 | 亚洲女人av | 色多视频在线观看 | 草莓视频在线观看免费观看 | 97免费在线观看视频 | 天天曰天天射 | 久久草| 国产香蕉av | 久久视频免费 | 亚洲精品中文字幕视频 | 久久久久麻豆v国产 | 久久999久久 | 麻豆一区二区三区视频 | 欧美成人91 | 中文字幕免费久久 | 麻豆一精品传二传媒短视频 | 免费中文字幕 | 久久免费视频网 | 天天操人人要 | 国产黄色精品 | 欧美va天堂va视频va在线 | 国产精品婷婷午夜在线观看 | 免费观看91视频 | 婷婷久久网站 | 国产又粗又硬又爽视频 | 午夜丁香网 | 超碰在线亚洲 | 久久视频在线 | 91福利视频久久久久 | 91一区啪爱嗯打偷拍欧美 | 黄色小说在线免费观看 | 在线看小早川怜子av | 黄网av在线 | 二区三区在线 | 草久热 | 久久99国产精品久久 | 亚洲一级理论片 | 亚洲第一伊人 | 国产xx在线| 中文字幕一区二区三 | 免费电影一区二区三区 | 亚洲黄色在线播放 | 狠狠操狠狠干天天操 | 成人在线你懂得 | 日韩av一区二区三区四区 | 免费黄在线看 | 午夜精品久久久久久 | 免费网站污 | 香蕉影院在线 | 午夜久久久久久久 | 久久99久国产精品黄毛片入口 | 欧美人人 | 日韩69视频 | 国产白浆在线观看 | 日韩久久久久久久久 | 黄色日本免费 | 欧美日韩视频在线观看一区二区 | 日韩精品免费在线 | 日韩欧美高清在线 | 人人干狠狠操 | 精品国产色 | 日韩一区二区免费视频 | 久久6精品 | 少妇视频一区 | 久久久久久草 | 香蕉视频在线免费 | 欧美福利在线播放 | 亚洲狠狠 | 日韩理论在线视频 | 日本公妇色中文字幕 | 国产福利91精品一区二区三区 | 国产综合在线观看视频 | 日韩特级毛片 | 成年免费在线视频 | а天堂中文最新一区二区三区 | 九九热在线视频 | 久久影院亚洲 | 美女视频免费精品 | 日韩精品一区二区在线 | 日韩欧美国产激情在线播放 | 免费黄色av片 | 欧美与欧洲交xxxx免费观看 | 国产福利小视频在线 | 国产成人精品一区二三区 | 美女视频网 | 久草在线资源网 | 在线观看av网站 | 五月天婷亚洲天综合网鲁鲁鲁 | 不卡视频一区二区三区 | 色天天天| 黄色aaa毛片 | 午夜精品一区二区三区在线观看 | 国产99免费| 久久精品国产精品亚洲 | 在线免费观看一区二区三区 | 欧美激情精品久久久 | 亚洲精品免费观看视频 | 天天爱天天操天天爽 | 国产精品女教师 | 天天草天天干天天 | www操操| 国产一级h | 成人黄色免费在线观看 | a色视频| 高清一区二区 | 色成人亚洲 | 日韩a在线播放 | 国产视频在线看 | 中文字幕欲求不满 | 手机看片午夜 | 欧美精品久久久久久久久老牛影院 | 国产精品免费久久久久久久久久中文 | 在线观看你懂的网站 | 99婷婷狠狠成为人免费视频 | 日韩精品一区二区三区三炮视频 | 成人久久18免费网站图片 | 一本一道久久a久久精品蜜桃 | 国产五月婷 | 人人插人人干 | 国产亚洲在线 | 免费精品在线视频 | 最近中文字幕视频网 | 麻豆免费视频 | 中文字幕免费高清 | 亚洲国产成人精品电影在线观看 | 国产欧美在线一区二区三区 | 欧美日韩国产一区二 | 夜夜澡人模人人添人人看 | 久草91视频 | 丁香视频免费观看 | 天天色综合1| 日韩精品免费专区 | 国产永久免费观看 | 午夜性福利 | 中文字幕一区二区三区乱码不卡 | 欧美性黄网官网 | 91试看 | 免费视频国产 | 在线视频 国产 日韩 | 亚洲欧美视频 | 国产精品第一页在线 | 中文字幕亚洲国产 | 天天插天天狠天天透 | 欧美91精品国产自产 | 亚洲日本黄色 | 国产精品女教师 | 丝袜美女在线观看 | 日韩av片在线| 国产专区视频在线观看 | 在线观看岛国 | 国产日本亚洲 | 久久久久久久久久久久影院 | 狠狠天天 | 免费福利视频导航 | 97在线看 | 国产精品系列在线播放 | a天堂一码二码专区 | 国产精品久久久久久久久毛片 | 深夜激情影院 | 日韩亚洲在线视频 | 国产视频一级 | 欧美一区二区日韩一区二区 | 国产人成看黄久久久久久久久 | 欧洲一区二区在线观看 | 亚洲视频1区2区 | 精品亚洲视频在线观看 | 国产日韩欧美在线一区 | 色网站中文字幕 | 久久精品国产v日韩v亚洲 | 久久在线观看视频 | 二区精品视频 | 欧美网站黄色 | www.看片网站 | 免费污片 | 手机在线看片日韩 | 成人av在线资源 | 黄色av成人在线 | www.天天操.com | 国产色爽 | 亚洲最大成人免费网站 | 91精品啪在线观看国产81旧版 | 欧美污污视频 | www国产精品com | 欧美视频xxx | 欧美成人h版在线观看 | 中文字幕免费高清av | 欧美日韩中文字幕综合视频 | 中文av在线播放 | 亚洲国产日韩在线 | 黄色精品一区二区 | 国产高清绿奴videos | 国产精品18久久久久久久 | 久久成人国产精品 | 亚洲欧美视频一区二区三区 | 亚洲精品美女在线观看播放 | 成人午夜毛片 | 亚洲女欲精品久久久久久久18 | 国产在线观 | 国产最新在线 | 在线观看视频黄色 | 亚洲三级网站 | 一区 在线观看 | 亚洲国产午夜 | 亚洲 欧洲 国产 日本 综合 | 99精品视频免费在线观看 | 碰碰影院| 日日干天天爽 | 91在线视频免费91 | 中文字幕欧美三区 | 主播av在线 | 在线观看不卡视频 | a级片网站 | 免费人做人爱www的视 | 国产原创在线 | .精品久久久麻豆国产精品 亚洲va欧美 | 欧美一区在线观看视频 | 日韩视频中文 | 亚洲视频网站在线观看 | 麻豆传媒在线免费看 | 99久视频 | 99精品乱码国产在线观看 | 欧美精彩视频在线观看 | 91经典在线 | 久久免费观看少妇a级毛片 久久久久成人免费 | 精品国产自在精品国产精野外直播 | 欧美黑人巨大xxxxx | 国产乱对白刺激视频在线观看女王 | 少妇视频在线播放 | 99九九99九九九视频精品 | 视频国产在线 | 在线观看91视频 | 久久伊人五月天 | 亚洲精品国产欧美在线观看 | 久久国产精品一区二区三区四区 | 婷婷av网 | 久久视影 | 91日韩在线专区 | 天天插天天色 | 96久久欧美麻豆网站 | 91精品久久久久久 | 99麻豆视频| 欧美精品成人在线 | 久久国产高清 | 亚州精品在线视频 | 日韩一区二区三区视频在线 | 日韩精品中文字幕在线不卡尤物 | 免费视频在线观看网站 | www黄在线 | 成人国产精品久久久 | 亚洲精品国偷自产在线91正片 | 久久99国产精品免费网站 | 狠狠操精品 | 久久久国产一区 | 免费在线观看午夜视频 | 丁香婷婷深情五月亚洲 | 成年人黄色免费视频 | 日本中文字幕免费观看 | 欧美性黑人 | 狠狠干狠狠久久 | 欧美极度另类 | 成人午夜电影在线播放 | 国产97免费 | 99免费在线视频观看 | 又黄又爽又色无遮挡免费 | 久久国产99 | 日本精品久久久久久 | 成人av中文字幕在线观看 | 一区二区三区四区精品视频 | 九九热国产视频 | 综合久久婷婷 | 日韩免费在线播放 | 中文字幕在线观看亚洲 | 操天天操 | av三级av | 亚洲最大成人网4388xx | 区一区二区三区中文字幕 | 97精品国产手机 | 久久成人午夜 | 99在线观看视频网站 | 国产五月婷婷 | 中文有码在线视频 | 色婷久久| 狠狠色狠狠综合久久 | 免费日韩 | 一级黄色片网站 | 一区二区男女 | 在线观看免费av网 | 欧美成人xxxxxxxx | 97人人模人人爽人人喊网 | 91av电影在线 | 亚洲电影免费 | 香蕉视频网址 | 午夜国产福利视频 | 久久精品网站视频 | 国产不卡在线播放 | 欧美一级免费在线 | 日韩亚洲在线 | 97人人模人人爽人人喊网 | 日韩三级成人 | 国产韩国日本高清视频 | 亚洲精色| 亚洲资源网 | 国产成人精品一区二区在线 | 三级av免费观看 | 欧美性另类| 亚洲日本中文字幕在线观看 | 91 在线视频| 黄色成人av | 玖玖在线看 | 国产精品一区二区三区在线播放 | 亚洲精品在线国产 | 国产一区欧美二区 | 黄色av免费 | 亚洲精品免费在线视频 | 一区二区三区在线看 | 午夜 免费 | 免费成人结看片 | 在线观看亚洲专区 | 91中文字幕网 | 激情五月婷婷综合 | 黄色免费av| 日韩天天综合 | 五月天网站在线 | 97超碰在线资源 | 超级av在线| 日本黄色大片儿 | 国产精品一区二区你懂的 | 国产午夜精品一区二区三区 | 国产一区播放 | 日韩欧美网站 | 91一区二区三区在线观看 | 午夜在线国产 | 天天干夜夜干 | 久久免费视频观看 | 精品久久久99 | 成人日批视频 | 91麻豆精品国产91久久久使用方法 | 人人澡超碰碰97碰碰碰软件 | 欧美在线久久 | 久久网站免费 | 亚洲欧美怡红院 | 免费视频一级片 | 99精品国产99久久久久久福利 | 亚洲国产精久久久久久久 | 日韩欧美精品免费 | 高清日韩一区二区 | 99精品国产一区二区 | 久草色在线观看 | 国产盗摄精品一区二区 | 国产999精品久久久久久 | 中文字幕在线观看一区二区三区 | 日韩va在线观看 | 91在线精品一区二区 | 国产美女精品 | 91久久精品一区二区三区 | 91精品国产成人www | 久热免费在线观看 | 美女久久久久久久 | 人人爽人人爽人人片av | 99久久夜色精品国产亚洲 | 人人爽人人搞 | 亚洲一一在线 | 成人三级视频 | 97精品在线视频 | 日韩电影一区二区在线观看 | 婷婷成人亚洲综合国产xv88 | 51久久夜色精品国产麻豆 | 日日天天狠狠 | 黄网站免费久久 | 久久a级片 | 欧美最猛性xxxxx亚洲精品 | 麻花豆传媒一二三产区 | 久草视频在线免费播放 | 亚洲成人av免费 | 欧美日韩国产在线 | 深夜免费福利 | 亚洲精品日韩一区二区电影 | 中文字幕在线播放第一页 | 国产爽妇网 | 欧美精品久久久 | 美女免费网视频 | 亚洲精选视频在线 | 九九欧美 | 免费看三级网站 | av综合在线观看 | 91资源在线免费观看 | 国产成人a v电影 | 亚洲午夜激情网 | 在线免费观看黄色 | 五月婷婷一区二区三区 | 国产黑丝一区二区 | japanesexxxhd奶水 91在线精品一区二区 | 91探花在线 | 一区二区三区在线影院 | 一区二区三区在线视频观看58 | 天天天在线综合网 | 欧美性色黄大片在线观看 | 亚洲精品在线观看中文字幕 | 九色视频网 | 欧美成人猛片 | 国产成人免费观看 | 国产在线第三页 | 免费在线观看视频一区 | 欧美精品一区二区三区一线天视频 | 在线观看黄色大片 | 最新国产精品亚洲 | 欧美激情综合色 | 免费成人在线观看 | 欧美精品网站 | 91网在线观看 | 正在播放国产一区二区 | 91精品一区二区三区蜜桃 | 欧美激情第八页 | 国产丝袜高跟 | 韩国精品一区二区三区六区色诱 | 精品美女久久久久久免费 | 色婷婷国产精品一区在线观看 | 久日精品 | 国内小视频在线观看 | 在线午夜av| 国产成人61精品免费看片 | 在线不卡的av | 国内精品久久久久久久97牛牛 | 又黄又色又爽 | 亚洲国产精品久久久久 | 欧美视频日韩 | 黄色免费观看 | 婷婷久草 | 一区二区视频网站 | 91夫妻自拍| 成年人网站免费观看 | 日韩爱爱片 | 欧美日韩一区久久 | 国产日韩欧美在线免费观看 | 97激情影院 | 亚洲国产精品一区二区久久hs | 91人人澡人人爽人人精品 | 欧美一二区视频 | 日韩影视大全 | 久久99精品久久只有精品 | 韩日三级av| 天天鲁天天干天天射 | 99热日本 | 国产一区观看 | 高清日韩一区二区 | av黄色在线播放 | 国产成人精品一区二区 | 久久精品一区 | 久久婷婷五月综合色丁香 | 视频在线观看日韩 | 成人精品国产 | 国产一区二区视频在线 | 久久视频一区 | 最新国产一区二区三区 | 国产精品网站一区二区三区 | 久久精品视频在线看 | 国产免费中文字幕 | 精品99久久久久久 | 在线观看完整版 | 免费日韩电影 | 久久国产精品视频观看 | 久草免费在线观看视频 | 国产馆在线播放 | 久久久久免费精品视频 | 免费男女羞羞的视频网站中文字幕 | 欧美片一区二区三区 | 亚洲一级理论片 | 日韩精品三区四区 | 999久久a精品合区久久久 | 国产精品一区久久久久 | www夜夜操com | 欧美性黄网官网 | 精品视频免费 | 一级久久精品 | 99亚洲国产| 午夜成人影视 | 久草在线官网 | 久久久婷 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 久久 亚洲视频 | 2019精品手机国产品在线 | 九九色视频 | 久久久久观看 | 日韩av片在线 | 日韩欧美视频 | 欧美不卡视频在线 | 一级一片免费观看 | 午夜精品久久久久99热app | 丁香导航| 欧美一进一出抽搐大尺度视频 | 热久久国产精品 | 手机av在线免费观看 | 中文字幕免费高清av | 国产一级免费观看 | 中文字幕一区二区三区四区久久 | 欧美夫妻生活视频 | 五月综合色 | av在线免费播放 | 91麻豆精品久久久久久 | 国产精品视频专区 | 国产剧情久久 | 国产97在线观看 | 欧美福利网址 | a√天堂中文在线 | 探花视频在线版播放免费观看 | 色播五月激情综合网 | 精品1区2区3区 | 久久国产精品一区二区三区四区 | 亚洲天堂网在线视频观看 | 成人黄色一级视频 | 91av原创 | 麻豆系列在线观看 | 中文字幕一区二 | 欧美日韩在线精品一区二区 | 亚洲视频h| 国产精品久久久久久69 | 97视频免费观看2区 亚洲视屏 | 一区二区三区日韩视频在线观看 | 99热精品久久 | 国产精品一区免费看8c0m | 国产精品99蜜臀久久不卡二区 | 免费在线中文字幕 | 精品在线不卡 | 亚洲精品一区二区18漫画 | 99re亚洲国产精品 | 婷婷六月天综合 | 91精品国产成人 | 成年人电影毛片 | 国产高清成人 | 久久久精品视频网站 | 日日夜夜爱 | 国产精品 中文字幕 亚洲 欧美 | 天天爱综合 | 97超碰中文字幕 | 日韩欧美综合在线视频 | 操操操人人| 国产精品涩涩屋www在线观看 | 久久久国产高清 | 日本精品一区二区三区在线播放视频 | av中文天堂 | 香蕉视频在线看 | 日韩视频免费看 | 国产又粗又猛又色又黄视频 | 免费观看www小视频的软件 | 久久久久伊人 | 91九色porny蝌蚪主页 | 91精品福利在线 | 米奇狠狠狠888 | 91视频在线播放视频 | 久久精品香蕉 | 92中文资源在线 | 天天激情站| 五月天伊人网 | 国产日韩欧美在线 | 国产精品免费观看国产网曝瓜 | 91黄色免费网站 | 国产精品一级在线 | 国产成人精品一区在线 | 亚洲好视频 | 九九热免费观看 | 最新日韩在线观看视频 | 五月婷婷导航 | 激情 婷婷 | 日韩视频在线观看视频 | 黄色最新网址 | 成人在线视频免费 | 美女免费黄网站 | 一区 二区 精品 | 日日夜精品 | 福利视频 | 免费福利在线观看 | 亚洲婷婷丁香 | 一区二区在线电影 | 久久精视频 | 69久久久 | 国产视频一区二区在线观看 | 国内精品久久久久久久久 | 日韩精品一区二区三区电影 | 久久免费视频一区 | 亚洲观看黄色网 | 夜色成人网 | 日韩国产欧美在线播放 | 99精品国产一区二区三区麻豆 | 免费黄色在线网站 | 欧美精品在线观看 | 精品国产乱子伦一区二区 | 在线观看黄色大片 | 国产一区免费看 | 一区二区三区福利 | 国产精品久久片 | 久久夜色精品国产欧美乱 | 国产精品久久久久久久久久久久午夜 | 国产福利一区二区三区在线观看 | 亚州国产精品 | 天天干天天干天天干天天干天天干天天干 | 五月婷婷中文网 | 国产精品12| 国产一区二区中文字幕 | 久久免费黄色大片 | 91传媒视频在线观看 | 国产视频一区二区三区在线 | 国产黄色片一级 | 97在线视 | 免费高清在线视频一区· | 91精品久久久久久久91蜜桃 | 狠狠色狠狠色综合日日小说 | 欧美午夜a| www.超碰 | 久久超碰免费 | 精品国产一区二区三区不卡 | 国产一级免费播放 | 日韩高清二区 | 国产日韩欧美视频在线观看 | 国产黄av| 国产一区二区三区免费在线观看 | 久久精品久久久久电影 | 国产一区二区午夜 | 九九久久国产精品 | 日日爱999| 国产高清福利在线 | 欧美日在线观看 | 98涩涩国产露脸精品国产网 | 一级免费观看 | 九九综合在线 | 中文字幕在线有码 | 国产精品乱码久久久 | 日日操夜夜操狠狠操 | 中文字幕二区 | 久久男人中文字幕资源站 | 不卡的av在线播放 | 久久超碰免费 |