From 911a9d39ed40ae93cb15c6bc0317ae26bb78ea88 Mon Sep 17 00:00:00 2001 From: nopnop2002 Date: Tue, 26 Apr 2022 15:33:47 +0900 Subject: [PATCH] Added RotateDemo --- RotateDemo/CMakeLists.txt | 8 ++ RotateDemo/README.md | 4 + RotateDemo/main/CMakeLists.txt | 4 + RotateDemo/main/component.mk | 8 ++ RotateDemo/main/main.c | 133 +++++++++++++++++++++++++++++++++ 5 files changed, 157 insertions(+) create mode 100644 RotateDemo/CMakeLists.txt create mode 100644 RotateDemo/README.md create mode 100644 RotateDemo/main/CMakeLists.txt create mode 100644 RotateDemo/main/component.mk create mode 100644 RotateDemo/main/main.c diff --git a/RotateDemo/CMakeLists.txt b/RotateDemo/CMakeLists.txt new file mode 100644 index 0000000..2aa16fe --- /dev/null +++ b/RotateDemo/CMakeLists.txt @@ -0,0 +1,8 @@ +# The following lines of boilerplate have to be in your project's CMakeLists +# in this exact order for cmake to work correctly +cmake_minimum_required(VERSION 3.5) + +set(EXTRA_COMPONENT_DIRS ../components/ssd1306) + +include($ENV{IDF_PATH}/tools/cmake/project.cmake) +project(ssd1306) diff --git a/RotateDemo/README.md b/RotateDemo/README.md new file mode 100644 index 0000000..8e8033f --- /dev/null +++ b/RotateDemo/README.md @@ -0,0 +1,4 @@ +# RotateDemo for SSD1306 + +![RoteteDemo](https://user-images.githubusercontent.com/6020549/165236460-e1fd757c-dcff-4601-bce1-b533599b5fc5.JPG) + diff --git a/RotateDemo/main/CMakeLists.txt b/RotateDemo/main/CMakeLists.txt new file mode 100644 index 0000000..647a294 --- /dev/null +++ b/RotateDemo/main/CMakeLists.txt @@ -0,0 +1,4 @@ +set(COMPONENT_SRCS "main.c") +set(COMPONENT_ADD_INCLUDEDIRS "") + +register_component() diff --git a/RotateDemo/main/component.mk b/RotateDemo/main/component.mk new file mode 100644 index 0000000..61f8990 --- /dev/null +++ b/RotateDemo/main/component.mk @@ -0,0 +1,8 @@ +# +# Main component makefile. +# +# This Makefile can be left empty. By default, it will take the sources in the +# src/ directory, compile them and link them into lib(subdirectory_name).a +# in the build directory. This behaviour is entirely configurable, +# please read the ESP-IDF documents if you need to do this. +# diff --git a/RotateDemo/main/main.c b/RotateDemo/main/main.c new file mode 100644 index 0000000..eccbc0a --- /dev/null +++ b/RotateDemo/main/main.c @@ -0,0 +1,133 @@ +#include +#include +#include +#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" + +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); + ssd1306_contrast(&dev, 0xff); + +#if CONFIG_SSD1306_128x64 + ssd1306_display_text(&dev, 0, "SSD1306 128x64", 14, false); + ssd1306_display_text(&dev, 1, "ABCDEFGHIJKLMNOP", 16, false); + ssd1306_display_text(&dev, 2, "abcdefghijklmnop",16, false); + ssd1306_display_text(&dev, 3, "Hello World!!", 13, false); + ssd1306_display_text(&dev, 4, "SSD1306 128x64", 14, true); + ssd1306_display_text(&dev, 5, "ABCDEFGHIJKLMNOP", 16, true); + ssd1306_display_text(&dev, 6, "abcdefghijklmnop",16, true); + ssd1306_display_text(&dev, 7, "Hello World!!", 13, true); + int pages = 7; +#endif // CONFIG_SSD1306_128x64 + +#if CONFIG_SSD1306_128x32 + ssd1306_display_text(&dev, 0, "SSD1306 128x32", 14, false); + ssd1306_display_text(&dev, 1, "Hello World!!", 13, false); + ssd1306_display_text(&dev, 2, "SSD1306 128x32", 14, true); + ssd1306_display_text(&dev, 3, "Hello World!!", 13, true); + int pages = 3; +#endif // CONFIG_SSD1306_128x32 + + vTaskDelay(3000 / portTICK_PERIOD_MS); + while(1) { + for(int i=0;i<128;i++) { + ssd1306_rotate(&dev, SCROLL_RIGHT, 1, 2, 0); + if (pages == 7) { + ssd1306_rotate(&dev, SCROLL_RIGHT, 5, 6, 0); + } + } + vTaskDelay(2000 / portTICK_PERIOD_MS); + + for(int i=0;i<128;i++) { + ssd1306_rotate(&dev, SCROLL_LEFT, 1, 2, 0); + if (pages == 7) { + ssd1306_rotate(&dev, SCROLL_LEFT, 5, 6, 0); + } + } + vTaskDelay(2000 / portTICK_PERIOD_MS); + + int height = ssd1306_get_height(&dev); + ESP_LOGD(TAG, "height=%d", height); + for(int i=0;i