Double click BOOT to switch 4G/Wi-Fi
This commit is contained in:
parent
ee0df3470c
commit
b6489a3456
@ -145,8 +145,6 @@ elseif(CONFIG_BOARD_TYPE_XINGZHI_Cube_1_54TFT_WIFI)
|
|||||||
set(BOARD_TYPE "xingzhi-cube-1.54tft-wifi")
|
set(BOARD_TYPE "xingzhi-cube-1.54tft-wifi")
|
||||||
elseif(CONFIG_BOARD_TYPE_XINGZHI_Cube_1_54TFT_ML307)
|
elseif(CONFIG_BOARD_TYPE_XINGZHI_Cube_1_54TFT_ML307)
|
||||||
set(BOARD_TYPE "xingzhi-cube-1.54tft-ml307")
|
set(BOARD_TYPE "xingzhi-cube-1.54tft-ml307")
|
||||||
elseif(CONFIG_BOARD_TYPE_XINGZHI_Cube_1_54TFT_DUAL)
|
|
||||||
set(BOARD_TYPE "xingzhi-cube-1.54tft-dual")
|
|
||||||
elseif(CONFIG_BOARD_TYPE_SENSECAP_WATCHER)
|
elseif(CONFIG_BOARD_TYPE_SENSECAP_WATCHER)
|
||||||
set(BOARD_TYPE "sensecap-watcher")
|
set(BOARD_TYPE "sensecap-watcher")
|
||||||
elseif(CONFIG_BOARD_TYPE_DOIT_S3_AIBOX)
|
elseif(CONFIG_BOARD_TYPE_DOIT_S3_AIBOX)
|
||||||
|
|||||||
@ -140,8 +140,6 @@ choice BOARD_TYPE
|
|||||||
bool "无名科技星智1.54(WIFI)"
|
bool "无名科技星智1.54(WIFI)"
|
||||||
config BOARD_TYPE_XINGZHI_Cube_1_54TFT_ML307
|
config BOARD_TYPE_XINGZHI_Cube_1_54TFT_ML307
|
||||||
bool "无名科技星智1.54(ML307)"
|
bool "无名科技星智1.54(ML307)"
|
||||||
config BOARD_TYPE_XINGZHI_Cube_1_54TFT_DUAL
|
|
||||||
bool "无名科技星智1.54(DUAL)"
|
|
||||||
config BOARD_TYPE_SENSECAP_WATCHER
|
config BOARD_TYPE_SENSECAP_WATCHER
|
||||||
bool "SenseCAP Watcher"
|
bool "SenseCAP Watcher"
|
||||||
config BOARD_TYPE_DOIT_S3_AIBOX
|
config BOARD_TYPE_DOIT_S3_AIBOX
|
||||||
|
|||||||
@ -15,6 +15,8 @@
|
|||||||
"REGISTERING_NETWORK": "Waiting for network...",
|
"REGISTERING_NETWORK": "Waiting for network...",
|
||||||
"CHECKING_NEW_VERSION": "Checking for new version...",
|
"CHECKING_NEW_VERSION": "Checking for new version...",
|
||||||
"CHECK_NEW_VERSION_FAILED": "Check for new version failed, will retry in %d seconds: %s",
|
"CHECK_NEW_VERSION_FAILED": "Check for new version failed, will retry in %d seconds: %s",
|
||||||
|
"SWITCH_TO_WIFI_NETWORK": "Switching to Wi-Fi...",
|
||||||
|
"SWITCH_TO_4G_NETWORK": "Switching to 4G...",
|
||||||
|
|
||||||
"STANDBY": "Standby",
|
"STANDBY": "Standby",
|
||||||
"CONNECT_TO": "Connect to ",
|
"CONNECT_TO": "Connect to ",
|
||||||
|
|||||||
@ -15,6 +15,8 @@
|
|||||||
"REGISTERING_NETWORK": "ネットワーク接続待機中...",
|
"REGISTERING_NETWORK": "ネットワーク接続待機中...",
|
||||||
"CHECKING_NEW_VERSION": "新しいバージョンを確認中...",
|
"CHECKING_NEW_VERSION": "新しいバージョンを確認中...",
|
||||||
"CHECK_NEW_VERSION_FAILED": "更新確認に失敗しました。%d 秒後に再試行します: %s",
|
"CHECK_NEW_VERSION_FAILED": "更新確認に失敗しました。%d 秒後に再試行します: %s",
|
||||||
|
"SWITCH_TO_WIFI_NETWORK": "Wi-Fiに切り替え中...",
|
||||||
|
"SWITCH_TO_4G_NETWORK": "4Gに切り替え中...",
|
||||||
|
|
||||||
"STANDBY": "待機中",
|
"STANDBY": "待機中",
|
||||||
"CONNECT_TO": "接続先 ",
|
"CONNECT_TO": "接続先 ",
|
||||||
|
|||||||
@ -15,6 +15,8 @@
|
|||||||
"REGISTERING_NETWORK":"等待网络...",
|
"REGISTERING_NETWORK":"等待网络...",
|
||||||
"CHECKING_NEW_VERSION":"检查新版本...",
|
"CHECKING_NEW_VERSION":"检查新版本...",
|
||||||
"CHECK_NEW_VERSION_FAILED":"检查新版本失败,将在 %d 秒后重试:%s",
|
"CHECK_NEW_VERSION_FAILED":"检查新版本失败,将在 %d 秒后重试:%s",
|
||||||
|
"SWITCH_TO_WIFI_NETWORK":"切换到 Wi-Fi...",
|
||||||
|
"SWITCH_TO_4G_NETWORK":"切换到 4G...",
|
||||||
|
|
||||||
"STANDBY":"待命",
|
"STANDBY":"待命",
|
||||||
"CONNECT_TO":"连接 ",
|
"CONNECT_TO":"连接 ",
|
||||||
|
|||||||
@ -15,6 +15,8 @@
|
|||||||
"REGISTERING_NETWORK": "等待網絡...",
|
"REGISTERING_NETWORK": "等待網絡...",
|
||||||
"CHECKING_NEW_VERSION": "檢查新版本...",
|
"CHECKING_NEW_VERSION": "檢查新版本...",
|
||||||
"CHECK_NEW_VERSION_FAILED": "檢查新版本失敗,將在 %d 秒後重試:%s",
|
"CHECK_NEW_VERSION_FAILED": "檢查新版本失敗,將在 %d 秒後重試:%s",
|
||||||
|
"SWITCH_TO_WIFI_NETWORK": "切換到 Wi-Fi...",
|
||||||
|
"SWITCH_TO_4G_NETWORK": "切換到 4G...",
|
||||||
|
|
||||||
"STANDBY": "待命",
|
"STANDBY": "待命",
|
||||||
"CONNECT_TO": "連接 ",
|
"CONNECT_TO": "連接 ",
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
#include "ml307_board.h"
|
#include "dual_network_board.h"
|
||||||
#include "audio_codecs/no_audio_codec.h"
|
#include "audio_codecs/no_audio_codec.h"
|
||||||
#include "display/oled_display.h"
|
#include "display/oled_display.h"
|
||||||
#include "system_reset.h"
|
#include "system_reset.h"
|
||||||
@ -13,13 +13,14 @@
|
|||||||
#include <driver/i2c_master.h>
|
#include <driver/i2c_master.h>
|
||||||
#include <esp_lcd_panel_ops.h>
|
#include <esp_lcd_panel_ops.h>
|
||||||
#include <esp_lcd_panel_vendor.h>
|
#include <esp_lcd_panel_vendor.h>
|
||||||
|
#include <wifi_station.h>
|
||||||
|
|
||||||
#define TAG "CompactMl307Board"
|
#define TAG "CompactMl307Board"
|
||||||
|
|
||||||
LV_FONT_DECLARE(font_puhui_14_1);
|
LV_FONT_DECLARE(font_puhui_14_1);
|
||||||
LV_FONT_DECLARE(font_awesome_14_1);
|
LV_FONT_DECLARE(font_awesome_14_1);
|
||||||
|
|
||||||
class CompactMl307Board : public Ml307Board {
|
class CompactMl307Board : public DualNetworkBoard {
|
||||||
private:
|
private:
|
||||||
i2c_master_bus_handle_t display_i2c_bus_;
|
i2c_master_bus_handle_t display_i2c_bus_;
|
||||||
esp_lcd_panel_io_handle_t panel_io_ = nullptr;
|
esp_lcd_panel_io_handle_t panel_io_ = nullptr;
|
||||||
@ -96,8 +97,23 @@ private:
|
|||||||
|
|
||||||
void InitializeButtons() {
|
void InitializeButtons() {
|
||||||
boot_button_.OnClick([this]() {
|
boot_button_.OnClick([this]() {
|
||||||
Application::GetInstance().ToggleChatState();
|
auto& app = Application::GetInstance();
|
||||||
|
if (GetNetworkType() == NetworkType::WIFI) {
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting && !WifiStation::GetInstance().IsConnected()) {
|
||||||
|
// cast to WifiBoard
|
||||||
|
auto& wifi_board = static_cast<WifiBoard&>(GetCurrentBoard());
|
||||||
|
wifi_board.ResetWifiConfiguration();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
app.ToggleChatState();
|
||||||
});
|
});
|
||||||
|
boot_button_.OnDoubleClick([this]() {
|
||||||
|
auto& app = Application::GetInstance();
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting || app.GetDeviceState() == kDeviceStateWifiConfiguring) {
|
||||||
|
SwitchNetworkType();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
touch_button_.OnPressDown([this]() {
|
touch_button_.OnPressDown([this]() {
|
||||||
Application::GetInstance().StartListening();
|
Application::GetInstance().StartListening();
|
||||||
});
|
});
|
||||||
@ -144,7 +160,7 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
CompactMl307Board() : Ml307Board(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
CompactMl307Board() : DualNetworkBoard(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
||||||
boot_button_(BOOT_BUTTON_GPIO),
|
boot_button_(BOOT_BUTTON_GPIO),
|
||||||
touch_button_(TOUCH_BUTTON_GPIO),
|
touch_button_(TOUCH_BUTTON_GPIO),
|
||||||
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
||||||
|
|||||||
@ -42,14 +42,18 @@ void DualNetworkBoard::InitializeCurrentBoard() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void DualNetworkBoard::SwitchNetType() {
|
void DualNetworkBoard::SwitchNetworkType() {
|
||||||
|
auto display = GetDisplay();
|
||||||
if (network_type_ == NetworkType::WIFI) {
|
if (network_type_ == NetworkType::WIFI) {
|
||||||
ESP_LOGI(TAG, "Switch to ML307 mode");
|
|
||||||
SaveNetworkTypeToSettings(NetworkType::ML307);
|
SaveNetworkTypeToSettings(NetworkType::ML307);
|
||||||
|
display->ShowNotification(Lang::Strings::SWITCH_TO_4G_NETWORK);
|
||||||
} else {
|
} else {
|
||||||
ESP_LOGI(TAG, "Switch to WiFi mode");
|
|
||||||
SaveNetworkTypeToSettings(NetworkType::WIFI);
|
SaveNetworkTypeToSettings(NetworkType::WIFI);
|
||||||
|
display->ShowNotification(Lang::Strings::SWITCH_TO_WIFI_NETWORK);
|
||||||
}
|
}
|
||||||
|
vTaskDelay(pdMS_TO_TICKS(1000));
|
||||||
|
auto& app = Application::GetInstance();
|
||||||
|
app.Reboot();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -38,7 +38,7 @@ public:
|
|||||||
virtual ~DualNetworkBoard() = default;
|
virtual ~DualNetworkBoard() = default;
|
||||||
|
|
||||||
// 切换网络类型
|
// 切换网络类型
|
||||||
void SwitchNetType();
|
void SwitchNetworkType();
|
||||||
|
|
||||||
// 获取当前网络类型
|
// 获取当前网络类型
|
||||||
NetworkType GetNetworkType() const { return network_type_; }
|
NetworkType GetNetworkType() const { return network_type_; }
|
||||||
|
|||||||
@ -1,4 +1,4 @@
|
|||||||
#include "ml307_board.h"
|
#include "dual_network_board.h"
|
||||||
#include "audio_codecs/box_audio_codec.h"
|
#include "audio_codecs/box_audio_codec.h"
|
||||||
#include "display/oled_display.h"
|
#include "display/oled_display.h"
|
||||||
#include "application.h"
|
#include "application.h"
|
||||||
@ -10,6 +10,7 @@
|
|||||||
#include "axp2101.h"
|
#include "axp2101.h"
|
||||||
#include "assets/lang_config.h"
|
#include "assets/lang_config.h"
|
||||||
|
|
||||||
|
#include <wifi_station.h>
|
||||||
#include <esp_log.h>
|
#include <esp_log.h>
|
||||||
#include <driver/gpio.h>
|
#include <driver/gpio.h>
|
||||||
#include <driver/i2c_master.h>
|
#include <driver/i2c_master.h>
|
||||||
@ -51,7 +52,7 @@ public:
|
|||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
class KevinBoxBoard : public Ml307Board {
|
class KevinBoxBoard : public DualNetworkBoard {
|
||||||
private:
|
private:
|
||||||
i2c_master_bus_handle_t display_i2c_bus_;
|
i2c_master_bus_handle_t display_i2c_bus_;
|
||||||
i2c_master_bus_handle_t codec_i2c_bus_;
|
i2c_master_bus_handle_t codec_i2c_bus_;
|
||||||
@ -169,10 +170,28 @@ private:
|
|||||||
void InitializeButtons() {
|
void InitializeButtons() {
|
||||||
boot_button_.OnPressDown([this]() {
|
boot_button_.OnPressDown([this]() {
|
||||||
power_save_timer_->WakeUp();
|
power_save_timer_->WakeUp();
|
||||||
Application::GetInstance().StartListening();
|
auto& app = Application::GetInstance();
|
||||||
|
app.StartListening();
|
||||||
});
|
});
|
||||||
boot_button_.OnPressUp([this]() {
|
boot_button_.OnPressUp([this]() {
|
||||||
Application::GetInstance().StopListening();
|
auto& app = Application::GetInstance();
|
||||||
|
app.StopListening();
|
||||||
|
});
|
||||||
|
boot_button_.OnClick([this]() {
|
||||||
|
auto& app = Application::GetInstance();
|
||||||
|
if (GetNetworkType() == NetworkType::WIFI) {
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting && !WifiStation::GetInstance().IsConnected()) {
|
||||||
|
// cast to WifiBoard
|
||||||
|
auto& wifi_board = static_cast<WifiBoard&>(GetCurrentBoard());
|
||||||
|
wifi_board.ResetWifiConfiguration();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
boot_button_.OnDoubleClick([this]() {
|
||||||
|
auto& app = Application::GetInstance();
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting || app.GetDeviceState() == kDeviceStateWifiConfiguring) {
|
||||||
|
SwitchNetworkType();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
volume_up_button_.OnClick([this]() {
|
volume_up_button_.OnClick([this]() {
|
||||||
@ -218,7 +237,7 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
KevinBoxBoard() : Ml307Board(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
KevinBoxBoard() : DualNetworkBoard(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
||||||
boot_button_(BOOT_BUTTON_GPIO),
|
boot_button_(BOOT_BUTTON_GPIO),
|
||||||
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
||||||
volume_down_button_(VOLUME_DOWN_BUTTON_GPIO) {
|
volume_down_button_(VOLUME_DOWN_BUTTON_GPIO) {
|
||||||
|
|||||||
@ -1,14 +1,14 @@
|
|||||||
#include "ml307_board.h"
|
#include "dual_network_board.h"
|
||||||
#include "audio_codecs/no_audio_codec.h"
|
#include "audio_codecs/no_audio_codec.h"
|
||||||
#include "display/oled_display.h"
|
#include "display/oled_display.h"
|
||||||
#include "system_reset.h"
|
#include "system_reset.h"
|
||||||
#include "application.h"
|
#include "application.h"
|
||||||
#include "button.h"
|
#include "button.h"
|
||||||
#include "config.h"
|
#include "config.h"
|
||||||
|
#include "power_save_timer.h"
|
||||||
#include "iot/thing_manager.h"
|
#include "iot/thing_manager.h"
|
||||||
#include "led/single_led.h"
|
#include "led/single_led.h"
|
||||||
#include "assets/lang_config.h"
|
#include "assets/lang_config.h"
|
||||||
#include "power_save_timer.h"
|
|
||||||
#include "../xingzhi-cube-1.54tft-wifi/power_manager.h"
|
#include "../xingzhi-cube-1.54tft-wifi/power_manager.h"
|
||||||
|
|
||||||
#include <driver/rtc_io.h>
|
#include <driver/rtc_io.h>
|
||||||
@ -17,6 +17,7 @@
|
|||||||
#include <driver/i2c_master.h>
|
#include <driver/i2c_master.h>
|
||||||
#include <esp_lcd_panel_ops.h>
|
#include <esp_lcd_panel_ops.h>
|
||||||
#include <esp_lcd_panel_vendor.h>
|
#include <esp_lcd_panel_vendor.h>
|
||||||
|
#include <wifi_station.h>
|
||||||
|
|
||||||
#define TAG "XINGZHI_CUBE_0_96OLED_ML307"
|
#define TAG "XINGZHI_CUBE_0_96OLED_ML307"
|
||||||
|
|
||||||
@ -24,7 +25,7 @@ LV_FONT_DECLARE(font_puhui_14_1);
|
|||||||
LV_FONT_DECLARE(font_awesome_14_1);
|
LV_FONT_DECLARE(font_awesome_14_1);
|
||||||
|
|
||||||
|
|
||||||
class XINGZHI_CUBE_0_96OLED_ML307 : public Ml307Board {
|
class XINGZHI_CUBE_0_96OLED_ML307 : public DualNetworkBoard {
|
||||||
private:
|
private:
|
||||||
i2c_master_bus_handle_t display_i2c_bus_;
|
i2c_master_bus_handle_t display_i2c_bus_;
|
||||||
Button boot_button_;
|
Button boot_button_;
|
||||||
@ -143,8 +144,21 @@ private:
|
|||||||
boot_button_.OnClick([this]() {
|
boot_button_.OnClick([this]() {
|
||||||
power_save_timer_->WakeUp();
|
power_save_timer_->WakeUp();
|
||||||
auto& app = Application::GetInstance();
|
auto& app = Application::GetInstance();
|
||||||
|
if (GetNetworkType() == NetworkType::WIFI) {
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting && !WifiStation::GetInstance().IsConnected()) {
|
||||||
|
// cast to WifiBoard
|
||||||
|
auto& wifi_board = static_cast<WifiBoard&>(GetCurrentBoard());
|
||||||
|
wifi_board.ResetWifiConfiguration();
|
||||||
|
}
|
||||||
|
}
|
||||||
app.ToggleChatState();
|
app.ToggleChatState();
|
||||||
});
|
});
|
||||||
|
boot_button_.OnDoubleClick([this]() {
|
||||||
|
auto& app = Application::GetInstance();
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting || app.GetDeviceState() == kDeviceStateWifiConfiguring) {
|
||||||
|
SwitchNetworkType();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
volume_up_button_.OnClick([this]() {
|
volume_up_button_.OnClick([this]() {
|
||||||
power_save_timer_->WakeUp();
|
power_save_timer_->WakeUp();
|
||||||
@ -188,7 +202,7 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
public:
|
public:
|
||||||
XINGZHI_CUBE_0_96OLED_ML307() : Ml307Board(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
XINGZHI_CUBE_0_96OLED_ML307() : DualNetworkBoard(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
||||||
boot_button_(BOOT_BUTTON_GPIO),
|
boot_button_(BOOT_BUTTON_GPIO),
|
||||||
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
||||||
volume_down_button_(VOLUME_DOWN_BUTTON_GPIO) {
|
volume_down_button_(VOLUME_DOWN_BUTTON_GPIO) {
|
||||||
@ -231,7 +245,7 @@ public:
|
|||||||
if (!enabled) {
|
if (!enabled) {
|
||||||
power_save_timer_->WakeUp();
|
power_save_timer_->WakeUp();
|
||||||
}
|
}
|
||||||
Ml307Board::SetPowerSaveMode(enabled);
|
DualNetworkBoard::SetPowerSaveMode(enabled);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
@ -1,40 +0,0 @@
|
|||||||
|
|
||||||
#ifndef _BOARD_CONFIG_H_
|
|
||||||
#define _BOARD_CONFIG_H_
|
|
||||||
|
|
||||||
#include <driver/gpio.h>
|
|
||||||
|
|
||||||
#define AUDIO_INPUT_SAMPLE_RATE 16000
|
|
||||||
#define AUDIO_OUTPUT_SAMPLE_RATE 24000
|
|
||||||
|
|
||||||
#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 BOOT_BUTTON_GPIO GPIO_NUM_0
|
|
||||||
#define VOLUME_UP_BUTTON_GPIO GPIO_NUM_40
|
|
||||||
#define VOLUME_DOWN_BUTTON_GPIO GPIO_NUM_39
|
|
||||||
|
|
||||||
#define DISPLAY_SDA GPIO_NUM_10
|
|
||||||
#define DISPLAY_SCL GPIO_NUM_9
|
|
||||||
#define DISPLAY_DC GPIO_NUM_8
|
|
||||||
#define DISPLAY_CS GPIO_NUM_14
|
|
||||||
#define DISPLAY_RES GPIO_NUM_18
|
|
||||||
#define DISPLAY_WIDTH 240
|
|
||||||
#define DISPLAY_HEIGHT 240
|
|
||||||
#define DISPLAY_SWAP_XY false
|
|
||||||
#define DISPLAY_MIRROR_X false
|
|
||||||
#define DISPLAY_MIRROR_Y false
|
|
||||||
#define BACKLIGHT_INVERT false
|
|
||||||
#define DISPLAY_OFFSET_X 0
|
|
||||||
#define DISPLAY_OFFSET_Y 0
|
|
||||||
#define DISPLAY_BACKLIGHT_PIN GPIO_NUM_13
|
|
||||||
#define DISPLAY_BACKLIGHT_OUTPUT_INVERT false
|
|
||||||
|
|
||||||
#define ML307_RX_PIN GPIO_NUM_11
|
|
||||||
#define ML307_TX_PIN GPIO_NUM_12
|
|
||||||
|
|
||||||
#endif // _BOARD_CONFIG_H_
|
|
||||||
@ -1,15 +0,0 @@
|
|||||||
{
|
|
||||||
"target": "esp32s3",
|
|
||||||
"builds": [
|
|
||||||
{
|
|
||||||
"name": "xingzhi-cube-1.54tft-dual",
|
|
||||||
"sdkconfig_append": []
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "xingzhi-cube-1.54tft-dual-wechatui",
|
|
||||||
"sdkconfig_append": [
|
|
||||||
"CONFIG_USE_WECHAT_MESSAGE_STYLE=y"
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
@ -1,243 +0,0 @@
|
|||||||
#include "ml307_board.h"
|
|
||||||
#include "audio_codecs/no_audio_codec.h"
|
|
||||||
#include "display/lcd_display.h"
|
|
||||||
#include "system_reset.h"
|
|
||||||
#include "application.h"
|
|
||||||
#include "button.h"
|
|
||||||
#include "config.h"
|
|
||||||
#include "power_save_timer.h"
|
|
||||||
#include "iot/thing_manager.h"
|
|
||||||
#include "led/single_led.h"
|
|
||||||
#include "assets/lang_config.h"
|
|
||||||
#include "../xingzhi-cube-1.54tft-wifi/power_manager.h"
|
|
||||||
#include "boards/common/dual_network_board.h"
|
|
||||||
|
|
||||||
#include <esp_log.h>
|
|
||||||
#include <esp_lcd_panel_vendor.h>
|
|
||||||
#include <wifi_station.h>
|
|
||||||
|
|
||||||
#include <driver/rtc_io.h>
|
|
||||||
#include <esp_sleep.h>
|
|
||||||
|
|
||||||
#define TAG "XINGZHI_CUBE_1_54TFT_DUAL"
|
|
||||||
|
|
||||||
LV_FONT_DECLARE(font_puhui_20_4);
|
|
||||||
LV_FONT_DECLARE(font_awesome_20_4);
|
|
||||||
|
|
||||||
|
|
||||||
class XINGZHI_CUBE_1_54TFT_DUAL : DualNetworkBoard {
|
|
||||||
private:
|
|
||||||
Button boot_button_;
|
|
||||||
Button volume_up_button_;
|
|
||||||
Button volume_down_button_;
|
|
||||||
SpiLcdDisplay* display_;
|
|
||||||
PowerSaveTimer* power_save_timer_;
|
|
||||||
PowerManager* power_manager_;
|
|
||||||
esp_lcd_panel_io_handle_t panel_io_ = nullptr;
|
|
||||||
esp_lcd_panel_handle_t panel_ = nullptr;
|
|
||||||
|
|
||||||
void InitializePowerManager() {
|
|
||||||
power_manager_ = new PowerManager(GPIO_NUM_38);
|
|
||||||
power_manager_->OnChargingStatusChanged([this](bool is_charging) {
|
|
||||||
if (is_charging) {
|
|
||||||
power_save_timer_->SetEnabled(false);
|
|
||||||
} else {
|
|
||||||
power_save_timer_->SetEnabled(true);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void InitializePowerSaveTimer() {
|
|
||||||
rtc_gpio_init(GPIO_NUM_21);
|
|
||||||
rtc_gpio_set_direction(GPIO_NUM_21, RTC_GPIO_MODE_OUTPUT_ONLY);
|
|
||||||
rtc_gpio_set_level(GPIO_NUM_21, 1);
|
|
||||||
|
|
||||||
power_save_timer_ = new PowerSaveTimer(-1, 60, 300);
|
|
||||||
power_save_timer_->OnEnterSleepMode([this]() {
|
|
||||||
ESP_LOGI(TAG, "Enabling sleep mode");
|
|
||||||
display_->SetChatMessage("system", "");
|
|
||||||
display_->SetEmotion("sleepy");
|
|
||||||
GetBacklight()->SetBrightness(1);
|
|
||||||
});
|
|
||||||
power_save_timer_->OnExitSleepMode([this]() {
|
|
||||||
display_->SetChatMessage("system", "");
|
|
||||||
display_->SetEmotion("neutral");
|
|
||||||
GetBacklight()->RestoreBrightness();
|
|
||||||
});
|
|
||||||
power_save_timer_->OnShutdownRequest([this]() {
|
|
||||||
ESP_LOGI(TAG, "Shutting down");
|
|
||||||
rtc_gpio_set_level(GPIO_NUM_21, 0);
|
|
||||||
// 启用保持功能,确保睡眠期间电平不变
|
|
||||||
rtc_gpio_hold_en(GPIO_NUM_21);
|
|
||||||
esp_lcd_panel_disp_on_off(panel_, false); //关闭显示
|
|
||||||
esp_deep_sleep_start();
|
|
||||||
});
|
|
||||||
power_save_timer_->SetEnabled(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
void InitializeSpi() {
|
|
||||||
spi_bus_config_t buscfg = {};
|
|
||||||
buscfg.mosi_io_num = DISPLAY_SDA;
|
|
||||||
buscfg.miso_io_num = GPIO_NUM_NC;
|
|
||||||
buscfg.sclk_io_num = DISPLAY_SCL;
|
|
||||||
buscfg.quadwp_io_num = GPIO_NUM_NC;
|
|
||||||
buscfg.quadhd_io_num = GPIO_NUM_NC;
|
|
||||||
buscfg.max_transfer_sz = DISPLAY_WIDTH * DISPLAY_HEIGHT * sizeof(uint16_t);
|
|
||||||
ESP_ERROR_CHECK(spi_bus_initialize(SPI3_HOST, &buscfg, SPI_DMA_CH_AUTO));
|
|
||||||
}
|
|
||||||
|
|
||||||
void InitializeButtons() {
|
|
||||||
boot_button_.OnPressDown([this]() {
|
|
||||||
auto& app = Application::GetInstance();
|
|
||||||
if (GetNetworkType() == NetworkType::WIFI) {
|
|
||||||
if (app.GetDeviceState() == kDeviceStateStarting && !WifiStation::GetInstance().IsConnected()) {
|
|
||||||
// cast to WifiBoard
|
|
||||||
auto& wifi_board = static_cast<WifiBoard&>(GetCurrentBoard());
|
|
||||||
wifi_board.ResetWifiConfiguration();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
boot_button_.OnClick([this]() {
|
|
||||||
power_save_timer_->WakeUp();
|
|
||||||
auto& app = Application::GetInstance();
|
|
||||||
app.ToggleChatState();
|
|
||||||
});
|
|
||||||
|
|
||||||
boot_button_.OnLongPress([this]() {
|
|
||||||
SwitchNetType();
|
|
||||||
auto& app = Application::GetInstance();
|
|
||||||
app.Reboot();
|
|
||||||
});
|
|
||||||
|
|
||||||
|
|
||||||
volume_up_button_.OnClick([this]() {
|
|
||||||
power_save_timer_->WakeUp();
|
|
||||||
auto codec = GetAudioCodec();
|
|
||||||
auto volume = codec->output_volume() + 10;
|
|
||||||
if (volume > 100) {
|
|
||||||
volume = 100;
|
|
||||||
}
|
|
||||||
codec->SetOutputVolume(volume);
|
|
||||||
GetDisplay()->ShowNotification(Lang::Strings::VOLUME + std::to_string(volume));
|
|
||||||
});
|
|
||||||
|
|
||||||
volume_up_button_.OnLongPress([this]() {
|
|
||||||
power_save_timer_->WakeUp();
|
|
||||||
GetAudioCodec()->SetOutputVolume(100);
|
|
||||||
GetDisplay()->ShowNotification(Lang::Strings::MAX_VOLUME);
|
|
||||||
});
|
|
||||||
|
|
||||||
volume_down_button_.OnClick([this]() {
|
|
||||||
power_save_timer_->WakeUp();
|
|
||||||
auto codec = GetAudioCodec();
|
|
||||||
auto volume = codec->output_volume() - 10;
|
|
||||||
if (volume < 0) {
|
|
||||||
volume = 0;
|
|
||||||
}
|
|
||||||
codec->SetOutputVolume(volume);
|
|
||||||
GetDisplay()->ShowNotification(Lang::Strings::VOLUME + std::to_string(volume));
|
|
||||||
});
|
|
||||||
|
|
||||||
volume_down_button_.OnLongPress([this]() {
|
|
||||||
power_save_timer_->WakeUp();
|
|
||||||
GetAudioCodec()->SetOutputVolume(0);
|
|
||||||
GetDisplay()->ShowNotification(Lang::Strings::MUTED);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void InitializeSt7789Display() {
|
|
||||||
ESP_LOGD(TAG, "Install panel IO");
|
|
||||||
esp_lcd_panel_io_spi_config_t io_config = {};
|
|
||||||
io_config.cs_gpio_num = DISPLAY_CS;
|
|
||||||
io_config.dc_gpio_num = DISPLAY_DC;
|
|
||||||
io_config.spi_mode = 3;
|
|
||||||
io_config.pclk_hz = 80 * 1000 * 1000;
|
|
||||||
io_config.trans_queue_depth = 10;
|
|
||||||
io_config.lcd_cmd_bits = 8;
|
|
||||||
io_config.lcd_param_bits = 8;
|
|
||||||
ESP_ERROR_CHECK(esp_lcd_new_panel_io_spi(SPI3_HOST, &io_config, &panel_io_));
|
|
||||||
|
|
||||||
ESP_LOGD(TAG, "Install LCD driver");
|
|
||||||
esp_lcd_panel_dev_config_t panel_config = {};
|
|
||||||
panel_config.reset_gpio_num = DISPLAY_RES;
|
|
||||||
panel_config.rgb_ele_order = LCD_RGB_ELEMENT_ORDER_RGB;
|
|
||||||
panel_config.bits_per_pixel = 16;
|
|
||||||
ESP_ERROR_CHECK(esp_lcd_new_panel_st7789(panel_io_, &panel_config, &panel_));
|
|
||||||
ESP_ERROR_CHECK(esp_lcd_panel_reset(panel_));
|
|
||||||
ESP_ERROR_CHECK(esp_lcd_panel_init(panel_));
|
|
||||||
ESP_ERROR_CHECK(esp_lcd_panel_swap_xy(panel_, DISPLAY_SWAP_XY));
|
|
||||||
ESP_ERROR_CHECK(esp_lcd_panel_mirror(panel_, DISPLAY_MIRROR_X, DISPLAY_MIRROR_Y));
|
|
||||||
ESP_ERROR_CHECK(esp_lcd_panel_invert_color(panel_, true));
|
|
||||||
|
|
||||||
display_ = new SpiLcdDisplay(panel_io_, panel_, DISPLAY_WIDTH, DISPLAY_HEIGHT, DISPLAY_OFFSET_X, DISPLAY_OFFSET_Y,
|
|
||||||
DISPLAY_MIRROR_X, DISPLAY_MIRROR_Y, DISPLAY_SWAP_XY,
|
|
||||||
{
|
|
||||||
.text_font = &font_puhui_20_4,
|
|
||||||
.icon_font = &font_awesome_20_4,
|
|
||||||
#if CONFIG_USE_WECHAT_MESSAGE_STYLE
|
|
||||||
.emoji_font = font_emoji_32_init(),
|
|
||||||
#else
|
|
||||||
.emoji_font = font_emoji_64_init(),
|
|
||||||
#endif
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
void InitializeIot() {
|
|
||||||
auto& thing_manager = iot::ThingManager::GetInstance();
|
|
||||||
thing_manager.AddThing(iot::CreateThing("Speaker"));
|
|
||||||
thing_manager.AddThing(iot::CreateThing("Screen"));
|
|
||||||
thing_manager.AddThing(iot::CreateThing("Battery"));
|
|
||||||
}
|
|
||||||
|
|
||||||
public:
|
|
||||||
XINGZHI_CUBE_1_54TFT_DUAL() :
|
|
||||||
DualNetworkBoard(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
|
||||||
boot_button_(BOOT_BUTTON_GPIO, false, 3000),
|
|
||||||
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
|
||||||
volume_down_button_(VOLUME_DOWN_BUTTON_GPIO) {
|
|
||||||
InitializePowerManager();
|
|
||||||
InitializePowerSaveTimer();
|
|
||||||
InitializeSpi();
|
|
||||||
InitializeButtons();
|
|
||||||
InitializeSt7789Display();
|
|
||||||
InitializeIot();
|
|
||||||
GetBacklight()->RestoreBrightness();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual AudioCodec* GetAudioCodec() override {
|
|
||||||
static NoAudioCodecSimplex audio_codec(AUDIO_INPUT_SAMPLE_RATE, AUDIO_OUTPUT_SAMPLE_RATE,
|
|
||||||
AUDIO_I2S_SPK_GPIO_BCLK, AUDIO_I2S_SPK_GPIO_LRCK, AUDIO_I2S_SPK_GPIO_DOUT, AUDIO_I2S_MIC_GPIO_SCK, AUDIO_I2S_MIC_GPIO_WS, AUDIO_I2S_MIC_GPIO_DIN);
|
|
||||||
return &audio_codec;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual Display* GetDisplay() override {
|
|
||||||
return display_;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual Backlight* GetBacklight() override {
|
|
||||||
static PwmBacklight backlight(DISPLAY_BACKLIGHT_PIN, DISPLAY_BACKLIGHT_OUTPUT_INVERT);
|
|
||||||
return &backlight;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual bool GetBatteryLevel(int& level, bool& charging, bool& discharging) override {
|
|
||||||
static bool last_discharging = false;
|
|
||||||
charging = power_manager_->IsCharging();
|
|
||||||
discharging = power_manager_->IsDischarging();
|
|
||||||
if (discharging != last_discharging) {
|
|
||||||
power_save_timer_->SetEnabled(discharging);
|
|
||||||
last_discharging = discharging;
|
|
||||||
}
|
|
||||||
level = power_manager_->GetBatteryLevel();
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void SetPowerSaveMode(bool enabled) override {
|
|
||||||
if (!enabled) {
|
|
||||||
power_save_timer_->WakeUp();
|
|
||||||
}
|
|
||||||
DualNetworkBoard::SetPowerSaveMode(enabled);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
DECLARE_BOARD(XINGZHI_CUBE_1_54TFT_DUAL);
|
|
||||||
@ -1,4 +1,4 @@
|
|||||||
#include "ml307_board.h"
|
#include "dual_network_board.h"
|
||||||
#include "audio_codecs/no_audio_codec.h"
|
#include "audio_codecs/no_audio_codec.h"
|
||||||
#include "display/lcd_display.h"
|
#include "display/lcd_display.h"
|
||||||
#include "system_reset.h"
|
#include "system_reset.h"
|
||||||
@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
#include <esp_log.h>
|
#include <esp_log.h>
|
||||||
#include <esp_lcd_panel_vendor.h>
|
#include <esp_lcd_panel_vendor.h>
|
||||||
|
#include <wifi_station.h>
|
||||||
|
|
||||||
#include <driver/rtc_io.h>
|
#include <driver/rtc_io.h>
|
||||||
#include <esp_sleep.h>
|
#include <esp_sleep.h>
|
||||||
@ -23,7 +24,7 @@ LV_FONT_DECLARE(font_puhui_20_4);
|
|||||||
LV_FONT_DECLARE(font_awesome_20_4);
|
LV_FONT_DECLARE(font_awesome_20_4);
|
||||||
|
|
||||||
|
|
||||||
class XINGZHI_CUBE_1_54TFT_ML307 : public Ml307Board {
|
class XINGZHI_CUBE_1_54TFT_ML307 : public DualNetworkBoard {
|
||||||
private:
|
private:
|
||||||
Button boot_button_;
|
Button boot_button_;
|
||||||
Button volume_up_button_;
|
Button volume_up_button_;
|
||||||
@ -88,8 +89,21 @@ private:
|
|||||||
boot_button_.OnClick([this]() {
|
boot_button_.OnClick([this]() {
|
||||||
power_save_timer_->WakeUp();
|
power_save_timer_->WakeUp();
|
||||||
auto& app = Application::GetInstance();
|
auto& app = Application::GetInstance();
|
||||||
|
if (GetNetworkType() == NetworkType::WIFI) {
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting && !WifiStation::GetInstance().IsConnected()) {
|
||||||
|
// cast to WifiBoard
|
||||||
|
auto& wifi_board = static_cast<WifiBoard&>(GetCurrentBoard());
|
||||||
|
wifi_board.ResetWifiConfiguration();
|
||||||
|
}
|
||||||
|
}
|
||||||
app.ToggleChatState();
|
app.ToggleChatState();
|
||||||
});
|
});
|
||||||
|
boot_button_.OnDoubleClick([this]() {
|
||||||
|
auto& app = Application::GetInstance();
|
||||||
|
if (app.GetDeviceState() == kDeviceStateStarting || app.GetDeviceState() == kDeviceStateWifiConfiguring) {
|
||||||
|
SwitchNetworkType();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
volume_up_button_.OnClick([this]() {
|
volume_up_button_.OnClick([this]() {
|
||||||
power_save_timer_->WakeUp();
|
power_save_timer_->WakeUp();
|
||||||
@ -172,7 +186,7 @@ private:
|
|||||||
|
|
||||||
public:
|
public:
|
||||||
XINGZHI_CUBE_1_54TFT_ML307() :
|
XINGZHI_CUBE_1_54TFT_ML307() :
|
||||||
Ml307Board(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
DualNetworkBoard(ML307_TX_PIN, ML307_RX_PIN, 4096),
|
||||||
boot_button_(BOOT_BUTTON_GPIO),
|
boot_button_(BOOT_BUTTON_GPIO),
|
||||||
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
volume_up_button_(VOLUME_UP_BUTTON_GPIO),
|
||||||
volume_down_button_(VOLUME_DOWN_BUTTON_GPIO) {
|
volume_down_button_(VOLUME_DOWN_BUTTON_GPIO) {
|
||||||
@ -216,7 +230,7 @@ public:
|
|||||||
if (!enabled) {
|
if (!enabled) {
|
||||||
power_save_timer_->WakeUp();
|
power_save_timer_->WakeUp();
|
||||||
}
|
}
|
||||||
Ml307Board::SetPowerSaveMode(enabled);
|
DualNetworkBoard::SetPowerSaveMode(enabled);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user