Skip to content

A series of unicode helper classes compatible with both tcMenu and Adafruit/U8G2/TFT_eSPI

License

Notifications You must be signed in to change notification settings

TcMenu/tcUnicodeHelper

Folders and files

NameName
Last commit message
Last commit date

Latest commit

7b60d7b · Nov 4, 2024

History

72 Commits
Aug 10, 2024
Sep 14, 2024
Aug 10, 2024
Mar 17, 2024
Sep 15, 2024
Aug 10, 2024
Nov 26, 2023
Jul 27, 2024
Nov 28, 2022
Sep 8, 2024
Nov 4, 2024
Nov 4, 2024
Aug 3, 2024
Oct 12, 2024
Aug 3, 2024

Repository files navigation

TcUnicode support for Adafruit_GFX, U8G2, TFT_eSPI, tcMenu.

Build Test License: Apache 2.0 GitHub release davetcc JSC TechMinds

Summary

TcUnicode provides Unicode character support to a wide range of display libraries (Adafruit_GFX, U8G2, TFT_eSPI, and also TcMenu). There is no need to use special versions of the libraries to use TcUnicode, and there is even a UI for creating the fonts.

TcMenu organisation made this framework available for you to use. It takes significant effort to keep all our libraries current and working on a wide range of boards. Please consider making at least a one off donation via the sponsor buttons if you find it useful.

Buy Me A Coffee

In any fork, please ensure all text up to here is left unaltered.

What is this library and this format?

This library allows you to use Adafruit and TcUnicode fonts with a wide variety of different drawing libraries, without needing any alteration to that library. Importantly, this means you can use Unicode with any Adafruit GFX based library, TcMenu Drawable, U8G2 and TFT_eSPI

This format and library has now been around for a while and has been battle tested in TcMenu. It provides a very extensible unicode format that works across many libraries and boards. Currently supported on:

  • TcMenu Device Drawable - the designer supports this format natively.
  • Any Adafruit_GFX compatible library - see the packaged Adafruit example.
  • U8G2 library - although the library has good Unicode support, this is another option. See the packaged example.
  • TFT_eSPI - although the library has good Unicode support, this is another option. See the packaged example.

Includes a UTF-8 decoder for mbed and Arduino

This package includes a strict asynchronous UTF8 decoder that needs very little memory to operate with, it is backed by a series of tests that ensure it is quite strict. Given the way it operates it is possible to use it with the Print interface as it can push one char at a time. Safely bailing out if a stream is interrupted midway.

Creating your own tcUnicode or Adafruit GFX fonts

TcMenu Designer can create tcUnicode and Adafruit fonts built into the tcMenu Designer application. As of Designer 4.3 the bitmap font generator has been substantially improved and produces very high quality font exports, even at very small sizes and includes a bitmap editor to touch up any erring pixels.

If someone from the U8G2 and TFT_eSPI teams help us, we'll make it possible to generate U8G2 and TFT_eSPI bitmap fonts from there too.

TcUnicode represents fonts with a wide range of glyphs from different Unicode groups efficiently, if you've got large gaps between ranges, TcUnicode is more efficient than AdaFruit format.

TextPipelines

The way we've implemented the interface between primitive drawing and the Unicode handler means in future we can provide transformations, for example a rotation transformation. For now, they only provide the direct support for drawing on each display type.

How does this support work?

Firstly, you can create fonts by generating from a desktop font file directly from "tcMenu Designer" UI on most desktop platforms, and then they are included into your project as a header file.

There is a custom dialog within "TcMenu Designer UI" where you can select the Unicode blocks, and even sub ranges within blocks that you want to support using the UI.

Please raise all questions in the main TcMenu repository discussions.

Library and Font Licences

The library is source code is Apache 2 licenced The included fonts are separately licenced Font licence page

Questions and documentation