Interfacing SSD1306 OLED Display with Raspberry Pi

Published  April 13, 2018   4
S Saddam
Author
Interfacing OLED Display with Raspberry Pi
Most of us would be familiar with the 16×2 Dot matrix LCD display that is used in most of the projects to display some information to the user.  But these LCD displays have a lot of limitations. In this tutorial, we are going to learn about OLED display and how to use them with Raspberry Pi. There are lots of types of OLED displays available in the market and there are lots of ways to get them working. We have already used 7 Pin OLED with Arduino.

 

Hardware Required:

  • 128×64 OLED display Module (SSD1306)
  • Raspberry Pi
  • Breadboard
  • Connecting Wires
  • Power supply

 

Getting to know about OLED Displays:

The term OLED stands for “Organic Light emitting diode” it uses the same technology that is used in most of our televisions but has fewer pixels compared to them.  It is real fun to have these cool looking display modules to be interfaced with the Raspberry Pi since it will make our projects look cool. We have covered a full Article on OLED displays and its types here. Here, we are using a Monochrome 4-pin SSD1306 0.96” OLED display. This LCD can only work with the I2C mode.

Oled Oled in action

Below are the connections of OLED with Raspberry pi:​

OLED Pin RPI Pin
VCC 3.3v
GND GND
SDA SDA (Physical pin 3)
SCL SCL (Physical pin 5)

 

Circuit Diagram:

Interfacing Circuit diagram of OLED Display with Raspberry Pi

Interfacing OLED Display with Raspberry-Pi circuit hardware

 

Connecting OLED with Raspberry Pi:

RPI community has already given us a lot of Libraries which can be directly used to make this a lot simpler. I tried out a few libraries and found that the Adafruit_SSD1306 OLED Library was very easy to use and has a handful of graphical options hence we will use the same in this tutorial.

Step 1: Enable I2C communication

Before installing Adafruit SSD1306 library we need to enable I2C communication in Raspberry Pi.

To do this type in Raspberry Pi console:

sudo raspi-config

And then a blue screen will appear. Now select interface option

For enabling I2C communication select interface option

After this, we need to need to select I2C

Select I2C in interface option

After this, we need to select yes and press enter and then ok

Click yes for enable I2C interface

After this, we need to reboot raspberry pi by issuing below command:

sodo reboot

 

Step 2: Find OLED I2C address and update it

Then we need to find OLED I2C address by using given command and you will see a hex address.

sudo i2cdetect –y 1

Find OLED I2C address and update it

Then update Raspberry Pi using given command:

sudo apt-get update

 

Step 3: Install python-pip and GPIO Library

After this we need to install pip by using given command:

sudo apt-get install build-essential python-dev python-pip

And install Raspberry Pi GPIO library

sudo pip installs RPi.GPIO

 

Step 4: Install the Python Imaging Library and smbus library

Finally, we need to install the Python Imaging Library and smbus library in Raspberry Pi by using given command:

sudo apt-get install python-imaging python-smbus

Install the Python Imaging Library and smbus library


Step 5: install the Adafruit SSD1306 python library

Now its time to install the Adafruit SSD1306 python library code and examples by using given commands:

sudo apt-get install git
git clone https://github.com/adafruit/Adafruit_Python_SSD1306.git
cd Adafruit_Python_SSD1306
sudo python setup.py install

Install the Adafruit SSD1306 python library

Now user can find the code of OLED interfacing in Raspberry Pi and you can play directly or customize it yourself. Here we have customized a example code for demonstration. You can find full Python code at the end of the article.

Interfacing OLED Display with Raspberry-Pi in action

 

Programming Explanation:

Programming part for interfacing OLED with RPi project is easy. first, we need to import some necessary libraries.

import time
import Adafruit_GPIO.SPI as SPI
import Adafruit_SSD1306
from PIL import Image
from PIL import ImageDraw
from PIL import ImageFont
import subprocess

 

After this initialize the display

RST = 0

disp = Adafruit_SSD1306.SSD1306_128_64(rst=RST)
disp.begin()
disp.clear()
disp.display()

width = disp.width
height = disp.height

image1 = Image.new('1', (width, height))

draw = ImageDraw.Draw(image1)
draw.rectangle((0,0,width,height), outline=0, fill=0)

padding = -2
top = padding

bottom = height-padding
x = 0
font = ImageFont.load_default()
 
After this, we can send data or image to OLED by using given code
# Write two lines of text.

disp.clear()
disp.display()
draw.text((x, top),       "OLED Interfacing " ,  font=font, fill=255)
draw.text((x, top+8),     "Circuit Digest", font=font, fill=255)
draw.text((x, top+16),    "For more Videos",  font=font, fill=255)
draw.text((x, top+25),    "Visit at",  font=font, fill=255)
draw.text((x, top+34),    "www.circuitdigest.com",  font=font, fill=255)

# Display image.
disp.image(image1)
disp.display()
time.sleep(2)

if disp.height == 64:
   image = Image.open('img1.png').convert('1')
else:
   image = Image.open('img1.png').convert('1')

disp.image(image)
disp.display()
time.sleep(2)

if disp.height == 64:
   image = Image.open('img3.jpg').convert('1')
else:
   image = Image.open('img3.jpg').convert('1')

 

This OLED comes in two variants one is 128*32 and other is 128*64 so the user can select anyone accordingly while initializing OLED. Here we have written this code for both. The user needs to only initialize OLED for 128*64 pixel like:

disp = Adafruit_SSD1306.SSD1306_128_64(rst=RST)

All the code and functions are easy to understand and no further explanation is needed. Just start and try playing with height, width & images and try some other functions to create some more cool geometric figures.

Full python code and Demonstration Video is given below and here you find the images which we have used in this program.

Also check OLED Interfacing with Arduino.

Complete Project Code

import time
import Adafruit_GPIO.SPI as SPI
import Adafruit_SSD1306
from PIL import Image
from PIL import ImageDraw
from PIL import ImageFont
import subprocess RST = 0 disp = Adafruit_SSD1306.SSD1306_128_64(rst=RST)
disp.begin()
disp.clear()
disp.display() width = disp.width
height = disp.height
image1 = Image.new('1', (width, height))
draw = ImageDraw.Draw(image1)
draw.rectangle((0,0,width,height), outline=0, fill=0) padding = -2
top = padding
bottom = height-padding
x = 0
font = ImageFont.load_default() while True:
draw.rectangle((0,0,width,height), outline=0, fill=0) # Write two lines of text.
disp.clear()
disp.display()
draw.text((x, top), "OLED Interfacing " , font=font, fill=255)
draw.text((x, top+8), "Circuit Digest", font=font, fill=255)
draw.text((x, top+16), "For more Videos", font=font, fill=255)
draw.text((x, top+25), "Visit at", font=font, fill=255)
draw.text((x, top+34), "www.circuitdigest.com", font=font, fill=255) # Display image.
disp.image(image1)
disp.display()
time.sleep(2) if disp.height == 64:
image = Image.open('img1.png').convert('1')
else:
image = Image.open('img1.png').convert('1') disp.image(image)
disp.display()
time.sleep(2) if disp.height == 64:
image = Image.open('img3.jpg').convert('1')
else:
image = Image.open('img3.jpg').convert('1') disp.image(image)
disp.display()
time.sleep(2) if disp.height == 64:
image = Image.open('img4.jpg').convert('1')
else:
image = Image.open('img4.jpg').convert('1') disp.image(image)
disp.display()
time.sleep(2)
Video

Have any question realated to this Article?

Ask Our Community Members

Comments

Hi, appreciate this page is a little older, but Im having problems finding the images from the source code. The link to the zip from the page returns page not found.

The requested page "/microcontroller-projects/sites/default/files/OLED-Raspberry-Pi-interfacing-pics.zip" could not be found.

Does anyone have them to post anywhere? Hoping to finish this tutorial with the images.

thankyou