아두이노 나노 ESP32 - 버튼 LED | Arduino Nano ESP32 - Button LED

이 튜토리얼은 아두이노 나노 ESP32와 버튼을 사용하여 LED를 제어하는 방법을 안내합니다. 우리는 두 가지 구별되는 사용 사례를 탐구할 것입니다:

사례 1 - 다음과 같이 설명된 LED와 버튼 상태 간의 동기화:

사례 2 - 다음과 같이 각 버튼을 누를 때마다 LED 상태를 토글하는 것:

아두이노 나노 ESP32가 버튼에서 HIGH 상태에서 LOW 상태로의 전환(누름을 나타냄)을 감지하면, 현재 LED가 꺼져 있으면 켜고, 켜져 있으면 끕니다.

버튼을 놓아도 LED 상태에는 영향을 주지 않습니다.

사례 2에서는 버튼을 디바운스(debounce)하여 제대로 기능하도록 하는 것이 중요합니다. 아두이노 나노 ESP32 코드를 사용할 때 버튼 디바운싱을 적용했을 때와 적용하지 않았을 때의 LED 동작을 비교함으로써 디바운싱의 중요성을 살펴보겠습니다.

준비물

1×Arduino Nano ESP32 Amazon
1×USB Cable Type-C 쿠팡 | Amazon
1×Push Button 쿠팡 | Amazon
1×(Optional) Panel-mount Push Button Amazon
1×LED Amazon
1×220 ohm resistor Amazon
1×Breadboard 쿠팡 | Amazon
1×Jumper Wires Amazon
1×(Optional) 5V Power Adapter for Arduino Nano ESP32 Amazon
1×(Recommended) Screw Terminal Expansion Board for Arduino Nano 쿠팡 | Amazon
공개: 이 섹션에서 제공된 링크 중 일부는 제휴 링크입니다. 이 링크를 통해 구매한 경우 추가 비용없이 수수료를 받을 수 있습니다. 지원해 주셔서 감사합니다.

LED와 버튼에 관하여

만약 여러분이 LED와 버튼(핀 배치, 작동 방식 및 프로그래밍 포함)에 익숙하지 않다면, 다음 튜토리얼들이 도움이 될 것입니다:

선연결

Arduino Nano ESP32 Button LED wiring diagram

이 이미지는 Fritzing을 사용하여 만들어졌습니다. 이미지를 확대하려면 클릭하세요.

응용 프로그램 1 - LED 상태가 버튼 상태와 동기화됩니다

아두이노 나노 ESP32 코드

/* * 이 Arduino Nano ESP32 코드는 newbiely.kr 에서 개발되었습니다 * 이 Arduino Nano ESP32 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/arduino-nano-esp32/arduino-nano-esp32-button-led */ #define BUTTON_PIN D2 // 버튼이 연결된 아두이노 나노 ESP32 핀 #define LED_PIN D5 // LED가 연결된 아두이노 나노 ESP32 핀 int button_state = 0; // 푸시버튼 상태를 읽기 위한 변수 void setup() { // LED 핀을 디지털 출력으로 설정 pinMode(LED_PIN, OUTPUT); // 버튼 핀을 풀업 입력으로 초기화 (스위치가 열려있을 때 HIGH 그리고 닫혀있을 때 LOW) pinMode(BUTTON_PIN, INPUT_PULLUP); } void loop() { // 푸시버튼 상태를 읽음: button_state = digitalRead(BUTTON_PIN); // 버튼의 상태에 따라 LED 제어 if(button_state == LOW) // 버튼이 눌리면 digitalWrite(LED_PIN, HIGH); // LED 켜기 else // 그렇지 않으면, 버튼이 눌리지 않았으면 digitalWrite(LED_PIN, LOW); // LED 끄기 }

사용 방법

  • 아두이노 나노 ESP32를 처음 사용하는 경우, 아두이노 나노 ESP32의 환경 설정 방법 보기를 참조하세요.
  • 도표에 표시된 대로 구성 요소를 연결하세요.
  • USB 케이블을 사용하여 아두이노 나노 ESP32 보드를 컴퓨터에 연결하세요.
  • 컴퓨터에서 아두이노 IDE를 엽니다.
  • 올바른 아두이노 나노 ESP32 보드(예: NodeMCU 1.0 (ESP-12E Module))와 해당 COM 포트를 선택하세요.
  • USB 케이블로 아두이노 나노 ESP32를 컴퓨터에 연결하세요.
  • 아두이노 IDE를 시작하고, 올바른 보드와 포트를 선택하세요.
  • 코드를 복사하고 아두이노 IDE에서 엽니다.
  • 아두이노 IDE에서 Upload 버튼을 클릭하여 코드를 컴파일하고 아두이노 나노 ESP32에 업로드하세요.
Arduino IDE Upload Code
  • 버튼을 누르고 몇 초 동안 계속 누르세요.
  • LED 상태의 변화를 확인하세요.

버튼 상태와 LED 상태가 동기화되어 있음을 알게 될 것입니다.

코드 설명

소스 코드의 주석에 포함된 줄별 설명을 확인하세요!

애플리케이션 2 - 버튼 토글 LED

아두이노 나노 ESP32 코드 - 디바운싱 없이 버튼으로 LED 토글하기

/* * 이 Arduino Nano ESP32 코드는 newbiely.kr 에서 개발되었습니다 * 이 Arduino Nano ESP32 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/arduino-nano-esp32/arduino-nano-esp32-button-led */ #define BUTTON_PIN D2 // Arduino Nano ESP32 핀이 버튼에 연결됨 #define LED_PIN D5 // Arduino Nano ESP32 핀이 LED에 연결됨 int led_state = LOW; // LED의 현재 상태 int prev_button_state; // 버튼의 이전 상태 int button_state; // 버튼의 현재 상태 void setup() { Serial.begin(9600); // 직렬 통신을 사용하여 시리얼 모니터와 통신을 초기화합니다. pinMode(BUTTON_PIN, INPUT_PULLUP); // 아두이노 핀을 입력 풀업 모드로 설정 pinMode(LED_PIN, OUTPUT); // 아두이노 핀을 출력 모드로 설정 button_state = digitalRead(BUTTON_PIN); } void loop() { prev_button_state = button_state; // 마지막 상태 저장 button_state = digitalRead(BUTTON_PIN); // 새로운 상태 읽기 if(prev_button_state == HIGH && button_state == LOW) { Serial.println("The button is pressed"); // LED의 상태 토글 led_state = !led_state; // 토글된 상태에 따라 LED 제어 digitalWrite(LED_PIN, led_state); } }

코드 설명

Arduino Nano ESP32 코드 위의 주석 줄에서 설명을 찾을 수 있습니다.

코드에서 led_state = !led_state라는 표현은 다음 코드와 동일합니다:

if(led_state == LOW) led_state = HIGH; else led_state = LOW;

사용 방법

  • 코드를 복사하여 아두이노 IDE에서 열십시오.
  • 코드를 아두이노 나노 ESP32에 업로드하십시오.
  • 릴리스와 버튼을 여러 번 누르십시오.
  • LED의 상태 변화를 확인하십시오.

버튼을 누를 때마다 LED 상태가 토글됨을 관찰할 수 있습니다. 그러나 이러한 동작은 항상 일관되지 않을 수 있습니다. 때로는 단일 버튼 누름 내에서 LED 상태가 여러 번 빠르게 토글될 수 있거나 전혀 토글되지 않을 수도 있습니다(맨눈으로 보기 어려울 수 있는 빠른 연속으로 두 번 토글됨).

이 문제를 해결하기 위해서는 버튼에 대한 디바운스가 필요합니다.

아두이노 나노 ESP32 코드 - 디바운싱을 사용한 버튼으로 LED 토글하기

버튼 디바운싱은 초보자에게 도전적일 수 있습니다. 다행히 ezButton 라이브러리가 이를 쉽게 해줍니다.

디바운싱이 왜 필요한가요? 자세한 내용은 아두이노 나노 ESP32 - 버튼 디바운스 튜토리얼을 참조하세요.

/* * 이 Arduino Nano ESP32 코드는 newbiely.kr 에서 개발되었습니다 * 이 Arduino Nano ESP32 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/arduino-nano-esp32/arduino-nano-esp32-button-led */ #include <ezButton.h> #define BUTTON_PIN D2 // 아두이노 나노 ESP32 핀이 버튼에 연결됨 #define LED_PIN D5 // 아두이노 나노 ESP32 핀이 LED에 연결됨 ezButton button(BUTTON_PIN); // ezButton 객체 생성 int led_state = LOW; // LED의 현재 상태 void setup() { Serial.begin(9600); // 시리얼 모니터와 통신하기 위해 시리얼 초기화. pinMode(LED_PIN, OUTPUT); // 아두이노 핀을 출력 모드로 설정 button.setDebounceTime(50); // 디바운스 시간을 50 밀리초로 설정 } void loop() { button.loop(); // 반드시 loop() 함수를 먼저 호출해야 함 if(button.isPressed()) { Serial.println("The button is pressed"); // LED의 상태 토글 led_state = !led_state; // 토글된 상태에 따라 LED 제어 digitalWrite(LED_PIN, led_state); } }

사용 방법

  • EzButton 라이브러리를 설치하세요. 지침은 How To를 참조하세요.
  • 코드를 복사하고 Arduino IDE로 열어주세요.
  • Arduino IDE에서 Upload 버튼을 클릭하여 코드를 Arduino Nano ESP32에 업로드하세요.
  • 버튼을 여러 번 눌렀다 놓으세요.
  • LED의 상태 변경을 확인하세요.

버튼을 누를 때마다 LED 상태가 정확히 한 번씩 토글되는 것을 볼 수 있습니다.

동영상

비디오 제작은 시간이 많이 걸리는 작업입니다. 비디오 튜토리얼이 학습에 도움이 되었다면, YouTube 채널 을 구독하여 알려 주시기 바랍니다. 비디오에 대한 높은 수요가 있다면, 비디오를 만들기 위해 노력하겠습니다.

※ OUR MESSAGES

  • Please feel free to share the link of this tutorial. However, Please do not use our content on any other websites. We invested a lot of effort and time to create the content, please respect our work!