0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

启明智显分享丨ESP32学习笔记参考

QiMingZhiXian 来源:QiMingZhiXian 作者:QiMingZhiXian 2022-03-22 17:52 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

--提示:启明智显专为智能产品提供一站式彩屏显示+连接+云端服务+APP软件开发、维护等解决方案,帮厂商快速实现硬件的智能化。作为启明云端旗下方案公司,我们用心整理了开发小伙伴在开发过程中可能会遇到的问题以及快速上手的简明教程,同时也用心整理了连接+显示应用的新方案!希望你能第一时间了解并快速用上好的方案和产品!--

## 一、LED PWM 控制器

### 1、简介

LED 控制器 (LEDC) 主要用于控制 LED,也可产生 PWM 信号用于其他设备的控制。 该控制器有 16 路通道,可以产生独立的波形来驱动 RGB LED 等设备。

LEDC 通道共有两组,分别为 8 路高速通道和 8 路低速通道。高速通道模式在硬件中实现,可以自动且无干扰地改变 PWM 占空比。低速通道模式下,PWM 占空比需要由软件中的驱动器改变。每组通道都可以使用不同的时钟源。

LED PWM 控制器可在无需 CPU 干预的情况下自动改变占空比,实现亮度和颜色渐变。

[参考](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html)

设置 LEDC 通道在 [高速模式或低速模式](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#ledc-api-high-low-speed-mode) 下运行,需要进行如下配置:

1. [定时器配置](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#ledc-api-configure-timer) 指定 PWM 信号的频率和占空比分辨率。
2. [通道配置](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#ledc-api-configure-channel) 绑定定时器和输出 PWM 信号的 GPIO。
3. [改变 PWM 信号](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#ledc-api-change-pwm-signal) 输出 PWM 信号来驱动 LED。可通过软件控制或使用硬件渐变功能来改变 LED 的亮度。

另一个可选步骤是可以在渐变终端设置一个中断。

pYYBAGI5mFuAc6fOAABw7swroKI099.png图1

在解释ESP32上的PWM功能之前,让我们讨论一些与PWM相关的术语。
● **TON(导通时间)**:信号为高电平时的持续时间。

● **TOFF(关断时间)**:信号为低电平时的持续时间。

● **周期**:PWM信号的导通时间和关断时间之和。

● **占空比**:PWM信号周期内信号为高电平的时间百分比。

​ 例如,如果总周期为10ms的脉冲保持 ON(高)5ms。然后,占空比将为:占空比 = 5/10 * 100 = 50%

pYYBAGI5mLyAegNRAABb1_Plw7Q491.png图2

● **PWM的频率:**PWM信号的频率决定了PWM完成一个周期的速度。一个周期是一个PWM信号的完整ON和OFF,如上图所示。

### 2、配置定时器

要设置定时器,可调用函数 [`ledc_timer_config()`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv417ledc_timer_configPK19ledc_timer_config_t),并将包括如下配置参数的数据结构 [`ledc_timer_config_t`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv419ledc_timer_config_t) 传递给该函数:

- 速度模式 [`ledc_mode_t`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv411ledc_mode_t)
- 定时器索引 [`ledc_timer_t`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv412ledc_timer_t)
- PWM 信号频率
- PWM 占空比分辨率
- 时钟源 [`ledc_clk_cfg_t`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv414ledc_clk_cfg_t)

频率和占空比分辨率相互关联。PWM 频率越高,占空比分辨率越低,反之亦然。如果 API 不是用来改变 LED 亮度,而是用于其它目的,这种相互关系可能会很重要。更多信息详见 [频率和占空比分辨率支持范围](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#ledc-api-supported-range-frequency-duty-resolution) 一节。

时钟源同样可以限制PWM频率。选择的时钟源频率越高,可以配置的PWM频率上限就越高。

时钟名称 时钟频率 速度模式 时钟功能
APB_CLK 80 MHz 高速 / 低速 /
REF_TICK 1 MHz 高速 / 低速 支持动态调频(DFS)功能
RTC8M_CLK ~8 MHz 低速 支持动态调频(DFS)功能,支持Light-sleep模式

**通道配置**

定时器设置好后,请配置所需的通道([`ledc_channel_t`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv414ledc_channel_t) 之一)。配置通道需调用函数 [`ledc_channel_config()`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv419ledc_channel_configPK21ledc_channel_config_t)。

通道的配置与定时器设置类似,需向通道配置函数传递包括通道配置参数的结构体 [`ledc_channel_config_t`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv421ledc_channel_config_t) 。

此时,通道会按照 [`ledc_channel_config_t`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv421ledc_channel_config_t) 的配置开始运作,并在选定的 GPIO 上生成由定时器设置指定的频率和占空比的 PWM 信号。在通道运作过程中,可以随时通过调用函数 [`ledc_stop()`](https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-reference/peripherals/ledc.html#_CPPv49ledc_stop11ledc_mode_t14ledc_channel_t8uint32_t) 将其暂停。

### 3、示例

```c
//1. ESP32 下面是一个呼吸灯的整理,可以直接使用,欢迎参考。
#include
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "driver/ledc.h"
#include "esp_err.h"
#define LEDC_HS_TIMER LEDC_TIMER_0
#define LEDC_HS_MODE LEDC_HIGH_SPEED_MODE
#define LEDC_HS_CH0_CHANNEL LEDC_CHANNEL_0
#define LEDC_HS_CH0_GPIO (2)
#define LEDC_TEST_DUTY (4000)
#define LEDC_TEST_FADE_TIME (3000)
void app_main(void)
{
//1. PWM: 定时器配置

ledc_timer_config_t ledc_timer = {
.duty_resolution = LEDC_TIMER_13_BIT, // resolution of PWM duty
.freq_hz = 5000, // frequency of PWM signal
.speed_mode = LEDC_HS_MODE, // timer mode
.timer_num = LEDC_HS_TIMER, // timer index
.clk_cfg = LEDC_AUTO_CLK, // Auto select the source clock
};

ledc_timer_config(&ledc_timer);
//2. PWM:通道配置
ledc_channel_config_t ledc_channel= {
.channel = LEDC_HS_CH0_CHANNEL,
.duty = 0,
.gpio_num = LEDC_HS_CH0_GPIO, //这里是SDK带的呼吸灯案例,你看下能看懂不,我现在给你修改个引脚,你的灯就用上了, 2表示你板子上的那个灯 2引脚的那个
.speed_mode = LEDC_HS_MODE,
.hpoint = 0,
.timer_sel = LEDC_HS_TIMER
};

ledc_channel_config(&ledc_channel);
//3.PWM:使用硬件渐变
ledc_fade_func_install(0);
//4. 输出PWM信号控制灯

while (1) {
//灯:由灭慢慢变亮
printf("1. LEDC fade up to duty = %d\n", LEDC_TEST_DUTY);
ledc_set_fade_with_time(ledc_channel.speed_mode,
ledc_channel.channel, LEDC_TEST_DUTY, LEDC_TEST_FADE_TIME);
ledc_fade_start(ledc_channel.speed_mode,
ledc_channel.channel, LEDC_FADE_NO_WAIT);
vTaskDelay(LEDC_TEST_FADE_TIME / portTICK_PERIOD_MS);
//灯:由亮慢慢变灭
printf("2. LEDC fade down to duty = 0\n");
ledc_set_fade_with_time(ledc_channel.speed_mode,
ledc_channel.channel, 0, LEDC_TEST_FADE_TIME);
ledc_fade_start(ledc_channel.speed_mode,
ledc_channel.channel, LEDC_FADE_NO_WAIT);
vTaskDelay(LEDC_TEST_FADE_TIME / portTICK_PERIOD_MS);
}
}
```


## 二、Motor Control Pulse Width Modulator(MCPWM)

### 1、简介

ESP32有两个MCPWM单元,可用于控制不同类型的电机。每个单元有三对PWM输出。

**作用**:

- PWM输出
- 每个单元还能够收集诸如同步信号等输入,检测电机过电流或过电压等故障信号,
- 以及在例如转子位置上获得捕获信号的反馈。

每个A/B对可由三个定时器中的任何一个MCPWM定时器0、1和2中的任何一个时钟。(相同的定时器可用于时钟多对PWM输出)

poYBAGDUrDuAGICVAADbYmZt8Wc001.png图3

从上图我们不难发现,MCPWM具有的功能(上图彩色的虚线框)有:

- `OPERATOR `操作器模块
- `CAPTURE `状态捕获模块
- `FAULT DETECT`故障处理器模块
- `CLOCK/TIMER`时钟、时钟预分频器模块
(黑色虚线框指的是GPIO矩阵 (GPIO Matrix))

**1、操作器模块 Operator**

**操作员 (Operator) 用于操作连接到MCPWM单元的电机。**例如改变旋转方向(顺时针或逆时针),或改变转速。

​ 操作员输出一共有 3 对,我们可以对其施加控制信号。标记为“A”和“B”的称为一对。A、B均有自己对应的名为“Generator”的子模块来驱动诸如PWM的输出信号。

​ 为了提供PWM信号,每个Operator本身由三个可用的定时器(MCPWM Timer)中的任何一个进行计时。

​ 为了简化API,API会 自动关联 具有相同索引`Timer`以驱动`Operator`。例如`Timer 0`与`Operator 0`关联。

**2、捕获模块 Capture**
捕获模块在功能上相当于由沿中断控制的捕获定时器

​ 对于无刷直流电机,控制的要求之一是感应转子位置。

​ 为了完成这一任务,每个 MCPWM单元提供三个传感输入以及专用的硬件。该硬件能够检测输入信号的边缘,并测量信号之间的时间。

​ 因此,控制软件更简单,CPU功率可能用于其他任务。

注意:3个Capture可以在不使用PWM输出时**单独使用**,即只配置Capture实现边缘捕获功能。**因此MCPWM还可用于非电机外设**。例如,使用MCPWM的Capture0去捕获**HC-SR04**超声波模块ECHO引脚的高电平时间,进而实现测距。

**3、故障处理器模块 Fault Detect**
MCPWM的每个单元都能够感知外部信号,包括有关电机、电机驱动器或连接到MCPWM的任何其他设备的故障信息。每个单元有三个错误输入,可以路由到用户可选择的GPIO。当接收到故障信号时,MCPWM可以配置为对A/B输出执行四种预定义的动作之一:

- 锁定输出的当前状态

- 设置低输出

- 设置高输出

- 开关输出

用户应确定电机可能的故障模式以及在检测到特定故障时应采取的行动。

例如:对有刷电机驱动所有输出为低,或对步进电机锁定电流状态等。这个动作会使电机处于安全状态,以减少故障造成的损坏的可能性。


**4、载波 Carrier和中断 Interrupts**
MCPWM有一个载波子模块,如果使用互感原理(如通过变压器)向电机驱动传递A/B输出信号(例如需要让电机驱动器输入电流与ESP32 GPIO输出电流相互隔离)。任何A和B输出信号都可以100%占空,并且当电机在满载时需要稳定运行时,信号不会改变。

​ 通过调用`mcpwm_isr_register()`可以注册MCPWM中断处理程序。
注意,如果使用了`mcpwm_capture_enable_channel()`,那么将安装一个默认的ISR例程来实现简化API的回调。因此,如果使用了`mcpwm_capture_enable_channel()`,请不要再调用mcpwm_isr_register()这个函数来注册中断。

### 2、使用 MCPWM 输出 PWM 信号

#### 2.1 创建MCPWM

初始化MCPWM需要的步骤:

- 配置GPIO口

- 在一个`mcpwm_config_t`结构体中设置定时器频率和初始任务的设置。

- 非必须:设置定时器分辨率(默认为10,000,000)。使用函数`mcpwm_group_set_resolution() `和 `mcpwm_timer_set_resolution()`
- 使用上述参数调用mcpwm_init()以使配置生效。

1,配置GPIO口:使用函数mcpwm_gpio_init()或函数mcpwm_set_pin()。

两者的区别是前者为指定的功能配置 GPIO,而后者是一次性配置所有的GPIO。

**mcpwm_gpio_init()** //初始化一个GPIO

```c
esp_err_t mcpwm_gpio_init(mcpwm_unit_t mcpwm_num, mcpwm_io_signals_t io_signal, int gpio_num)
//mcpwm_num类型为:mcpwm_unit_t;MCPWM单元
//io_signal类型为:mcpwm_io_signals_t;MCPWM功能signal,如MCPWM0A表示某MCPWM的A输出
//gpio_num类型为:int;表示想要配置为哪个GPIO
```

**mcpwm_set_pin()** //配置所有与MCPWM有关的GPIO

```c
esp_err_t mcpwm_set_pin(mcpwm_unit_t mcpwm_num, const mcpwm_pin_config_t *mcpwm_pin)
//mcpwm_num类型为:mcpwm_unit_t;表示MCPWM单元索引
//*mcpwm_pin类型为:mcpwm_pin_config_t指针;表示一个结构体,包含所有与MCPWM功能对于的GPIO
```

2,配置mcpwm参数

通过函数`mcpwm_init()`,传递一个`mcpwm_config_t`结构体指针

**mcpwm_init()**

```c
esp_err_t mcpwm_init(mcpwm_unit_t mcpwm_num,
mcpwm_timer_t timer_num,
const mcpwm_config_t *mcpwm_conf)
//mcpwm_num类型为:mcpwm_unit_t;表示MCPWM索引
//timer_num类型为:mcpwm_timer_t;表示初始化哪个MCPWM定时器,对应与其相同索引的Operator
//*mcpwm_conf类型为:const mcpwm_config_t;表示配置结构体指针

typedef struct {
uint32_t frequency;//频率
float cmpr_a;//A输出的占空比
float cmpr_b;//B输出的占空比
mcpwm_duty_type_t duty_mode;//占空比模式 (对应高还是低)
mcpwm_counter_type_t counter_mode;//定时器计数方向
}

//示例
mcpwm_config_t mcpwmConfig = {
.frequency = 1000,
.cmpr_a = 0,
.cmpr_b = 0,
.counter_mode = MCPWM_UP_COUNTER,
.duty_mode = MCPWM_DUTY_MODE_0,
};
mcpwm_init(MCPWM_UNIT_0, MCPWM_TIMER_0, &mcpwmConfig);
```

#### 2.2 PWM信号控制

- **1、设置为全速(非PWM信号)**
我们可以使用`mcpwm_set_signal_high()`或`mcpwm_set_signal_low()`函数来驱动特定的信号稳定为高或低。这将使电机以最大速度旋转或停止。

**mcpwm_set_signal_high(或low) ()** // 设置MCPWM的某个generator信号为高[或低]

```c
esp_err_t mcpwm_set_signal_high(mcpwm_unit_t mcpwm_num,
mcpwm_timer_t timer_num,
mcpwm_generator_t gen)
//mcpwm_num类型为:mcpwm_unit_t;表示MCPWM单元
//timer_num类型为:mcpwm_timer_t;表示哪组MCPWM Operator
//gen类型为:mcpwm_generator_t;表示对应的A还是B
```

- **2、设置PWM信号**
若要更改PWM的占空比,调用`mcpwm_set_duty()`并以%为单位提供占空比的百分数值。如果您希望以微秒为单位设置任务,则可以选择调用`mcpwm_set_duty_in_us()`。可以通过调用`mcpwm_set_duty_type()`来改变PWM占空比的模式(占空比数值对应高还是对应低)。

**mcpwm_set_duty (in_us) ()** //设置占空比

```c
esp_err_t mcpwm_set_duty(mcpwm_unit_t mcpwm_num,
mcpwm_timer_t timer_num,
mcpwm_generator_t gen,
float duty)
//mcpwm_num类型为:mcpwm_unit_t;表示MCPWM单元
//timer_num类型为:mcpwm_timer_t;表示哪组MCPWM输出
//gen类型为:mcpwm_generator_t;表示A输出还是B输出
//duty[_in_us]类型为:float;表示占空比百分数%[或微秒]
```

**mcpwm_set_duty_type()** //设置占空比类型,并恢复PWM输出

```c
esp_err_t mcpwm_set_duty_type(mcpwm_unit_t mcpwm_num,
mcpwm_timer_t timer_num,
mcpwm_generator_t gen,
mcpwm_duty_type_t duty_type)
//mcpwm_num类型为:mcpwm_unit_t;表示MCPWM单元
//timer_num类型为:mcpwm_timer_t;表示哪组MCPWM输出
//gen类型为:mcpwm_generator_t;表示A输出还是B输出
//duty_type类型为:mcpwm_duty_type_t;表示占空比
```

- **3、启动输出**
通过调用`mcpwm_start()`或`mcpwm_stop()`来驱动PWM信号的输出。 当使用`mcpwm_init()`后,ESP32 会自动调用`mcpwm_start()`启动电机

**mcpwm_start(或stop)()** // 启动[或关闭]MCPWM输出

```c
esp_err_t mcpwm_start(mcpwm_unit_t mcpwm_num,
//mcpwm_num类型为:mcpwm_unit_t;表示MCPWM单元
mcpwm_timer_t timer_num)
//timer_num类型为:mcpwm_timer_t;表示哪组MCPWM
```

### 3、示例

使用mcpwm驱动直流电机

```c
#include
#include "freertos/FreeRTOS.h"
#include "freertos/task.h"
#include "driver/mcpwm.h"

#define GPIO_PWM0A_OUT 15 //设置 GPIO 15 作为 PWM0A
#define GPIO_PWM0B_OUT 16 //设置 GPIO 16 作为 PWM0B

//---------电机向前移动
static void brushed_motor_forward(mcpwm_unit_t mcpwm_num, mcpwm_timer_t timer_num, float duty_cycle)
{
mcpwm_set_signal_low(mcpwm_num, timer_num, MCPWM_OPR_B);
mcpwm_set_duty(mcpwm_num, timer_num, MCPWM_OPR_A, duty_cycle);
mcpwm_set_duty_type(mcpwm_num, timer_num, MCPWM_OPR_A, MCPWM_DUTY_MODE_1);
}

//--------- 电机向后移动
static void brushed_motor_backward(mcpwm_unit_t mcpwm_num, mcpwm_timer_t timer_num, float duty_cycle)
{
mcpwm_set_signal_low(mcpwm_num, timer_num, MCPWM_OPR_A);
//设置MCPWM的某个generator信号为高[或低]
mcpwm_set_duty(mcpwm_num, timer_num, MCPWM_OPR_B, duty_cycle);
//设置占空比
//mcpwm_num类型为:mcpwm_unit_t;表示MCPWM单元
//timer_num类型为:mcpwm_timer_t;表示哪组MCPWM输出
//gen类型为:mcpwm_generator_t;表示A输出还是B输出
//duty[_in_us]类型为:float;表示占空比百分数%[或微秒]

mcpwm_set_duty_type(mcpwm_num, timer_num, MCPWM_OPR_B, MCPWM_DUTY_MODE_1);
// 设置占空比类型,并恢复PWM输出
}

//---------电机停止
static void brushed_motor_stop(mcpwm_unit_t mcpwm_num, mcpwm_timer_t timer_num)
{
mcpwm_set_signal_low(mcpwm_num, timer_num, MCPWM_OPR_A);
mcpwm_set_signal_low(mcpwm_num, timer_num, MCPWM_OPR_B);
}

//---------为直流电机配置MCPWM
static void mcpwm_task(void *arg)
{
//1. mcpwm gpio 初始化
printf("initializing mcpwm gpio!\n");
mcpwm_gpio_init(MCPWM_UNIT_0, MCPWM0A, GPIO_PWM0A_OUT); //配置GPIO口
mcpwm_gpio_init(MCPWM_UNIT_0, MCPWM0B, GPIO_PWM0B_OUT);

//2. 初始化 mcpwm 配置
printf("Setting mcpwm!\n");
mcpwm_config_t pwm_config = {
.frequency = 1000, //频率 = 500Hz,
.cmpr_a = 0, // PWMxA占空比 = 0
.cmpr_b = 0, // PWMxB占空比 = 0
.duty_mode = MCPWM_DUTY_MODE_0, //占空比模式 (对应高还是低)
.counter_mode = MCPWM_UP_COUNTER, //定时器计数方向
};
mcpwm_init(MCPWM_UNIT_0, MCPWM_TIMER_0, &pwm_config);

while (1)
{
brushed_motor_forward(MCPWM_UNIT_0, MCPWM_TIMER_0, 50.0);
printf("正转\n");
vTaskDelay(2000 / portTICK_RATE_MS);
brushed_motor_backward(MCPWM_UNIT_0, MCPWM_TIMER_0, 30.0);
printf("逆转\n");
vTaskDelay(2000 / portTICK_RATE_MS);
brushed_motor_stop(MCPWM_UNIT_0, MCPWM_TIMER_0);
printf("停\n");
vTaskDelay(2000 / portTICK_RATE_MS);
}
}

void app_main(void)
{
printf("Testing motor !\n");
xTaskCreate(mcpwm_task, "Mcpwm_task", 4096, NULL, 5, NULL);
}
```
审核编辑:符乾江

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • led
    led
    +关注

    关注

    244

    文章

    24722

    浏览量

    692452
  • PWM
    PWM
    +关注

    关注

    116

    文章

    5894

    浏览量

    226555
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    乐鑫科技新品ESP32-H4亮点速递!

    近期,乐鑫科技新品发布节奏持续加快。作为乐鑫科技一级代理商,启明云端为您带来最新芯片产品ESP32-H4的详细解读。ESP32-H4隶属于乐鑫科技ESP32-H系列,在低功耗物联网应用
    的头像 发表于 04-16 18:05 319次阅读
    乐鑫科技新品<b class='flag-5'>ESP32</b>-H4亮点速递!

    ESP32里的AI Agent:EmbedClaw上手教程!启明云端乐鑫代理及方案商

    EmbedClawEmbedClaw是启明云端开源的一个可以跑在ESP32上的AIAgent项目。这个项目最有意思的地方,不是“能聊天”,而是它把几个最容易缠在一起的模块拆开了:LLM:现在接的是千
    的头像 发表于 03-11 18:13 1321次阅读
    <b class='flag-5'>ESP32</b>里的AI Agent:EmbedClaw上手教程!<b class='flag-5'>启明</b>云端乐鑫代理及方案商

    再升级!启明智5G CPE专属APP即将来袭!

    好消息要开门见山!启明智5GCPE专属APP,它真的来了!启明智的CPE,要真正实现“随时随地,尽在掌握”了!1回顾来时路:云端管理与无感升级的基石此前,我们通过远程WEB管理平台
    的头像 发表于 02-10 18:03 813次阅读
    再升级!<b class='flag-5'>启明智</b><b class='flag-5'>显</b>5G CPE专属APP即将来袭!

    启明智5G CPE解决方案:支持快速OEM贴牌,一键打造自主品牌

    在竞争激烈的5GCPE市场中,如何快速推出有竞争力的自主品牌产品?对于众多OEM客户而言,拥有一套成熟可靠、支持深度定制且能快速上市的解决方案至关重要。启明智5GCPE解决方案,正是为赋能品牌而生
    的头像 发表于 01-27 18:24 605次阅读
    <b class='flag-5'>启明智</b><b class='flag-5'>显</b>5G CPE解决方案:支持快速OEM贴牌,一键打造自主品牌

    乐鑫科技ESP-AMP框架详解!两款已支持的ESP32-P4C5开发板推荐!启明云端乐鑫科技代理

    操作系统,并提供完整的核间通信机制。启明云端旗两款高性能开发板——WT99P4C5-S1与WTDKP4C5-S1,搭载乐鑫科技ESP32-P4芯片和ESP32-C5芯
    的头像 发表于 12-18 18:02 1959次阅读
    乐鑫科技<b class='flag-5'>ESP</b>-AMP框架详解!两款已支持的<b class='flag-5'>ESP32</b>-P4C5开发板推荐!<b class='flag-5'>启明</b>云端乐鑫科技代理

    LVGL实战指南:手把手教你玩转ESP32-S3 2.8寸串口屏UI开发

    ,让你在最短时间内,亲眼看到LVGL界面在启明智ESP32-S32.8寸屏上流畅运行。无需痛苦的摸索,跟着我们的步骤,从零到一,全程畅通无阻。搭建ESP-IDF环境
    的头像 发表于 10-30 18:04 2805次阅读
    LVGL实战指南:手把手教你玩转<b class='flag-5'>ESP32</b>-S3 2.8寸串口屏UI开发

    启明智彩屏产品重磅合集:全尺寸、多接口,一站式赋能智能设备升级

    在智能化浪潮席卷全球的今天,显示技术作为人机交互的核心载体,正以前所未有的深度融入各行各业。启明智彩屏产品系列覆盖0.96至55英寸全尺寸范围,基于ESP32系列及Model3C、Model3A等
    的头像 发表于 09-11 18:03 1184次阅读
    <b class='flag-5'>启明智</b><b class='flag-5'>显</b>彩屏产品重磅合集:全尺寸、多接口,一站式赋能智能设备升级

    启明智5G CPE,咖啡连锁店铺的云端智能管理中枢

    在连锁零售、餐饮等行业,分散的门店管理是核心痛点。传统网络依赖拉网线和本地调试,总部难以统一管控设备。启明智5GCPE的云端设备管理平台,让某咖啡品牌总部拥有“云端指挥中心”,打破地域限制,实现
    的头像 发表于 07-23 18:02 1231次阅读
    <b class='flag-5'>启明智</b><b class='flag-5'>显</b>5G CPE,咖啡连锁店铺的云端智能管理中枢

    启明智5G CPE 重磅升级:云端设备管理与远程OTA全面上线!

    启明智旗下5GCPE产品迎来重要升级,核心聚焦于云端设备管理与高效OTA升级功能。此次升级打破了传统设备管理的地域限制,为用户提供远程化、集中化的设备管控能力,显著提升运维效率与灵活性。核心
    的头像 发表于 07-15 18:07 1387次阅读
    <b class='flag-5'>启明智</b><b class='flag-5'>显</b>5G CPE 重磅升级:云端设备管理与远程OTA全面上线!

    你说性能强就强吗?启明智5G CPE直接用实测数据说话!

    谁家卖产品都会说自己的产品有多厉害,但是拿到手就翻车,也就那么回事。我们也经常说启明智5GCPE性能有多顶,性价比有多高。光说也说服不了人,不如上家伙实测一下!看看到底有多顶。本次我们拿出启明智
    的头像 发表于 07-01 18:03 2511次阅读
    你说性能强就强吗?<b class='flag-5'>启明智</b><b class='flag-5'>显</b>5G CPE直接用实测数据说话!

    启明智CPE系列固件升级至 6.5.1,功能再拓展​

    近日,启明智宣布其CPE系列固件迎来重大升级,新版本6.5.1在原有功能基础上,新增了多项实用特性,为用户带来更为出色的网络体验。启明智CPE系列产品凭借其强大的功能,在市场上已获
    的头像 发表于 06-25 18:01 1123次阅读
    <b class='flag-5'>启明智</b><b class='flag-5'>显</b>CPE系列固件升级至 6.5.1,功能再拓展​

    启明智5G CPE重磅升级!全线支持原生OpenWrt 24.10.1!

    启明智5GCPE系列再度迎来升级!即日起,全系5GCPE产品支持OpenWrt24.10.1系统,以更强大的内核、更极致的兼容性,重塑智能网络体验新标准!OpenWrt24.10.1:自由拓展无边
    的头像 发表于 06-24 18:04 1455次阅读
    <b class='flag-5'>启明智</b><b class='flag-5'>显</b>5G CPE重磅升级!全线支持原生OpenWrt 24.10.1!

    启明智4.3寸触摸串口屏如何在新能源充电桩中大展身手

    显示屏是新能源充电桩的重要组件,它提供充电关键信息,影响着用户的充电体验。启明智ESP32-S3方案4.3寸触摸串口屏SC07应用于新能源充电桩中,卓越的显示效果、触摸操作、远程控制等一系列功能
    的头像 发表于 05-08 18:04 4216次阅读
    看<b class='flag-5'>启明智</b><b class='flag-5'>显</b>4.3寸触摸串口屏如何在新能源充电桩中大展身手

    好消息!启明智 ZX7981EP 路由器支持刷入 iStoreOS

    启明智ZX7981EP路由器迎来重大升级,全面支持刷入iStoreOS系统,再度为用户解锁一个功能更强大、定制更灵活的网络环境!ZX7981EP:强悍无线路由超强存储组合,海量数据随心
    的头像 发表于 04-27 18:39 1838次阅读
    好消息!<b class='flag-5'>启明智</b><b class='flag-5'>显</b> ZX7981EP 路由器支持刷入 iStoreOS

    启明智4.3寸SC07智能串口屏储能设备HMI解决方案

    。因此,启明智提出将ESP32-S3方案4.3寸智能串口屏SC07应用于储能设备。强大性能,稳定运行NO.1ESP32-S3芯片具备强大运算能力,满足储能设备对大量
    的头像 发表于 04-25 18:04 697次阅读
    <b class='flag-5'>启明智</b><b class='flag-5'>显</b>4.3寸SC07智能串口屏储能设备HMI解决方案