Microsoft MVP성태의 닷넷 이야기
사물인터넷: 39. 아두이노에서 적외선 송신기 기본 사용법 [링크 복사], [링크+제목 복사],
조회: 19942
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
(연관된 글이 5개 있습니다.)

아두이노에서 적외선 송신기 기본 사용법

지난 글에 IR 수신기를 알아봤으니,

아두이노에서 적외선 수신기 기본 사용법
; https://www.sysnet.pe.kr/2/0/11670

이제 당연히 그 수신했던 데이터를 송신해 볼 차례입니다. ^^ 이를 위해 송신기에 사용한 부품 먼저 소개합니다.

Infrared_led.jpg

구매 링크는 다음과 같습니다.

아두이노 KY-005 적외선 발광 센서 모듈(AS0164)
; http://arduinostory.com/goods/goods_view.php?goodsNo=1000000164

제조사: 애니벤더
원산지: 중국
사양:
    펄스 순방향 전류: 0.3 ~ 1A
    역방향 전압: 5V
    온도 범위: -25 ~ +80
    크기: 가로 19mm x 세로 15mm

역시 별다른 datasheet가 없는데요, 동일하진 않지만 유사한 모델로 보이는 다음의 문서를 찾을 수 있어 사용하는데 지장은 없습니다.

KY-005 Infrared Transmitter Module
; https://arduinomodules.info/ky-005-infrared-transmitter-sensor-module/

Operating Voltage 5V 
Forward Current 30 ~ 60 mA 
Power Consumption 90mW 
Operating Temperature -25°C to 80°C [-13°F to 176°F] 
Dimensions  18.5mm x 15mm [0.728in x 0.591in] 

게다가 Pin 배치 역시 지난 IR 수신기 때와 비슷하므로,

KY-005 Arduino
S Signal
Middle +5V
- GND

이에 맞게 배치를 하면 됩니다.

ir_send_1.png

보는 바와 같이 제 경우에는 Signal 핀을 아두이노의 13번 핀에 연결하고 추가로 4번 핀을 Push 버튼으로 입력받는 용도로 했습니다. 즉, Push 버튼을 한 번 누르면 IR 송신을 하도록 만들고 싶은 것입니다. 여기서 주의할 것은, IR 송신을 위한 핀이 아두이노의 CPU에 종류에 따라 이미 정해져 있다는 것입니다. (기본 핀을 바꾸려면 헤더 파일의 코드를 변경해야 합니다.) 이에 대해서는 IRRemote 라이브러리의 readme에 자세하게 나와 있습니다.

z3t0/Arduino-IRremote 
; https://github.com/z3t0/Arduino-IRremote

제가 테스트하는 아두이노 레오나르도 호환 보드는 Atmega32u4를 사용하기 때문에 "Atmega32u4 5, 9, 13"에 해당하고 이 중에서 굵은 글씨로 되어 있는 13번을 따른 것입니다. 이제 코딩을 해야 하는데요, 지난번과 동일하게 IRRemote 라이브러리를 포함한 다음 이전에 수신해 두었던 데이터를,

33E09F86
Unknown encoding: 33E09F86 (32 bits)
Raw (26): 3550 -1750 600 -400 600 -1800 550 -450 600 -450 600 -1800 550 -450 600 -450 600 -500 600 -450 600 -400 650 -400 550 

(Unknown 인코딩이므로) Raw 데이터 그대로 전송하면 됩니다 따라서 이것을 음수 표현 없이 다음과 같이 배열로 만들어 줍니다.

#include <boarddefs.h>
#include <IRremote.h>
#include <IRremoteInt.h>
#include <ir_Lego_PF_BitStreamEncoder.h>

const int buttonPin = 4;
const int khz = 38;

IRsend irsend;

unsigned int light_onoff_signal_buf[] = { 3550, 1750, 600, 400, 600, 1800, 550, 450, 600, 450, 600, 1800, 550, 450, 600, 450, 600, 500, 600, 450, 600, 400, 650, 400, 550 };

그다음, 이것을 4번 핀에 연결한 버튼이 눌린 경우 sendRaw 함수를 이용해 전송하면 됩니다.

void setup()
{
    Serial.begin(9600);
    pinMode(buttonPin, INPUT_PULLUP); // 풀업 모드의 입력
}

void loop() 
{
    int buttonState = digitalRead(buttonPin);
    if (buttonState == HIGH)
    {
    }
    else
    {
        Serial.println("Sent");
        irsend.sendRaw(light_onoff_signal_buf, sizeof(light_onoff_signal_buf) / sizeof(int), khz);
    }

    delay(1000);
}

우와~~~ 정말 형광등이 꺼졌다 켜졌다 합니다. ^^

첨부 파일은 이 글의 전체 소스 코드와 회로 그림에 대한 원본 fzz 파일이 들어 있습니다. 또한 아래는 KY-005 Infrared Transmitter Module에 대한 Fritzing 부품 파일입니다.

KY-005 Infrared Transmitter Module Zip File
; https://arduinomodules.info/download/ky-005-infrared-transmitter-module-zip-file/




참고로, 실습을 해보면 아시겠지만 "아두이노 KY-005 적외선 발광 센서 모듈(AS0164)"의 기능이 그리 훌륭하지 않습니다. 제 경우에 약 3m부터는 IR LED의 방향이 (아주) 정확히 수신 센서의 방향을 향해야만 동작을 했습니다. 따라서 처음 테스트할 때는 동작 유무 확인을 위해 수신 센서 근방에서 하는 것이 좋습니다. 집에서 전등 On/off를 하는 리모컨에 달린 IR 송신기와 비교해보면, 일상적으로 사용하기에는 불편할 정도라는 것을 알 수 있습니다. 테스트 용이 아닌, 현실적으로 응용하고 싶다면 저 부품이 아닌 다른 걸로 선택하시는 것이 좋을 것입니다.

재미있는 것은, 이 글의 회로도에는 Vcc 입력 핀을 아두이노의 5V 핀과 연결했지만 사실 그 입력은 IR 송신기에서 사용하지 않습니다. IR 송신 보드를 자세히 보면 그 핀이 아무런 역할도 하지 않음을 알 수 있습니다. 즉, 그냥 5V 입력 핀을 연결하지 않아도 됩니다. (그렇게 따지면 IR LED는 아두이노 입력 핀의 3.3V 전압으로 작동했다는 이야기가 됩니다.)

제가 가지고 있는 IR 송신기의 보드 일체형이 아닌 단품으로 된 제품이 있는데, 일반 LED처럼 다리가 2개 달린 IR LED입니다. 따라서, Signal + GND 핀만 의미가 있는 것입니다. 아래는 단품 IR LED와 5V 전압을 컬렉터 입력으로 PN2222A 트랜지스터를 이용해 증폭을 한 것으로,

ir_send_2.png

성능이 좀 더 나아집니다. 그런데, 집에 있는 형광등 리모컨이 3V(1.5V 건전지 2개)에서 동작함에도 불구하고 확실히 "아두이노 KY-005 적외선 발광 센서 모듈(AS0164)" 제품보다 훨씬 송신 감도가 좋습니다. (아마도 송신기의 제품 차이가 있는 것 같습니다.) 이를 감안하면 기존 리모컨을 대체하는 용도로는 현재의 부품 구성으로는 사용 측면에서 답답함이 좀 있습니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]

[연관 글]






[최초 등록일: ]
[최종 수정일: 10/24/2018]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13570정성태2/29/20245362닷넷: 2222. C# - WPF의 Dispatcher Queue 동작 확인파일 다운로드1
13569정성태2/28/20245710닷넷: 2221. C# - LoadContext, LoadFromContext 그리고 GAC파일 다운로드1
13568정성태2/27/20244935닷넷: 2220. C# - .NET Framework 프로세스의 LoaderOptimization 설정을 확인하는 방법파일 다운로드1
13567정성태2/27/20244959오류 유형: 898. .NET Framework 3.5 이하에서 mscoree.tlb 참조 시 System.BadImageFormatException파일 다운로드1
13566정성태2/27/20244947오류 유형: 897. Windows 7 SDK 설치 시 ".NET Development" 옵션이 비활성으로 선택이 안 되는 경우
13565정성태2/23/20244938닷넷: 2219. .NET CLR2 보안 모델에서의 개별 System.Security.Permissions 제어
13564정성태2/22/20245371Windows: 259. Hyper-V Generation 1 유형의 VM을 Generation 2 유형으로 바꾸는 방법
13563정성태2/21/20245301디버깅 기술: 196. windbg - async/await 비동기인 경우 메모리 덤프 분석의 어려움
13562정성태2/21/20245246오류 유형: 896. ASP.NET - .NET Framework 기본 예제에서 System.Web에 대한 System.IO.FileNotFoundException 예외 발생
13561정성태2/20/20245592닷넷: 2218. C# - (예를 들어, Socket) 비동기 I/O에 대한 await 호출 시 CancellationToken을 이용한 취소파일 다운로드1
13560정성태2/19/20245505디버깅 기술: 195. windbg 분석 사례 - Semaphore 잠금으로 인한 Hang 현상 (닷넷)
13559정성태2/19/20246317오류 유형: 895. ASP.NET - System.Security.SecurityException: 'Requested registry access is not allowed.'
13558정성태2/18/20245588닷넷: 2217. C# - 최댓값이 1인 SemaphoreSlim 보다 Mutex 또는 lock(obj)를 선택하는 것이 나은 이유
13557정성태2/18/20245009Windows: 258. Task Scheduler의 Author 속성 값을 변경하는 방법
13556정성태2/17/20245162Windows: 257. Windows - Symbolic (hard/soft) Link 및 Junction 차이점
13555정성태2/15/20245605닷넷: 2216. C# - SemaphoreSlim 사용 시 주의점
13554정성태2/15/20244784VS.NET IDE: 189. Visual Studio - 닷넷 소스코드 디컴파일 찾기가 안 될 때
13553정성태2/14/20244846닷넷: 2215. windbg - thin/fat lock 없이 동작하는 Monitor.Wait + Pulse
13552정성태2/13/20244865닷넷: 2214. windbg - Monitor.Enter의 thin lock과 fat lock
13551정성태2/12/20245655닷넷: 2213. ASP.NET/Core 웹 응용 프로그램 - 2차 스레드의 예외로 인한 비정상 종료
13550정성태2/11/20245754Windows: 256. C# - Server socket이 닫히면 Accept 시켰던 자식 소켓이 닫힐까요?
13549정성태2/3/20246160개발 환경 구성: 706. C# - 컨테이너에서 실행하기 위한 (소켓) 콘솔 프로젝트 구성
13548정성태2/1/20245912개발 환경 구성: 705. "Docker Desktop for Windows" - ASP.NET Core 응용 프로그램의 소켓 주소 바인딩(IPv4/IPv6 loopback, Any)
13547정성태1/31/20245573개발 환경 구성: 704. Visual Studio - .NET 8 프로젝트부터 dockerfile에 추가된 "USER app" 설정
13546정성태1/30/20245304Windows: 255. (디버거의 영향 등으로) 대상 프로세스가 멈추면 Socket KeepAlive로 연결이 끊길까요?
13545정성태1/30/20245191닷넷: 2212. ASP.NET Core - 우선순위에 따른 HTTP/HTTPS 호스트:포트 바인딩 방법
1  2  3  4  5  6  7  8  9  [10]  11  12  13  14  15  ...