mirror of
https://github.com/Threnklyn/esphome-dev.git
synced 2026-05-22 21:58:29 +02:00
bfb9cb6732
* push final files
* Update max7219digit.cpp
reenter small bug fix on uint8 declaration
* small debug
* set max offset to 100
* remove unwanted file
* Update font file to make travis happy
* travis update
* further progress in keeping Yarvis happy
* travis font
* travis will never be satisfied but one step ahead
* YARVIS TAKE 10000000
* never ending yarvis
* Almost there with Yarvis
* removed double declaration YARVIS
* added namespace to font file (TRAVIS)
* almost there last changes for YARVIS
* further travis updates
* removed files for travis
* fix display.py length of line travis remark
* further update on display.py
* file delete travis requirement
* final entry for travis?
* Some further debug on max offset
* Travis updates
* scroll_left_new
* 90degreesrotate
* added option to config rotate90
* four orientations for the chips
* new setup for scroll
* replaced small bug missing {}
* debug changed int8 to int16 on scroll function
* removed small merge failure
* travis updates round 1
* travis updates round 2
* travis details round 3
* added options to set scroll parameters in yaml conf
* removed ttf and png to satisfy travis
* travis update
* travis updates
* travis
* further updates after input from @glmnet
* remove deleted comments
* Added ENUM TYPE to config file
* change in test file
* removed test files
* updates for pull request
* Typing error removed
* travis update
* PR updates travis
* Update test3.yaml
* Update test3.yaml
* update device schema as per #988
* Delete partitions.csv
* repair on image display and invert routine
* further update and a bit of cleanup
* added writing 0 in draw pixel
* small deletion error
* travis updates
* Update max7219digit.cpp
adding intensity value to dynamically set value
* Update max7219digit.h
adding option for intensity
* remove some files from tests
108 lines
3.6 KiB
C++
108 lines
3.6 KiB
C++
#pragma once
|
|
|
|
#include "esphome/core/component.h"
|
|
#include "esphome/core/defines.h"
|
|
#include "esphome/components/display/display_buffer.h"
|
|
#include "esphome/components/spi/spi.h"
|
|
|
|
#ifdef USE_TIME
|
|
#include "esphome/components/time/real_time_clock.h"
|
|
#endif
|
|
|
|
namespace esphome {
|
|
namespace max7219digit {
|
|
|
|
class MAX7219Component;
|
|
|
|
using max7219_writer_t = std::function<void(MAX7219Component &)>;
|
|
|
|
class MAX7219Component : public PollingComponent,
|
|
public display::DisplayBuffer,
|
|
public spi::SPIDevice<spi::BIT_ORDER_MSB_FIRST, spi::CLOCK_POLARITY_LOW,
|
|
spi::CLOCK_PHASE_LEADING, spi::DATA_RATE_1MHZ> {
|
|
public:
|
|
void set_writer(max7219_writer_t &&writer) { this->writer_local_ = writer; };
|
|
|
|
void setup() override;
|
|
|
|
void loop() override;
|
|
|
|
void dump_config() override;
|
|
|
|
void update() override;
|
|
|
|
float get_setup_priority() const override;
|
|
|
|
void display();
|
|
|
|
void invert_on_off(bool on_off);
|
|
void invert_on_off();
|
|
|
|
void turn_on_off(bool on_off);
|
|
|
|
void draw_absolute_pixel_internal(int x, int y, int color) override;
|
|
int get_height_internal() override;
|
|
int get_width_internal() override;
|
|
|
|
void set_intensity(uint8_t intensity) { this->intensity_ = intensity; };
|
|
void set_num_chips(uint8_t num_chips) { this->num_chips_ = num_chips; };
|
|
void set_chip_orientation(uint8_t rotate) { this->orientation_ = rotate; };
|
|
void set_scroll_speed(uint16_t speed) { this->scroll_speed_ = speed; };
|
|
void set_scroll_dwell(uint16_t dwell) { this->scroll_dwell_ = dwell; };
|
|
void set_scroll_delay(uint16_t delay) { this->scroll_delay_ = delay; };
|
|
void set_scroll(bool on_off) { this->scroll_ = on_off; };
|
|
void set_scroll_mode(uint8_t mode) { this->scroll_mode_ = mode; };
|
|
|
|
void send_char(byte chip, byte data);
|
|
void send64pixels(byte chip, const byte pixels[8]);
|
|
|
|
void scroll_left();
|
|
void scroll(bool on_off, uint8_t mode, uint16_t speed, uint16_t delay, uint16_t dwell);
|
|
void scroll(bool on_off, uint8_t mode);
|
|
void scroll(bool on_off);
|
|
void intensity(uint8_t intensity);
|
|
|
|
/// Evaluate the printf-format and print the result at the given position.
|
|
uint8_t printdigitf(uint8_t pos, const char *format, ...) __attribute__((format(printf, 3, 4)));
|
|
/// Evaluate the printf-format and print the result at position 0.
|
|
uint8_t printdigitf(const char *format, ...) __attribute__((format(printf, 2, 3)));
|
|
|
|
/// Print `str` at the given position.
|
|
uint8_t printdigit(uint8_t pos, const char *str);
|
|
/// Print `str` at position 0.
|
|
uint8_t printdigit(const char *str);
|
|
|
|
#ifdef USE_TIME
|
|
/// Evaluate the strftime-format and print the result at the given position.
|
|
uint8_t strftimedigit(uint8_t pos, const char *format, time::ESPTime time) __attribute__((format(strftime, 3, 0)));
|
|
|
|
/// Evaluate the strftime-format and print the result at position 0.
|
|
uint8_t strftimedigit(const char *format, time::ESPTime time) __attribute__((format(strftime, 2, 0)));
|
|
#endif
|
|
|
|
protected:
|
|
void send_byte_(uint8_t a_register, uint8_t data);
|
|
void send_to_all_(uint8_t a_register, uint8_t data);
|
|
|
|
uint8_t intensity_; /// Intensity of the display from 0 to 15 (most)
|
|
uint8_t num_chips_;
|
|
bool scroll_;
|
|
bool update_{false};
|
|
uint16_t scroll_speed_;
|
|
uint16_t scroll_delay_;
|
|
uint16_t scroll_dwell_;
|
|
uint16_t old_buffer_size_ = 0;
|
|
uint8_t scroll_mode_;
|
|
bool invert_ = false;
|
|
uint8_t orientation_;
|
|
uint8_t bckgrnd_ = 0x0;
|
|
std::vector<uint8_t> max_displaybuffer_;
|
|
unsigned long last_scroll_ = 0;
|
|
uint16_t stepsleft_;
|
|
size_t get_buffer_length_();
|
|
optional<max7219_writer_t> writer_local_{};
|
|
};
|
|
|
|
} // namespace max7219digit
|
|
} // namespace esphome
|