ESP8266 - 빛 센서 | ESP8266 - Light Sensor

이 튜토리얼은 ESP8266과 함께 광 센서를 사용하는 방법을 알려줍니다. 자세히:

모듈 형태의 광 센서를 찾고 계시다면, ESP8266 - LDR 광 센서 모듈에 대한 튜토리얼을 확인해 보시는 것을 추천합니다.

준비물

1×ESP8266 NodeMCU Amazon
1×Micro USB Cable Amazon
1×Light Sensor Amazon
1×10 kΩ resistor Amazon
1×Breadboard 쿠팡 | Amazon
1×Jumper Wires Amazon
1×(Optional) 5V Power Adapter for ESP8266 Amazon
1×(Optional) ESP8266 Screw Terminal Adapter Amazon
공개: 이 섹션에서 제공된 링크 중 일부는 제휴 링크입니다. 이 링크를 통해 구매한 경우 추가 비용없이 수수료를 받을 수 있습니다. 지원해 주셔서 감사합니다.

조도 센서에 대하여

이 튜토리얼에서 사용하는 센서는 광저항, 빛에 의존하는 저항, LDR 또는 광전지로도 알려져 있습니다.

빛을 감지하는 용도로만 사용되는 것이 아니라, 주변 빛의 강도를 측정하는 데에도 사용됩니다.

광 센서 핀아웃

포토레지스터는 레지스터의 한 종류로서 핀이 대칭이기 때문에 구분할 필요가 없는 두 개의 핀을 가지고 있습니다.

Light Sensor pinout

작동 원리

포토레지스터의 면이 노출되는 빛의 양은 그저항에 영향을 미칩니다. 이 저항을 측정함으로써 주변 빛의 밝기를 결정할 수 있습니다.

How Light Sensor Works

WARNING

광 센서에서 나오는 값은 광량의 정확한 측정이 아닌, 빛의 강도에 대한 대략적인 지표만을 제공합니다. 따라서, 높은 정확도를 요구하는 응용 프로그램에는 사용해서는 안 됩니다.

ESP8266 - 광 센서

ESP8266의 아날로그 핀은 아날로그 입력으로 사용할 수 있습니다. 이러한 아날로그 입력 핀은 전압(0볼트에서 VCC까지의 범위)을 정수값(0에서 1023까지의 범위)으로 변환하는데, 이를 ADC 값 또는 아날로그 값이라고 합니다.

포토레지스터의 한 핀을 아날로그 입력 핀에 연결하십시오. analogRead() 함수를 사용하여 핀에서 아날로그 값을 읽으십시오. 이를 통해 상대적으로 조명 수준을 결정할 수 있습니다.

선연결

ESP8266 NodeMCU Light Sensor wiring diagram

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

ESP8266의 핀 배치ESP8266 및 다른 구성 요소에 전원을 공급하는 방법에 대해 더 많이 보십시오.

ESP8266 코드

아래 코드는 포토셀에서 값을 읽고 광량 수준을 질적으로 결정합니다.

/* * 이 ESP8266 NodeMCU 코드는 newbiely.kr 에서 개발되었습니다 * 이 ESP8266 NodeMCU 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/esp8266/esp8266-light-sensor */ #define LIGHT_SENSOR_PIN A0 // ESP8266의 핀 ADC0 void setup() { // 시리얼 모니터와 통신하기 위해 시리얼을 초기화합니다. Serial.begin(9600); } void loop() { // 아날로그 핀에서 입력을 읽습니다 (값은 0에서 1023 사이) int analog_value = analogRead(LIGHT_SENSOR_PIN); Serial.print("Analog Value = "); Serial.print(analog_value); // 아날로그 값을 그대로 읽습니다. // 여러 개의 임계값을 설정합니다. 질적으로 결정됩니다. if (analog_value < 40) { Serial.println(" => Dark"); } else if (analog_value < 800) { Serial.println(" => Dim"); } else if (analog_value < 2000) { Serial.println(" => Light"); } else if (analog_value < 3200) { Serial.println(" => Bright"); } else { Serial.println(" => Very bright"); } delay(500); }

사용 방법

Arduino IDE에서 ESP8266을 시작하는 방법은 다음 단계를 따르세요:

  • ESP8266을 처음 사용하는 경우 Arduino IDE에서 ESP8266 환경 설정 방법 튜토리얼을 확인하세요.
  • 도표에 표시된 대로 구성요소를 연결하세요.
  • USB 케이블을 사용하여 컴퓨터에 ESP8266 보드를 연결하세요.
  • 컴퓨터에서 Arduino IDE를 엽니다.
  • 올바른 ESP8266 보드 (예: NodeMCU 1.0 (ESP-12E Module))와 해당 COM 포트를 선택하세요.
  • 코드를 복사하고 Arduino IDE로 엽니다.
  • Arduino IDE에서 Upload 버튼을 클릭하여 ESP8266에 코드를 컴파일하고 업로드하세요.
  • 시리얼 모니터를 엽니다.
  • 센서에 빛을 비추세요.
  • 시리얼 모니터에서 결과를 확인하세요.
COM6
Send
Analog reading: 163 - Dim Analog reading: 152 - Dim Analog reading: 187 - Dim Analog reading: 188 - Dim Analog reading: 957 - Very bright Analog reading: 972 - Very bright Analog reading: 981 - Very bright
Autoscroll Show timestamp
Clear output
9600 baud  
Newline  

빛 센서와 LED

환경이 어두울 때 코드가 LED를 활성화시키고, 그렇지 않으면 비활성화시킬 것입니다.

/* * 이 ESP8266 NodeMCU 코드는 newbiely.kr 에서 개발되었습니다 * 이 ESP8266 NodeMCU 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/esp8266/esp8266-light-sensor */ #define LIGHT_SENSOR_PIN A0 // ESP8266 핀이 빛 센서에 연결됨 #define LED_PIN D8 // ESP8266 핀이 LED에 연결됨 #define ANALOG_THRESHOLD 500 void setup() { pinMode(LED_PIN, OUTPUT); // ESP8266 핀을 출력 모드로 구성 } void loop() { int analog_value = analogRead(LIGHT_SENSOR_PIN); // 아날로그 핀의 값을 읽음 if (analog_value < ANALOG_THRESHOLD) digitalWrite(LED_PIN, HIGH); // LED를 켬 else digitalWrite(LED_PIN, LOW); // LED를 끔 }

위의 코드에 대한 배선도.

ESP8266 NodeMCU Light Sensor LED wiring diagram

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

동영상

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

도전하세요

  • 방 안의 불이 어두워지면 자동으로 켜세요.
  • 이를 수행하는 방법에 대한 지침은 ESP8266 - 릴레이를 참조하세요.

※ 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!