This is a personal fork of CrossPoint Reader with a focus on improved fonts and minimal reading stats.
My goal with this fork was to maintain the core Crosspoint firmware while integrating my preferred typography and some lightweight reading statistics. I’ve focused on keeping the underlying system stable while layering in a few "nice-to-have" features and UI refinements along the way.
|
Font: Bitter, Size: 12 pt, Margin: 15 |
Reading Stats with custom front button mapping shown |
Note: This firmware is confirmed to be working on both the X3 and X4.
- New reader fonts: ChareInk, Lexend Deca, and Bitter.
- Unicode emoji and miscellaneous symbols support (a limited subset).
- Adjusted font sizes: 8 pt, 9 pt, 10 pt, 12 pt, 14 pt, 16 pt, 18 pt, and 20 pt. See Font Build Variants for more details.
- Added
strikethroughsupport. - Made underlines thicker for better visibility.
- Added a custom
Minimaltheme and sleep screen option for the minimalists out there. - Added support for
<hr>section breaks. - Added support for "redaction" style rendering.
- Added improved support for tables with simple markup.
- Added ability to add bookmarks.
- Added ability to remap front buttons that only applies in the reader.
- Added Bionic Reading and Guide Dots as optional reader modes.
- Added Force Paragraph Indents for books that render as one giant wall of text.
- Added ability to pin a sleep image as a favorite. The favorited image will always be displayed when your sleep settings are set to
CustomorCover + Custom(when no cover is available). - Added more in-reader control remapping options for side buttons, short power button clicks, and long-press menu actions.
- Added ability to mark a book as finished from the in-book menu. A pop-up will also display once 99% of the book is reached. This status allows tracking of total books read.
- Added ability to move finished books to "Read" folder.
- In-book menu to quickly adjust reader options without having to exit the book.
- Reading stats: total books read, total reading time, number of sessions, pages turned, average session time, pages turned per minute. You can also set your reading stats as your sleep screen.
- Reading stats syncing between two devices.
- Added customizable Auto Page Turn Interval (anything between 5-120 seconds).
- Added ability to view Recent Books as a 3x3 grid view.
- To view a more detailed list for each version, visit the releases page to read release notes.
The default fonts have been replaced with ChareInk, Lexend Deca, and Bitter. These fonts have been chosen specifically to improve reading fluency and e-ink performance. These 'sturdier' typefaces feature uniform stroke weights and open geometries, allowing the X4/X3 to render crisp, high-contrast text with font-aliasing on while significantly reducing ghosting and artifacts.
- ChareInk - A cult favorite among the e-reading community for over a decade based off of the typeface Charis. It is specially designed to make long texts pleasant and easy to read.
- Lexend Deca - A research-backed sans-serif typeface designed to improve reading fluency. Lexend was engineered based on the theory that reading issues are often a design problem (visual crowding) rather than a cognitive one.
- Bitter - A "contemporary" slab serif typeface for text, it is specially designed for comfortably reading on digital screens. The consistent stroke weight of Bitter helps it render particularly well on e-ink devices. The medium weight has been chosen specifically for improved rendering on the X4/X3.
The UI now uses Inter as the display font which has improved readability at smaller sizes.
- Support for a limited set of Unicode Emoticons and Miscellaneous Symbols using Noto Emoji and Noto Sans Symbols font.
There are 4 available build variants to choose from due to build size constraints: teensy, tiny, xlarge, and no_emoji.
See Font Build Variants for the full point-size and emoji-support matrix.
Reader Options, Bionic Reading, Guide Dots, Force Paragraph Indents, reading stats, and finished-book behavior are documented in Reader Features.
CrossInk adds configurable button shortcuts.
See Controls for the full action list and defaults.
The device simulator renders the e-ink display in an SDL2 window so firmware changes can be sanity-checked without flashing hardware.
See Simulator for setup, platform notes, keyboard controls, and cache tips.
Download a firmware-*.bin from the releases page, then flash it with the web installer or command line.
See Installation for step-by-step flashing and revert instructions.
- User Guide
- Installation
- Font Build Variants
- Reader Features
- Controls
- Simulator
- Data Cache
- Web server usage
- Web server endpoints
- Common issues
- Project scope
- Contributing docs
CrossInk uses PlatformIO for building and flashing firmware.
See Getting Started for prerequisites, clone setup, hooks, and validation commands.
Connect your Xteink X4 or X3 via USB-C and run:
pio run -e tiny --target uploadReplace tiny with another build variant if needed. See Font Build Variants.
See Testing and Debugging for serial logging, simulator checks, static analysis, and bug-report guidance.
The ESP32-C3 has about 380 KB of usable RAM, so CrossInk stores reusable book and device data on the SD card instead of rebuilding everything in memory.
See Data Cache for the .crosspoint layout and File Formats for binary cache details.