forked from xiaozhi/xiaozhi-esp32
Add camera support for Otto Robot board (#1520)
* otto v1.4.0 MCP 1.使用MCP协议控制机器人 2.gif继承lcdDisplay,避免修改lcdDisplay * otto v1.4.1 gif as components gif as components * electronBot v1.1.0 mcp 1.增加electronBot支持 2.mcp协议 3.gif 作为组件 4.display子类 * 规范代码 1.规范代码 2.修复切换主题死机bug * fix(ota): 修复 ottoRobot和electronBot OTA 升级崩溃问题 bug * 1.增加robot舵机初始位置校准 2.fix(mcp_sever) 超出范围异常捕获类型 bug * refactor: Update Electron and Otto emoji display implementations - Removed GIF selection from Kconfig for Electron and Otto boards. - Updated Electron and Otto bot versions to 2.0.4 in their respective config files. - Refactored emoji display classes to utilize EmojiCollection for managing emojis. - Enhanced chat label setup and status display functionality in both classes. - Cleaned up unused code and improved initialization logging for emoji displays. * Rename OTTO_ICON_FONT.c to otto_icon_font.c * Rename OTTO_ICON_FONT.c to otto_icon_font.c * refactor: Update Otto emoji display configurations and functionalities - Changed chat label text mode to circular scrolling for both Otto and Electron emoji displays. - Bumped Otto robot version to 2.0.5 in the configuration file. - Added new actions for Otto robot including Sit, WhirlwindLeg, Fitness, Greeting, Shy, RadioCalisthenics, MagicCircle, and Showcase. - Enhanced servo sequence handling and added support for executing custom servo sequences. - Improved logging and error handling for servo sequence execution. * refactor: Update chat label long mode for Electron and Otto emoji displays - Changed chat label text mode from wrap to circular scrolling for both Electron and Otto emoji displays. - Improved consistency in chat label setup across both implementations. * Update Otto robot README with new actions and parameters * Update Otto controller parameters for oscillation settings - Changed default oscillation period from 500ms to 300ms. - Increased default steps from 5.0 to 8.0. - Updated default amplitude from 20 degrees to 0 degrees. - Enhanced documentation with new examples for oscillation modes and sequences. * Fix default amplitude initialization in Otto controller to use a single zero instead of two digits. * chore: update txp666/otto-emoji-gif-component version to 1.0.3 in idf_component.yml * Refactor Otto controller - Consolidated movement actions into a unified tool for the Otto robot, allowing for a single action command with various parameters. - Removed individual movement tools (walk, turn, jump, etc.) and replaced them with a more flexible action system. * Enhance Otto robot functionality by adding WebSocket control server and IP address retrieval feature. Updated config to support WebSocket, and revised README to include new control options and usage examples. * Add camera support for Otto Robot board - Introduced configuration option to enable the Otto Robot camera in Kconfig. - Updated config.h to define camera-related GPIO pins and settings. - Modified config.json to include camera configuration. - Enhanced otto_robot.cc to initialize I2C and camera components when the camera is enabled. - Adjusted power_manager.h to manage battery updates during camera operations. - Removed unused SetupChatLabel method from OttoEmojiDisplay class.
This commit is contained in:
@@ -12,7 +12,7 @@ private:
|
||||
static constexpr struct {
|
||||
uint16_t adc;
|
||||
uint8_t level;
|
||||
} BATTERY_LEVELS[] = {{2150, 0}, {2450, 100}};
|
||||
} BATTERY_LEVELS[] = {{2050, 0}, {2450, 100}};
|
||||
static constexpr size_t BATTERY_LEVELS_COUNT = 2;
|
||||
static constexpr size_t ADC_VALUES_COUNT = 10;
|
||||
|
||||
@@ -25,12 +25,23 @@ private:
|
||||
size_t adc_values_count_ = 0;
|
||||
uint8_t battery_level_ = 100;
|
||||
bool is_charging_ = false;
|
||||
inline static bool battery_update_paused_ = false; // 静态标志:是否暂停电量更新
|
||||
|
||||
adc_oneshot_unit_handle_t adc_handle_;
|
||||
|
||||
void CheckBatteryStatus() {
|
||||
// 如果电量更新被暂停(动作进行中),则跳过更新
|
||||
if (battery_update_paused_) {
|
||||
return;
|
||||
}
|
||||
|
||||
ReadBatteryAdcData();
|
||||
|
||||
if (charging_pin_ == GPIO_NUM_NC) {
|
||||
is_charging_ = false;
|
||||
} else {
|
||||
is_charging_ = gpio_get_level(charging_pin_) == 0;
|
||||
ReadBatteryAdcData();
|
||||
}
|
||||
}
|
||||
|
||||
void ReadBatteryAdcData() {
|
||||
@@ -71,6 +82,8 @@ public:
|
||||
PowerManager(gpio_num_t charging_pin, adc_unit_t adc_unit = ADC_UNIT_2,
|
||||
adc_channel_t adc_channel = ADC_CHANNEL_3)
|
||||
: charging_pin_(charging_pin), adc_unit_(adc_unit), adc_channel_(adc_channel) {
|
||||
|
||||
if (charging_pin_ != GPIO_NUM_NC) {
|
||||
gpio_config_t io_conf = {};
|
||||
io_conf.intr_type = GPIO_INTR_DISABLE;
|
||||
io_conf.mode = GPIO_MODE_INPUT;
|
||||
@@ -78,6 +91,10 @@ public:
|
||||
io_conf.pull_down_en = GPIO_PULLDOWN_DISABLE;
|
||||
io_conf.pull_up_en = GPIO_PULLUP_ENABLE;
|
||||
gpio_config(&io_conf);
|
||||
ESP_LOGI("PowerManager", "充电检测引脚配置完成: GPIO%d", charging_pin_);
|
||||
} else {
|
||||
ESP_LOGI("PowerManager", "充电检测引脚未配置,不进行充电状态检测");
|
||||
}
|
||||
|
||||
esp_timer_create_args_t timer_args = {
|
||||
.callback =
|
||||
@@ -97,18 +114,20 @@ public:
|
||||
}
|
||||
|
||||
void InitializeAdc() {
|
||||
adc_oneshot_unit_init_cfg_t init_config = {
|
||||
.unit_id = adc_unit_,
|
||||
.ulp_mode = ADC_ULP_MODE_DISABLE,
|
||||
};
|
||||
ESP_ERROR_CHECK(adc_oneshot_new_unit(&init_config, &adc_handle_));
|
||||
adc_oneshot_unit_init_cfg_t init_config = {
|
||||
.unit_id = adc_unit_,
|
||||
.clk_src = ADC_RTC_CLK_SRC_DEFAULT,
|
||||
.ulp_mode = ADC_ULP_MODE_DISABLE,
|
||||
};
|
||||
ESP_ERROR_CHECK(adc_oneshot_new_unit(&init_config, &adc_handle_));
|
||||
|
||||
adc_oneshot_chan_cfg_t chan_config = {
|
||||
.atten = ADC_ATTEN_DB_12,
|
||||
.bitwidth = ADC_BITWIDTH_12,
|
||||
};
|
||||
adc_oneshot_chan_cfg_t chan_config = {
|
||||
.atten = ADC_ATTEN_DB_12,
|
||||
.bitwidth = ADC_BITWIDTH_12,
|
||||
};
|
||||
|
||||
ESP_ERROR_CHECK(adc_oneshot_config_channel(adc_handle_, adc_channel_, &chan_config));
|
||||
ESP_ERROR_CHECK(
|
||||
adc_oneshot_config_channel(adc_handle_, adc_channel_, &chan_config));
|
||||
}
|
||||
|
||||
~PowerManager() {
|
||||
@@ -124,5 +143,9 @@ public:
|
||||
bool IsCharging() { return is_charging_; }
|
||||
|
||||
uint8_t GetBatteryLevel() { return battery_level_; }
|
||||
|
||||
// 暂停/恢复电量更新(用于动作执行时屏蔽更新)
|
||||
static void PauseBatteryUpdate() { battery_update_paused_ = true; }
|
||||
static void ResumeBatteryUpdate() { battery_update_paused_ = false; }
|
||||
};
|
||||
#endif // __POWER_MANAGER_H__
|
||||
Reference in New Issue
Block a user