This Python 3 module implements a driver for the IT8951 e-paper controller, via SPI. The driver was developed using the 6-inch e-Paper HAT from Waveshare. It hopefully will work for other (related) hardware too.
To install, clone the repository, enter the directory and run
pip install -r requirements.txt
pip install ./
Make sure that SPI is enabled in raspi-config
.
If there are errors related to gcc
, you can try:
sudo pacman -Sy gcc. # Fix 1
sudo pacman -Sy base-devel # Fix 2
sudo pacman -Sy python3 cmake # Fix 3
If the error is still there, it can come from a regression in Python 3.10. Install previous version:
asdf install python 3.9.13
Then in the IT8951 folder:
asdf local python 3.9.13
For some examples of usage, take a look at the integration tests.
You should try setting different VCOM values and seeing how that affects the performance of your display. Every one is different. There might be a suggested VCOM value marked on the cable of your display.
You might be able to squeeze some extra performance out of the data transfer by increasing the SPI
clock frequency.
The SPI frequency for transferring pixel data is by default set at 24 MHz, which is the maximum
stated in the IT8951 chip spec here
(page 41).
But, you could try setting higher and seeing if it works anyway.
It is set by passing the spi_hz
argument to the Display or EPD classes (see example in tests/integration/tests.py
).
For this version the backend was rewritten, so that the SPI communication happens directly
by communicating with the Linux kernel through /dev/spidev*
. This means:
sudo
no longer required- requires neither the
bcm2835
C library nor thespidev
Python module - data transfer is way faster than before!
If you modify spi.pyx
, make sure to set the USE_CYTHON
environment variable before building---otherwise your
changes will not be compiled into spi.c
.
You can run this library on desktop Linux distributions (e.g. on Ubuntu) using a "virtual" display, for testing and development. Instead of appearing on a real ePaper device, the contents will be shown in a TKInter
window on the desktop. For an example, see the integration tests at test/integration/test.py when passed the -v
option.
Windows is curently not supported (the cython
build will fail because the C code depends on some Linux components). It might work if you use some Linux compatibility layer like WSL
or Mingw
.
To get it working first install pillow
with pip
. Do not install RPi.GPIO
(it is only for the Pi, on desktop it will just exit with an error). You may also need the following dependencies (on Ubuntu + related):
sudo apt-get install python3-dev
sudo apt-get install python3-tk
Finally, you need to compile the Cython code. From the IT8951 directory you can either do
python setup.py build_ext --inplace
to build the files right in the source tree, or actually install the package with
pip3 install ./
Now you should be able to run the tests with the -v
flag: python test.py -v
.