mirror of
https://github.com/nopnop2002/esp-idf-ssd1306.git
synced 2024-09-19 17:56:25 -04:00
Deleted unnecessary files
This commit is contained in:
parent
911a9d39ed
commit
3414fb0629
211
ImageDemo/main/_
211
ImageDemo/main/_
@ -1,211 +0,0 @@
|
|||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
#include "freertos/FreeRTOS.h"
|
|
||||||
#include "freertos/task.h"
|
|
||||||
#include "esp_log.h"
|
|
||||||
|
|
||||||
#include "ssd1306.h"
|
|
||||||
#include "font8x8_basic.h"
|
|
||||||
|
|
||||||
/*
|
|
||||||
You have to set this config value with menuconfig
|
|
||||||
CONFIG_INTERFACE
|
|
||||||
|
|
||||||
for i2c
|
|
||||||
CONFIG_MODEL
|
|
||||||
CONFIG_SDA_GPIO
|
|
||||||
CONFIG_SCL_GPIO
|
|
||||||
CONFIG_RESET_GPIO
|
|
||||||
|
|
||||||
for SPI
|
|
||||||
CONFIG_CS_GPIO
|
|
||||||
CONFIG_DC_GPIO
|
|
||||||
CONFIG_RESET_GPIO
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define TAG "SSD1306"
|
|
||||||
|
|
||||||
// https://www.mischianti.org/2021/07/14/ssd1306-oled-display-draw-images-splash-and-animations-2/
|
|
||||||
uint8_t batman[] = {
|
|
||||||
0b11111111, 0b11111111, 0b11111111, 0b11111111,
|
|
||||||
0b11111111, 0b10011111, 0b11111001, 0b11111111,
|
|
||||||
0b11111110, 0b00111110, 0b01111100, 0b01111111,
|
|
||||||
0b11111000, 0b00111100, 0b00111100, 0b00011111,
|
|
||||||
0b11110000, 0b00011100, 0b00111000, 0b00001111,
|
|
||||||
0b11110000, 0b00000000, 0b00000000, 0b00001111,
|
|
||||||
0b11100000, 0b00000000, 0b00000000, 0b00000111,
|
|
||||||
0b11100000, 0b00000000, 0b00000000, 0b00000111,
|
|
||||||
0b11110000, 0b00000000, 0b00000000, 0b00001111,
|
|
||||||
0b11110000, 0b11000100, 0b00100011, 0b00001111,
|
|
||||||
0b11111001, 0b11111110, 0b01111111, 0b10011111,
|
|
||||||
0b11111100, 0b11111110, 0b01111111, 0b00111111,
|
|
||||||
0b11111111, 0b11111111, 0b11111111, 0b11111111
|
|
||||||
};
|
|
||||||
|
|
||||||
// https://www.mischianti.org/2021/07/14/ssd1306-oled-display-draw-images-splash-and-animations-2/
|
|
||||||
uint8_t logoMischianti [1024] = {
|
|
||||||
// 'logoBN128x64, 128x64px
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xc0, 0x03, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0xe0, 0x07, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0xe0, 0x07, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0xf0, 0x07, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xf3, 0xcf, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0xe0, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0xc0, 0x7f, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0xe7, 0xc0, 0x7f, 0xe7, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x3f, 0xff, 0xe0, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x01, 0xf8, 0x0f, 0xff, 0xff, 0xf0, 0x1f, 0x80, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x03, 0xe0, 0x03, 0xff, 0xff, 0xc0, 0x03, 0xc0, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x07, 0x80, 0x00, 0xff, 0xff, 0x00, 0x41, 0xe0, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x7f, 0xfe, 0x00, 0xe0, 0xf0, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x1f, 0xf8, 0x00, 0xe0, 0x70, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x0f, 0xf0, 0x00, 0xe0, 0x70, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x1c, 0x00, 0x00, 0x07, 0xe0, 0x00, 0xe0, 0x38, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x1c, 0x7f, 0xf0, 0x03, 0xe0, 0x00, 0xe0, 0x38, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x1c, 0x7f, 0xf0, 0x03, 0xc0, 0x1f, 0xff, 0x38, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x1c, 0x7f, 0xf0, 0x03, 0xe0, 0x1f, 0xff, 0x38, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x1c, 0x00, 0x00, 0x07, 0xe0, 0x00, 0x60, 0x38, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x0f, 0xf0, 0x00, 0xe0, 0x70, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x0e, 0x00, 0x00, 0x1f, 0xf8, 0x00, 0xe0, 0x70, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x7c, 0x3e, 0x00, 0xe0, 0xf0, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x07, 0x80, 0x00, 0xf8, 0x1f, 0x00, 0x61, 0xe0, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x03, 0xc0, 0x03, 0xe0, 0x07, 0xc0, 0x03, 0xc0, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x01, 0xf8, 0x0f, 0xc0, 0x03, 0xf0, 0x1f, 0x80, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x3f, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x3f, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x3f, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x38, 0x00, 0x00, 0x1c, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x3c, 0x00, 0x00, 0x1c, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1c, 0x00, 0x00, 0x3c, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1f, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1f, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0f, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0f, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x07, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x03, 0xe0, 0x07, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0xf0, 0x0f, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0xfc, 0x3f, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x7f, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x1f, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x0f, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00, 0x08, 0x10, 0x00, 0x00, 0x80, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00,
|
|
||||||
0x00, 0x46, 0x63, 0x31, 0x90, 0xff, 0x13, 0xc3, 0x8b, 0x91, 0xe5, 0xdc, 0x80, 0xf3, 0xbf, 0x00,
|
|
||||||
0x00, 0x66, 0x73, 0x39, 0x90, 0xcd, 0x92, 0x24, 0x4c, 0x92, 0x26, 0x48, 0x81, 0x13, 0x27, 0x00,
|
|
||||||
0x00, 0x2e, 0x57, 0x2b, 0x90, 0x88, 0x93, 0x04, 0x08, 0xd0, 0x24, 0x68, 0x81, 0x1a, 0x23, 0x00,
|
|
||||||
0x00, 0x2a, 0xd5, 0x6a, 0xb0, 0x88, 0x91, 0xcc, 0x08, 0xd3, 0xe4, 0x68, 0x83, 0x1a, 0x63, 0x00,
|
|
||||||
0x00, 0x2b, 0x95, 0xca, 0xe0, 0x88, 0x90, 0x64, 0x08, 0xd2, 0x24, 0x68, 0x81, 0x1a, 0x63, 0x00,
|
|
||||||
0x00, 0x39, 0x9c, 0xce, 0x60, 0x88, 0x96, 0x24, 0x48, 0xd6, 0x64, 0x68, 0x81, 0x12, 0x27, 0x00,
|
|
||||||
0x00, 0x11, 0x88, 0xc4, 0x6c, 0x88, 0x93, 0xc3, 0x88, 0xd3, 0xb4, 0x6e, 0x98, 0xf2, 0x3f, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x22, 0x00,
|
|
||||||
0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x3c, 0x00
|
|
||||||
};
|
|
||||||
|
|
||||||
void app_main(void)
|
|
||||||
{
|
|
||||||
SSD1306_t dev;
|
|
||||||
|
|
||||||
#if CONFIG_I2C_INTERFACE
|
|
||||||
ESP_LOGI(TAG, "INTERFACE is i2c");
|
|
||||||
ESP_LOGI(TAG, "CONFIG_SDA_GPIO=%d",CONFIG_SDA_GPIO);
|
|
||||||
ESP_LOGI(TAG, "CONFIG_SCL_GPIO=%d",CONFIG_SCL_GPIO);
|
|
||||||
ESP_LOGI(TAG, "CONFIG_RESET_GPIO=%d",CONFIG_RESET_GPIO);
|
|
||||||
i2c_master_init(&dev, CONFIG_SDA_GPIO, CONFIG_SCL_GPIO, CONFIG_RESET_GPIO);
|
|
||||||
#endif // CONFIG_I2C_INTERFACE
|
|
||||||
|
|
||||||
#if CONFIG_SPI_INTERFACE
|
|
||||||
ESP_LOGI(TAG, "INTERFACE is SPI");
|
|
||||||
ESP_LOGI(TAG, "CONFIG_MOSI_GPIO=%d",CONFIG_MOSI_GPIO);
|
|
||||||
ESP_LOGI(TAG, "CONFIG_SCLK_GPIO=%d",CONFIG_SCLK_GPIO);
|
|
||||||
ESP_LOGI(TAG, "CONFIG_CS_GPIO=%d",CONFIG_CS_GPIO);
|
|
||||||
ESP_LOGI(TAG, "CONFIG_DC_GPIO=%d",CONFIG_DC_GPIO);
|
|
||||||
ESP_LOGI(TAG, "CONFIG_RESET_GPIO=%d",CONFIG_RESET_GPIO);
|
|
||||||
spi_master_init(&dev, CONFIG_MOSI_GPIO, CONFIG_SCLK_GPIO, CONFIG_CS_GPIO, CONFIG_DC_GPIO, CONFIG_RESET_GPIO);
|
|
||||||
#endif // CONFIG_SPI_INTERFACE
|
|
||||||
|
|
||||||
#if CONFIG_FLIP
|
|
||||||
dev._flip = true;
|
|
||||||
ESP_LOGW(TAG, "Flip upside down");
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if CONFIG_SSD1306_128x64
|
|
||||||
ESP_LOGI(TAG, "Panel is 128x64");
|
|
||||||
ssd1306_init(&dev, 128, 64);
|
|
||||||
#endif // CONFIG_SSD1306_128x64
|
|
||||||
#if CONFIG_SSD1306_128x32
|
|
||||||
ESP_LOGI(TAG, "Panel is 128x32");
|
|
||||||
ssd1306_init(&dev, 128, 32);
|
|
||||||
#endif // CONFIG_SSD1306_128x32
|
|
||||||
|
|
||||||
ssd1306_clear_screen(&dev, false);
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
// for test code
|
|
||||||
int srcBits = 7;
|
|
||||||
int dstBits = 0;
|
|
||||||
for (int i=0;i<8;i++) {
|
|
||||||
uint8_t dst = 0;
|
|
||||||
dst = ssd1306_copy_bit(0xf0, srcBits, dst, dstBits);
|
|
||||||
ESP_LOGI(TAG, "dst=%02x", dst);
|
|
||||||
srcBits--;
|
|
||||||
dstBits++;
|
|
||||||
}
|
|
||||||
srcBits = 7;
|
|
||||||
dstBits = 0;
|
|
||||||
for (int i=0;i<8;i++) {
|
|
||||||
uint8_t dst = 0;
|
|
||||||
dst = ssd1306_copy_bit(0x0f, srcBits, dst, dstBits);
|
|
||||||
ESP_LOGI(TAG, "dst=%02x", dst);
|
|
||||||
srcBits--;
|
|
||||||
dstBits++;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
while(1) {
|
|
||||||
ssd1306_contrast(&dev, 0xff);
|
|
||||||
#if CONFIG_SSD1306_128x64
|
|
||||||
ssd1306_display_text(&dev, 0, "SSD1306 128x64", 14, false);
|
|
||||||
#endif // CONFIG_SSD1306_128x64
|
|
||||||
|
|
||||||
#if CONFIG_SSD1306_128x32
|
|
||||||
ssd1306_display_text(&dev, 0, "SSD1306 128x32", 14, false);
|
|
||||||
#endif // CONFIG_SSD1306_128x32
|
|
||||||
ssd1306_display_text(&dev, 1, "BATMAN", 6, false);
|
|
||||||
|
|
||||||
int bitmapWidth = 4*8;
|
|
||||||
int width = ssd1306_get_width(&dev);
|
|
||||||
int xpos = width / 2; // center of width
|
|
||||||
xpos = xpos - bitmapWidth/2;
|
|
||||||
int ypos = 16;
|
|
||||||
ESP_LOGI(TAG, "width=%d xpos=%d", width, xpos);
|
|
||||||
ssd1306_bitmaps(&dev, xpos, ypos, batman, 4, 12);
|
|
||||||
vTaskDelay(3000 / portTICK_PERIOD_MS);
|
|
||||||
|
|
||||||
for(int i=0;i<128;i++) {
|
|
||||||
ssd1306_rotate(&dev, SCROLL_RIGHT, 2, 3, 0);
|
|
||||||
}
|
|
||||||
vTaskDelay(2000 / portTICK_PERIOD_MS);
|
|
||||||
|
|
||||||
#if CONFIG_SSD1306_128x64
|
|
||||||
ssd1306_clear_screen(&dev, false);
|
|
||||||
ssd1306_bitmaps(&dev, 0, 0, logoMischianti, 16, 64);
|
|
||||||
vTaskDelay(2000 / portTICK_PERIOD_MS);
|
|
||||||
|
|
||||||
for(int i=0;i<64;i++) {
|
|
||||||
ssd1306_rotate(&dev, SCROLL_UP, 0, 127, 0);
|
|
||||||
}
|
|
||||||
vTaskDelay(2000 / portTICK_PERIOD_MS);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in New Issue
Block a user