Using your Kindle as an e-ink monitor #872
Labels
Git-Repo
Source code repository like gitlab or gh
github
gh tools like cli, Actions, Issues, Pages
New-Label
Choose this option if the existing labels are insufficient to describe the content accurately
software-engineering
Best practice for software engineering
source-code
Code snippets
Using your Kindle as an e-ink monitor
Snippet
README
Using your Kindle as an e-ink monitor
🖥️ See Demo
3.5 fps, Paperwhite 3
@adtac_
step 1: jailbreak your Kindle
mobileread.com is your best resource here, follow the instructions from the LanguageBreak thread.
I didn't really follow the LanguageBreak instructions because I didn't care about most of the features + I was curious to do it myself, but the LanguageBreak github repo was invaluable for debugging.
It doesn't matter how you jailbreak your device as long as you get to a root shell somehow.
step 2: listener server on the Kindle
I wrote a Go program to receive files on port 8000 and then invoke eips, which is Kindle's built-in utility to draw images on the screen.
For example, if the Go program received a JPG file and saved it under
/tmp/img.jpg
, the following command would draw the image with a partial update (full update looks awful):Read the eips wiki for details on what the flags mean.
You may want to clear the screen with a
eips -c
before the first frame.Unfortunately I lost the Go source code, but it was pretty simple, like under 30 lines.
step 3: screencapture + imagemagick
I wrote a script to use screencapture on macOS to repeatedly capture the screen into a png file, which is then converted into a shape, size and color the Kindle likes using imagemagick, and then transferred over usbnet using netcat.
Change the resolution to match your device and port to match the listener server.
step 4: ???
I hacked this together last night for fun and obviously there's a lot of room for improvement here, both in terms of performance and usability.
It's super wasteful to send a full jpeg file for each frame when the delta between consecutive frames is mostly going to be empty and very compressible (like when you're using a text editor).
Without reinventing codecs like h.264 and protocols like vnc, it should be
be possible to quickly improve this with just the tools we already have.
Have fun!
Other useful resources
Suggested labels
None
The text was updated successfully, but these errors were encountered: