Files
crosspoint-reader/README.md

148 lines
5.5 KiB
Markdown
Raw Normal View History

2025-12-03 22:00:29 +11:00
# CrossPoint Reader
Firmware for the **Xteink X4** e-paper display reader (unaffiliated with Xteink).
Built using **PlatformIO** and targeting the **ESP32-C3** microcontroller.
CrossPoint Reader is a purpose-built firmware designed to be a drop-in, fully open-source replacement for the official
Xteink firmware. It aims to match or improve upon the standard EPUB reading experience.
2025-12-14 13:46:15 +11:00
![](./docs/images/cover.jpg)
2025-12-03 22:00:29 +11:00
## Motivation
E-paper devices are fantastic for reading, but most commercially available readers are closed systems with limited
customisation. The **Xteink X4** is an affordable, e-paper device, however the official firmware remains closed.
CrossPoint exists partly as a fun side-project and partly to open up the ecosystem and truely unlock the device's
potential.
CrossPoint Reader aims to:
* Provide a **fully open-source alternative** to the official firmware.
* Offer a **document reader** capable of handling EPUB content on constrained hardware.
* Support **customisable font, layout, and display** options.
* Run purely on the **Xteink X4 hardware**.
This project is **not affiliated with Xteink**; it's built as a community project.
2025-12-20 01:44:39 +11:00
## Features & Usage
2025-12-03 22:00:29 +11:00
- [x] EPUB parsing and rendering
2025-12-20 01:44:39 +11:00
- [ ] Image support within EPUB
2025-12-03 22:00:29 +11:00
- [x] Saved reading position
2025-12-20 01:44:39 +11:00
- [x] File explorer with file picker
2025-12-04 00:14:47 +11:00
- [x] Basic EPUB picker from root directory
- [x] Support nested folders
2025-12-04 00:14:47 +11:00
- [ ] EPUB picker with cover art
2025-12-20 01:44:39 +11:00
- [x] Custom sleep screen
- [ ] Cover sleep screen
- [x] Wifi book upload
- [ ] Wifi OTA updates
2025-12-03 22:00:29 +11:00
- [ ] Configurable font, layout, and display options
2025-12-20 01:44:39 +11:00
- [ ] Screen rotation
See [the user guide](./USER_GUIDE.md) for instructions on operating CrossPoint.
2025-12-03 22:00:29 +11:00
2025-12-09 00:07:38 +11:00
## Installing
### Web (latest firmware)
1. Connect your Xteink X4 to your computer via USB-C
2. Go to https://xteink.dve.al/ and click "Flash CrossPoint firmware"
To revert back to the official firmware, you can flash the latest official firmware from https://xteink.dve.al/, or swap
back to the other partition using the "Swap boot partition" button here https://xteink.dve.al/debug.
### Web (specific firmware version)
1. Connect your Xteink X4 to your computer via USB-C
2. Download the `firmware.bin` file from the release of your choice via the [releases page](https://github.com/daveallie/crosspoint-reader/releases)
3. Go to https://xteink.dve.al/ and flash the firmware file using the "OTA fast flash controls" section
To revert back to the official firmware, you can flash the latest official firmware from https://xteink.dve.al/, or swap
back to the other partition using the "Swap boot partition" button here https://xteink.dve.al/debug.
### Manual
See [Development](#development) below.
## Development
2025-12-03 22:00:29 +11:00
### Prerequisites
* **PlatformIO Core** (`pio`) or **VS Code + PlatformIO IDE**
* Python 3.8+
* USB-C cable for flashing the ESP32-C3
* Xteink X4
### Checking out the code
CrossPoint uses PlatformIO for building and flashing the firmware. To get started, clone the repository:
```
git clone --recursive https://github.com/daveallie/crosspoint-reader
# Or, if you've already cloned without --recursive:
git submodule update --init --recursive
```
2025-12-03 22:00:29 +11:00
### Flashing your device
Connect your Xteink X4 to your computer via USB-C and run the following command.
```sh
pio run --target upload
```
2025-12-03 22:21:11 +11:00
2025-12-03 22:00:29 +11:00
## Internals
CrossPoint Reader is pretty aggressive about caching data down to the SD card to minimise RAM usage. The ESP32-C3 only
has ~380KB of usable RAM, so we have to be careful. A lot of the decisions made in the design of the firmware were based
on this constraint.
### Data caching
2025-12-03 22:00:29 +11:00
The first time chapters of a book are loaded, they are cached to the SD card. Subsequent loads are served from the
2025-12-03 22:00:29 +11:00
cache. This cache directory exists at `.crosspoint` on the SD card. The structure is as follows:
```
.crosspoint/
├── epub_12471232/ # Each EPUB is cached to a subdirectory named `epub_<hash>`
│ ├── progress.bin # Stores reading progress (chapter, page, etc.)
│ ├── cover.bmp # Book cover image (once generated)
│ ├── book.bin # Book metadata (title, author, spine, table of contents, etc.)
│ └── sections/ # All chapter data is stored in the sections subdirectory
│ ├── 0.bin # Chapter data (screen count, all text layout info, etc.)
│ ├── 1.bin # files are named by their index in the spine
│ └── ...
2025-12-03 22:00:29 +11:00
└── epub_189013891/
```
Deleting the `.crosspoint` directory will clear the entire cache.
2025-12-03 22:00:29 +11:00
Due the way it's currently implemented, the cache is not automatically cleared when a book is deleted and moving a book
file will use a new cache directory, resetting the reading progress.
For more details on the internal file structures, see the [file formats document](./docs/file-formats.md).
2025-12-03 22:00:29 +11:00
## Contributing
Contributions are very welcome!
2025-12-14 13:46:03 +11:00
If you're looking for a way to help out, take a look at the [ideas discussion board](https://github.com/daveallie/crosspoint-reader/discussions/categories/ideas).
If there's something there you'd like to work on, leave a comment so that we can avoid duplicated effort.
2025-12-03 22:00:29 +11:00
### To submit a contribution:
1. Fork the repo
2. Create a branch (`feature/dithering-improvement`)
3. Make changes
4. Submit a PR
---
CrossPoint Reader is **not affiliated with Xteink or any manufacturer of the X4 hardware**.
2025-12-06 13:32:09 +11:00
Huge shoutout to [**diy-esp32-epub-reader** by atomic14](https://github.com/atomic14/diy-esp32-epub-reader), which was a project I took a lot of inspiration from as I
was making CrossPoint.