#include "encoder.h" #include "zboard.h" #include #include "zport.h" #include "udpclient.h" static encoder_light_state_t camera_encoder_state = STANDBY; static encoder_light_state_t driven_encoder_gear_state = STANDBY; static uint32_t camera_encoder_lastprocess = 0; static uint32_t driven_encoder_gear_lastprocess = 0; static encoder_t m_uarts[] = { {&camera_encoder, TIM_CHANNEL_1 | TIM_CHANNEL_2}, // 相机编码器 {&driven_encoder_gear, TIM_CHANNEL_1 | TIM_CHANNEL_2} // 从动编码器 }; void encoder_all_start(void) { for (uint8_t i = 0; i < (sizeof(m_uarts) / sizeof(encoder_t)); i++) { HAL_TIM_Encoder_Start(m_uarts[i].tim_handler, m_uarts[i].tim_channel); } } void encoder_all_stop(void) { for (uint8_t i = 0; i < (sizeof(m_uarts) / sizeof(encoder_t)); i++) { HAL_TIM_Encoder_Stop(m_uarts[i].tim_handler, m_uarts[i].tim_channel); } } bool encoder_clear_counter(encoder_usage_t encoder) { for (uint8_t i = 0; i < (sizeof(m_uarts) / sizeof(encoder_t)); i++) { if (encoder == i) { __HAL_TIM_GET_COUNTER(m_uarts[i].tim_handler) = 0; return true; } } return false; } void encoder_all_clear_counter(void) { for (uint8_t i = 0; i < (sizeof(m_uarts) / sizeof(encoder_t)); i++) { __HAL_TIM_GET_COUNTER(m_uarts[i].tim_handler) = 0; // 计数器值重新置位 } } bool encoder_read_with_encoder(encoder_usage_t encoder, uint32_t *encoder_value) { bool get_encoder_value_flag = false; switch (encoder) { case CAMERA_ENCODER: *encoder_value += (short)__HAL_TIM_GET_COUNTER(m_uarts[encoder].tim_handler); __HAL_TIM_GET_COUNTER(m_uarts[encoder].tim_handler) = 0; /* 清零 */ get_encoder_value_flag = true; break; case DRIVEN_ENCODER_GEAR: *encoder_value += (short)__HAL_TIM_GET_COUNTER(m_uarts[encoder].tim_handler); __HAL_TIM_GET_COUNTER(m_uarts[encoder].tim_handler) = 0; /* 清零 */ get_encoder_value_flag = true; break; default: break; } return get_encoder_value_flag; } void encoder_light_schedule(void) { if (camera_encoder_state == STANDBY) { if (sys_haspassedms(camera_encoder_lastprocess) > 500) { camera_encoder_lastprocess = HAL_GetTick(); HAL_GPIO_TogglePin(ENCODER_LIGHT_GPIO_Port, ENCODER_LIGHT_Pin); } } if (driven_encoder_gear_state == STANDBY) { if (sys_haspassedms(camera_encoder_lastprocess) > 500) { driven_encoder_gear_lastprocess = HAL_GetTick(); // HAL_GPIO_TogglePin(ENCODER_LIGHT_GPIO_Port, ENCODER_LIGHT_Pin); } } } void encoder_set_state(encoder_usage_t encoder, encoder_light_state_t state) { /* 主动上报的时候常亮,接收到触发指令直接翻转led,待机中0.5s周期闪烁 */ if (encoder == CAMERA_ENCODER) { camera_encoder_state = state; if (state == STANDBY) { camera_encoder_lastprocess = HAL_GetTick(); HAL_GPIO_TogglePin(ENCODER_LIGHT_GPIO_Port, ENCODER_LIGHT_Pin); } else if (state == WORKING) { /* 如果工作状态的时候触发了genlock等,灯的状态不应该变成待机状态,只有同为待机的时候闪烁,上层写的时候需要加判断 */ HAL_GPIO_WritePin(ENCODER_LIGHT_GPIO_Port, ENCODER_LIGHT_Pin, GPIO_PIN_RESET); } } else if (encoder == DRIVEN_ENCODER_GEAR) { driven_encoder_gear_state = state; if (state == STANDBY) { driven_encoder_gear_lastprocess = HAL_GetTick(); // HAL_GPIO_TogglePin(ENCODER_LIGHT_GPIO_Port, ENCODER_LIGHT_Pin); } else if (state == WORKING) { // HAL_GPIO_WritePin(ENCODER_LIGHT_GPIO_Port, ENCODER_LIGHT_Pin, GPIO_PIN_SET); } } } encoder_light_state_t encoder_get_state(encoder_usage_t encoder) { if (encoder == CAMERA_ENCODER) { return camera_encoder_state; } else if (encoder == DRIVEN_ENCODER_GEAR) { return driven_encoder_gear_state; } return ENCODER_STATE_NUMBER_AND_ERR_STATE; } void encoder_all_encoder_clear_counter_and_structer_count(void) { udp_client_get_active_report_data_structer()->encoder_1_count = 0; udp_client_get_active_report_data_structer()->encoder_2_count = 0; encoder_all_clear_counter(); } void encoder_switch_encoder_clear_count_and_structer_count(encoder_usage_t encoder) { switch (encoder) { case CAMERA_ENCODER: udp_client_get_active_report_data_structer()->encoder_1_count = 0; encoder_clear_counter(CAMERA_ENCODER); break; case DRIVEN_ENCODER_GEAR: udp_client_get_active_report_data_structer()->encoder_2_count = 0; encoder_clear_counter(DRIVEN_ENCODER_GEAR); break; default: break; } }