mirror of
https://github.com/meshtastic/firmware.git
synced 2025-04-23 17:13:38 +00:00

* chore: todo.txt
* chore: InkHUD documentation
Word salad for maintainers
* refactor: don't init system applets using onActivate
System applets cannot be deactivated, so we will avoid using onActivate / onDeactivate methods entirely.
* chore: update the example applets
* fix: SSD16XX reset pulse
Allow time for controller IC to wake. Aligns with manufacturer's suggestions.
T-Echo button timing adjusted to prevent bouncing as a result(?) of slightly faster refreshes.
* fix: allow timeout if display update fails
Result is not graceful, but avoids total display lockup requiring power cycle.
Typical cause of failure is poor wiring / power supply.
* fix: improve display health on shutdown
Two extra full refreshes, masquerading as a "shutting down" screen. One is drawn white-on-black, to really shake the pixels up.
* feat: driver for display HINK_E042A87
As of Feb. 2025, these panels are used for "WeActStudio 4.2in B&W" display modules.
* fix: inkhud rotation should default to 0
* Revert "chore: todo.txt"
This reverts commit bea7df44a7
.
* fix: more generous timeout for display updates
Previously this was tied to the expected duration of the update, but this didn't account for any delay if our polling thread got held up by an unrelated firmware task.
* fix: don't use the full shutdown screen during reboot
* fix: cooldown period during the display shutdown display sequence
Observed to prevent border pixels from being locked in place with some residual charge?
109 lines
4.3 KiB
C++
109 lines
4.3 KiB
C++
#pragma once
|
|
|
|
#include "configuration.h"
|
|
|
|
#ifdef MESHTASTIC_INCLUDE_NICHE_GRAPHICS
|
|
|
|
// InkHUD-specific components
|
|
// ---------------------------
|
|
#include "graphics/niche/InkHUD/InkHUD.h"
|
|
|
|
// Applets
|
|
#include "graphics/niche/InkHUD/Applets/User/AllMessage/AllMessageApplet.h"
|
|
#include "graphics/niche/InkHUD/Applets/User/DM/DMApplet.h"
|
|
#include "graphics/niche/InkHUD/Applets/User/Heard/HeardApplet.h"
|
|
#include "graphics/niche/InkHUD/Applets/User/Positions/PositionsApplet.h"
|
|
#include "graphics/niche/InkHUD/Applets/User/RecentsList/RecentsListApplet.h"
|
|
#include "graphics/niche/InkHUD/Applets/User/ThreadedMessage/ThreadedMessageApplet.h"
|
|
|
|
// #include "graphics/niche/InkHUD/Applets/Examples/BasicExample/BasicExampleApplet.h"
|
|
// #include "graphics/niche/InkHUD/Applets/Examples/NewMsgExample/NewMsgExampleApplet.h"
|
|
|
|
// Shared NicheGraphics components
|
|
// --------------------------------
|
|
#include "graphics/niche/Drivers/EInk/LCMEN2R13EFC1.h"
|
|
#include "graphics/niche/Inputs/TwoButton.h"
|
|
|
|
#include "graphics/niche/Fonts/FreeSans6pt7b.h"
|
|
#include "graphics/niche/Fonts/FreeSans6pt8bCyrillic.h"
|
|
#include <Fonts/FreeSans9pt7b.h>
|
|
|
|
void setupNicheGraphics()
|
|
{
|
|
using namespace NicheGraphics;
|
|
|
|
// SPI
|
|
// -----------------------------
|
|
|
|
// Display is connected to HSPI
|
|
SPIClass *hspi = new SPIClass(HSPI);
|
|
hspi->begin(PIN_EINK_SCLK, -1, PIN_EINK_MOSI, PIN_EINK_CS);
|
|
|
|
// E-Ink Driver
|
|
// -----------------------------
|
|
|
|
// Use E-Ink driver
|
|
Drivers::EInk *driver = new Drivers::LCMEN213EFC1;
|
|
driver->begin(hspi, PIN_EINK_DC, PIN_EINK_CS, PIN_EINK_BUSY, PIN_EINK_RES);
|
|
|
|
// InkHUD
|
|
// ----------------------------
|
|
|
|
InkHUD::InkHUD *inkhud = InkHUD::InkHUD::getInstance();
|
|
|
|
// Set the driver
|
|
inkhud->setDriver(driver);
|
|
|
|
// Set how many FAST updates per FULL update
|
|
// Set how unhealthy additional FAST updates beyond this number are
|
|
inkhud->setDisplayResilience(10, 1.5);
|
|
|
|
// Prepare fonts
|
|
InkHUD::Applet::fontLarge = InkHUD::AppletFont(FreeSans9pt7b);
|
|
InkHUD::Applet::fontSmall = InkHUD::AppletFont(FreeSans6pt7b);
|
|
/*
|
|
// Font localization demo: Cyrillic
|
|
InkHUD::Applet::fontSmall = InkHUD::AppletFont(FreeSans6pt8bCyrillic);
|
|
InkHUD::Applet::fontSmall.addSubstitutionsWin1251();
|
|
*/
|
|
|
|
// Customize default settings
|
|
inkhud->persistence->settings.userTiles.maxCount = 2; // How many tiles can the display handle?
|
|
inkhud->persistence->settings.rotation = 3; // 270 degrees clockwise
|
|
inkhud->persistence->settings.userTiles.count = 1; // One tile only by default, keep things simple for new users
|
|
inkhud->persistence->settings.optionalMenuItems.nextTile = false; // Behavior handled by aux button instead
|
|
|
|
// Pick applets
|
|
inkhud->addApplet("All Messages", new InkHUD::AllMessageApplet, true, true); // Activated, autoshown
|
|
inkhud->addApplet("DMs", new InkHUD::DMApplet); // Inactive
|
|
inkhud->addApplet("Channel 0", new InkHUD::ThreadedMessageApplet(0)); // Inactive
|
|
inkhud->addApplet("Channel 1", new InkHUD::ThreadedMessageApplet(1)); // Inactive
|
|
inkhud->addApplet("Positions", new InkHUD::PositionsApplet, true); // Activated
|
|
inkhud->addApplet("Recents List", new InkHUD::RecentsListApplet); // Inactive
|
|
inkhud->addApplet("Heard", new InkHUD::HeardApplet, true, false, 0); // Activated, not autoshown, default on tile 0
|
|
// inkhud->addApplet("Basic", new InkHUD::BasicExampleApplet);
|
|
// inkhud->addApplet("NewMsg", new InkHUD::NewMsgExampleApplet);
|
|
|
|
// Start running InkHUD
|
|
inkhud->begin();
|
|
|
|
// Buttons
|
|
// --------------------------
|
|
|
|
Inputs::TwoButton *buttons = Inputs::TwoButton::getInstance(); // Shared NicheGraphics component
|
|
constexpr uint8_t MAIN_BUTTON = 0;
|
|
constexpr uint8_t AUX_BUTTON = 1;
|
|
|
|
// Setup the main user button
|
|
buttons->setWiring(MAIN_BUTTON, BUTTON_PIN);
|
|
buttons->setHandlerShortPress(MAIN_BUTTON, []() { InkHUD::InkHUD::getInstance()->shortpress(); });
|
|
buttons->setHandlerLongPress(MAIN_BUTTON, []() { InkHUD::InkHUD::getInstance()->longpress(); });
|
|
|
|
// Setup the aux button
|
|
// Bonus feature of VME213
|
|
buttons->setWiring(AUX_BUTTON, BUTTON_PIN_SECONDARY);
|
|
buttons->setHandlerShortPress(AUX_BUTTON, []() { InkHUD::InkHUD::getInstance()->nextTile(); });
|
|
buttons->start();
|
|
}
|
|
|
|
#endif |