아두이노 SSD1309 OLED 디스플레이 128x64 | 2.42인치 I2C OLED 튜토리얼
OLED(유기 발광 다이오드) 디스플레이는 자체 발광 픽셀을 통해 진정한 검은색, 높은 명암비, 넓은 시야각을 제공합니다 — 기존 LCD에 비해 훌륭한 업그레이드입니다. SSD1309는 2.42인치(2.4인치라고도 표기됨) 128×64 I2C OLED 모듈에서 흔히 발견되는 드라이버 IC입니다.

이 단계별 가이드에서는 DIYables_OLED_SSD1309 라이브러리를 사용하여 SSD1309 OLED 128×64를 Arduino 보드와 연결하고 프로그래밍하는 방법을 배웁니다. 구체적으로 다음을 다룹니다:
- I2C를 통해 2.42인치 SSD1309 OLED를 Arduino에 배선하기
- 화면에 텍스트와 숫자 출력하기
- 텍스트를 세로 및 가로 중앙에 배치하기
- 기하 도형 그리기(선, 사각형, 원, 삼각형, 둥근 사각형)
- 단색 비트맵 이미지 렌더링하기
- 네 방향 하드웨어 스크롤하기
- 대비 조정 및 디스플레이 어둡게 하기
- Adafruit GFX 폰트 컬렉션의 사용자 정의 외부 폰트 사용하기
필요한 하드웨어
| 1 | × | 아두이노 우노 R3 | 쿠팡 | 아마존 | |
| 1 | × | USB 2.0 타입 A-to-B 케이블 (USB-A PC용) | 쿠팡 | 아마존 | |
| 1 | × | USB 2.0 타입 C-to-B 케이블 (USB-C PC용) | 아마존 | |
| 1 | × | SSD1309 I2C OLED Display 128x64 (2.42 inch) | 아마존 | |
| 1 | × | 점퍼케이블 | 쿠팡 | 아마존 | |
| 1 | × | (추천) 아두이노 우노용 스크루 터미널 블록 쉴드 | 쿠팡 | 아마존 | |
| 1 | × | (추천) Sensors/Servo Expansion Shield for Arduino Uno | 아마존 | |
| 1 | × | (추천) 아두이노 우노용 브레드보드 쉴드 | 쿠팡 | 아마존 | |
| 1 | × | (추천) 아두이노 우노용 케이스 | 쿠팡 | 아마존 | |
| 1 | × | (추천) 아두이노 우노용 프로토타이핑 베이스 플레이트 & 브레드보드 키트 | 아마존 |
SSD1309 2.42인치 OLED 디스플레이에 대하여
SSD1309는 128×64 도트 매트릭스 패널용으로 설계된 단일 칩 CMOS OLED 드라이버 IC입니다. 널리 사용되는 SSD1306과 레지스터 호환이 가능하므로, 기존 코드 예제를 최소한의 변경으로 활용할 수 있습니다. 주요 하드웨어 차이점:
- 내장 차지 펌프 없음 — SSD1309는 외부 VCC 레일이 필요하지만, 사실상 모든 브레이크아웃 보드(2.42인치 및 2.4인치 모듈 포함)에는 온보드 부스트 컨버터가 탑재되어 있어 사용자에게는 투명하게 처리됩니다.
- 더 높은 전압 허용 범위 — SSD1309는 최대 16V VCC를 허용하는 반면 SSD1306은 약 4.2V로 제한됩니다.
2.42인치(2.4인치) OLED 모듈은 일반적으로 SSD1309 드라이버를 사용하며 I2C 인터페이스로 128×64 픽셀 해상도를 제공합니다. 패널 색상(흰색, 파란색, 노란색, 녹색 또는 이중 영역)은 물리적 OLED 재료에 의해 결정되며 소프트웨어로 제어할 수 없습니다.
이 튜토리얼은 I2C 버스를 통해 디스플레이와 통신하며, 두 개의 신호 와이어(SDA와 SCL)만 필요하고 다른 I2C 주변 장치와 버스를 공유할 수 있습니다.
SSD1309 OLED 핀아웃(I2C 모듈)
일반적인 2.42인치 SSD1309 I2C OLED 모듈에는 네 개의 핀이 있습니다:
- GND — Arduino 접지 레일에 연결합니다.
- VCC — 전원 입력. Arduino 5V(또는 모듈의 온보드 레귤레이터에 따라 3.3V)에 연결합니다.
- SCL — I2C 클록 라인.
- SDA — I2C 데이터 라인.

※ 주의:
- 핀 순서는 제조업체마다 다릅니다. 배선 전에 항상 특정 모듈에 실크스크린으로 인쇄된 라벨을 확인하세요.
- 이 튜토리얼은 DIYables의 2.42인치 SSD1309 OLED 디스플레이로 검증되었습니다. 다른 SSD1309 기반 2.4/2.42인치 모듈도 동일하게 작동해야 합니다.
배선도 — Arduino & SSD1309 OLED 128×64
- Arduino와 2.42인치 SSD1309 OLED 128×64 사이의 회로도 배선

이 이미지는 Fritzing을 사용하여 만들어졌습니다. 이미지를 확대하려면 클릭하세요.
- Arduino와 SSD1309 OLED 128×64 사이의 실제 배선 사진

이 이미지는 Fritzing을 사용하여 만들어졌습니다. 이미지를 확대하려면 클릭하세요.
다른 Arduino 변형을 사용할 때는 I2C 핀이 변경됩니다. 아래 표에는 올바른 연결이 나와 있습니다:
| OLED 모듈 | Arduino Uno, Nano | Arduino Mega |
|---|---|---|
| Vin | 5V | 5V |
| GND | GND | GND |
| SDA | A4 | 20 |
| SCL | A5 | 21 |
시작하기 — Arduino에서 SSD1309 OLED 사용
1단계: DIYables_OLED_SSD1309 라이브러리 설치
- Arduino IDE를 열고 왼쪽 사이드바에서 Libraries 아이콘을 클릭합니다.
- 검색 상자에 "DIYables_OLED_SSD1309"를 입력하고 DIYables에서 게시한 라이브러리를 찾습니다.
- Install 버튼을 클릭합니다.

- IDE에서 필수 의존성(Adafruit GFX Library)을 설치하라는 메시지가 표시됩니다. 계속하려면 Install All을 클릭합니다.

2단계: 기본 프로그래밍 패턴
SSD1309를 구동하는 모든 스케치는 동일한 패턴을 따릅니다: 헤더 포함, 디스플레이 객체 생성, setup()에서 초기화, 오프스크린 버퍼에 그리기, display()로 버퍼를 화면에 전송.
- 필요한 헤더 포함:
- 화면 크기 설정(2.42인치 모듈의 경우 128×64):
- 디스플레이 객체 생성(리셋 핀이 연결되지 않은 경우 -1 전달):
- setup() 내에서 디스플레이 초기화:
- 이후에는 드로잉 함수(clearDisplay(), drawPixel(), print() 등)를 호출하고 oled.display()로 화면을 업데이트합니다.
※ 주의:
이 튜토리얼의 모든 예제 코드는 SSD1309 OLED 128×64(2.42인치)를 대상으로 하며 DIYables_OLED_SSD1309 라이브러리를 사용합니다.
Arduino 코드 — SSD1309 OLED에 Hello World 표시
가장 간단한 시작점: 다양한 크기로 텍스트 몇 줄을 출력합니다.
Arduino 코드 — SSD1309 OLED에 텍스트 표시
다음 예제는 더 많은 텍스트 기능을 시연합니다 — 다양한 크기, 숫자 서식, RAM 절약을 위한 F() 매크로.
자주 사용하는 디스플레이 함수 레퍼런스
DIYables 라이브러리를 통해 SSD1309 OLED를 작업할 때 가장 자주 사용하는 함수의 빠른 레퍼런스:
- oled.clearDisplay() — 프레임 버퍼 지우기(모든 픽셀 끄기).
- oled.display() — 버퍼를 OLED로 전송하여 변경 사항을 표시합니다.
- oled.drawPixel(x, y, color) — 개별 픽셀 설정 또는 지우기.
- oled.setTextSize(n) — 폰트를 *n* 배율로 스케일(1 = 6×8, 2 = 12×16, …, 최대 8).
- oled.setCursor(x, y) — 텍스트 커서를 픽셀 좌표 *(x, y)*로 이동합니다.
- oled.setTextColor(SSD1309_PIXEL_ON) — 텍스트 전경만(배경은 투명).
- oled.setTextColor(SSD1309_PIXEL_OFF, SSD1309_PIXEL_ON) — 명시적 배경 색상이 있는 텍스트.
- oled.println("message") — 문자열을 출력하고 다음 줄로 이동합니다.
- oled.println(number) — 10진수로 정수 출력.
- oled.println(number, HEX) — 16진수로 정수 출력.
- oled.startscrollright(start, stop) — *start*와 *stop* 페이지 사이를 오른쪽으로 하드웨어 스크롤.
- oled.startscrollleft(start, stop) — 하드웨어 왼쪽 스크롤.
- oled.startscrolldiagright(start, stop) — 하드웨어 대각선 오른쪽 스크롤.
- oled.startscrolldiagleft(start, stop) — 하드웨어 대각선 왼쪽 스크롤.
- oled.stopscroll() — 활성화된 하드웨어 스크롤 중지.
- oled.setContrast(value) — 디스플레이 밝기 조정(0~255).
- oled.dim(true/false) — 디스플레이를 최소 밝기로 빠르게 어둡게 하거나 이전 대비로 복원합니다.
- oled.invertDisplay(true/false) — 하드웨어 수준의 색상 반전(켜진 픽셀 ↔ 꺼진 픽셀).
SSD1309 OLED에서 텍스트를 세로 및 가로 중앙에 배치하는 방법
Arduino 코드 — SSD1309 OLED에 도형 그리기
DIYables_OLED_SSD1309 라이브러리가 Adafruit_GFX를 확장하기 때문에 완전한 도형 그리기 기본 요소 세트를 사용할 수 있습니다: 픽셀, 선, 사각형, 채워진 사각형, 원, 채워진 원, 삼각형, 채워진 삼각형, 둥근 사각형. 아래 스케치는 애니메이션 데모로 모두 순환합니다.
Arduino 코드 — SSD1309 OLED 하드웨어 스크롤
SSD1309에는 CPU 부하 없이 디스플레이 콘텐츠를 이동하는 내장 스크롤 엔진이 있습니다. DIYables 라이브러리는 오른쪽, 왼쪽, 대각선 오른쪽, 대각선 왼쪽의 네 가지 스크롤 방향을 제공합니다. 각각 시작 페이지와 끝 페이지 매개변수를 받습니다(페이지는 64픽셀 높이 디스플레이에서 0~7로 번호가 매겨진 8픽셀 높이의 가로 띠입니다).
※ 주의:
스크롤을 시작하기 전에 항상 display()를 호출하여 콘텐츠를 OLED에 전송하세요. 스크롤이 활성화된 동안 새 콘텐츠를 그리지 마세요 — 먼저 stopscroll()을 호출하세요.
Arduino 코드 — SSD1309 OLED에 비트맵 이미지 표시
SSD1309 OLED에 비트맵을 렌더링하려면 먼저 이미지를 C 바이트 배열로 변환해야 합니다. 무료 image2cpp 온라인 도구를 사용합니다:
- 이미지(PNG, JPG, BMP 등)를 업로드합니다.
- 캔버스 크기를 128×64(또는 더 작게)로 설정합니다.
- 출력 형식으로 Arduino code를 선택합니다.
- 생성된 배열을 스케치에 복사합니다.

아래 예제는 16×16 하트 아이콘과 전체 너비 DIYables 로고 사이를 번갈아 표시합니다:
※ 주의:
- 비트맵 크기는 화면 해상도(2.42인치 모듈의 경우 128×64)를 초과할 수 없습니다.
Arduino 코드 — SSD1309 OLED 대비 및 어둡게 하기
SSD1309는 256단계의 대비(0~255)를 지원합니다. DIYables 라이브러리는 세밀한 제어를 위한 setContrast()와 최소 밝기와 이전에 구성된 수준 사이를 빠르게 전환하기 위한 dim()을 제공합니다.
Arduino 코드 — SSD1309 OLED 사용자 정의 외부 폰트
Adafruit GFX 라이브러리에는 수십 개의 확장 가능한 FreeFont 글꼴(Serif, Sans, Mono — 각각 Regular, Bold, Italic, 네 가지 크기)이 포함되어 있습니다. 해당 헤더를 포함하고 setFont()를 호출하여 SSD1309 디스플레이에서 이들 중 어떤 것이든 활성화할 수 있습니다.
※ 주의:
- 외부 폰트가 활성화되면 커서 Y 좌표는 왼쪽 상단이 아닌 텍스트 기준선을 참조합니다. 이는 내장 5×7 폰트와 다릅니다.
- 외부 폰트는 플래시(PROGMEM)에 저장됩니다. 메모리가 제한된 AVR 보드(Arduino Uno = 32KB 플래시)에서는 신중하게 사용하세요.
SSD1309 OLED 문제 해결
스케치를 업로드한 후 2.42인치 SSD1309 OLED에 아무것도 표시되지 않는 경우 다음 확인 사항을 검토하세요:
- 배선 확인 — SDA, SCL, VCC, GND가 올바른 Arduino 핀에 연결되어 있는지 확인합니다.
- 드라이버 칩 확인 — 이 라이브러리는 SSD1309용으로 설계되었습니다. 모듈이 다른 컨트롤러(예: SH1106)를 사용하는 경우 올바르게 응답하지 않습니다.
- I2C 주소 확인 — 대부분의 SSD1309 모듈의 기본 주소는 0x3C이지만 일부는 0x3D를 사용합니다. 아래 I2C 스캐너 스케치를 실행하여 실제 주소를 감지합니다:
SSD1309가 감지될 때 예상되는 시리얼 모니터 출력:
- display()가 호출되었는지 확인 — SSD1309는 프레임 버퍼를 사용합니다. 드로잉 함수는 RAM의 버퍼만 수정합니다. oled.display()를 호출해야 화면에 표시됩니다.
- 전원 공급 확인 — 2.42인치 모듈은 더 작은 OLED보다 더 많은 전류를 소비합니다. 전원 공급이 충분한 전류(전체 밝기에서 일반적으로 20~40mA)를 공급할 수 있는지 확인합니다.