Paperd.Ink Library 0.0.5
Library for interacting with Paperd.Ink devices.
Loading...
Searching...
No Matches
GxEPD2_290c.h
Go to the documentation of this file.
1// Display Library for SPI e-paper panels from Dalian Good Display and boards from Waveshare.
2// Requires HW SPI and Adafruit_GFX. Caution: these e-papers require 3.3V supply AND data lines!
3//
4// based on Demo Example from Good Display: http://www.e-paper-display.com/download_list/downloadcategoryid=34&isMode=false.html
5// Controller: IL0373 : http://www.e-paper-display.com/download_detail/downloadsId=535.html
6//
7// Author: Jean-Marc Zingg
8//
9// Version: see library.properties
10//
11// Library: https://github.com/ZinggJM/GxEPD2
12
13#ifndef _GxEPD2_290c_H_
14#define _GxEPD2_290c_H_
15
16#include "../GxEPD2_EPD.h"
17
18class GxEPD2_290c : public GxEPD2_EPD
19{
20 public:
21 // attributes
22 static const uint16_t WIDTH = 128;
23 static const uint16_t WIDTH_VISIBLE = WIDTH;
24 static const uint16_t HEIGHT = 296;
26 static const bool hasColor = true;
27 static const bool hasPartialUpdate = true;
28 static const bool usePartialUpdateWindow = true; // set false for better image
29 static const bool hasFastPartialUpdate = false;
30 static const uint16_t power_on_time = 40; // ms, e.g. 36557us
31 static const uint16_t power_off_time = 30; // ms, e.g. 20291us
32 static const uint16_t full_refresh_time = 15000; // ms, e.g. 14845408us
33 static const uint16_t partial_refresh_time = 15000; // ms, e.g. 14845408us
34 // constructor
35 GxEPD2_290c(int16_t cs, int16_t dc, int16_t rst, int16_t busy);
36 // methods (virtual)
37 // Support for Bitmaps (Sprites) to Controller Buffer and to Screen
38 void clearScreen(uint8_t value = 0xFF); // init controller memory and screen (default white)
39 void clearScreen(uint8_t black_value, uint8_t color_value); // init controller memory and screen
40 void writeScreenBuffer(uint8_t value = 0xFF); // init controller memory (default white)
41 void writeScreenBuffer(uint8_t black_value, uint8_t color_value); // init controller memory
42 // write to controller memory, without screen refresh; x and w should be multiple of 8
43 void writeImage(const uint8_t bitmap[], int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
44 void writeImagePart(const uint8_t bitmap[], int16_t x_part, int16_t y_part, int16_t w_bitmap, int16_t h_bitmap,
45 int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
46 void writeImage(const uint8_t* black, const uint8_t* color, int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
47 void writeImagePart(const uint8_t* black, const uint8_t* color, int16_t x_part, int16_t y_part, int16_t w_bitmap, int16_t h_bitmap,
48 int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
49 // write sprite of native data to controller memory, without screen refresh; x and w should be multiple of 8
50 void writeNative(const uint8_t* data1, const uint8_t* data2, int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
51 // write to controller memory, with screen refresh; x and w should be multiple of 8
52 void drawImage(const uint8_t bitmap[], int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
53 void drawImagePart(const uint8_t bitmap[], int16_t x_part, int16_t y_part, int16_t w_bitmap, int16_t h_bitmap,
54 int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
55 void drawImage(const uint8_t* black, const uint8_t* color, int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
56 void drawImagePart(const uint8_t* black, const uint8_t* color, int16_t x_part, int16_t y_part, int16_t w_bitmap, int16_t h_bitmap,
57 int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
58 // write sprite of native data to controller memory, with screen refresh; x and w should be multiple of 8
59 void drawNative(const uint8_t* data1, const uint8_t* data2, int16_t x, int16_t y, int16_t w, int16_t h, bool invert = false, bool mirror_y = false, bool pgm = false);
60 void refresh(bool partial_update_mode = false); // screen refresh from controller memory to full screen
61 void refresh(int16_t x, int16_t y, int16_t w, int16_t h); // screen refresh from controller memory, partial screen
62 void powerOff(); // turns off generation of panel driving voltages, avoids screen fading over time
63 void hibernate(); // turns powerOff() and sets controller to deep sleep for minimum power use, ONLY if wakeable by RST (rst >= 0)
64 private:
65 void _writeScreenBuffer(uint8_t value);
66 void _setPartialRamArea(uint16_t x, uint16_t y, uint16_t w, uint16_t h);
67 void _PowerOn();
68 void _PowerOff();
69 void _InitDisplay();
70 void _Init_Full();
71 void _Init_Part();
72 void _Update_Full();
73 void _Update_Part();
74};
75
76#endif
static const uint16_t power_off_time
Definition GxEPD2_290c.h:31
void writeScreenBuffer(uint8_t value=0xFF)
static const uint16_t full_refresh_time
Definition GxEPD2_290c.h:32
static const uint16_t power_on_time
Definition GxEPD2_290c.h:30
static const bool usePartialUpdateWindow
Definition GxEPD2_290c.h:28
static const uint16_t HEIGHT
Definition GxEPD2_290c.h:24
void writeImagePart(const uint8_t bitmap[], int16_t x_part, int16_t y_part, int16_t w_bitmap, int16_t h_bitmap, int16_t x, int16_t y, int16_t w, int16_t h, bool invert=false, bool mirror_y=false, bool pgm=false)
void writeImage(const uint8_t bitmap[], int16_t x, int16_t y, int16_t w, int16_t h, bool invert=false, bool mirror_y=false, bool pgm=false)
static const GxEPD2::Panel panel
Definition GxEPD2_290c.h:25
void drawImage(const uint8_t bitmap[], int16_t x, int16_t y, int16_t w, int16_t h, bool invert=false, bool mirror_y=false, bool pgm=false)
void drawNative(const uint8_t *data1, const uint8_t *data2, int16_t x, int16_t y, int16_t w, int16_t h, bool invert=false, bool mirror_y=false, bool pgm=false)
static const uint16_t WIDTH
Definition GxEPD2_290c.h:22
void drawImagePart(const uint8_t bitmap[], int16_t x_part, int16_t y_part, int16_t w_bitmap, int16_t h_bitmap, int16_t x, int16_t y, int16_t w, int16_t h, bool invert=false, bool mirror_y=false, bool pgm=false)
void clearScreen(uint8_t value=0xFF)
static const bool hasFastPartialUpdate
Definition GxEPD2_290c.h:29
static const uint16_t WIDTH_VISIBLE
Definition GxEPD2_290c.h:23
static const bool hasPartialUpdate
Definition GxEPD2_290c.h:27
static const uint16_t partial_refresh_time
Definition GxEPD2_290c.h:33
static const bool hasColor
Definition GxEPD2_290c.h:26
void refresh(bool partial_update_mode=false)
GxEPD2_290c(int16_t cs, int16_t dc, int16_t rst, int16_t busy)
void writeNative(const uint8_t *data1, const uint8_t *data2, int16_t x, int16_t y, int16_t w, int16_t h, bool invert=false, bool mirror_y=false, bool pgm=false)
Panel
Definition GxEPD2.h:37
@ GDEW029Z10
Definition GxEPD2.h:85