From 948e0395743c8bfc3264ef2415d093a10b9a377a Mon Sep 17 00:00:00 2001 From: notComposer Date: Sun, 18 Feb 2024 00:44:31 +0800 Subject: [PATCH] fix shift back in screenshot and mayhem hub (#1910) * fix_shift_back * clean up * gitignore * remove the workaround in notpad cuz it's been fixed in this PR * format * add credit for mark * 2024 --- .gitignore | 4 ++- firmware/application/apps/ui_text_editor.cpp | 4 --- firmware/common/portapack_io.hpp | 32 +++++++++++++++----- 3 files changed, 27 insertions(+), 13 deletions(-) diff --git a/.gitignore b/.gitignore index cc292cb3..a40570ca 100644 --- a/.gitignore +++ b/.gitignore @@ -68,9 +68,11 @@ CMakeFiles/ .DS_Store /firmware/CMakeCache.txt -# Python env/ venv +# Python env/ venv and cache env/ venv/ +**/__pycache__/ +*.pyc # Other *.bak diff --git a/firmware/application/apps/ui_text_editor.cpp b/firmware/application/apps/ui_text_editor.cpp index a1584853..fdf4a0de 100644 --- a/firmware/application/apps/ui_text_editor.cpp +++ b/firmware/application/apps/ui_text_editor.cpp @@ -27,8 +27,6 @@ #include "log_file.hpp" #include "string_format.hpp" -#include "portapack_persistent_memory.hpp" - using namespace portapack; namespace fs = std::filesystem; @@ -556,8 +554,6 @@ void TextEditorView::open_file(const fs::path& path) { viewer.set_file(*file_); } - portapack::persistent_memory::set_apply_fake_brightness(false); // work around to resolve the display issue in notepad app. not elegant i know, so TODO. - refresh_ui(); } diff --git a/firmware/common/portapack_io.hpp b/firmware/common/portapack_io.hpp index 8fa45d8b..a23627a2 100644 --- a/firmware/common/portapack_io.hpp +++ b/firmware/common/portapack_io.hpp @@ -2,6 +2,7 @@ * Copyright (C) 2014 Jared Boone, ShareBrained Technology, Inc. * Copyleft (ɔ) 2024 zxkmm under GPL license * Copyright (C) 2024 u-foka + * Copyright (C) 2024 Mark Thompson * * This file is part of PortaPack. * @@ -147,7 +148,7 @@ class IO { void lcd_write_pixel(ui::Color pixel) { if (get_dark_cover()) { - darken_color(pixel, get_brightness()); // Darken the pixel color + shift_color(pixel, get_brightness(), false); // Darken the pixel color } lcd_write_data(pixel.v); } @@ -158,7 +159,7 @@ class IO { void lcd_write_pixels(ui::Color pixel, size_t n) { if (get_dark_cover()) { - darken_color(pixel, get_brightness()); // Darken the pixel color + shift_color(pixel, get_brightness(), false); // Darken the pixel color } while (n--) { lcd_write_data(pixel.v); @@ -167,7 +168,7 @@ class IO { void lcd_write_pixels_unrolled8(ui::Color pixel, size_t n) { if (get_dark_cover()) { - darken_color(pixel, get_brightness()); // Darken the pixel color + shift_color(pixel, get_brightness(), false); // Darken the pixel color } auto v = pixel.v; n >>= 3; @@ -331,7 +332,7 @@ class IO { addr(1); /* Set up for data phase (most likely after a command) */ } - void darken_color(ui::Color& pixel, uint8_t darken_level_shift) { + void shift_color(ui::Color& pixel, uint8_t shift_level, bool shift_left) { // TODO: 1. do we need edge control? // currently didn't see and issue without edge control // but maybe hurts screen hardware without one? @@ -343,9 +344,15 @@ class IO { uint16_t g = (pixel.v >> 5) & 0x3F; // Extract green uint16_t b = pixel.v & 0x1F; // Extract blue - r = r >> darken_level_shift; // Darken red - g = g >> darken_level_shift; // Darken green - b = b >> darken_level_shift; // Darken blue + if (shift_left) { // Shfting + r = r << shift_level; + g = g << shift_level; + b = b << shift_level; + } else if (!shift_left) { + r = r >> shift_level; + g = g >> shift_level; + b = b >> shift_level; + } pixel.v = (r << 11) | (g << 5) | b; // Combine back to color, check UI::color for the color layout } @@ -417,7 +424,16 @@ class IO { halPolledDelay(18); // 90ns const auto value_low = data_read(); - return (value_high << 8) | value_low; + uint32_t original_value = (value_high << 8) | value_low; + + if (get_dark_cover()) { + ui::Color pixel; + pixel.v = original_value; + shift_color(pixel, get_brightness(), true); + original_value = pixel.v; + } + + return original_value; } void io_write(const bool address, const uint_fast16_t value) {