mirror of
https://github.com/esphome/esphome.git
synced 2025-01-23 04:45:58 +01:00
[max6921] fix code codebase standards issues
This commit is contained in:
parent
429beca84a
commit
d429c3d694
3 changed files with 34 additions and 39 deletions
|
@ -130,7 +130,7 @@ void Display::setup(std::vector<uint8_t> &seg_to_out_map, std::vector<uint8_t> &
|
||||||
ESP_LOGCONFIG(TAG, "Display digits: %u", this->num_digits_);
|
ESP_LOGCONFIG(TAG, "Display digits: %u", this->num_digits_);
|
||||||
|
|
||||||
// setup font...
|
// setup font...
|
||||||
init_font_();
|
this->init_font_();
|
||||||
|
|
||||||
// display output buffer...
|
// display output buffer...
|
||||||
this->out_buf_size_ = this->num_digits_ * 3;
|
this->out_buf_size_ = this->num_digits_ * 3;
|
||||||
|
@ -317,17 +317,17 @@ void Display::update() {
|
||||||
if ((this->mode != DISP_MODE_PRINT) && (this->disp_text_.effect != TEXT_EFFECT_NONE)) { // any effect enabled?
|
if ((this->mode != DISP_MODE_PRINT) && (this->disp_text_.effect != TEXT_EFFECT_NONE)) { // any effect enabled?
|
||||||
switch (this->disp_text_.effect) {
|
switch (this->disp_text_.effect) {
|
||||||
case TEXT_EFFECT_BLINK:
|
case TEXT_EFFECT_BLINK:
|
||||||
update_out_buf_();
|
this->update_out_buf_();
|
||||||
if (this->disp_text_.blink())
|
if (this->disp_text_.blink())
|
||||||
set_mode(DISP_MODE_PRINT);
|
this->set_mode(DISP_MODE_PRINT);
|
||||||
break;
|
break;
|
||||||
case TEXT_EFFECT_SCROLL_LEFT:
|
case TEXT_EFFECT_SCROLL_LEFT:
|
||||||
update_out_buf_();
|
this->update_out_buf_();
|
||||||
if (this->disp_text_.scroll_left())
|
if (this->disp_text_.scroll_left())
|
||||||
set_mode(DISP_MODE_PRINT);
|
this->set_mode(DISP_MODE_PRINT);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
set_mode(DISP_MODE_PRINT);
|
this->set_mode(DISP_MODE_PRINT);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -336,7 +336,7 @@ void Display::update() {
|
||||||
if ((this->mode != DISP_MODE_PRINT) && (this->disp_text_.duration_ms > 0)) {
|
if ((this->mode != DISP_MODE_PRINT) && (this->disp_text_.duration_ms > 0)) {
|
||||||
if ((millis() - this->disp_text_.get_duration_start()) >= this->disp_text_.duration_ms) {
|
if ((millis() - this->disp_text_.get_duration_start()) >= this->disp_text_.duration_ms) {
|
||||||
ESP_LOGD(TAG, "Effect duration of %" PRIu32 "ms expired", this->disp_text_.duration_ms);
|
ESP_LOGD(TAG, "Effect duration of %" PRIu32 "ms expired", this->disp_text_.duration_ms);
|
||||||
set_mode(DISP_MODE_PRINT);
|
this->set_mode(DISP_MODE_PRINT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -346,7 +346,7 @@ void Display::update() {
|
||||||
if (disp_text_other.repeat_on) {
|
if (disp_text_other.repeat_on) {
|
||||||
if ((millis() - disp_text_other.get_repeat_start()) >= disp_text_other.repeat_interval_ms) {
|
if ((millis() - disp_text_other.get_repeat_start()) >= disp_text_other.repeat_interval_ms) {
|
||||||
ESP_LOGD(TAG, "Repeat interval of %" PRIu32 "ms expired", disp_text_other.repeat_interval_ms);
|
ESP_LOGD(TAG, "Repeat interval of %" PRIu32 "ms expired", disp_text_other.repeat_interval_ms);
|
||||||
set_mode(DISP_MODE_OTHER);
|
this->set_mode(DISP_MODE_OTHER);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -375,10 +375,10 @@ void Display::set_demo_mode(DemoModeT mode, uint32_t interval, uint8_t cycle_num
|
||||||
disp_text.set_text_effect(TEXT_EFFECT_SCROLL_LEFT, cycle_num, interval);
|
disp_text.set_text_effect(TEXT_EFFECT_SCROLL_LEFT, cycle_num, interval);
|
||||||
disp_text.set_duration(0);
|
disp_text.set_duration(0);
|
||||||
disp_text.set_repeats(0, 0);
|
disp_text.set_repeats(0, 0);
|
||||||
set_mode(DISP_MODE_OTHER);
|
this->set_mode(DISP_MODE_OTHER);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
set_mode(DISP_MODE_PRINT);
|
this->set_mode(DISP_MODE_PRINT);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -405,8 +405,8 @@ DisplayModeT Display::set_mode(DisplayModeT mode) {
|
||||||
|
|
||||||
switch (this->mode) {
|
switch (this->mode) {
|
||||||
case DISP_MODE_PRINT: {
|
case DISP_MODE_PRINT: {
|
||||||
clear(); // clear display buffer
|
this->clear(); // clear display buffer
|
||||||
restore_update_interval();
|
this->restore_update_interval();
|
||||||
// handle repeats of "other" mode...
|
// handle repeats of "other" mode...
|
||||||
DisplayText &disp_text_other = this->disp_text_ctrl_[DISP_MODE_OTHER];
|
DisplayText &disp_text_other = this->disp_text_ctrl_[DISP_MODE_OTHER];
|
||||||
if (disp_text_other.repeat_on) {
|
if (disp_text_other.repeat_on) {
|
||||||
|
@ -427,11 +427,11 @@ DisplayModeT Display::set_mode(DisplayModeT mode) {
|
||||||
}
|
}
|
||||||
|
|
||||||
case DISP_MODE_OTHER: {
|
case DISP_MODE_OTHER: {
|
||||||
clear(); // clear display buffer
|
this->clear(); // clear display buffer
|
||||||
if (this->disp_text_.effect == TEXT_EFFECT_NONE) {
|
if (this->disp_text_.effect == TEXT_EFFECT_NONE) {
|
||||||
update_out_buf_(); // show static text again
|
this->update_out_buf_(); // show static text again
|
||||||
} else {
|
} else {
|
||||||
set_update_interval(this->disp_text_.update_interval_ms);
|
this->set_update_interval(this->disp_text_.update_interval_ms);
|
||||||
}
|
}
|
||||||
this->disp_text_.start_duration();
|
this->disp_text_.start_duration();
|
||||||
break;
|
break;
|
||||||
|
@ -499,7 +499,7 @@ int Display::set_text(const std::string &text, uint8_t start_pos, const std::str
|
||||||
disp_text.set_repeats(repeat_num, repeat_interval);
|
disp_text.set_repeats(repeat_num, repeat_interval);
|
||||||
|
|
||||||
// update display mode...
|
// update display mode...
|
||||||
set_mode(DISP_MODE_OTHER);
|
this->set_mode(DISP_MODE_OTHER);
|
||||||
|
|
||||||
ESP_LOGV(TAG,
|
ESP_LOGV(TAG,
|
||||||
"Set text (result): text=%s, start-pos=%u, vi-idx=%u, vi-len=%u, "
|
"Set text (result): text=%s, start-pos=%u, vi-idx=%u, vi-len=%u, "
|
||||||
|
@ -507,7 +507,7 @@ int Display::set_text(const std::string &text, uint8_t start_pos, const std::str
|
||||||
disp_text.text, disp_text.start_pos, disp_text.visible_idx, disp_text.visible_len, disp_text.duration_ms,
|
disp_text.text, disp_text.start_pos, disp_text.visible_idx, disp_text.visible_len, disp_text.duration_ms,
|
||||||
disp_text.repeat_on, disp_text.repeat_num, disp_text.repeat_interval_ms);
|
disp_text.repeat_on, disp_text.repeat_num, disp_text.repeat_interval_ms);
|
||||||
|
|
||||||
return update_out_buf_();
|
return this->update_out_buf_();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -530,7 +530,7 @@ int Display::set_text(const char *text, uint8_t start_pos) {
|
||||||
std::string text_str = text;
|
std::string text_str = text;
|
||||||
disp_text.set_text(start_pos, this->num_digits_ - 1, text_str);
|
disp_text.set_text(start_pos, this->num_digits_ - 1, text_str);
|
||||||
|
|
||||||
return update_out_buf_();
|
return this->update_out_buf_();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -561,12 +561,12 @@ int Display::update_out_buf_() {
|
||||||
|
|
||||||
// special handling for point segment...
|
// special handling for point segment...
|
||||||
is_process_next_char = false;
|
is_process_next_char = false;
|
||||||
if (is_point_seg_only(pos_char)) { // is point segment only?
|
if (this->is_point_seg_only(pos_char)) { // is point segment only?
|
||||||
if (this->disp_text_.visible_idx + visible_idx_offset - 1 > 0) { // not the 1st text character?
|
if (this->disp_text_.visible_idx + visible_idx_offset - 1 > 0) { // not the 1st text character?
|
||||||
if (!is_point_seg_only(this->disp_text_.text[this->disp_text_.visible_idx + visible_idx_offset -
|
if (!this->is_point_seg_only(this->disp_text_.text[this->disp_text_.visible_idx + visible_idx_offset -
|
||||||
2])) { // previous text character wasn't a point?
|
2])) { // previous text character wasn't a point?
|
||||||
if (pos == 0) { // 1st (most left) display position?
|
if (pos == 0) { // 1st (most left) display position?
|
||||||
is_process_next_char = true; // yes -> ignore point, process next character
|
is_process_next_char = true; // yes -> ignore point, process next character
|
||||||
ignored_char_at_1st_pos = true;
|
ignored_char_at_1st_pos = true;
|
||||||
} else {
|
} else {
|
||||||
--pos; // no -> add point to previous display position
|
--pos; // no -> add point to previous display position
|
||||||
|
@ -578,7 +578,7 @@ int Display::update_out_buf_() {
|
||||||
}
|
}
|
||||||
} while (is_process_next_char);
|
} while (is_process_next_char);
|
||||||
if (is_clear_pos)
|
if (is_clear_pos)
|
||||||
clear(pos);
|
this->clear(pos);
|
||||||
|
|
||||||
// create segment data...
|
// create segment data...
|
||||||
if ((pos_char >= ' ') && ((pos_char - ' ') < ARRAY_ELEM_COUNT(ASCII_TO_SEG))) { // supported char?
|
if ((pos_char >= ' ') && ((pos_char - ' ') < ARRAY_ELEM_COUNT(ASCII_TO_SEG))) { // supported char?
|
||||||
|
@ -773,7 +773,7 @@ void DisplayText::set_text_align(TextAlignT align) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
this->align = align;
|
this->align = align;
|
||||||
init_text_align_();
|
this->init_text_align_();
|
||||||
ESP_LOGD(TAG, "Set text align: align=%i, start-pos=%u, max-pos=%u, vi-idx=%u, vi-len=%u", this->align,
|
ESP_LOGD(TAG, "Set text align: align=%i, start-pos=%u, max-pos=%u, vi-idx=%u, vi-len=%u", this->align,
|
||||||
this->start_pos, this->max_pos, this->visible_idx, this->visible_len);
|
this->start_pos, this->max_pos, this->visible_idx, this->visible_len);
|
||||||
}
|
}
|
||||||
|
@ -800,7 +800,7 @@ void DisplayText::set_text_align(const std::string &align) {
|
||||||
ESP_LOGW(TAG, "No text align given");
|
ESP_LOGW(TAG, "No text align given");
|
||||||
if (text_align >= TEXT_ALIGN_LAST_ENUM)
|
if (text_align >= TEXT_ALIGN_LAST_ENUM)
|
||||||
return;
|
return;
|
||||||
set_text_align(text_align);
|
this->set_text_align(text_align);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -827,7 +827,7 @@ void DisplayText::set_text_effect(TextEffectT effect, uint8_t cycle_num, uint32_
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
init_text_effect_();
|
this->init_text_effect_();
|
||||||
ESP_LOGD(TAG,
|
ESP_LOGD(TAG,
|
||||||
"Set text effect: effect=%i, cycles=%u, upd-interval=%" PRIu32 "ms, start-pos=%u, "
|
"Set text effect: effect=%i, cycles=%u, upd-interval=%" PRIu32 "ms, start-pos=%u, "
|
||||||
"max-pos=%u, vi-idx=%u, vi-len=%u",
|
"max-pos=%u, vi-idx=%u, vi-len=%u",
|
||||||
|
@ -859,7 +859,7 @@ void DisplayText::set_text_effect(const std::string &effect, uint8_t cycle_num,
|
||||||
ESP_LOGW(TAG, "No text effect given");
|
ESP_LOGW(TAG, "No text effect given");
|
||||||
if (text_effect >= TEXT_EFFECT_LAST_ENUM)
|
if (text_effect >= TEXT_EFFECT_LAST_ENUM)
|
||||||
return;
|
return;
|
||||||
set_text_effect(text_effect, cycle_num, update_interval);
|
this->set_text_effect(text_effect, cycle_num, update_interval);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -884,7 +884,7 @@ bool DisplayText::blink() {
|
||||||
ESP_LOGV(TAG, "\"Off\" phase of blink cycle started (%u cycles left)", this->cycle_num - this->cycle_current);
|
ESP_LOGV(TAG, "\"Off\" phase of blink cycle started (%u cycles left)", this->cycle_num - this->cycle_current);
|
||||||
if ((this->cycle_num == 0) || // endless cycles or
|
if ((this->cycle_num == 0) || // endless cycles or
|
||||||
(this->cycle_current < this->cycle_num)) { // number of cycles not finished?
|
(this->cycle_current < this->cycle_num)) { // number of cycles not finished?
|
||||||
init_text_effect_(); // next display buffer update starts "on" phase
|
this->init_text_effect_(); // next display buffer update starts "on" phase
|
||||||
}
|
}
|
||||||
if (this->cycle_num > 0) // defined number of cycles?
|
if (this->cycle_num > 0) // defined number of cycles?
|
||||||
++this->cycle_current; // yes -> increase current cycle count
|
++this->cycle_current; // yes -> increase current cycle count
|
||||||
|
@ -908,7 +908,7 @@ bool DisplayText::scroll_left() {
|
||||||
|
|
||||||
// update effect mode...
|
// update effect mode...
|
||||||
if (this->visible_len == 0) { // cycle finished?
|
if (this->visible_len == 0) { // cycle finished?
|
||||||
init_text_effect_();
|
this->init_text_effect_();
|
||||||
if (this->cycle_current <= this->cycle_num) {
|
if (this->cycle_current <= this->cycle_num) {
|
||||||
ESP_LOGV(TAG, "Scroll cycle finished (%u left)", this->cycle_num - this->cycle_current);
|
ESP_LOGV(TAG, "Scroll cycle finished (%u left)", this->cycle_num - this->cycle_current);
|
||||||
if (this->cycle_current++ >= this->cycle_num) {
|
if (this->cycle_current++ >= this->cycle_num) {
|
||||||
|
|
|
@ -131,10 +131,8 @@ class Display : public DisplayBrightness, public DisplayMode {
|
||||||
DisplayText &disp_text_ = disp_text_ctrl_[0];
|
DisplayText &disp_text_ = disp_text_ctrl_[0];
|
||||||
uint32_t default_update_interval_;
|
uint32_t default_update_interval_;
|
||||||
static void display_refresh_task(void *pv);
|
static void display_refresh_task(void *pv);
|
||||||
int update_out_buf_();
|
|
||||||
|
|
||||||
private:
|
|
||||||
void init_font_();
|
void init_font_();
|
||||||
|
int update_out_buf_();
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace max6921
|
} // namespace max6921
|
||||||
|
|
|
@ -40,19 +40,16 @@ class MAX6921Component : public PollingComponent,
|
||||||
void update() override;
|
void update() override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
GPIOPin *load_pin_{};
|
|
||||||
InternalGPIOPin *blank_pin_{};
|
InternalGPIOPin *blank_pin_{};
|
||||||
|
GPIOPin *load_pin_{};
|
||||||
|
std::vector<uint8_t> pos_to_out_map_; // mapping of display positions to MAX6921 OUT pins
|
||||||
|
std::vector<uint8_t> seg_to_out_map_; // mapping of display segments to MAX6921 OUT pins
|
||||||
bool setup_finished_{false};
|
bool setup_finished_{false};
|
||||||
void disable_blank_() { this->blank_pin_->digital_write(false); } // display on
|
void disable_blank_() { this->blank_pin_->digital_write(false); } // display on
|
||||||
void IRAM_ATTR HOT disable_load_() { this->load_pin_->digital_write(false); }
|
void IRAM_ATTR HOT disable_load_() { this->load_pin_->digital_write(false); }
|
||||||
void enable_blank_() { this->blank_pin_->digital_write(true); } // display off
|
void enable_blank_() { this->blank_pin_->digital_write(true); } // display off
|
||||||
void IRAM_ATTR HOT enable_load_() { this->load_pin_->digital_write(true); }
|
void IRAM_ATTR HOT enable_load_() { this->load_pin_->digital_write(true); }
|
||||||
void update_demo_mode_scroll_font_();
|
|
||||||
optional<max6921_writer_t> writer_{};
|
optional<max6921_writer_t> writer_{};
|
||||||
|
|
||||||
private:
|
|
||||||
std::vector<uint8_t> seg_to_out_map_; // mapping of display segments to MAX6921 OUT pins
|
|
||||||
std::vector<uint8_t> pos_to_out_map_; // mapping of display positions to MAX6921 OUT pins
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace max6921
|
} // namespace max6921
|
||||||
|
|
Loading…
Reference in a new issue