Skip to main content

Font conversion and visualization tool for embedded systems

Project description

Colossus_LTSM

Donate CI PyPI version

Table of Contents

Overview

Colossus_LTSM is a Python tool for converting TrueType fonts (.ttf) into C/C++ bitmap arrays and for visualizing font data stored in C/C++ header files.
It is aimed at users working with embedded systems, LCDs, and GUIs where compact fonts are needed.

  • Convert .ttf fonts to C/C++ arrays
  • Adjustable font size, ASCII range, and addressing mode
  • Visualize fonts from existing C/C++ headers
  • GUI built with Tkinter
  • Lightweight: only depends on Pillow

Installation

  1. github repository
  2. Arch Linux AUR package
  3. Pypi package

The program is present in python package index, Pypi. Install (you can use pip or pipx) to the location or environment of your choice.

# For example with pipx 
pipx install colossus-ltsm

Libraries

Pillow for image processing

Usage

  1. Github repository: Colossus_LTSM
  2. PyPI package name: colossus-ltsm
  3. Import path: import colossus_ltsm
  4. Executable command: colossus

Run the GUI:

Select from application menu(if desktop entry installed) or run from terminal with:

colossus
# or directly with Python
 python3 -m colossus_ltsm.colossus_main

Input

  • Select a .ttf font file
  • Set font size, Width and Height(e.g., 12, 16, 24)
  • Define ASCII range (e.g., 32-126)
  • Choose data addressing mode (horizontal or vertical)
  • Choose C or C++ arrays
  • Choose file extension (.h or .hpp)
  • Choose font name and file name
  • Some ttf files are available in the extras/ttf directory for testing.

Output

  • Generates a C or C++ header file with bitmap arrays.
  • Visualizes the font in the GUI, a PNG image can also be exported.

Example output :

// Example Font
// An 8 by 8 character size font starting at 
// ASCII offset 0x30 in ASCII table with 0x02 characters in font. 
// 0 and 1 , size 20 bytes, 4 Control bytes at start.
static const std::array<uint8_t, 20> FontBinaryExample =
{
0x08, 0x08, 0x30, 0x01,   // x-size, y-size, offset, (last character-offset : 0x31-0x30)
0x7C,0xC6,0xCE,0xD6,0xE6,0xC6,0x7C,0x00, // ASCII font data '0' : 0x30
0x18,0x38,0x18,0x18,0x18,0x18,0x7E,0x00 // ASCII font data  '1' : 0x31
};

Exported PNG image of font data visualization:

 img font

Configuration file

The configuration file is created on startup and populated by default values. The file is located at '~/.config/colossus_ltsm/colossus_ltsm.cfg' on Linux systems.

Setting Value Default Note
scale int 4 Scale of font displayed
Columns int 16 Number of columns of font characters to display
glyph color hex color #0078FF Color of font glyphs in visualization
background color hex color #000000 Background color for visualization
screen_resolution str 1000x800 Window size for GUI on start up
debug bool False Enable debug output to terminal
input_path str $HOME input file path when a file dialog opens
output_path str $HOME output file path when a file dialog opens

Desktop Entry

A button on the main GUI allows Linux users to install a desktop entry and icon for Colossus.This creates a .desktop file in ~/.local/share/applications/ and an icon in ~/.local/share/icons/, allowing Colossus to be launched from the application menu. The button is automatically disabled if the desktop entry is already installed. Uses Curl to download the icon from GitHub and creates the desktop entry file with the correct paths.

Glyph rendering

Glyph rendering help readme. Explains how the converter measures and positions glyphs within the bitmap cell, and how to interpret messages in the conversion log related to width scaling and clipping.

Screenshots

 image

Projects

Some of my libraries that use these fonts are:

MCU type Library link Data adddressing mode
Arduino GFX Horizontal
Raspberry Pi Pico GFX 16 bit Horizontal
Raspberry Pi Pico GFX 1 bit Vertical
Raspberry Pi GFX Horizontal
PIC OLED Vertical

See also

Guardian_LTSM is a Python tool for converting image files into C/C++ data arrays and for visualizing image data stored in C/C++ header files. It is aimed at users working with embedded systems, LCDs, and GUIs where compact images are needed.

Guardian_LTSM

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

colossus_ltsm-1.0.3.tar.gz (21.3 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

colossus_ltsm-1.0.3-py3-none-any.whl (19.6 kB view details)

Uploaded Python 3

File details

Details for the file colossus_ltsm-1.0.3.tar.gz.

File metadata

  • Download URL: colossus_ltsm-1.0.3.tar.gz
  • Upload date:
  • Size: 21.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for colossus_ltsm-1.0.3.tar.gz
Algorithm Hash digest
SHA256 0ab3e4e1f5b4d3e98949419cc070ee777f9c98d3b8251091e9908f5b12591ec4
MD5 51ad1ee7c2aee2e22de1bcd9d66db672
BLAKE2b-256 d2ec978c1687d551c7d8893e8294aac2054b3e283473de4c6b95091fc87f6fa3

See more details on using hashes here.

File details

Details for the file colossus_ltsm-1.0.3-py3-none-any.whl.

File metadata

  • Download URL: colossus_ltsm-1.0.3-py3-none-any.whl
  • Upload date:
  • Size: 19.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for colossus_ltsm-1.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 174bd4ea2dbe50652f4d950eb1c2b0f53dbde494395ca6b2ecb2b300d710530e
MD5 a319c4f5d61f95d6ad4c4d31455f81a6
BLAKE2b-256 442ca71e0a178753963de38447d8f4809ee9296d2ca0fd5e70c283182bb4b9df

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page