ESP32:Примеры/Вывод ШИМ от одного канала на несколько разных GPIO-контактов

Материал из Онлайн справочника
Перейти к навигации Перейти к поиску

Перевод: Максим Кузьмин (Cubewriter) Контакты:</br>* Skype: cubewriter</br>* E-mail: cubewriter@gmail.com</br>* Максим Кузьмин на freelance.ru
Проверка/Оформление/Редактирование: Мякишев Е.А.


Pixel Art Mini Meow Animated.gif Черновик


Вывод ШИМ от одного канала на несколько разных GPIO-контактов

На этом примере мы научимся менять яркость нескольких светодиодов при помощи ШИМ-контроллера платы ESP32, программируемого с помощью IDE Arduino.

Функционал ESP32 позволяет использовать один канал для вывода сгенерированного ШИМ-сигнала на несколько разных GPIO-контактов. Для этого вам нужно лишь привязать все эти GPIO-контакты к одному и тому же ШИМ-каналу в блоке setup().

ШИМ-контроллер ESP32 оснащен 16 независимыми каналами, которые можно настроить на генерирование ШИМ-сигналов с различными свойствами.

Чтобы поменять яркость светодиода при помощи ШИМ и IDE Arduino, нужно сделать следующее:

  • Выберите ШИМ-канал. Всего их 16 (с номерами от «0» до «15»)
  • Задайте частоту ШИМ-сигнала. Для светодиода подойдут 5000 Гц
  • Вам также нужно будет задать разрешение ШИМ-сигнала: оно может варьироваться между 1 и 16 битами. Мы воспользуемся 8-битным разрешением, т.е. управление яркостью светодиода будет осуществляться при помощи значений между «0» и «255»
  • Далее нужно задать GPIO-контакт или GPIO-контакты, где будет генерироваться ШИМ-сигнал. Для этого используется следующая функция:
ledcAttachPin(GPIO, channel)

Эта функция использует два параметра: «GPIO» – это контакт, на который будет выведен ШИМ-сигнал, а «channel» – это канал, который будет генерировать ШИМ-сигнал.

  • Наконец, для управления яркостью светодиода при помощи ШИМ-сигнала понадобится следующая функция:
ledcWrite(channel, dutycycle)

У нее два параметра: «channel» – канал, генерирующий ШИМ-сигнал, и «dutycycle» – коэффициент заполнения ШИМ-сигнала.

В начале скетча мы задаем контакты, к которым подключены светодиоды. В нашем случае светодиоды подключены к контактам GPIO16, GPIO17, GPIO5.

const int ledPin = 16;  // «16» соответствует контакту GPIO16
const int ledPin2 = 17; // «17» соответствует контакту GPIO17
const int ledPin3 = 5;  // «5» соответствует контакту GPIO5

Затем задаем свойства ШИМ-сигнала: частота – 5000 Гц, канал для генерирования сигнала – 0, разрешение – 8 бит. Если хотите, можете поэкспериментировать с этими свойствами, чтобы получить какие-нибудь другие ШИМ-сигналы.

// задаем свойства ШИМ-сигнала:
const int freq = 5000;
const int ledChannel = 0;
const int resolution = 8;

В блоке setup() настраиваем ШИМ-сигнал при помощи свойств, заданных выше. Делаем это при помощи функции ledcSetup(), параметрами для которой служат канал для генерирования ШИМ, частота и разрешение:

ledcSetup(ledChannel, freq, resolution);

Далее нам нужно задать контакты, на который будет выведен ШИМ-сигнал. Делаем это при помощи функции ledcAttachPin(), которая принимает в качестве параметров GPIO-контакт, на который нужно вывести ШИМ-сигнал, и канал, который будет его генерировать. В нашем случае GPIO-контактами для вывода ШИМ будет «ledPin» (т.е. контакт GPIO16),«ledPin2» (т.е. контакт GPIO17),«ledPin3» (т.е. контакт GPIO5), а каналом, генерирующим ШИМ-сигнал – «ledChannel» (т.е. канал 0):

ledcAttachPin(ledPin, ledChannel);
ledcAttachPin(ledPin2, ledChannel);
ledcAttachPin(ledPin3, ledChannel);

Это значит, что на этих контактах будет выводиться один и тот же ШИМ-сигнал, сгенерированный ШИМ-каналом 0.

В блоке loop() мы сначала меняем коэффициент заполнения с «0» до «255», тем самым увеличивая яркость светодиодов.

// увеличиваем яркость светодиода:
for(int dutyCycle = 0; dutyCycle <= 255; dutyCycle++){
 // меняем яркость светодиода при помощи ШИМ:
 ledcWrite(ledChannel, dutyCycle);
 delay(15);
}

Затем уменьшаем коэффициент заполнения с «255» до «0», уменьшая яркость светодиодов.

// уменьшаем яркость светодиода:
for(int dutyCycle = 255; dutyCycle >= 0; dutyCycle--){
 // меняем яркость светодиода при помощи ШИМ:
 ledcWrite(ledChannel, dutyCycle);
 delay(15);
}

Чтобы задать яркость светодиодов, нам нужна лишь функция ledcWrite(), параметрами в которой служат канал, генерирующий ШИМ, и коэффициент заполнения ШИМ-сигнала.

ledcWrite(ledChannel, dutyCycle);

Поскольку мы используем 8-битное разрешение, коэффициент заполнения ШИМ-сигнала будет варьироваться между «0» и «255». Обратите внимание, что в функции ledcWrite() первым параметром является канал, генерирующий ШИМ, а не GPIO-контакт.

Загрузите код на ESP32. Убедитесь, что в IDE Arduino выбраны правильная плата и COM-порт.

Взгляните на цепь. Все три GPIO-контакта выводят один и тот же ШИМ-сигнал, поэтому яркость всех трех светодиодов будет синхронно уменьшаться и увеличиваться.

Необходимое оборудование

Схема

Pixel Art Mini Meow Animated.gif На данной схеме используется плата ESP32S-HiLetgo, если вы используете другую, сверьтесь с вашей распиновкой.


Esp32 pwm leds exm 1.png

Код

 1 // номера контактов для светодиодов:
 2 const int ledPin = 16;  // «16» соответствует контакту GPIO16
 3 const int ledPin2 = 17; // «17» соответствует контакту GPIO17
 4 const int ledPin3 = 5;  // «5» соответствует контакту GPIO5
 5 
 6 // задаем свойства ШИМ-сигнала:
 7 const int freq = 5000;
 8 const int ledChannel = 0;
 9 const int resolution = 8;
10  
11 void setup(){
12   // настраиваем ШИМ-сигнал согласно свойствам, заданным выше:
13   ledcSetup(ledChannel, freq, resolution);
14   
15   // привязываем канал к трем GPIO-контактам:
16   ledcAttachPin(ledPin, ledChannel);
17   ledcAttachPin(ledPin2, ledChannel);
18   ledcAttachPin(ledPin3, ledChannel);
19 }
20  
21 void loop(){
22   // увеличиваем яркость светодиода:
23   for(int dutyCycle = 0; dutyCycle <= 255; dutyCycle++){   
24     // меняем яркость светодиода при помощи ШИМ:
25     ledcWrite(ledChannel, dutyCycle);
26     delay(15);
27   }
28 
29   // уменьшаем яркость светодиода:
30   for(int dutyCycle = 255; dutyCycle >= 0; dutyCycle--){
31     // меняем яркость светодиода при помощи ШИМ:
32     ledcWrite(ledChannel, dutyCycle);   
33     delay(15);
34   }
35 }

См.также

Внешние ссылки