Introduction
============
.. image:: https://readthedocs.org/projects/adafruit-circuitpython-jd79661/badge/?version=latest
:target: https://docs.circuitpython.org/projects/jd79661/en/latest/
:alt: Documentation Status
.. image:: https://raw.githubusercontent.com/adafruit/Adafruit_CircuitPython_Bundle/main/badges/adafruit_discord.svg
:target: https://adafru.it/discord
:alt: Discord
.. image:: https://github.com/adafruit/Adafruit_CircuitPython_JD79661/workflows/Build%20CI/badge.svg
:target: https://github.com/adafruit/Adafruit_CircuitPython_JD79661/actions
:alt: Build Status
.. image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json
:target: https://github.com/astral-sh/ruff
:alt: Code Style: Ruff
CircuitPython library for the JD79661 e-paper driver IC
Dependencies
=============
This driver depends on:
* `Adafruit CircuitPython <https://github.com/adafruit/circuitpython>`_
Please ensure all dependencies are available on the CircuitPython filesystem.
This is easily achieved by downloading
`the Adafruit library and driver bundle <https://circuitpython.org/libraries>`_
or individual libraries can be installed using
`circup <https://github.com/adafruit/circup>`_.
`Purchase one from the Adafruit shop <http://www.adafruit.com/products/6373>`_
Installing from PyPI
=====================
On supported GNU/Linux systems like the Raspberry Pi, you can install the driver locally `from
PyPI <https://pypi.org/project/adafruit-circuitpython-jd79661/>`_.
To install for current user:
.. code-block:: shell
pip3 install adafruit-circuitpython-jd79661
To install system-wide (this may be required in some cases):
.. code-block:: shell
sudo pip3 install adafruit-circuitpython-jd79661
To install in a virtual environment in your current project:
.. code-block:: shell
mkdir project-name && cd project-name
python3 -m venv .venv
source .env/bin/activate
pip3 install adafruit-circuitpython-jd79661
Installing to a Connected CircuitPython Device with Circup
==========================================================
Make sure that you have ``circup`` installed in your Python environment.
Install it with the following command if necessary:
.. code-block:: shell
pip3 install circup
With ``circup`` installed and your CircuitPython device connected use the
following command to install:
.. code-block:: shell
circup install adafruit_jd79661
Or the following command to update an existing version:
.. code-block:: shell
circup update
Usage Example
=============
.. code-block:: python
import time
import board
import busio
import displayio
from fourwire import FourWire
import adafruit_jd79661
displayio.release_displays()
# This pinout works on a MagTag with the newer screen and may need to be altered for other boards.
spi = busio.SPI(board.EPD_SCK, board.EPD_MOSI) # Uses SCK and MOSI
epd_cs = board.EPD_CS
epd_dc = board.EPD_DC
epd_reset = board.EPD_RESET
epd_busy = board.EPD_BUSY
display_bus = FourWire(spi, command=epd_dc, chip_select=epd_cs, reset=epd_reset, baudrate=1000000)
time.sleep(1)
display = adafruit_jd79661.JD79661(
display_bus,
width=250,
height=122,
busy_pin=epd_busy,
rotation=270,
colstart=0,
highlight_color=0x00FF00,
highlight_color2=0xFF0000,
)
g = displayio.Group()
pic = displayio.OnDiskBitmap("/display-ruler-640x360.bmp")
t = displayio.TileGrid(pic, pixel_shader=pic.pixel_shader)
g.append(t)
display.root_group = g
display.refresh()
print("refreshed")
time.sleep(display.time_to_refresh + 5)
# Always refresh a little longer. It's not a problem to refresh
# a few seconds more, but it's terrible to refresh too early
# (the display will throw an exception when if the refresh
# is too soon)
print("waited correct time")
# Keep the display the same
while True:
time.sleep(10)
Documentation
=============
API documentation for this library can be found on `Read the Docs <https://docs.circuitpython.org/projects/jd79661/en/latest/>`_.
For information on building library documentation, please check out
`this guide <https://learn.adafruit.com/creating-and-sharing-a-circuitpython-library/sharing-our-docs-on-readthedocs#sphinx-5-1>`_.
Contributing
============
Contributions are welcome! Please read our `Code of Conduct
<https://github.com/adafruit/Adafruit_CircuitPython_JD79661/blob/HEAD/CODE_OF_CONDUCT.md>`_
before contributing to help this project stay welcoming.
Raw data
{
"_id": null,
"home_page": null,
"name": "adafruit-circuitpython-jd79661",
"maintainer": null,
"docs_url": null,
"requires_python": null,
"maintainer_email": null,
"keywords": "adafruit, blinka, circuitpython, micropython, jd79661, epd, epaper",
"author": null,
"author_email": "Adafruit Industries <circuitpython@adafruit.com>",
"download_url": "https://files.pythonhosted.org/packages/30/9a/5e126826241e27779e936473254954787a6e4a8b0190a284382e6a1d97fd/adafruit_circuitpython_jd79661-1.0.0.tar.gz",
"platform": null,
"description": "Introduction\n============\n\n\n.. image:: https://readthedocs.org/projects/adafruit-circuitpython-jd79661/badge/?version=latest\n :target: https://docs.circuitpython.org/projects/jd79661/en/latest/\n :alt: Documentation Status\n\n\n.. image:: https://raw.githubusercontent.com/adafruit/Adafruit_CircuitPython_Bundle/main/badges/adafruit_discord.svg\n :target: https://adafru.it/discord\n :alt: Discord\n\n\n.. image:: https://github.com/adafruit/Adafruit_CircuitPython_JD79661/workflows/Build%20CI/badge.svg\n :target: https://github.com/adafruit/Adafruit_CircuitPython_JD79661/actions\n :alt: Build Status\n\n\n.. image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json\n :target: https://github.com/astral-sh/ruff\n :alt: Code Style: Ruff\n\nCircuitPython library for the JD79661 e-paper driver IC\n\n\nDependencies\n=============\nThis driver depends on:\n\n* `Adafruit CircuitPython <https://github.com/adafruit/circuitpython>`_\n\nPlease ensure all dependencies are available on the CircuitPython filesystem.\nThis is easily achieved by downloading\n`the Adafruit library and driver bundle <https://circuitpython.org/libraries>`_\nor individual libraries can be installed using\n`circup <https://github.com/adafruit/circup>`_.\n\n`Purchase one from the Adafruit shop <http://www.adafruit.com/products/6373>`_\n\nInstalling from PyPI\n=====================\n\nOn supported GNU/Linux systems like the Raspberry Pi, you can install the driver locally `from\nPyPI <https://pypi.org/project/adafruit-circuitpython-jd79661/>`_.\nTo install for current user:\n\n.. code-block:: shell\n\n pip3 install adafruit-circuitpython-jd79661\n\nTo install system-wide (this may be required in some cases):\n\n.. code-block:: shell\n\n sudo pip3 install adafruit-circuitpython-jd79661\n\nTo install in a virtual environment in your current project:\n\n.. code-block:: shell\n\n mkdir project-name && cd project-name\n python3 -m venv .venv\n source .env/bin/activate\n pip3 install adafruit-circuitpython-jd79661\n\nInstalling to a Connected CircuitPython Device with Circup\n==========================================================\n\nMake sure that you have ``circup`` installed in your Python environment.\nInstall it with the following command if necessary:\n\n.. code-block:: shell\n\n pip3 install circup\n\nWith ``circup`` installed and your CircuitPython device connected use the\nfollowing command to install:\n\n.. code-block:: shell\n\n circup install adafruit_jd79661\n\nOr the following command to update an existing version:\n\n.. code-block:: shell\n\n circup update\n\nUsage Example\n=============\n\n.. code-block:: python\n\n import time\n\n import board\n import busio\n import displayio\n from fourwire import FourWire\n\n import adafruit_jd79661\n\n displayio.release_displays()\n\n # This pinout works on a MagTag with the newer screen and may need to be altered for other boards.\n spi = busio.SPI(board.EPD_SCK, board.EPD_MOSI) # Uses SCK and MOSI\n epd_cs = board.EPD_CS\n epd_dc = board.EPD_DC\n epd_reset = board.EPD_RESET\n epd_busy = board.EPD_BUSY\n\n display_bus = FourWire(spi, command=epd_dc, chip_select=epd_cs, reset=epd_reset, baudrate=1000000)\n time.sleep(1)\n\n display = adafruit_jd79661.JD79661(\n display_bus,\n width=250,\n height=122,\n busy_pin=epd_busy,\n rotation=270,\n colstart=0,\n highlight_color=0x00FF00,\n highlight_color2=0xFF0000,\n )\n\n g = displayio.Group()\n\n pic = displayio.OnDiskBitmap(\"/display-ruler-640x360.bmp\")\n t = displayio.TileGrid(pic, pixel_shader=pic.pixel_shader)\n g.append(t)\n\n display.root_group = g\n\n display.refresh()\n\n print(\"refreshed\")\n\n time.sleep(display.time_to_refresh + 5)\n # Always refresh a little longer. It's not a problem to refresh\n # a few seconds more, but it's terrible to refresh too early\n # (the display will throw an exception when if the refresh\n # is too soon)\n print(\"waited correct time\")\n\n\n # Keep the display the same\n while True:\n time.sleep(10)\n\n\nDocumentation\n=============\nAPI documentation for this library can be found on `Read the Docs <https://docs.circuitpython.org/projects/jd79661/en/latest/>`_.\n\nFor information on building library documentation, please check out\n`this guide <https://learn.adafruit.com/creating-and-sharing-a-circuitpython-library/sharing-our-docs-on-readthedocs#sphinx-5-1>`_.\n\nContributing\n============\n\nContributions are welcome! Please read our `Code of Conduct\n<https://github.com/adafruit/Adafruit_CircuitPython_JD79661/blob/HEAD/CODE_OF_CONDUCT.md>`_\nbefore contributing to help this project stay welcoming.\n",
"bugtrack_url": null,
"license": "MIT",
"summary": "CircuitPython library for the JD79661 e-paper driver IC",
"version": "1.0.0",
"project_urls": {
"Homepage": "https://github.com/adafruit/Adafruit_CircuitPython_JD79661"
},
"split_keywords": [
"adafruit",
" blinka",
" circuitpython",
" micropython",
" jd79661",
" epd",
" epaper"
],
"urls": [
{
"comment_text": null,
"digests": {
"blake2b_256": "dbeae3d19c5c8212e01c79ca0236449bb1fdbfc4f426fe2cc38cbe845220cd46",
"md5": "e5fc86d0f51981ac4b1ea1eeb6eb4bbf",
"sha256": "7f0744ed5710f7838d2c6a009bcffac7f2b855392e61ad3b104f09c0e55385c9"
},
"downloads": -1,
"filename": "adafruit_circuitpython_jd79661-1.0.0-py3-none-any.whl",
"has_sig": false,
"md5_digest": "e5fc86d0f51981ac4b1ea1eeb6eb4bbf",
"packagetype": "bdist_wheel",
"python_version": "py3",
"requires_python": null,
"size": 5929,
"upload_time": "2025-07-31T18:16:55",
"upload_time_iso_8601": "2025-07-31T18:16:55.648635Z",
"url": "https://files.pythonhosted.org/packages/db/ea/e3d19c5c8212e01c79ca0236449bb1fdbfc4f426fe2cc38cbe845220cd46/adafruit_circuitpython_jd79661-1.0.0-py3-none-any.whl",
"yanked": false,
"yanked_reason": null
},
{
"comment_text": null,
"digests": {
"blake2b_256": "309a5e126826241e27779e936473254954787a6e4a8b0190a284382e6a1d97fd",
"md5": "cd2e049812d9803d800525f0e7cbfbdb",
"sha256": "6e60d2081b86e903ad7699b686bdf86ce6083c48a4578aaa7c8316e05f767c87"
},
"downloads": -1,
"filename": "adafruit_circuitpython_jd79661-1.0.0.tar.gz",
"has_sig": false,
"md5_digest": "cd2e049812d9803d800525f0e7cbfbdb",
"packagetype": "sdist",
"python_version": "source",
"requires_python": null,
"size": 24484,
"upload_time": "2025-07-31T18:16:57",
"upload_time_iso_8601": "2025-07-31T18:16:57.919321Z",
"url": "https://files.pythonhosted.org/packages/30/9a/5e126826241e27779e936473254954787a6e4a8b0190a284382e6a1d97fd/adafruit_circuitpython_jd79661-1.0.0.tar.gz",
"yanked": false,
"yanked_reason": null
}
],
"upload_time": "2025-07-31 18:16:57",
"github": true,
"gitlab": false,
"bitbucket": false,
"codeberg": false,
"github_user": "adafruit",
"github_project": "Adafruit_CircuitPython_JD79661",
"travis_ci": false,
"coveralls": false,
"github_actions": true,
"requirements": [
{
"name": "Adafruit-Blinka",
"specs": []
}
],
"lcname": "adafruit-circuitpython-jd79661"
}