Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dhallgb/eInk-micropython
e-Ink library for Waveshare 4.3inch device on MicroPython
https://github.com/dhallgb/eInk-micropython
Last synced: about 2 months ago
JSON representation
e-Ink library for Waveshare 4.3inch device on MicroPython
- Host: GitHub
- URL: https://github.com/dhallgb/eInk-micropython
- Owner: dhallgb
- License: mit
- Created: 2016-09-17T09:04:39.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2022-04-16T12:15:32.000Z (over 2 years ago)
- Last Synced: 2024-08-05T00:07:04.104Z (5 months ago)
- Language: Python
- Size: 18.6 KB
- Stars: 23
- Watchers: 2
- Forks: 6
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-micropython - eInk-micropython - eInk library for Waveshare 4.3inch device on MicroPython. (Libraries / Display)
README
# MicroPython e-Ink library for Waveshare 4.3inch display.
This is a simple library for displaying information on a Waveshare 4.3 e-ink display from a device running Micropython. These are boards like the Pyboard, WiPy, or those based around the ESP8266 chip such as the Adafruit Feather Huzzah. As an alternative if you are running this on a full CPython implementation such as a Odroid or Raspberry Pi, see https://github.com/yy502/ePaperDisplay as that library has many more functions.
### Conversion
It takes as its base a pure conversion from the Waveshare code. I used a few things to start the conversion from C code into Python:- a utility called cpp2python from https://github.com/hlamer/cpp2python
- a demo script h2py.py in the Python demo/scripts directory to convert the header file
- seasnake from the excellent BeeWare project at http://pybee.org/, but now abandoned - BeeWare itself is still very alive!
- ctopy from http://www.catb.org/~esr/ctopy/...but mostly just hand-cranked the Python code whilst browsing the C routines.
### Adaption to MicroPython and embedded devices
The original (and derivations) used excessive string concatenation which consumes memory space. In the constrained memory environment of the embedded systems on which MicroPython runs, memory is at a premium so I adapted the library for the following:- no extraneous operations, just the raw commands
- constant binary strings for complete commands (eg. clear, update) where possible so not to use string concatenation
- precalculated parity bytes