107 lines
3.3 KiB
C
Raw Normal View History

2025-03-01 15:54:04 -05:00
/*#############################################################################
## Author: Shaun Reed ##
## Legal: All Content (c) 2025 Shaun Reed, all rights reserved ##
## ##
## Contact: shaunrd0@gmail.com | URL: www.shaunreed.com ##
##############################################################################
*/
2025-02-15 10:11:49 -05:00
#ifndef SSD1306_H
#define SSD1306_H
#include <esp_lcd_panel_ssd1306.h>
#include "panel_device.h"
// According to specific display hardware.
2025-02-15 10:11:49 -05:00
// https://www.digikey.com/en/products/detail/winstar-display/WEA012864DWPP3N00003/20533255
#define SCREEN_WIDTH 128 // OLED display width, in pixels.
#define SCREEN_HEIGHT 64 // OLED display height, in pixels.
// According to SSD1306 datasheet.
// https://cdn-shop.adafruit.com/datasheets/SSD1306.pdf
2025-02-15 10:11:49 -05:00
#define I2C_HW_ADDR 0x3C
#define LCD_PIXEL_CLOCK_HZ (400 * 1000)
2025-02-16 09:38:28 -05:00
// Bit number used to represent command and parameter
2025-02-15 10:11:49 -05:00
#define LCD_CMD_BITS 8
#define LCD_PARAM_BITS 8
2025-02-16 14:31:50 -05:00
/**
* Example of implementing the IPanelDevice interface for SSD1306 LCD device.
*/
2025-02-16 09:38:28 -05:00
class SSD1306 final : public IPanelDevice {
2025-02-15 10:11:49 -05:00
public:
2025-02-16 14:31:50 -05:00
/**
* Construct a new SSD1306 device.
*
* @param i2c I2C master bus to manage this device.
*/
2025-02-15 18:16:25 -05:00
explicit SSD1306(I2C &i2c) :
2025-02-15 17:12:06 -05:00
SSD1306(i2c, {.height = SCREEN_HEIGHT}) { }
2025-02-15 10:11:49 -05:00
2025-02-16 14:31:50 -05:00
/**
* Construct a new SSD1306 device given a specific SSD1306 configuration.
*
* @param i2c I2C master bus to manage this device.
* @param config SSD1306 vendor configuration.
* @param width Width of the device screen in pixels.
* @param height Height of the device screen in pixels.
*/
2025-02-15 18:16:25 -05:00
SSD1306(I2C &i2c,
esp_lcd_panel_ssd1306_config_t config,
int width = SCREEN_WIDTH,
int height = SCREEN_HEIGHT
) :
IPanelDevice(i2c,
(esp_lcd_panel_io_i2c_config_t) {
.dev_addr = I2C_HW_ADDR,
// User data to pass to the LVGL flush_ready callback.
// See IPanelDevice::lvgl_flush_ready_cb
.user_ctx = nullptr,
.control_phase_bytes = 1,
.dc_bit_offset = 6,
.lcd_cmd_bits = LCD_CMD_BITS,
.lcd_param_bits = LCD_PARAM_BITS,
.scl_speed_hz = LCD_PIXEL_CLOCK_HZ,
},
width,
height
),
ssd1306_config_(config) { }
2025-02-15 17:12:06 -05:00
2025-02-16 09:38:28 -05:00
~SSD1306() final = default;
2025-02-15 17:12:06 -05:00
2025-02-26 19:26:53 -05:00
//
// PUBLIC METHODS
2025-02-16 14:31:50 -05:00
/**
* Provides the SSD1306 vendor configuration to IPanelDevice consumers.
*
* @return Address of the SSD1306 vendor configuration structure.
*/
2025-02-15 18:26:26 -05:00
void *vendor_config() override
{
return &ssd1306_config_;
}
2025-02-26 19:26:53 -05:00
//
// PUBLIC MEMBERS
2025-02-16 14:31:50 -05:00
/// SSD1306 configuration structure.
2025-02-15 17:12:06 -05:00
esp_lcd_panel_ssd1306_config_t ssd1306_config_;
2025-02-15 10:11:49 -05:00
2025-02-15 17:12:06 -05:00
private:
2025-02-26 19:26:53 -05:00
//
// PRIVATE METHODS
2025-02-16 14:31:50 -05:00
/// Initializes the ESP LCD panel handle for the SSD1306 device.
2025-02-15 17:12:06 -05:00
void init_panel(esp_lcd_panel_dev_config_t &config,
esp_lcd_panel_io_handle_t io,
2025-02-16 07:21:16 -05:00
esp_lcd_panel_handle_t &panel) override
{
ESP_ERROR_CHECK(esp_lcd_new_panel_ssd1306(io, &config, &panel));
}
2025-02-15 10:11:49 -05:00
};
#endif // SSD1306_H