You are currently viewing 具有Arduino IDE的ESP8266 0.96英寸OLED顯示螢幕

具有Arduino IDE的ESP8266 0.96英寸OLED顯示螢幕

本指南展示了如何使用Arduino IDE將0.96英寸SSD1306 OLED顯示器與ESP8266一起使用。我們將向您展示如何編寫文本,設置不同的字體,繪製形狀以及顯示點陣圖圖像。

我們還有專門的指南,介紹如何使用DHT傳感器和ESP8266顯示溫度和濕度讀數。

OLED顯示器不需要背光,因此在黑暗環境中可以產生很好的對比度。此外,其像素僅在打開時才消耗能量,因此與其他顯示器相比,OLED顯示器消耗的功率更少。

我們使用的模型有四個引腳,並使用I2C通信協議與任何微控制器進行通信。有些型號帶有額外的RESET引腳,或者使用SPI通信協議進行通信。

 OLED顯示器SSD1306引腳接線 

由於OLED顯示器使用I2C通信協議,因此接線非常簡單。您可以使用下表作為參考。
PinESP8266
Vin3.3V
GNDGND
SCLGPIO 5 (D1)
SDAGPIO 4 (D2)

或者,您可以按照下面原理圖將ESP8266連接到OLED顯示器。

ESP8266 Arduino OLED顯示電路原理圖

在此範例中,我們使用I2C通信協議。ESP8266中最適的I2C通信管腳是GPIO 5 (SCL)和 GPIO 4 (SDA)。

如果您使用的是帶有SPI通信協議的OLED顯示器,請使用以下GPIO。

  • GPIO 14:CLK
  • GPIO 12:MISO
  • GPIO 13:MOSI
  • GPIO 15:CS

安裝SSD1306 OLED庫– ESP8266 

ESP8266有多個可用的庫來控制OLED顯示器。在本教程中,我們將使用兩個Adafruit庫:Adafruit_SSD1306庫Adafruit_GFX庫

請按照以下步驟安裝這些庫。

1.打開您的Arduino IDE,然後轉到 草稿碼 匯入程式庫 > 管理程式庫。程式庫管理員應會開啟。

2.在搜索框中鍵入“ SSD1306 ”,然後從Adafruit安裝SSD1306庫。

3.從Adafruit安裝SSD1306庫後,在搜索框中鍵入“ GFX ”並安裝該庫。

4.安裝庫之後,重新啟動Arduino IDE。

我們將使用Arduino IDE來對ESP8266進行編程,因此您必須在Arduino IDE中安裝ESP8266插件。如果還沒有,請先閱讀下面教程:

使用ESP8266測試OLED顯示器 

將OLED顯示器連接到ESP8266並安裝所有必需的庫之後,您可以使用程式庫中的範例查看一切是否正常運行。 在Arduino IDE中,轉到“檔案 >“例” >“ Adafruit SSD1306”,然後為您所使用的顯示器選擇範例。

應加載以下程式碼:

/*********
  完整說明請參閱 https://honeststore.com.tw    
*********/

#include <SPI.h>
#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h> #define SCREEN_WIDTH 128 // OLED display width, in pixels #define SCREEN_HEIGHT 64 // OLED display height, in pixels // SSD1306顯示器的聲明連接到I2C(SDA, SCL pins) #define OLED_RESET -1 // Reset pin # (or -1 if sharing Arduino reset pin) Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, OLED_RESET); #define NUMFLAKES 10 // 動畫例中的雪花數量 #define LOGO_HEIGHT 16 #define LOGO_WIDTH 16 static const unsigned char PROGMEM logo_bmp[] = { B00000000, B11000000, B00000001, B11000000, B00000001, B11000000, B00000011, B11100000, B11110011, B11100000, B11111110, B11111000, B01111110, B11111111, B00110011, B10011111, B00011111, B11111100, B00001101, B01110000, B00011011, B10100000, B00111111, B11100000, B00111111, B11110000, B01111100, B11110000, B01110000, B01110000, B00000000, B00110000 }; void setup() { Serial.begin(115200); // SSD1306_SWITCHCAPVCC = generate display voltage from 3.3V internally if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { Serial.println(F("SSD1306 allocation failed")); for(;;); // Don't proceed, loop forever } // 在螢幕上顯示初始顯示緩衝區內容 display.display(); delay(2000); // Pause for 2 seconds // 清除緩衝區 display.clearDisplay(); // Draw a single pixel in white display.drawPixel(10, 10, WHITE); // Show the display buffer on the screen. You MUST call display() after // drawing commands to make them visible on screen! display.display(); delay(2000); // display.display() is NOT necessary after every single drawing command, // unless that's what you want...rather, you can batch up a bunch of // drawing operations and then update the screen all at once by calling // display.display(). These examples demonstrate both approaches... testdrawline(); // 畫出多個直線 testdrawrect(); // 繪製矩形 (outlines) testfillrect(); // 繪製矩形 (filled) testdrawcircle(); // 繪製圓圈 (outlines) testfillcircle(); // 繪製圓圈 (filled) testdrawroundrect(); // 繪製圓角矩形 (outlines) testfillroundrect(); // 繪製圓角矩形 (filled) testdrawtriangle(); // 繪製三角形 (outlines) testfilltriangle(); // 繪製三角形 (filled) testdrawchar(); // 繪製預設字體的字符 testdrawstyles(); // 繪製“程式化”字符 testscrolltext(); // 繪製滾動文字 testdrawbitmap(); // 繪製一個小點陣圖圖像 // Invert and restore display, pausing in-between display.invertDisplay(true); delay(1000); display.invertDisplay(false); delay(1000); testanimate(logo_bmp, LOGO_WIDTH, LOGO_HEIGHT); // Animate bitmaps } void loop() { } void testdrawline() { int16_t i; display.clearDisplay(); // Clear display buffer for(i=0; i<display.width(); i+=4) { display.drawLine(0, 0, i, display.height()-1, WHITE); display.display(); // Update screen with each newly-drawn line delay(1); } for(i=0; i<display.height(); i+=4) { display.drawLine(0, 0, display.width()-1, i, WHITE); display.display(); delay(1); } delay(250); display.clearDisplay(); for(i=0; i<display.width(); i+=4) { display.drawLine(0, display.height()-1, i, 0, WHITE); display.display(); delay(1); } for(i=display.height()-1; i>=0; i-=4) { display.drawLine(0, display.height()-1, display.width()-1, i, WHITE); display.display(); delay(1); } delay(250); display.clearDisplay(); for(i=display.width()-1; i>=0; i-=4) { display.drawLine(display.width()-1, display.height()-1, i, 0, WHITE); display.display(); delay(1); } for(i=display.height()-1; i>=0; i-=4) { display.drawLine(display.width()-1, display.height()-1, 0, i, WHITE); display.display(); delay(1); } delay(250); display.clearDisplay(); for(i=0; i<display.height(); i+=4) { display.drawLine(display.width()-1, 0, 0, i, WHITE); display.display(); delay(1); } for(i=0; i<display.width(); i+=4) { display.drawLine(display.width()-1, 0, i, display.height()-1, WHITE); display.display(); delay(1); } delay(2000); // Pause for 2 seconds } void testdrawrect(void) { display.clearDisplay(); for(int16_t i=0; i<display.height()/2; i+=2) { display.drawRect(i, i, display.width()-2*i, display.height()-2*i, WHITE); display.display(); // Update screen with each newly-drawn rectangle delay(1); } delay(2000); } void testfillrect(void) { display.clearDisplay(); for(int16_t i=0; i<display.height()/2; i+=3) { // The INVERSE color is used so rectangles alternate white/black display.fillRect(i, i, display.width()-i*2, display.height()-i*2, INVERSE); display.display(); // Update screen with each newly-drawn rectangle delay(1); } delay(2000); } void testdrawcircle(void) { display.clearDisplay(); for(int16_t i=0; i<max(display.width(),display.height())/2; i+=2) { display.drawCircle(display.width()/2, display.height()/2, i, WHITE); display.display(); delay(1); } delay(2000); } void testfillcircle(void) { display.clearDisplay(); for(int16_t i=max(display.width(),display.height())/2; i>0; i-=3) { // The INVERSE color is used so circles alternate white/black display.fillCircle(display.width() / 2, display.height() / 2, i, INVERSE); display.display(); // Update screen with each newly-drawn circle delay(1); } delay(2000); } void testdrawroundrect(void) { display.clearDisplay(); for(int16_t i=0; i<display.height()/2-2; i+=2) { display.drawRoundRect(i, i, display.width()-2*i, display.height()-2*i, display.height()/4, WHITE); display.display(); delay(1); } delay(2000); } void testfillroundrect(void) { display.clearDisplay(); for(int16_t i=0; i<display.height()/2-2; i+=2) { // The INVERSE color is used so round-rects alternate white/black display.fillRoundRect(i, i, display.width()-2*i, display.height()-2*i, display.height()/4, INVERSE); display.display(); delay(1); } delay(2000); } void testdrawtriangle(void) { display.clearDisplay(); for(int16_t i=0; i<max(display.width(),display.height())/2; i+=5) { display.drawTriangle( display.width()/2 , display.height()/2-i, display.width()/2-i, display.height()/2+i, display.width()/2+i, display.height()/2+i, WHITE); display.display(); delay(1); } delay(2000); } void testfilltriangle(void) { display.clearDisplay(); for(int16_t i=max(display.width(),display.height())/2; i>0; i-=5) { // The INVERSE color is used so triangles alternate white/black display.fillTriangle( display.width()/2 , display.height()/2-i, display.width()/2-i, display.height()/2+i, display.width()/2+i, display.height()/2+i, INVERSE); display.display(); delay(1); } delay(2000); } void testdrawchar(void) { display.clearDisplay(); display.setTextSize(1); // Normal 1:1 pixel scale display.setTextColor(WHITE); // Draw white text display.setCursor(0, 0); // Start at top-left corner display.cp437(true); // Use full 256 char 'Code Page 437' font // Not all the characters will fit on the display. This is normal. // Library will draw what it can and the rest will be clipped. for(int16_t i=0; i<256; i++) { if(i == '\n') display.write(' '); else display.write(i); } display.display(); delay(2000); } void testdrawstyles(void) { display.clearDisplay(); display.setTextSize(1); // Normal 1:1 pixel scale display.setTextColor(WHITE); // Draw white text display.setCursor(0,0); // Start at top-left corner display.println(F("Hello, world!")); display.setTextColor(BLACK, WHITE); // Draw 'inverse' text display.println(3.141592); display.setTextSize(2); // Draw 2X-scale text display.setTextColor(WHITE); display.print(F("0x")); display.println(0xDEADBEEF, HEX); display.display(); delay(2000); } void testscrolltext(void) { display.clearDisplay(); display.setTextSize(2); // Draw 2X-scale text display.setTextColor(WHITE); display.setCursor(10, 0); display.println(F("scroll")); display.display(); // Show initial text delay(100); // Scroll in various directions, pausing in-between: display.startscrollright(0x00, 0x0F); delay(2000); display.stopscroll(); delay(1000); display.startscrollleft(0x00, 0x0F); delay(2000); display.stopscroll(); delay(1000); display.startscrolldiagright(0x00, 0x07); delay(2000); display.startscrolldiagleft(0x00, 0x07); delay(2000); display.stopscroll(); delay(1000); } void testdrawbitmap(void) { display.clearDisplay(); display.drawBitmap( (display.width() - LOGO_WIDTH ) / 2, (display.height() - LOGO_HEIGHT) / 2, logo_bmp, LOGO_WIDTH, LOGO_HEIGHT, 1); display.display(); delay(1000); } #define XPOS 0 // Indexes into the 'icons' array in function below #define YPOS 1 #define DELTAY 2 void testanimate(const uint8_t *bitmap, uint8_t w, uint8_t h) { int8_t f, icons[NUMFLAKES][3]; // Initialize 'snowflake' positions for(f=0; f< NUMFLAKES; f++) { icons[f][XPOS] = random(1 - LOGO_WIDTH, display.width()); icons[f][YPOS] = -LOGO_HEIGHT; icons[f][DELTAY] = random(1, 6); Serial.print(F("x: ")); Serial.print(icons[f][XPOS], DEC); Serial.print(F(" y: ")); Serial.print(icons[f][YPOS], DEC); Serial.print(F(" dy: ")); Serial.println(icons[f][DELTAY], DEC); } for(;;) { // Loop forever... display.clearDisplay(); // Clear the display buffer // Draw each snowflake: for(f=0; f< NUMFLAKES; f++) { display.drawBitmap(icons[f][XPOS], icons[f][YPOS], bitmap, w, h, WHITE); } display.display(); // Show the display buffer on the screen delay(200); // Pause for 1/10 second // Then update coordinates of each flake... for(f=0; f< NUMFLAKES; f++) { icons[f][YPOS] += icons[f][DELTAY]; // If snowflake is off the bottom of the screen... if (icons[f][YPOS] >= display.height()) { // Reinitialize to a random position, just off the top icons[f][XPOS] = random(1 - LOGO_WIDTH, display.width()); icons[f][YPOS] = -LOGO_HEIGHT; icons[f][DELTAY] = random(1, 6); } } } }

如果您的OLED沒有RESET引腳,則應將OLED_RESET變數設置為-1,如下所示:

#define OLED_RESET -1 // Reset pin # (or -1 if sharing Arduino reset pin)

注意:如果OLED具有RESET引腳,則應將其連接到與GPIO 4不同的GPIO,因為該引腳正在EPS8266中用於I2C通信。 將程式碼上傳到ESP8266開發板。不要忘記在“工具”選單中選擇正確的開發版和COM端口。 如下面的短視頻所示,您應該在OLED中獲得一系列不同的動畫。

如果您的OLED顯示器什麼都不顯示:

  • 檢查OLED顯示器是否已正確連接到ESP8266
  • 仔細檢查OLED顯示器的I2C地址:在OLED連接到ESP8266的情況下,上傳此程式碼並在Serial Monitor中檢查I2C地址

如有必要,應在下一行中更改OLED地址。這裡的情況下,地址為0x3C。

if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { 

 寫text – OLED顯示 

用於OLED顯示器的Adafruit庫帶有一些用於編寫text的功能。在本節中,您將學習如何使用庫函數來編寫和滾動text。

“Hello world!” OLED顯示器

以下草稿碼顯示 Hello world! OLED顯示器中顯示消息。

/*********
  Terry Lee
  完整說明請參閱 https://honeststore.com.tw    
*********/

#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h> #define SCREEN_WIDTH 128 // OLED display width, in pixels #define SCREEN_HEIGHT 64 // OLED display height, in pixels // Declaration for an SSD1306 display connected to I2C (SDA, SCL pins) Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1); void setup() { Serial.begin(115200); if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { // Address 0x3D for 128x64 Serial.println(F("SSD1306 allocation failed")); for(;;); } delay(2000); display.clearDisplay(); display.setTextSize(1); display.setTextColor(WHITE); display.setCursor(0, 10); // Display static text display.println("Hello, world!"); display.display(); } void loop() { }

上載程式碼後,這將在OLED中顯示:

讓我們快速看一下程式碼的工作方式。

導入庫

首先,您需要導入必要的庫。使用I2C的Wire庫和Adafruit庫寫入顯示: Adafruit_GFX 和 Adafruit_SSD1306

#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h>

初始化OLED顯示器

然後,定義OLED的寬度和高度。在此範例中,我們使用128×64 OLED顯示器。如果您使用其他尺寸,則可以在SCREEN_WIDTH和 SCREEN_HEIGHT 變數設定。

#define SCREEN_WIDTH 128 // OLED display width, in pixels
#define SCREEN_HEIGHT 64 // OLED display height, in pixels

然後,使用I2C通信協議(前面定義的寬度和高度)初始化顯示物件(&Wire)。

Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1);

(-1)參數表示您的OLED顯示器沒有RESET引腳。如果您的OLED顯示器確實具有RESET引腳,則應將其連接到GPIO。在這種情況下,您應該傳遞GPIO號作為參數。
在setup()裡,以115200的鮑率初始化序列監視器,以進行調試。

Serial.begin(115200);

使用初始化OLED顯示器 begin() 方法如下:

if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { 
  Serial.println("SSD1306 allocation failed");
  for(;;); // Don't proceed, loop forever
}

如果我們無法連接到顯示器,此程式碼段還會在序列監視器上印出一條消息。

Serial.println("SSD1306 allocation failed");

如果您使用其他OLED顯示器,則可能需要更改OLED地址。在我們的例子中,地址是0x3C

if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { 

如果該地址不起作用,則可以運作I2C掃描儀草稿碼以找到您的OLED地址。您可以在此處找到I2C掃描儀草稿碼

初始化顯示後,加入兩秒鐘的延遲,以便OLED有足夠的時間在寫入text之前進行初始化:

delay(2000);

清除顯示內容,設置字體大小,顏色並編寫text

初始化顯示後,用 clearDisplay() 方法:

display.clearDisplay();

在編寫text之前,您需要設置text大小,顏色以及在OLED中顯示text的位置。

使用設置字體大小 setTextSize() 方法:

display.setTextSize(1);             

用設置字體顏色 setTextColor() 方法:

display.setTextColor(WHITE);        

WHITE 設置白色字體和黑色背景。

使用定義text開始的位置 setCursor(x,y)方法。在這種情況下,我們將text設置為以(0,10)坐標開始。

display.setCursor(0,10);             

最後,您可以使用 println() 方法如下:

display.println("Hello, world!");

然後,您需要呼叫 display() 在螢幕上實際顯示text的方法。

display.display();

滾動文字

Adafruit OLED庫提供了有用的方法來輕鬆滾動text文字。

  • startscrollright(0x00,0x0F):從左向右滾動文字
  • startscrollleft(0x00,0x0F):從右向左滾動文字
  • startscrolldiagright(0x00,0x07):將文字從左下角滾動到右上角
  • startscrolldiagleft(0x00,0x07):將文字從右下角滾動到左上角

下面的草稿碼實現了這些方法。

/*********
  Terry Lee
  完整說明請參閱 https://honeststore.com.tw   
*********/

#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h> #define SCREEN_WIDTH 128 // OLED display width, in pixels #define SCREEN_HEIGHT 64 // OLED display height, in pixels // Declaration for an SSD1306 display connected to I2C (SDA, SCL pins) Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1); void setup() { Serial.begin(115200); if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { // Address 0x3D for 128x64 Serial.println(F("SSD1306 allocation failed")); for(;;); } delay(2000); display.clearDisplay(); display.setTextSize(1); display.setTextColor(WHITE); display.setCursor(0, 0); // Display static text display.println("Scrolling Text"); display.display(); delay(100); } void loop() { // Scroll in various directions, pausing in-between: display.startscrollright(0x00, 0x0F); delay(2000); display.stopscroll(); delay(1000); display.startscrollleft(0x00, 0x0F); delay(2000); display.stopscroll(); delay(1000); display.startscrolldiagright(0x00, 0x07); delay(2000); display.startscrolldiagleft(0x00, 0x07); delay(2000); display.stopscroll(); delay(1000); }

文字滾動,如下面的短視頻所示。

使用其他字體– OLED顯示 

除了內置字體,Adafruit GFX庫還允許我們使用其他替代字體。它允許您在Serif,Sans和Mono之間進行選擇。每種字體都有粗體,斜體和不同大小。

大小由實際字體設置。所以setTextSize()方法不適用於這些字體。字體有9、12、18和24點的大小,並且還包含7位元字符(ASCII碼)(在字體名稱中描述為7b)。

您可以從下一個字體選擇中進行選擇:

FreeMono12pt7b.h		FreeSansBoldOblique12pt7b.h
FreeMono18pt7b.h		FreeSansBoldOblique18pt7b.h
FreeMono24pt7b.h		FreeSansBoldOblique24pt7b.h
FreeMono9pt7b.h			FreeSansBoldOblique9pt7b.h
FreeMonoBold12pt7b.h		FreeSansOblique12pt7b.h
FreeMonoBold18pt7b.h		FreeSansOblique18pt7b.h
FreeMonoBold24pt7b.h		FreeSansOblique24pt7b.h
FreeMonoBold9pt7b.h		FreeSansOblique9pt7b.h
FreeMonoBoldOblique12pt7b.h	FreeSerif12pt7b.h
FreeMonoBoldOblique18pt7b.h	FreeSerif18pt7b.h
FreeMonoBoldOblique24pt7b.h	FreeSerif24pt7b.h
FreeMonoBoldOblique9pt7b.h	FreeSerif9pt7b.h
FreeMonoOblique12pt7b.h		FreeSerifBold12pt7b.h
FreeMonoOblique18pt7b.h		FreeSerifBold18pt7b.h
FreeMonoOblique24pt7b.h		FreeSerifBold24pt7b.h
FreeMonoOblique9pt7b.h		FreeSerifBold9pt7b.h
FreeSans12pt7b.h		FreeSerifBoldItalic12pt7b.h
FreeSans18pt7b.h		FreeSerifBoldItalic18pt7b.h
FreeSans24pt7b.h		FreeSerifBoldItalic24pt7b.h
FreeSans9pt7b.h			FreeSerifBoldItalic9pt7b.h
FreeSansBold12pt7b.h		FreeSerifItalic12pt7b.h
FreeSansBold18pt7b.h		FreeSerifItalic18pt7b.h
FreeSansBold24pt7b.h		FreeSerifItalic24pt7b.h
FreeSansBold9pt7b.h		FreeSerifItalic9pt7b.h

與OLED顯示器配合使用的字體更好,字體為9點和12點。

要使用其中一種字體,首先需要將其include在草稿碼中,例如:

#include <Fonts/FreeSerif12pt7b.h>

接下來,您只需要使用 setFont() 方法並作為參數傳遞指定的字體:

display.setFont(&FreeSerif12pt7b);

指定字體後,所有寫入文字的方法都將使用該字體。要恢復使用原始字體,您只需調用setFont() 沒有參數的方法:

display.setFont();

將下一個草稿碼上傳到開發板上:

/*********
  Terry Lee
  完整說明請參閱https://honeststore.com.tw  
*********/

#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h> #include <Fonts/FreeSerif9pt7b.h> #define SCREEN_WIDTH 128 // OLED display width, in pixels #define SCREEN_HEIGHT 64 // OLED display height, in pixels // Declaration for an SSD1306 display connected to I2C (SDA, SCL pins) Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1); void setup() { Serial.begin(115200); if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { Serial.println("SSD1306 allocation failed"); for(;;); } delay(2000); display.setFont(&FreeSerif9pt7b); display.clearDisplay(); display.setTextSize(1); display.setTextColor(WHITE); display.setCursor(0,30); display.println("Hello, world!"); display.display(); delay(2000); } void loop() { }

現在,您的顯示器將顯示FreeSerif字體的“ Hello,world!” 消息。

在OLED顯示器中繪製形狀 

Adafruit OLED庫提供了有用的方法來繪製像素、線條和形狀。讓我們迅速看一下有提供那些方法。

畫一個像素

要在OLED顯示器中繪製像素,可以使用 drawPixel(x,y,color)接受x和y坐標作為像素出現位置以及顏色的方法。例如:

display.drawPixel(10, 10, WHITE);

畫一條線

使用 drawLine(x1,y1,x2,y2,顏色)建置線的方法。(x1,y1)座標指示線的開始座標,而(x2,y2)座標指示線的結束座標。例如:

display.drawLine(0, 20, 127, 40, WHITE);

畫一個矩形

drawRect(x,y,width,height,color)提供了一種繪製矩形的簡易方法。(x,y)坐標指示矩形的左上角。然後,您需要指定寬度,高度和顏色:

display.drawRect(20, 20, 60, 30, WHITE);

您可以使用 fillRect(x,y,寬度,高度,顏色)繪製一個實心的矩形。此方法接受與以下方法相同的參數drawRect()

該庫還提供了顯示帶有圓角矩形的方法: drawRoundRect() 和 fillRoundRect()。這些方法與先前使用方法相同的參數,外加拐角的半徑。例如:

display.drawRoundRect(20, 20, 60, 30, 2, WHITE);

或填充的圓角矩形:

display.fillRoundRect(10, 10, 30, 50, 2, WHITE);

畫一個圓

畫一個圓使用 drawCircle(x,y,半徑,顏色)方法。(x,y)坐標表示圓的中心,您還需指定圓的半徑。例如:

display.drawCircle(64, 32, 10, WHITE);

同樣,要建立實心圓,請使用 fillCircle() 具有相同參數的方法:

display.fillCircle(64, 32, 10, WHITE);

畫一個三角形

使用 drawTriangle(x1,y1,x2,y2,x3,y3,顏色)建立三角形的方法。此方法接受每個角和顏色的坐標作為參數。

display.drawTriangle(20, 20, 55, 20, 25, 40, WHITE);

使用 fillTriangle() 繪製實心三角形的方法。

display.fillTriangle(20, 20, 55, 20, 25, 40, WHITE);

反轉倒置

該庫提供了可用於形狀或文字的另一種方法: invertDisplay()方法。通過 true 作為參數來反轉屏幕的顏色或 false 恢復原始顏色。

如果在定義三角形後調用以下命令:

display.invertDisplay(true);

您將得到一個倒三角形,如下所示:

程式碼–繪製形狀

上傳以下草稿碼,該草稿碼實現了我們之前介紹的所有代碼片段,並遍歷了所有形狀。

/*********
  Terry Lee
  完整說明請參閱 https://honeststore.com.tw  
*********/

#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h> #define SCREEN_WIDTH 128 #define SCREEN_HEIGHT 64 // Declaration for an SSD1306 display connected to I2C (SDA, SCL pins) Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1); void setup() { Serial.begin(115200); if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { Serial.println(F("SSD1306 allocation failed")); for(;;); } delay(2000); // Pause for 2 seconds // Clear the buffer display.clearDisplay(); // 用白色繪製一個單點像素 display.drawPixel(64, 32, WHITE); display.display(); delay(3000); // 繪製線 display.clearDisplay(); display.drawLine(0, 0, 127, 20, WHITE); display.display(); delay(3000); // 繪製正方形 display.clearDisplay(); display.drawRect(30, 10, 50, 30, WHITE); display.display(); delay(3000); // 繪製實心正方形 display.fillRect(30, 10, 50, 30, WHITE); display.display(); delay(3000); // 繪製圓角正方形 display.clearDisplay(); display.drawRoundRect(10, 10, 30, 50, 2, WHITE); display.display(); delay(3000); // 繪製實心圓角正方形 display.clearDisplay(); display.fillRoundRect(10, 10, 30, 50, 2, WHITE); display.display(); delay(3000); // 繪製圓 display.clearDisplay(); display.drawCircle(64, 32, 10, WHITE); display.display(); delay(3000); // 繪製實心圓 display.fillCircle(64, 32, 10, WHITE); display.display(); delay(3000); // 繪製三角形 display.clearDisplay(); display.drawTriangle(10, 10, 55, 20, 5, 40, WHITE); display.display(); delay(3000); // 繪製實心三角形 display.fillTriangle(10, 10, 55, 20, 5, 40, WHITE); display.display(); delay(3000); // 反轉倒置實心三角形再復烣正常 display.invertDisplay(true); delay(3000); display.invertDisplay(false); delay(3000); } void loop() { }

 在OLED中顯示點陣圖圖像 

 

您可以在OLED顯示器上顯示128×64點陣圖單色圖像。

首先,使用成像程序調整照片或圖片的大小並將其另存為單色點陣圖。如果您使用的是Windows作業系統,則可以使用小畫家工具編輯。

然後,使用Image轉C陣列轉換器將圖像轉換為陣列。這裡使用LCD Image Converter

執行程序並新增一個Image開始。轉到Image>Import然後選擇您之前建立的點陣圖圖像。

轉到Options>Conversion,然後在Prepare標籤中,選擇以下選項:

  • Type: Monochrome, Threshold Dither
  • Main Scan Direction: Top to Bottom
  • Line Scan Direction: Forward

轉到Image tab,然後選擇以下選項:

  • Split to rows
  • Block size: 8 bit
  • Byte order: Little-Endian

然後,單擊確定。最後,在主菜單中,轉到“檔案” >“轉換”。應該保存一個擴展名為.c的新文件。該文件包含圖像的C陣列檔案。使用文字編輯器打開該文件,然後復制陣列。

在本例子中,這是我們得到的數組:

static const uint8_t image_data_Image[1024] = {
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x07, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x9f, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0xff, 0xff, 0xcf, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe7, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xef, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0xfd, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xf3, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xef, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfd, 0xdf, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfd, 0xbe, 0x7d, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfe, 0x7b, 0xfd, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xfe, 0x6f, 0xe7, 0xff, 0xcf, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xfe, 0x3f, 0xff, 0xff, 0xff, 0x5e, 0xff, 0xff, 0xd7, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xf9, 0xff, 0xff, 0xff, 0xff, 0x7b, 0xff, 0xff, 0xd7, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xef, 0xff, 0xff, 0xff, 0xff, 0x2f, 0xff, 0xff, 0xbb, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xbb, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0x7d, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfc, 0xfd, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xef, 0xfe, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xfe, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xdf, 0xff, 0x3f, 0xfe, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xfd, 0xff, 0xff, 0xf6, 0xff, 0xff, 0xf1, 0xe1, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xf7, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xb7, 0xed, 0xff, 0x7f, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0x9f, 0xff, 0xff, 0xfd, 0x7f, 0xff, 0xff, 0xdf, 0xdf, 0xff, 0x7f, 0xff, 0xff, 0xff, 
    0xff, 0xfe, 0x7f, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xff, 0xef, 0x33, 0xff, 0x7f, 0xff, 0xff, 0xff, 
    0xff, 0xfb, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xf4, 0xef, 0xff, 0xbf, 0xff, 0xff, 0xff, 
    0xff, 0xf7, 0xff, 0xef, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xf3, 0x9b, 0xff, 0xbf, 0xff, 0xff, 0xff, 
    0xff, 0xf7, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x67, 0xff, 0xdf, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xdb, 0xff, 0xff, 0xef, 0xff, 0xff, 0xfd, 0x3f, 0xff, 0xf7, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xfd, 0xdf, 0xff, 0xf9, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xfe, 0xef, 0xfc, 0xff, 0x3f, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xef, 0xf3, 0xff, 0xdf, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xff, 0xf7, 0xef, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xf7, 0xff, 0xff, 0x7f, 0xff, 0xfd, 0xff, 0xe7, 0xff, 0xf7, 0xdf, 0xff, 0xf7, 0xff, 0xff, 
    0xff, 0xf7, 0xff, 0xff, 0xbf, 0xff, 0xfe, 0xff, 0x3f, 0xff, 0xfb, 0xbf, 0xff, 0xfb, 0xff, 0xff, 
    0xff, 0xf7, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xfb, 0x7f, 0xff, 0xfb, 0xff, 0xff, 
    0xff, 0xfb, 0xff, 0xff, 0xdf, 0xff, 0xff, 0x7b, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfb, 0xff, 0xff, 
    0xff, 0xfb, 0xff, 0xff, 0xef, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xfb, 0xff, 0xff, 
    0xff, 0xfd, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xf8, 0x79, 0xff, 0xf7, 0xff, 0xff, 
    0xff, 0xfd, 0xff, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xcf, 0xff, 0xff, 0xf7, 0xff, 0xff, 
    0xff, 0xfe, 0x7f, 0xff, 0xfb, 0xff, 0xff, 0xef, 0xff, 0xff, 0x3f, 0xff, 0xff, 0xef, 0xff, 0xff, 
    0xff, 0xff, 0xbf, 0xff, 0xfd, 0xff, 0xf9, 0xf7, 0xff, 0xfc, 0xff, 0xff, 0xfe, 0xef, 0xff, 0xff, 
    0xff, 0xff, 0xdf, 0xff, 0xfe, 0xff, 0x9f, 0xfb, 0xff, 0xf3, 0xff, 0xff, 0xff, 0xaf, 0xff, 0xff, 
    0xff, 0xff, 0xef, 0xff, 0xff, 0x7f, 0x7f, 0xfd, 0xff, 0xcf, 0xff, 0xff, 0xff, 0xcf, 0xff, 0xff, 
    0xff, 0xff, 0xfb, 0xff, 0xff, 0xbe, 0xff, 0xfe, 0x7c, 0xff, 0xff, 0xfe, 0xff, 0xef, 0xff, 0xff, 
    0xff, 0xff, 0xfd, 0xff, 0xff, 0xdf, 0xff, 0xff, 0x87, 0xff, 0xff, 0xff, 0x7f, 0xef, 0xff, 0xff, 
    0xff, 0xff, 0xfe, 0x7f, 0xff, 0xef, 0xff, 0xff, 0x6f, 0xbf, 0xdf, 0xff, 0x7f, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xbf, 0xff, 0xf7, 0xff, 0xfe, 0xdf, 0x7f, 0xef, 0xff, 0xbf, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xdf, 0xff, 0xf9, 0xff, 0xfd, 0xde, 0xff, 0xf7, 0xff, 0xbf, 0xdf, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xf7, 0xff, 0xfe, 0x1f, 0xc7, 0xfe, 0xff, 0xf7, 0xff, 0xff, 0xdf, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xf8, 0x7f, 0xfd, 0xff, 0xff, 0xff, 0xdf, 0xbf, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xfe, 0x7f, 0xff, 0xde, 0xff, 0xdd, 0xff, 0xff, 0xff, 0xdc, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0x9f, 0xff, 0x33, 0xff, 0xfd, 0xff, 0xf7, 0xff, 0xa7, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xf3, 0xf8, 0x7f, 0xff, 0xed, 0xff, 0xff, 0xf9, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xf8, 0xff, 0xc8, 0x3f, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 
    0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff
};

將陣列複製到草稿碼。然後,要顯示陣列,請使用drawBitmap()接受以下參數(x,y,圖像陣列,圖像寬度,圖像高度,旋轉)的方法。(x,y)坐標定義開始顯示圖像的位置。

複製下面的程式碼以在OLED中顯示點陣圖圖像。

/*********
  Terry Lee
  完整說明請參閱 https://honeststore.com.tw  
*********/

#include <Wire.h>
#include <Adafruit_GFX.h>
#include <Adafruit_SSD1306.h> #define SCREEN_WIDTH 128 #define SCREEN_HEIGHT 64 Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, -1); static const uint8_t image_data_Image[1024] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x07, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x9f, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0xff, 0xff, 0xcf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe7, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xef, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0xfd, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xf3, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xef, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfd, 0xdf, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfd, 0xbe, 0x7d, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfe, 0x7b, 0xfd, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xfe, 0x6f, 0xe7, 0xff, 0xcf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x3f, 0xff, 0xff, 0xff, 0x5e, 0xff, 0xff, 0xd7, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf9, 0xff, 0xff, 0xff, 0xff, 0x7b, 0xff, 0xff, 0xd7, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xef, 0xff, 0xff, 0xff, 0xff, 0x2f, 0xff, 0xff, 0xbb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xbb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0x7d, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfc, 0xfd, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0x7f, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xef, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xdf, 0xff, 0x3f, 0xfe, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xf6, 0xff, 0xff, 0xf1, 0xe1, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xb7, 0xed, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff, 0x9f, 0xff, 0xff, 0xfd, 0x7f, 0xff, 0xff, 0xdf, 0xdf, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x7f, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xff, 0xef, 0x33, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xf4, 0xef, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 0xf7, 0xff, 0xef, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xf3, 0x9b, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 0xf7, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x67, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xdb, 0xff, 0xff, 0xef, 0xff, 0xff, 0xfd, 0x3f, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf3, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xfd, 0xdf, 0xff, 0xf9, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xfe, 0xef, 0xfc, 0xff, 0x3f, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xef, 0xf3, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xff, 0xf7, 0xef, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf7, 0xff, 0xff, 0x7f, 0xff, 0xfd, 0xff, 0xe7, 0xff, 0xf7, 0xdf, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xbf, 0xff, 0xfe, 0xff, 0x3f, 0xff, 0xfb, 0xbf, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xfb, 0x7f, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xdf, 0xff, 0xff, 0x7b, 0xff, 0xff, 0xfe, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xef, 0xff, 0xff, 0xbf, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xf8, 0x79, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xcf, 0xff, 0xff, 0xf7, 0xff, 0xff, 0xff, 0xfe, 0x7f, 0xff, 0xfb, 0xff, 0xff, 0xef, 0xff, 0xff, 0x3f, 0xff, 0xff, 0xef, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xfd, 0xff, 0xf9, 0xf7, 0xff, 0xfc, 0xff, 0xff, 0xfe, 0xef, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0xfe, 0xff, 0x9f, 0xfb, 0xff, 0xf3, 0xff, 0xff, 0xff, 0xaf, 0xff, 0xff, 0xff, 0xff, 0xef, 0xff, 0xff, 0x7f, 0x7f, 0xfd, 0xff, 0xcf, 0xff, 0xff, 0xff, 0xcf, 0xff, 0xff, 0xff, 0xff, 0xfb, 0xff, 0xff, 0xbe, 0xff, 0xfe, 0x7c, 0xff, 0xff, 0xfe, 0xff, 0xef, 0xff, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xdf, 0xff, 0xff, 0x87, 0xff, 0xff, 0xff, 0x7f, 0xef, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x7f, 0xff, 0xef, 0xff, 0xff, 0x6f, 0xbf, 0xdf, 0xff, 0x7f, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xbf, 0xff, 0xf7, 0xff, 0xfe, 0xdf, 0x7f, 0xef, 0xff, 0xbf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xdf, 0xff, 0xf9, 0xff, 0xfd, 0xde, 0xff, 0xf7, 0xff, 0xbf, 0xdf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf7, 0xff, 0xfe, 0x1f, 0xc7, 0xfe, 0xff, 0xf7, 0xff, 0xff, 0xdf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfd, 0xff, 0xff, 0xf8, 0x7f, 0xfd, 0xff, 0xff, 0xff, 0xdf, 0xbf, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x7f, 0xff, 0xde, 0xff, 0xdd, 0xff, 0xff, 0xff, 0xdc, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x9f, 0xff, 0x33, 0xff, 0xfd, 0xff, 0xf7, 0xff, 0xa7, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf3, 0xf8, 0x7f, 0xff, 0xed, 0xff, 0xff, 0xf9, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x0f, 0xff, 0xff, 0xf8, 0xff, 0xc8, 0x3f, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }; void setup() { Serial.begin(115200); if(!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) { Serial.println(F("SSD1306 allocation failed")); for(;;); } delay(2000); // Pause for 2 seconds // Clear the buffer. display.clearDisplay(); // Draw bitmap on the screen display.drawBitmap(0, 0, image_data_Image, 128, 64, 1); display.display(); } void loop() { }

上傳程式碼後,下面就是我們在顯示器上看到的。

 故障排除 

 

如果出現“ SSD1306分配失敗”錯誤,或者如果OLED在螢幕上未顯示任何內容,則可能是以下問題之一:

I2C地址錯誤

我們正在使用的OLED顯示器的I2C地址為0x3C。但是,您的可能會有所不同。因此,請確保使用I2C掃描儀草圖檢查顯示的I2C地址。

SDA和SCL連接不正確

請確保正確連接OLED顯示器的SDA和SCL引腳。如果是ESP8266,請將SDA引腳連接到GPIO 4 (D2)和SCL引腳連接到 GPIO 5 (D1)。

總結 

我們希望您發現本關於帶EPS8266的OLED顯示器的指南很有用。現在,您可以將OLED顯示器集成到自己的項目中。繼續進行下一個教程,以了解如何在OLED顯示屏上顯示傳感器讀數:
  • ESP8266 –顯示傳感器讀數OLED顯示

如果您喜歡ESP8266,肯定會喜歡我們的ESP8266資源:

  • 使用ESP8266的家庭自動化
  • 使用ESP8266的MicroPython編程
  • ESP8266超過30個項目
  • ESP8266引腳參考:您應使用哪個GPIO引腳?

ESP8266我們最受歡迎的一些項目:

  • 使用ESP8266入侵PIR運動傳感器
  • 為ESP8266構建多傳感器屏蔽
  • 具有Arduino IDE的ESP8266 Web服務器
  • 低功率氣象站數據記錄器

謝謝閱讀。

發佈留言