FontCollector for Advanced SubStation Alpha file.
Project description
FontCollector
FontCollector for Advanced SubStation Alpha file. This tool allows to recover and/or mux the fonts necessary in an mkv.
Installation
pip install FontCollector
Dependencies
Usage
$ fontcollector --help
usage: fontcollector [-h] --input [INPUT ...] [-mkv MKV] [--output OUTPUT] [-mkvpropedit MKVPROPEDIT] [--delete-fonts]
[--additional-fonts ADDITIONAL_FONTS [ADDITIONAL_FONTS ...]] [--exclude-system-fonts]
FontCollector for Advanced SubStation Alpha file.
options:
-h, --help show this help message and exit
--input [INPUT ...], -i [INPUT ...]
Subtitles file. Must be an ASS file/directory. You can specify more than one .ass file/path.
If no argument is specified, it will take all the font in the current path.
-mkv MKV
Video where the fonts will be merge. Must be a Matroska file.
--output OUTPUT, -o OUTPUT
Destination path of the font. If -o and -mkv aren't specified, it will be the current path.
-mkvpropedit MKVPROPEDIT
Path to mkvpropedit.exe if not in variable environments. If -mkv is not specified, it will do
nothing.
--delete-fonts, -d
If -d is specified, it will delete the font attached to the mkv before merging the new needed
font. If -mkv is not specified, it will do nothing.
--additional-fonts ADDITIONAL_FONTS [ADDITIONAL_FONTS ...], -add-fonts ADDITIONAL_FONTS [ADDITIONAL_FONTS ...]
May be a directory containing font files or a single font file. You can specify more than one
additional-fonts.
If it is a directory, it won't search recursively for fonts
--additional-fonts-recursive ADDITIONAL_FONTS_RECURSIVE [ADDITIONAL_FONTS_RECURSIVE ...], -add-fonts-rec ADDITIONAL_FONTS_RECURSIVE [ADDITIONAL_FONTS_RECURSIVE ...]
Path to font directory, which will be recursively searched for fonts.
--exclude-system-fonts
If specified, FontCollector won't use the system font to find the font used by an .ass file.
--collect-draw-fonts
If specified, FontCollector will collect the font used by the draw. For more detail when this
is usefull, see: https://github.com/libass/libass/issues/617
Examples
Recover fonts from 2 .ass files and save them in the current folder
fontCollector -i "file1.ass" "file2.ass"
Take all the .ass files from the current folder and save the font in the current folder
fontCollector -i .
Mux font from .ass file into an mkv
fontCollector -i "file1.ass" -mkv "example.mkv" -mkvpropedit "C:\Program Files\MKVToolNix\mkvpropedit.exe"
Mux the font from the .ass file into an mkv and delete the currently attached fonts.
fontCollector -i "file1.ass" -mkv "example.mkv" -mkvpropedit "C:\Program Files\MKVToolNix\mkvpropedit.exe" -d
Variable Font
Since Libass does not support variable font, this tool will automatically generate a OpenType Font Collection. The generated collection is designed to simulate how VSFilter/GDI handles variable font.
Acknowledgments
- fontmerge for the idea to automatically merge the font into the mkv.
- Myaamori-Aegisub-Scripts Without this tool, I probably could never have created the fontCollector. I got a lot of inspiration from his work.
- PyonFX I inspired myself from his setup.py to create mine.
- rcombs for her help with how VSFilter pick font when faux-bold need to be applied.
- assfc for all the idea behind the font_loader.
- Christopher Leung for his help on how GDI handle variable font.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file fontcollector-3.0.0.tar.gz
.
File metadata
- Download URL: fontcollector-3.0.0.tar.gz
- Upload date:
- Size: 44.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.9.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | b140059c423ae2f156b3cf150dfb4e2933ea6ef44078d0fd1c2f5e1910cef452 |
|
MD5 | 38ea93de16efd17936ef653ae4b357c1 |
|
BLAKE2b-256 | 3a650b7bd24408d1e4940d032c79533a8ade35a562eda10178910ccde68de09f |
File details
Details for the file FontCollector-3.0.0-py3-none-any.whl
.
File metadata
- Download URL: FontCollector-3.0.0-py3-none-any.whl
- Upload date:
- Size: 56.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.0 CPython/3.9.19
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cb9f3d19c7466099091aa6a66ae59987cbb7d70115a4f143c512f837c38b59d6 |
|
MD5 | f742c13a437dbc8470251a5051c451de |
|
BLAKE2b-256 | c96d7782d0c4ffb5d7757fbb430bb89532c51a67f1902edd4752648293c085f7 |