mirror of
https://github.com/nopnop2002/esp-idf-ssd1306.git
synced 2024-10-03 18:18:47 -04:00
Added MeterDemo
This commit is contained in:
parent
5bb7da9253
commit
6a99246d03
8
MeterDemo/CMakeLists.txt
Normal file
8
MeterDemo/CMakeLists.txt
Normal file
@ -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)
|
10
MeterDemo/README.md
Normal file
10
MeterDemo/README.md
Normal file
@ -0,0 +1,10 @@
|
|||||||
|
# MeterDemo for SSD1306
|
||||||
|
|
||||||
|
![MeterDemo](https://user-images.githubusercontent.com/6020549/166136718-5139deb8-df11-4756-b161-7830ce2251ea.JPG)
|
||||||
|
|
||||||
|
I borrowed the BIT MAP data from [here](https://forum.arduino.cc/t/analog-vu-meter-i2c-oled-sh1106-oledmeter-animation/388374).
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
This sample shows how to quickly redraw a BITMAP image.
|
||||||
|
High-speed drawing is possible by converting BITMAP data to Page and Segment.
|
4
MeterDemo/main/CMakeLists.txt
Normal file
4
MeterDemo/main/CMakeLists.txt
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
set(COMPONENT_SRCS "main.c")
|
||||||
|
set(COMPONENT_ADD_INCLUDEDIRS "")
|
||||||
|
|
||||||
|
register_component()
|
8
MeterDemo/main/component.mk
Normal file
8
MeterDemo/main/component.mk
Normal file
@ -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.
|
||||||
|
#
|
233
MeterDemo/main/main.c
Normal file
233
MeterDemo/main/main.c
Normal file
@ -0,0 +1,233 @@
|
|||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <math.h>
|
||||||
|
#include "freertos/FreeRTOS.h"
|
||||||
|
#include "freertos/task.h"
|
||||||
|
#include "driver/adc.h"
|
||||||
|
#include "esp_adc_cal.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://forum.arduino.cc/t/analog-vu-meter-i2c-oled-sh1106-oledmeter-animation/388374
|
||||||
|
// VU meter background mask image:
|
||||||
|
static uint8_t VUMeter1[1024] = {
|
||||||
|
// 128x84
|
||||||
|
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, 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, 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, 0x06, 0x03, 0x00, 0x60, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x00, 0x78, 0x09, 0x04, 0x80, 0x21, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x01, 0x98, 0x08, 0x06, 0x03, 0x80, 0x21, 0x20, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0xA4, 0x10, 0x09, 0x00, 0x80, 0x21, 0x20, 0x07, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0xA4, 0x10, 0x06, 0x03, 0x00, 0x20, 0xC0, 0x00, 0x80, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x71, 0x80, 0xA4, 0x10, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x0A, 0x40, 0x98, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x80, 0x3C, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x3A, 0x40, 0x00, 0x00, 0x02, 0x01, 0x00, 0x40, 0x80, 0x07, 0x00, 0x20, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x42, 0x40, 0x00, 0x08, 0x02, 0x01, 0x08, 0x40, 0x80, 0x00, 0x00, 0x38, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x79, 0x80, 0x04, 0x08, 0x02, 0x01, 0x08, 0x81, 0x10, 0x00, 0x00, 0x04, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x04, 0x08, 0x02, 0x01, 0x08, 0x81, 0x11, 0x04, 0x00, 0x38, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x00, 0x02, 0x04, 0x02, 0x01, 0x08, 0x81, 0x21, 0x04, 0x00, 0x00, 0x08, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x84, 0x02, 0x04, 0x0F, 0xFF, 0xFF, 0xC3, 0xE2, 0x04, 0x00, 0x00, 0x08, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0xC2, 0x01, 0x07, 0xF0, 0x00, 0x00, 0x3B, 0xFE, 0x08, 0x40, 0x40, 0x08, 0x00,
|
||||||
|
0x00, 0xFE, 0x00, 0x62, 0x01, 0xF8, 0x00, 0x00, 0x00, 0x03, 0xFF, 0xE8, 0x40, 0x80, 0x7F, 0x00,
|
||||||
|
0x00, 0x00, 0x00, 0x21, 0x1E, 0x00, 0x04, 0x00, 0x80, 0x00, 0x7F, 0xFE, 0x80, 0x80, 0x08, 0x00,
|
||||||
|
0x00, 0x00, 0x03, 0x31, 0xE0, 0x00, 0x04, 0x00, 0x80, 0x04, 0x01, 0xFF, 0xC1, 0x00, 0x08, 0x00,
|
||||||
|
0x00, 0x00, 0x07, 0x1E, 0x00, 0x40, 0x00, 0x00, 0x00, 0x04, 0x00, 0x1F, 0xFA, 0x00, 0x08, 0x00,
|
||||||
|
0x00, 0x00, 0x07, 0xF0, 0x00, 0x40, 0x3B, 0x07, 0x60, 0x00, 0x00, 0x01, 0xFF, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x03, 0x80, 0x00, 0x00, 0x34, 0x81, 0x90, 0xCC, 0xC0, 0x00, 0x3F, 0xC0, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x0C, 0x00, 0x03, 0x30, 0x0C, 0x82, 0x90, 0x53, 0x20, 0x00, 0x07, 0xF8, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x70, 0x40, 0x00, 0xC8, 0x3B, 0x02, 0x60, 0x53, 0x20, 0x00, 0x00, 0xFE, 0x00, 0x00,
|
||||||
|
0x00, 0x01, 0x80, 0x20, 0x01, 0xC8, 0x00, 0x00, 0x00, 0x4C, 0xC0, 0x00, 0x00, 0x3F, 0x80, 0x00,
|
||||||
|
0x00, 0x06, 0x00, 0x00, 0x03, 0x30, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x07, 0xE0, 0x00,
|
||||||
|
0x00, 0x08, 0x00, 0x0C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0xFC, 0x00,
|
||||||
|
0x00, 0x30, 0x00, 0x12, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x78, 0x00,
|
||||||
|
0x00, 0x00, 0x40, 0x12, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x10, 0x00,
|
||||||
|
0x00, 0x00, 0xA0, 0x0C, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x44, 0x00, 0x00, 0x00, 0x02, 0x02, 0x30, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x03, 0x06, 0x30, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x10, 0x00, 0x00, 0x00, 0x01, 0x8C, 0x30, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x22, 0x00, 0x00, 0x00, 0x00, 0xD8, 0x30, 0xC0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x05, 0x00, 0x00, 0x00, 0x00, 0x70, 0x19, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
|
||||||
|
0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x20, 0x0F, 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, 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, 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,
|
||||||
|
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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 0x00
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
//ADC Attenuation
|
||||||
|
#define ADC_EXAMPLE_ATTEN ADC_ATTEN_DB_11
|
||||||
|
|
||||||
|
//ADC Calibration
|
||||||
|
#if CONFIG_IDF_TARGET_ESP32
|
||||||
|
#define ADC_EXAMPLE_CALI_SCHEME ESP_ADC_CAL_VAL_EFUSE_VREF
|
||||||
|
#elif CONFIG_IDF_TARGET_ESP32S2
|
||||||
|
#define ADC_EXAMPLE_CALI_SCHEME ESP_ADC_CAL_VAL_EFUSE_TP
|
||||||
|
#elif CONFIG_IDF_TARGET_ESP32C3
|
||||||
|
#define ADC_EXAMPLE_CALI_SCHEME ESP_ADC_CAL_VAL_EFUSE_TP
|
||||||
|
#elif CONFIG_IDF_TARGET_ESP32S3
|
||||||
|
#define ADC_EXAMPLE_CALI_SCHEME ESP_ADC_CAL_VAL_EFUSE_TP_FIT
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static esp_adc_cal_characteristics_t adc1_chars;
|
||||||
|
static esp_adc_cal_characteristics_t adc2_chars;
|
||||||
|
|
||||||
|
static bool adc_calibration_init(void)
|
||||||
|
{
|
||||||
|
esp_err_t ret;
|
||||||
|
bool cali_enable = false;
|
||||||
|
|
||||||
|
ret = esp_adc_cal_check_efuse(ADC_EXAMPLE_CALI_SCHEME);
|
||||||
|
if (ret == ESP_ERR_NOT_SUPPORTED) {
|
||||||
|
ESP_LOGW(TAG, "Calibration scheme not supported, skip software calibration");
|
||||||
|
} else if (ret == ESP_ERR_INVALID_VERSION) {
|
||||||
|
ESP_LOGW(TAG, "eFuse not burnt, skip software calibration");
|
||||||
|
} else if (ret == ESP_OK) {
|
||||||
|
cali_enable = true;
|
||||||
|
esp_adc_cal_characterize(ADC_UNIT_1, ADC_EXAMPLE_ATTEN, ADC_WIDTH_BIT_DEFAULT, 0, &adc1_chars);
|
||||||
|
esp_adc_cal_characterize(ADC_UNIT_2, ADC_EXAMPLE_ATTEN, ADC_WIDTH_BIT_DEFAULT, 0, &adc2_chars);
|
||||||
|
} else {
|
||||||
|
ESP_LOGE(TAG, "Invalid arg");
|
||||||
|
}
|
||||||
|
|
||||||
|
return cali_enable;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void app_main(void)
|
||||||
|
{
|
||||||
|
adc_calibration_init();
|
||||||
|
// ADC1 config
|
||||||
|
//ESP_ERROR_CHECK(adc1_config_width(ADC_WIDTH_BIT_DEFAULT));
|
||||||
|
//ESP_ERROR_CHECK(adc1_config_width(ADC_WIDTH_BIT_10));
|
||||||
|
ESP_ERROR_CHECK(adc1_config_width(ADC_WIDTH_BIT_12));
|
||||||
|
ESP_ERROR_CHECK(adc1_config_channel_atten(ADC1_CHANNEL_0, ADC_EXAMPLE_ATTEN));
|
||||||
|
|
||||||
|
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_LOGE(TAG, "Panel is 128x32. This demo cannot be run.");
|
||||||
|
while(1) { vTaskDelay(1); }
|
||||||
|
#endif // CONFIG_SSD1306_128x32
|
||||||
|
|
||||||
|
ssd1306_contrast(&dev, 0xff);
|
||||||
|
ssd1306_clear_screen(&dev, false);
|
||||||
|
|
||||||
|
// This function internally converts vertical and horizontal.
|
||||||
|
// 128x64 --> 64x128
|
||||||
|
// And save it to internal buffer.
|
||||||
|
// The internal buffer is upside down vertically and horizontally.
|
||||||
|
// I use this function as converter.
|
||||||
|
ssd1306_bitmaps(&dev, 0, 0, VUMeter1, 128, 64, false);
|
||||||
|
|
||||||
|
// Allocate memory
|
||||||
|
uint8_t *buffer = (uint8_t *)malloc(1024);
|
||||||
|
if (buffer == NULL) {
|
||||||
|
ESP_LOGE(TAG, "malloc failed");
|
||||||
|
while(1) { vTaskDelay(1); }
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get from internal buffer to local buffer
|
||||||
|
ssd1306_get_buffer(&dev, buffer);
|
||||||
|
|
||||||
|
int hMeter = 65; // horizontal center for needle animation
|
||||||
|
//int vMeter = 85; // vertical center for needle animation (outside of dislay limits)
|
||||||
|
int vMeter = 63; // vertical center for needle animation (outside of dislay limits)
|
||||||
|
int rMeter = 50; // length of needle animation or arch of needle travel
|
||||||
|
|
||||||
|
while(1) {
|
||||||
|
//ssd1306_clear_screen(&dev, false);
|
||||||
|
int sample = adc1_get_raw(ADC1_CHANNEL_0); // 12 bits sampling
|
||||||
|
sample = sample / 4; // 12 bits -> 10 bits. Because the original code is for ATMEGA328.
|
||||||
|
ESP_LOGD(TAG, "sample=%d", sample);
|
||||||
|
float MeterValue = sample * 120.079 / 1023;
|
||||||
|
MeterValue = MeterValue - 60.039;
|
||||||
|
int a1 = (hMeter + (sin(MeterValue / 502.64 * 6.283) * rMeter));
|
||||||
|
int a2 = (vMeter - (cos(MeterValue / 502.64 * 6.283) * rMeter));
|
||||||
|
|
||||||
|
// Set background image
|
||||||
|
ssd1306_set_buffer(&dev, buffer);
|
||||||
|
|
||||||
|
// Set needle
|
||||||
|
_ssd1306_line(&dev, a1, a2, hMeter, vMeter, false);
|
||||||
|
|
||||||
|
// Display the entire image
|
||||||
|
ssd1306_show_buffer(&dev);
|
||||||
|
vTaskDelay(100 / portTICK_PERIOD_MS);
|
||||||
|
|
||||||
|
// Erase needle
|
||||||
|
_ssd1306_line(&dev, a1, a2, hMeter, vMeter, true);
|
||||||
|
}
|
||||||
|
}
|
@ -58,6 +58,24 @@ void ssd1306_show_buffer(SSD1306_t * dev)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ssd1306_set_buffer(SSD1306_t * dev, uint8_t * buffer)
|
||||||
|
{
|
||||||
|
int index = 0;
|
||||||
|
for (int page=0; page<dev->_pages;page++) {
|
||||||
|
memcpy(&dev->_page[page]._segs, &buffer[index], 128);
|
||||||
|
index = index + 128;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void ssd1306_get_buffer(SSD1306_t * dev, uint8_t * buffer)
|
||||||
|
{
|
||||||
|
int index = 0;
|
||||||
|
for (int page=0; page<dev->_pages;page++) {
|
||||||
|
memcpy(&buffer[index], &dev->_page[page]._segs, 128);
|
||||||
|
index = index + 128;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void ssd1306_display_image(SSD1306_t * dev, int page, int seg, uint8_t * images, int width)
|
void ssd1306_display_image(SSD1306_t * dev, int page, int seg, uint8_t * images, int width)
|
||||||
{
|
{
|
||||||
if (dev->_address == SPIAddress) {
|
if (dev->_address == SPIAddress) {
|
||||||
@ -111,12 +129,12 @@ ssd1306_display_text_x3(SSD1306_t * dev, int page, char * text, int text_len, bo
|
|||||||
out_column_t out_columns[8];
|
out_column_t out_columns[8];
|
||||||
memset(out_columns, 0, sizeof(out_columns));
|
memset(out_columns, 0, sizeof(out_columns));
|
||||||
|
|
||||||
for (uint8_t xx = 0; xx < 8; xx++) { // for each column (x-direction)
|
for (uint8_t xx = 0; xx < 8; xx++) { // for each column (x-direction)
|
||||||
|
|
||||||
uint32_t in_bitmask = 0b1;
|
uint32_t in_bitmask = 0b1;
|
||||||
uint32_t out_bitmask = 0b111;
|
uint32_t out_bitmask = 0b111;
|
||||||
|
|
||||||
for (uint8_t yy = 0; yy < 8; yy++) { // for pixel (y-direction)
|
for (uint8_t yy = 0; yy < 8; yy++) { // for pixel (y-direction)
|
||||||
if (in_columns[xx] & in_bitmask) {
|
if (in_columns[xx] & in_bitmask) {
|
||||||
out_columns[xx].u32 |= out_bitmask;
|
out_columns[xx].u32 |= out_bitmask;
|
||||||
}
|
}
|
||||||
@ -126,10 +144,10 @@ ssd1306_display_text_x3(SSD1306_t * dev, int page, char * text, int text_len, bo
|
|||||||
}
|
}
|
||||||
|
|
||||||
// render character in 8 column high pieces, making them 3x as wide
|
// render character in 8 column high pieces, making them 3x as wide
|
||||||
for (uint8_t yy = 0; yy < 3; yy++) { // for each group of 8 pixels high (y-direction)
|
for (uint8_t yy = 0; yy < 3; yy++) { // for each group of 8 pixels high (y-direction)
|
||||||
|
|
||||||
uint8_t image[24];
|
uint8_t image[24];
|
||||||
for (uint8_t xx = 0; xx < 8; xx++) { // for each column (x-direction)
|
for (uint8_t xx = 0; xx < 8; xx++) { // for each column (x-direction)
|
||||||
image[xx*3+0] =
|
image[xx*3+0] =
|
||||||
image[xx*3+1] =
|
image[xx*3+1] =
|
||||||
image[xx*3+2] = out_columns[xx].u8[yy];
|
image[xx*3+2] = out_columns[xx].u8[yy];
|
||||||
@ -388,7 +406,7 @@ void ssd1306_bitmaps(SSD1306_t * dev, int xpos, int ypos, uint8_t * bitmap, int
|
|||||||
uint8_t page = (ypos / 8);
|
uint8_t page = (ypos / 8);
|
||||||
uint8_t _seg = xpos;
|
uint8_t _seg = xpos;
|
||||||
uint8_t dstBits = (ypos % 8);
|
uint8_t dstBits = (ypos % 8);
|
||||||
ESP_LOGI(TAG, "ypos=%d page=%d dstBits=%d", ypos, page, dstBits);
|
ESP_LOGD(TAG, "ypos=%d page=%d dstBits=%d", ypos, page, dstBits);
|
||||||
int offset = 0;
|
int offset = 0;
|
||||||
for(int _height=0;_height<height;_height++) {
|
for(int _height=0;_height<height;_height++) {
|
||||||
for (int index=0;index<_width;index++) {
|
for (int index=0;index<_width;index++) {
|
||||||
@ -426,6 +444,69 @@ void ssd1306_bitmaps(SSD1306_t * dev, int xpos, int ypos, uint8_t * bitmap, int
|
|||||||
ssd1306_show_buffer(dev);
|
ssd1306_show_buffer(dev);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Set pixel to internal buffer. Not show it.
|
||||||
|
void _ssd1306_pixel(SSD1306_t * dev, int xpos, int ypos, bool invert)
|
||||||
|
{
|
||||||
|
uint8_t _page = (ypos / 8);
|
||||||
|
uint8_t _bits = (ypos % 8);
|
||||||
|
uint8_t _seg = xpos;
|
||||||
|
uint8_t wk0 = dev->_page[_page]._segs[_seg];
|
||||||
|
uint8_t wk1 = 1<< _bits;
|
||||||
|
ESP_LOGD(TAG, "ypos=%d _page=%d _bits=%d wk0=0x%02x wk1=0x%02x", ypos, _page, _bits, wk0, wk1);
|
||||||
|
if (invert) {
|
||||||
|
wk0 = wk0 & ~wk1;
|
||||||
|
} else {
|
||||||
|
wk0 = wk0 | wk1;
|
||||||
|
}
|
||||||
|
ESP_LOGD(TAG, "wk0=0x%02x wk1=0x%02x", wk0, wk1);
|
||||||
|
dev->_page[_page]._segs[_seg] = wk0;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set line to internal buffer. Not show it.
|
||||||
|
void _ssd1306_line(SSD1306_t * dev, int x1, int y1, int x2, int y2, bool invert)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
int dx,dy;
|
||||||
|
int sx,sy;
|
||||||
|
int E;
|
||||||
|
|
||||||
|
/* distance between two points */
|
||||||
|
dx = ( x2 > x1 ) ? x2 - x1 : x1 - x2;
|
||||||
|
dy = ( y2 > y1 ) ? y2 - y1 : y1 - y2;
|
||||||
|
|
||||||
|
/* direction of two point */
|
||||||
|
sx = ( x2 > x1 ) ? 1 : -1;
|
||||||
|
sy = ( y2 > y1 ) ? 1 : -1;
|
||||||
|
|
||||||
|
/* inclination < 1 */
|
||||||
|
if ( dx > dy ) {
|
||||||
|
E = -dx;
|
||||||
|
for ( i = 0 ; i <= dx ; i++ ) {
|
||||||
|
_ssd1306_pixel(dev, x1, y1, invert);
|
||||||
|
x1 += sx;
|
||||||
|
E += 2 * dy;
|
||||||
|
if ( E >= 0 ) {
|
||||||
|
y1 += sy;
|
||||||
|
E -= 2 * dx;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/* inclination >= 1 */
|
||||||
|
} else {
|
||||||
|
E = -dy;
|
||||||
|
for ( i = 0 ; i <= dy ; i++ ) {
|
||||||
|
_ssd1306_pixel(dev, x1, y1, invert);
|
||||||
|
y1 += sy;
|
||||||
|
E += 2 * dx;
|
||||||
|
if ( E >= 0 ) {
|
||||||
|
x1 += sx;
|
||||||
|
E -= 2 * dy;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void ssd1306_invert(uint8_t *buf, size_t blen)
|
void ssd1306_invert(uint8_t *buf, size_t blen)
|
||||||
{
|
{
|
||||||
uint8_t wk;
|
uint8_t wk;
|
||||||
|
@ -105,6 +105,8 @@ int ssd1306_get_width(SSD1306_t * dev);
|
|||||||
int ssd1306_get_height(SSD1306_t * dev);
|
int ssd1306_get_height(SSD1306_t * dev);
|
||||||
int ssd1306_get_pages(SSD1306_t * dev);
|
int ssd1306_get_pages(SSD1306_t * dev);
|
||||||
void ssd1306_show_buffer(SSD1306_t * dev);
|
void ssd1306_show_buffer(SSD1306_t * dev);
|
||||||
|
void ssd1306_set_buffer(SSD1306_t * dev, uint8_t * buffer);
|
||||||
|
void ssd1306_get_buffer(SSD1306_t * dev, uint8_t * buffer);
|
||||||
void ssd1306_display_image(SSD1306_t * dev, int page, int seg, uint8_t * images, int width);
|
void ssd1306_display_image(SSD1306_t * dev, int page, int seg, uint8_t * images, int width);
|
||||||
void ssd1306_display_text(SSD1306_t * dev, int page, char * text, int text_len, bool invert);
|
void ssd1306_display_text(SSD1306_t * dev, int page, char * text, int text_len, bool invert);
|
||||||
void ssd1306_display_text_x3(SSD1306_t * dev, int page, char * text, int text_len, bool invert);
|
void ssd1306_display_text_x3(SSD1306_t * dev, int page, char * text, int text_len, bool invert);
|
||||||
@ -117,6 +119,8 @@ void ssd1306_scroll_clear(SSD1306_t * dev);
|
|||||||
void ssd1306_hardware_scroll(SSD1306_t * dev, ssd1306_scroll_type_t scroll);
|
void ssd1306_hardware_scroll(SSD1306_t * dev, ssd1306_scroll_type_t scroll);
|
||||||
void ssd1306_wrap_arround(SSD1306_t * dev, ssd1306_scroll_type_t scroll, int start, int end, uint8_t delay);
|
void ssd1306_wrap_arround(SSD1306_t * dev, ssd1306_scroll_type_t scroll, int start, int end, uint8_t delay);
|
||||||
void ssd1306_bitmaps(SSD1306_t * dev, int xpos, int ypos, uint8_t * bitmap, int width, int height, bool invert);
|
void ssd1306_bitmaps(SSD1306_t * dev, int xpos, int ypos, uint8_t * bitmap, int width, int height, bool invert);
|
||||||
|
void _ssd1306_pixel(SSD1306_t * dev, int xpos, int ypos, bool invert);
|
||||||
|
void _ssd1306_line(SSD1306_t * dev, int x1, int y1, int x2, int y2, bool invert);
|
||||||
void ssd1306_invert(uint8_t *buf, size_t blen);
|
void ssd1306_invert(uint8_t *buf, size_t blen);
|
||||||
void ssd1306_flip(uint8_t *buf, size_t blen);
|
void ssd1306_flip(uint8_t *buf, size_t blen);
|
||||||
uint8_t ssd1306_copy_bit(uint8_t src, int srcBits, uint8_t dst, int dstBits);
|
uint8_t ssd1306_copy_bit(uint8_t src, int srcBits, uint8_t dst, int dstBits);
|
||||||
|
Loading…
Reference in New Issue
Block a user