A lightweight and versatile library to control SSD1306-based OLED displays with Arduino. This library offers a wide range of features including custom fonts, progress bars, animated text, bitmap rendering, and more. It works seamlessly with microcontrollers like Arduino, ESP32, and ESP8266 over I2C communication.
Additionally, the library includes a Bitmap Generator tool in Python, which helps convert images to bitmap arrays for easy display on the OLED screen.
Please note that SSD1306 has 128 independently controllable Columns along the width, and 8 independently controllable Pages along the height. The total pixel count along the height is divided into Pages of 8 pixels high. In scenarios such as printing texts, bitmaps, progress bars, you should keep this in mind.
- Text Display: Print static text and animated text (typewriter effect).
- Custom Fonts: Supports custom fonts and character sets.
- Progress Bar: Display progress bars with various styles.
- Bitmap Rendering: Draw bitmap images on the OLED display.
- Brightness Control: Adjust display brightness (0-100%).
- I2C Communication: Built on I2C communication for simple wiring.
- Custom Preferences: Customize OLED display setup with a set of options.
- Operator Overloading: Use simple operators to display text and bitmaps.
- Power Modes: Control the display power for optimized performance.
- Super Brightness: Turn super brightness on or off (may be unstable).
- Display Inversion: Invert or restore the display colors.
- Geometric Shapes: Draw rectangles, circles, and lines on the display with customizable thickness.
- Fragments and GridView: Dynamically manage and render multiple drawable objects on the screen efficiently.
To use the library, you need to download or clone this repository into your Arduino libraries folder.
git clone https://github.com/styropyr0/oled.h.git
Alternatively, you can manually download the ZIP file and add it to the Arduino IDE by navigating to Sketch → Include Library → Add .ZIP Library.
The library uses the Wire library for I2C communication, which is pre-installed with the Arduino IDE. No additional libraries are required.
- SSD1306-based OLED display (typically 128x64 or 128x32 pixels).
- Arduino Board (e.g., Arduino UNO, ESP32, or ESP8266).
By default, the library uses I2C communication. The I2C pins are:
- SDA (Data): Typically pin
A4
on most Arduino boards (varies by board). - SCL (Clock): Typically pin
A5
on most Arduino boards (varies by board).
For ESP32 and other microcontrollers, you can configure these pins in the Wire.begin(SDA_PIN, SCL_PIN);
function.
To use the library, instantiate the OLED class with the display’s width and height (e.g., 128x64 or 128x32).
#include <SSD1306.h>
// Create OLED object with width and height (128x64)
OLED oled(128, 64);
void setup() {
oled.begin(); // Initialize the OLED display
oled.clearScr(); // Clear the screen
oled.print("Hello, World!", 0, 0); // Print text at (0, 0)
oled << "This method also prints!" << 0 << 3; // Print text at (0, 3)
}
void loop() {
// Main loop logic
}
Fragments provide a way to dynamically manage and render multiple drawable objects on the screen efficiently. This feature is especially useful for applications that require frequent updates to specific parts of the display.
Fragments in this library are inspired by Android development fragments. Similar to their Android counterparts, they allow developers to handle multiple independent and reusable components within the OLED display. This can be particularly helpful in scenarios where different portions of the screen require updates independently.
Note: To use fragments, you need to include Fragments.h. It is separated from the main library to avoid taking up unnecessary memory when fragments are not used.
You can create a Fragmentto hold multiple Drawable objects. Drawables can be added, updated, or removed dynamically.
#include <SSD1306.h>
#include <Fragments.h>
// Create OLED and Fragment objects
OLED oled(128, 64);
FragmentManager manager(oled); // Create a manager for the Fragments. The manager is attached to the corresponding oled object.
void setup() {
oled.begin();
Fragment fragment(manager);
// Add drawables to the fragment
fragment.add(new Text("Hello", 0, 0));
fragment.add(new Circle(64, 32, 10, 2));
// Draw all the fragment’s drawables
fragment.inflate();
}
Fragments can be updated dynamically without re-adding all drawables, saving memory and processing time. There are three ways to recycle fragments:
-
Recycle Modified Drawables: Applies changes to modified drawables without re-inflating them.
fragment.recycle(); // Redraw the fragment’s contents on the OLED
-
Recycle All Drawables: Applies changes to all drawables by re-inflating them.
fragment.recycleAll(); // Re-inflate all drawables in the fragment
-
Recycle New Drawables: Applies changes to newly added drawables without re-inflating the existing ones.
fragment.recycleNew(); // Apply changes to newly added drawables
The GridView
class allows you to organize and render multiple drawables in a grid-like layout. This is ideal for creating tables or menu systems.
#include <SSD1306.h>
#include <Fragments.h>
// Create OLED, Fragment, and GridView objects
OLED oled(128, 64);
FragmentManager manager(oled);
void setup() {
oled.begin();
// Add a grid of circles to the fragment
Fragment fragment(manager); // Attach the manager to the required Fragment.
Circle* circle = new Circle(0, 0, 8, 2);
GridView* grid = new GridView(circle, 12, 4, 10, 10, 10, 10);
fragment.add(grid);
fragment.inflate(); // Draw the fragment containing the grid
}
You can now control the visibility of individual drawables within a fragment. This allows for more dynamic and flexible display management.
// Set visibility of a drawable
drawable->setVisibility(false); // Hide the drawable
drawable->setVisibility(true); // Show the drawable
Drawables now support change state management, allowing you to track and update only modified drawables.
After inflating a fragment, you can reassign or change the drawables dynamically. This allows for efficient updates without the need to re-inflate the entire fragment.
Text* textDrawable = new Text("New Text", 0, 0);
fragment.add(textDrawable);
fragment.inflate();
//Change the text content after some time
*textDrawable = Text("Updated Text", 0, 0);
fragment.recycleAll(); // Apply changes to the newly added drawable
The library now includes additional drawable types such as Rectangle
, Line
, HighlightedText
, AnimatedText
, and Bitmap
.
// Example of adding new drawable types
fragment.add(new Rectangle(10, 10, 50, 30, 5, 2));
fragment.add(new Line(0, 0, 127, 63, 2));
fragment.add(new HighlightedText("Highlighted", 0, 10));
fragment.add(new AnimatedText("Animated", 0, 20, 100, true));
fragment.add(new Bitmap(bitmapData, 0, 0, 16, 16));
Inspired by Android fragments, you can manage a back stack of fragments using addToBackStack()
and popBackStack()
methods.
Fragment fragment(manager);
manager.addToBackStack(&fragment); // Add fragment to back stack
manager.popBackStack(); // Pop the last fragment from the back stack
Here's an example code demonstrating the usage of the new features:
#include <SSD1306.h>
#include <Fragments.h>
// Create OLED object with width and height (128x64)
OLED oled(128, 64);
// Create a FragmentManager object and attach it to the OLED object
FragmentManager mgr(oled);
void setup() {
// Initialize the OLED display
oled.begin();
// Initialize serial communication for debugging
Serial.begin(9600);
// Create a Fragment object and attach it to the FragmentManager
Fragment fragment(mgr);
// Create drawable objects
Rectangle* rectangle = new Rectangle(30, 0, 15, 15, 3, 1);
Text* text = new Text("Hello World!", 0, 0);
// Add drawables to the fragment
fragment.add(rectangle);
fragment.add(text);
// Draw all the fragment’s drawables
fragment.inflate();
// Wait for 2 seconds
delay(2000);
// Reassign the text drawable with new content and position
*text = Text("This is new text!", 10, 3);
// Hide the rectangle drawable
rectangle->setVisibility(false);
// Recycle all drawables to apply changes
fragment.recycleAll();
}
void loop() {
// Main loop logic (empty in this example)
}
You can use custom fonts by defining an array of font data. This library uses 5x7 bitmaps for characters by default, but you can change the font with the setFont()
method.
// Define a simple custom font (5x7 pixels)
const uint8_t myFont[5][5] = {
{0x1F, 0x1F, 0x00, 0x00, 0x00}, // Example character data
// More characters...
};
OLED oled(128, 64);
void setup() {
oled.begin();
oled.setFont(myFont); // Set the custom font
oled.print("Custom Font", 0, 0); // Display with custom font
}
You can print static text at a given (x, y)
coordinate using the print()
method.
oled.print("Hello, OLED!", 0, 0); // Prints "Hello, OLED!" at (0, 0)
Use the printAnimated()
method for a typewriter effect, where text is displayed one character at a time.
oled.printAnimated("Welcome!", 0, 0, 100, false); // Print text with a 100 ms delay between characters, set true for highlight effect
You can display progress bars in multiple styles (1-10 for progress bars, 11-15 for loaders). The progressBar()
method accepts the progress value (0-100) and a style number.
oled.progressBar(50, 0, 10, 1); // Displays a 50% progress bar at (0, 10), style 1
The library includes the draw()
method to display bitmaps on the OLED. You can convert images into bitmap arrays using the Bitmap Generator Python tool (explained below).
const uint8_t myBitmap[] = {
// Your bitmap data here, generated by the Bitmap Generator
};
oled.draw(myBitmap, 0, 0, 16, 16); // Draw a 16x16 bitmap at coordinates (0, 0)
The library also includes operator overloading to simplify the process of displaying text and bitmaps. You can use the <<
operator to print text and the []
operator to display bitmaps.
oled << "Hello, World!" << 0 << 0; // Prints "Hello, World!" at (0, 0)
oled[myBitmap] << 0 << 0 << 16 << 16; // Draws a 16x16 bitmap at (0, 0)
Use the clearScr()
method to clear the screen.
oled.clearScr(); // Clears the display
Use the setBrightness()
method to adjust the display’s brightness. It accepts a percentage value (0-100).
oled.setBrightness(80); // Set the brightness to 80%
The manualSetup()
method allows you to pass an array of settings to configure the OLED display manually.
uint8_t customSettings[] = {
0xA8, 0x3F, // Multiplex ratio
0xD3, 0x00, // Display offset
// More settings...
};
oled.manualSetup(customSettings); // Apply custom settings
You can disable the display when you clear the screen using the turnOffOnClr()
method.
oled.turnOffOnClr(true); // Turn off display when cleared
The display can operate in different power modes. Choose between low power, balanced, or performance mode to optimize energy consumption or display quality.
oled.setPowerMode(LOW_POWER_MODE); // Set the display to low power mode
Enable or disable super brightness for high-intensity display, though note it may cause instability.
oled.superBrightness(true); // Turn on super brightness
Invert the pixels on the display to change all white pixels to black and vice versa.
oled.invertDisplay(); // Invert the display colors
You can turn the entire display on or off.
oled.entireDisplayON(); // Turn all pixels on
oled.entireDisplayOFF(); // Revert back to the content
You can draw shapes such as rectangles, circles, and lines on the OLED display.
oled.rectangle(10, 10, 50, 30, 5, 2); // Draw a rectangle at (10, 10) with width 50, height 30, 5px corner radius, and 2px thickness
oled.circle(64, 32, 20, 2); // Draw a circle at (64, 32) with radius 20, and thickness 2px
oled.line(0, 0, 127, 63, 2); // Draw a line from (0, 0) to (127, 63), 2px thick
Use the printHighlighted()
method to print the text as highlighted.
oled.printHighlighted("Welcome!", 0, 0); // Print text with a highlighted effect
Use the clearArea()
method to clear a specific region along the width of the display.
oled.clearArea(20, 40, 0); // Clears the region from 20 to 40 in the page 0.
Inspired by Android fragments, you can manage a back stack of fragments using addToBackStack()
and popBackStack()
methods.
Fragment fragment(manager);
manager.addToBackStack(&fragment); // Add fragment to back stack
manager.popBackStack(); // Pop the last fragment from the back stack
Here are the constants you can use to configure various settings for your SSD1306 OLED display.
Constant | Value | Description |
---|---|---|
OLED_OFF |
0xAE | Turns the display off. |
OLED_ON |
0xAF | Turns the display on. |
INVERT |
0xA7 | Inverts the display pixels. |
REVERT |
0xA6 | Reverts the display pixels. |
ENTIRE_DISP_ON |
0xA5 | Turns on all the pixels. |
RESUME_FROM_VRAM |
0xA4 | Resumes from VRAM. |
Constant | Value | Description |
---|---|---|
LOW_POWER_MODE |
0x00 | Low power mode. |
BALANCED_MODE |
0x01 | Balanced mode. |
PERFORMANCE_MODE |
0x02 | Performance mode. |
Constant | Value | Description |
---|---|---|
WIDTH_128 |
0x80 | Display width of 128 pixels. |
HEIGHT_64 |
0x40 | Display height of 64 pixels. |
Constant | Value | Description |
---|---|---|
HORIZONTAL |
0x00 | Horizontal memory addressing mode. |
VERTICAL |
0x01 | Vertical memory addressing mode. |
PAGE |
0x02 | Page addressing mode. |
Constant | Value | Description |
---|---|---|
CHRG_PUMP |
0x8D | Charge pump control command. |
CONTRAST |
0x81 | Set the display contrast. |
PRE_CHRG |
0xD9 | Pre-charge period control. |
VCOMH_DESEL |
0xDB | VCOMH deselect level. |
The Bitmap Generator tool helps you convert images to bitmaps that can be displayed on your SSD1306 OLED screen. This tool is written in Python and uses the Pillow library to process images.
You can run the Bitmap Generator directly from the command line:
python image_to_bitmap.py <image_path> <output_file>
For example, to convert an image located at images/logo.png
to a bitmap:
python image_to_bitmap.py images/logo.png output_logo.h
This library is licensed under the MIT License.