forked from xiaozhi/xiaozhi-esp32
Refactor Otto Robot configuration and initialization (#1534)
* 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. * Refactor Otto Robot configuration and initialization - Removed the camera configuration option from Kconfig and related code. - Introduced a new HardwareConfig struct to encapsulate hardware pin definitions and settings. - Updated config.h to define camera and non-camera configurations using the new struct. - Refactored otto_controller.cc and otto_robot.cc to utilize the HardwareConfig struct for initialization. - Enhanced camera detection and initialization logic based on hardware version. - Improved audio codec initialization based on configuration settings.
This commit is contained in:
@@ -2,36 +2,124 @@
|
||||
#define _BOARD_CONFIG_H_
|
||||
|
||||
#include <driver/gpio.h>
|
||||
#include <driver/adc.h>
|
||||
|
||||
#if CONFIG_OTTO_ROBOT_USE_CAMERA
|
||||
#define POWER_CHARGE_DETECT_PIN GPIO_NUM_NC
|
||||
#define POWER_ADC_UNIT ADC_UNIT_1
|
||||
#define POWER_ADC_CHANNEL ADC_CHANNEL_1
|
||||
struct HardwareConfig {
|
||||
gpio_num_t power_charge_detect_pin;
|
||||
adc_unit_t power_adc_unit;
|
||||
adc_channel_t power_adc_channel;
|
||||
|
||||
gpio_num_t right_leg_pin;
|
||||
gpio_num_t right_foot_pin;
|
||||
gpio_num_t left_leg_pin;
|
||||
gpio_num_t left_foot_pin;
|
||||
gpio_num_t left_hand_pin;
|
||||
gpio_num_t right_hand_pin;
|
||||
|
||||
int audio_input_sample_rate;
|
||||
int audio_output_sample_rate;
|
||||
bool audio_use_simplex;
|
||||
|
||||
gpio_num_t audio_i2s_gpio_ws;
|
||||
gpio_num_t audio_i2s_gpio_bclk;
|
||||
gpio_num_t audio_i2s_gpio_din;
|
||||
gpio_num_t audio_i2s_gpio_dout;
|
||||
|
||||
gpio_num_t audio_i2s_mic_gpio_ws;
|
||||
gpio_num_t audio_i2s_mic_gpio_sck;
|
||||
gpio_num_t audio_i2s_mic_gpio_din;
|
||||
gpio_num_t audio_i2s_spk_gpio_dout;
|
||||
gpio_num_t audio_i2s_spk_gpio_bclk;
|
||||
gpio_num_t audio_i2s_spk_gpio_lrck;
|
||||
|
||||
gpio_num_t display_backlight_pin;
|
||||
gpio_num_t display_mosi_pin;
|
||||
gpio_num_t display_clk_pin;
|
||||
gpio_num_t display_dc_pin;
|
||||
gpio_num_t display_rst_pin;
|
||||
gpio_num_t display_cs_pin;
|
||||
|
||||
gpio_num_t i2c_sda_pin;
|
||||
gpio_num_t i2c_scl_pin;
|
||||
};
|
||||
|
||||
#define RIGHT_LEG_PIN GPIO_NUM_43
|
||||
#define RIGHT_FOOT_PIN GPIO_NUM_44
|
||||
#define LEFT_LEG_PIN GPIO_NUM_5
|
||||
#define LEFT_FOOT_PIN GPIO_NUM_6
|
||||
#define LEFT_HAND_PIN GPIO_NUM_4
|
||||
#define RIGHT_HAND_PIN GPIO_NUM_7
|
||||
constexpr HardwareConfig CAMERA_VERSION_CONFIG = {
|
||||
.power_charge_detect_pin = GPIO_NUM_NC,
|
||||
.power_adc_unit = ADC_UNIT_1,
|
||||
.power_adc_channel = ADC_CHANNEL_1,
|
||||
|
||||
.right_leg_pin = GPIO_NUM_43,
|
||||
.right_foot_pin = GPIO_NUM_44,
|
||||
.left_leg_pin = GPIO_NUM_5,
|
||||
.left_foot_pin = GPIO_NUM_6,
|
||||
.left_hand_pin = GPIO_NUM_4,
|
||||
.right_hand_pin = GPIO_NUM_7,
|
||||
|
||||
.audio_input_sample_rate = 16000,
|
||||
.audio_output_sample_rate = 16000,
|
||||
.audio_use_simplex = false,
|
||||
|
||||
.audio_i2s_gpio_ws = GPIO_NUM_40,
|
||||
.audio_i2s_gpio_bclk = GPIO_NUM_42,
|
||||
.audio_i2s_gpio_din = GPIO_NUM_41,
|
||||
.audio_i2s_gpio_dout = GPIO_NUM_39,
|
||||
|
||||
.audio_i2s_mic_gpio_ws = GPIO_NUM_NC,
|
||||
.audio_i2s_mic_gpio_sck = GPIO_NUM_NC,
|
||||
.audio_i2s_mic_gpio_din = GPIO_NUM_NC,
|
||||
.audio_i2s_spk_gpio_dout = GPIO_NUM_NC,
|
||||
.audio_i2s_spk_gpio_bclk = GPIO_NUM_NC,
|
||||
.audio_i2s_spk_gpio_lrck = GPIO_NUM_NC,
|
||||
|
||||
.display_backlight_pin = GPIO_NUM_38,
|
||||
.display_mosi_pin = GPIO_NUM_45,
|
||||
.display_clk_pin = GPIO_NUM_48,
|
||||
.display_dc_pin = GPIO_NUM_47,
|
||||
.display_rst_pin = GPIO_NUM_1,
|
||||
.display_cs_pin = GPIO_NUM_NC,
|
||||
|
||||
.i2c_sda_pin = GPIO_NUM_15,
|
||||
.i2c_scl_pin = GPIO_NUM_16,
|
||||
};
|
||||
|
||||
#define AUDIO_INPUT_SAMPLE_RATE 16000
|
||||
#define AUDIO_OUTPUT_SAMPLE_RATE 16000
|
||||
|
||||
#define AUDIO_I2S_GPIO_WS GPIO_NUM_40
|
||||
#define AUDIO_I2S_GPIO_BCLK GPIO_NUM_42
|
||||
#define AUDIO_I2S_GPIO_DIN GPIO_NUM_41
|
||||
#define AUDIO_I2S_GPIO_DOUT GPIO_NUM_39
|
||||
|
||||
#define DISPLAY_BACKLIGHT_PIN GPIO_NUM_38
|
||||
#define DISPLAY_MOSI_PIN GPIO_NUM_45
|
||||
#define DISPLAY_CLK_PIN GPIO_NUM_48
|
||||
#define DISPLAY_DC_PIN GPIO_NUM_47
|
||||
#define DISPLAY_RST_PIN GPIO_NUM_1
|
||||
#define DISPLAY_CS_PIN GPIO_NUM_NC
|
||||
/* Camera PINs*/
|
||||
#define I2C_SDA_PIN GPIO_NUM_15
|
||||
#define I2C_SCL_PIN GPIO_NUM_16
|
||||
constexpr HardwareConfig NON_CAMERA_VERSION_CONFIG = {
|
||||
.power_charge_detect_pin = GPIO_NUM_21,
|
||||
.power_adc_unit = ADC_UNIT_2,
|
||||
.power_adc_channel = ADC_CHANNEL_3,
|
||||
|
||||
.right_leg_pin = GPIO_NUM_39,
|
||||
.right_foot_pin = GPIO_NUM_38,
|
||||
.left_leg_pin = GPIO_NUM_17,
|
||||
.left_foot_pin = GPIO_NUM_18,
|
||||
.left_hand_pin = GPIO_NUM_8,
|
||||
.right_hand_pin = GPIO_NUM_12,
|
||||
|
||||
.audio_input_sample_rate = 16000,
|
||||
.audio_output_sample_rate = 24000,
|
||||
.audio_use_simplex = true,
|
||||
|
||||
.audio_i2s_gpio_ws = GPIO_NUM_NC,
|
||||
.audio_i2s_gpio_bclk = GPIO_NUM_NC,
|
||||
.audio_i2s_gpio_din = GPIO_NUM_NC,
|
||||
.audio_i2s_gpio_dout = GPIO_NUM_NC,
|
||||
|
||||
.audio_i2s_mic_gpio_ws = GPIO_NUM_4,
|
||||
.audio_i2s_mic_gpio_sck = GPIO_NUM_5,
|
||||
.audio_i2s_mic_gpio_din = GPIO_NUM_6,
|
||||
.audio_i2s_spk_gpio_dout = GPIO_NUM_7,
|
||||
.audio_i2s_spk_gpio_bclk = GPIO_NUM_15,
|
||||
.audio_i2s_spk_gpio_lrck = GPIO_NUM_16,
|
||||
|
||||
.display_backlight_pin = GPIO_NUM_3,
|
||||
.display_mosi_pin = GPIO_NUM_10,
|
||||
.display_clk_pin = GPIO_NUM_9,
|
||||
.display_dc_pin = GPIO_NUM_46,
|
||||
.display_rst_pin = GPIO_NUM_11,
|
||||
.display_cs_pin = GPIO_NUM_12,
|
||||
|
||||
.i2c_sda_pin = GPIO_NUM_NC,
|
||||
.i2c_scl_pin = GPIO_NUM_NC,
|
||||
};
|
||||
|
||||
#define CAMERA_XCLK (GPIO_NUM_3)
|
||||
#define CAMERA_PCLK (GPIO_NUM_10)
|
||||
@@ -45,49 +133,12 @@
|
||||
#define CAMERA_D5 (GPIO_NUM_9)
|
||||
#define CAMERA_D6 (GPIO_NUM_46)
|
||||
#define CAMERA_D7 (GPIO_NUM_8)
|
||||
|
||||
#define CAMERA_PWDN (GPIO_NUM_NC)
|
||||
#define CAMERA_RESET (GPIO_NUM_NC)
|
||||
|
||||
#define CAMERA_XCLK_FREQ (16000000)
|
||||
#define LEDC_TIMER (LEDC_TIMER_0)
|
||||
#define LEDC_CHANNEL (LEDC_CHANNEL_0)
|
||||
|
||||
#define CAMERA_SIOD (GPIO_NUM_NC)
|
||||
#define CAMERA_SIOC (GPIO_NUM_NC)
|
||||
|
||||
#else
|
||||
#define POWER_CHARGE_DETECT_PIN GPIO_NUM_21
|
||||
#define POWER_ADC_UNIT ADC_UNIT_2
|
||||
#define POWER_ADC_CHANNEL ADC_CHANNEL_3
|
||||
|
||||
#define RIGHT_LEG_PIN GPIO_NUM_39
|
||||
#define RIGHT_FOOT_PIN GPIO_NUM_38
|
||||
#define LEFT_LEG_PIN GPIO_NUM_17
|
||||
#define LEFT_FOOT_PIN GPIO_NUM_18
|
||||
#define LEFT_HAND_PIN GPIO_NUM_8
|
||||
#define RIGHT_HAND_PIN GPIO_NUM_12
|
||||
|
||||
#define AUDIO_INPUT_SAMPLE_RATE 16000
|
||||
#define AUDIO_OUTPUT_SAMPLE_RATE 24000
|
||||
#define AUDIO_I2S_METHOD_SIMPLEX
|
||||
|
||||
#define AUDIO_I2S_MIC_GPIO_WS GPIO_NUM_4
|
||||
#define AUDIO_I2S_MIC_GPIO_SCK GPIO_NUM_5
|
||||
#define AUDIO_I2S_MIC_GPIO_DIN GPIO_NUM_6
|
||||
#define AUDIO_I2S_SPK_GPIO_DOUT GPIO_NUM_7
|
||||
#define AUDIO_I2S_SPK_GPIO_BCLK GPIO_NUM_15
|
||||
#define AUDIO_I2S_SPK_GPIO_LRCK GPIO_NUM_16
|
||||
|
||||
#define DISPLAY_BACKLIGHT_PIN GPIO_NUM_3
|
||||
#define DISPLAY_MOSI_PIN GPIO_NUM_10
|
||||
#define DISPLAY_CLK_PIN GPIO_NUM_9
|
||||
#define DISPLAY_DC_PIN GPIO_NUM_46
|
||||
#define DISPLAY_RST_PIN GPIO_NUM_11
|
||||
#define DISPLAY_CS_PIN GPIO_NUM_12
|
||||
|
||||
#endif
|
||||
|
||||
#define LCD_TYPE_ST7789_SERIAL
|
||||
#define DISPLAY_WIDTH 240
|
||||
#define DISPLAY_HEIGHT 240
|
||||
@@ -103,5 +154,4 @@
|
||||
|
||||
#define BOOT_BUTTON_GPIO GPIO_NUM_0
|
||||
|
||||
|
||||
#endif // _BOARD_CONFIG_H_
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user