esp32_SH1122 is a C++ esp-idf v5.x component, intended to serve as a driver for SH1122 driven 256x64 OLED displays with 16 shades of grayscale.
This library contains functions for basic graphics like lines, rectangles, and ellipses. It also contains support
for strings and bitmaps.
This library includes tools for encoding images into 16-shade grayscale bitmaps. The bitmaps use a custom run-length encoding format to minimize memory usage as much as possible.
See the Creating Bitmaps for more info.
Below are a few encoded bitmaps on the OLED next to their original source images.
This library contains close to 2000 different fonts from the U8G2 display library.
The fonts names remain the same; however, they have "sh1122_font" appended onto the front instead of u8g2_font.
A list of the fonts available within this library can be found here:
https://github.com/olikraus/u8g2/wiki/fntlistall
For more on using fonts, see Font System.
This library contains tools for creating screenshots and gifs for use in documentation.
See Taking Screenshots for more info.
Below is an example of screen recording gif displaying a splash screen.
The default wiring is depicted below, it can be changed at driver initialization (see Example).
-
Create a "components" directory in the root workspace directory of your esp-idf project if it does not exist already.
In workspace directory:
mkdir components
-
Cd into the components directory and clone the esp32_SH1122 repo.
cd components git clone https://github.com/myles-parfeniuk/esp32_SH1122.git
-
Ensure you clean your esp-idf project before rebuilding.
Within esp-idf enabled terminal:idf.py fullclean
This example draws a string on a dark gray background.
#include <stdio.h>
#include "SH1122Oled.hpp"
#include "fonts/sh1122_font_inr16_mf.hpp" //include any fonts you wish to use
extern "C" void app_main(void)
{
SH1122Oled oled; //using default initialization
//custom initialization example:
/*SH1122Oled oled(sh1122_oled_cfg_t(SPI3_HOST, //SPI peripheral
GPIO_NUM_4, //sda GPIO
GPIO_NUM_18, //sclk GPIO
GPIO_NUM_21, //chip select GPIO
GPIO_NUM_22, //reset GPIO
GPIO_NUM_23) //data/!command GPIO
);
*/
// load font for drawing string
SH1122Oled::load_font(sh1122_font_inr16_mf);
while (1)
{
oled.clear_buffer(); // clear buffer of previous frame before drawing
// draw background
oled.draw_rectangle(0, 0, SH1122Oled::WIDTH, SH1122Oled::HEIGHT, SH1122Oled::PixelIntensity::level_1);
// draw screen border
oled.draw_rectangle_frame(0, 0, SH1122Oled::WIDTH, SH1122Oled::HEIGHT, 2, SH1122Oled::PixelIntensity::level_10);
// draw the string
const int x = oled.font_get_string_center_x("esp32_SH1122"); // find the string x position for horizontal centering
const int y = oled.font_get_string_center_y("esp32_SH1122"); // find the string y position for vertical centering
oled.draw_string(x, y, SH1122Oled::PixelIntensity::level_15, "esp32_SH1122");
oled.update_screen(); // send the current buffer to the screen
vTaskDelay(50 / portTICK_PERIOD_MS);
}
}
To create bitmaps:
-
Place .png images into the
python_utilities/bitmap_encoder/input
directory. -
Run the
sh1122_encode_bitmap.py
script and append any arguments on you see fit.From terminal with python in path:
python sh1122_encode_bitmap.py
To see a full list of argument flags type:
python sh1122_encode_bitmap.py -help
-
Copy the .hpp files generated by the script from
python_utilities/bitmap_encoder/output
toyour_project/components/esp32_SH1122/bitmaps
-
To draw a bitmap include the respective .hpp file at the top of your project and call draw bitmap.
#include "SH1122Oled.hpp" #include "bitmaps/sh1122_bitmap_your_file.hpp" //... //somewhere in your code oled.draw_bitmap(0, 0, sh1122_bitmap_your_file);
All the font files are located within the fonts/
directory. Ensure you load a font before calling functions like
draw_string()
, draw_glyph()
, get_string_width()
, etc...
A full list of included fonts can be found at:
https://github.com/olikraus/u8g2/wiki/fntlistall
To use a font:
-
Include the respective font's header file at the top of your file:
#include "fonts/sh1122_font_inr16_mf.hpp"
-
Call load_font(), passing it the font look up table:
SH1122Oled::load_font(sh1122_font_inr16_mf);
-
Call whichever draw functions you like, for example:
oled.draw_string(x, y, SH1122Oled::PixelIntensity::level_15, "my string");
String functions also support variable argument lists like printf:
int my_number = 1122; oled.draw_string(x, y, SH1122Oled::PixelIntensity::level_15, "my number %d", my_number);
NOTE:
If you would like to use utf-8 encoded strings, call load_font_utf8()
instead of load_font()
, here is an example:
#include <stdio.h>
#include "SH1122Oled.hpp"
#include "fonts/sh1122_font_8x13_t_cyrillic.hpp"
#include "fonts/sh1122_font_f12_b_t_japanese1.hpp"
#include "fonts/sh1122_font_etl14thai_t.hpp"
#include "fonts/sh1122_font_shylock_nbp_t_all.hpp"
extern "C" void app_main(void)
{
SH1122Oled oled; // using default initialization
uint16_t x = 0U;
uint16_t y = 0U;
while (1)
{
oled.clear_buffer(); // clear buffer of previous frame before drawing
x = 5U;
y = 0U;
// load cyrillic font and draw string
SH1122Oled::load_font_utf8(sh1122_font_8x13_t_cyrillic);
oled.draw_string(x, y, SH1122Oled::PixelIntensity::level_15, "Привет Мир!");
y += 25;
// load japanese font and draw string
SH1122Oled::load_font_utf8(sh1122_font_f12_b_t_japanese1);
oled.draw_string(x, y, SH1122Oled::PixelIntensity::level_15, "こんにちは世界!");
y += 10;
// load thai font and draw string
SH1122Oled::load_font_utf8(sh1122_font_etl14thai_t);
oled.draw_string(x, y, SH1122Oled::PixelIntensity::level_15, "สวัสดีโลก!");
y += 15;
// load greek font and draw string
SH1122Oled::load_font_utf8(sh1122_font_shylock_nbp_t_all);
oled.draw_string(x, y, SH1122Oled::PixelIntensity::level_15, "Γειά σου Κόσμε!");
oled.update_screen(); // send the current buffer to the screen
vTaskDelay(50 / portTICK_PERIOD_MS);
}
}
To take screen shots:
-
Call the take_screenshot() method somewhere in your firmware, this function dumps the current frame buffer over serial.
oled.take_screen_shot()
-
While your firmware is flashed and executing, run the
sh1122_screenshot.py
script located inpython_utilities/screenshot
.
Ensure you close the esp-idf serial monitor if you have it open and append the comport name as well as baud rate onto the script execution call, for example:python sh1122_screenshot.py COM3 -b 115200
-
The script will display how many screen shots it has captured each time a new one is received, press the q key once you are done to save the images.
-
The output images (in png format) can be found in the
python_utilities/screenshot/output
directory.
NOTE:
For minimal latency you should increase your console baud rate in menuconfig to the maximum possible value.
For more info see the header at the top of sh1122_screenshot.py.
To create gifs from any captured screenshots simply run sh1122_gif_creator.py
, it will account for each frame duration according to the time stamps in the filenames of the screenshots.
API documentation generated with doxygen can be found in the documentation directory of the master branch.
Thanks to Oliver Krause and contributors of u8g2.
https://github.com/olikraus/u8g2
This library utilizes the same run-line encoding system used by U8G2 for fonts.
Distributed under the MIT License. See LICENSE.md
for more information.
Myles Parfeniuk - [email protected]
Project Link: https://github.com/myles-parfeniuk/esp32_SH1122.git