This is a simple CLI (Command Line Interface) application to convert VTT files to ASS subtitles.
This application is originally based on the vttconvert
module of anidl/hidive-downloader-nx repository. The maxwbot/maxwhidive repository was also used as inspiration for handling the positionning of subs.
Those two tools were missing features and didn't work well on a lot of more complex subtitles files. For that reason, I wrote a new tool that can handle everything.
- Convert simple VTT files
- Convert complex VTT files with positioning
- Convert Hidive VTT files with CSS styling
- Convert subtitles in batches by specifying the input directory
- Handles subtitles made for lower resolution video
- Can add offset to subtitle lines
- Can output result to the CLI
- Can output to the specifed directory
- Can change the base font size
- Can specify a custom font family for non-styled lines
- Can add a title to the converted files
- ruby 2.7.2 or newer
Development is currently done on ruby 3.0+, but the Gitlab runner for builds works with ruby version 2.7.2. Older versions of ruby may be compatible, but they won't be tested.
To install:
$ gem install vtt2ass
- Empty arguments lists the available commands
$ vtt2ass
Commands:
vtt2ass convert INPUT # Run the VTT to ASS conversion for the specified file(s)
vtt2ass help [COMMAND] # Describe available commands or one specific command
vtt2ass version # Show version
- Help command shows available options of the specified command
$ vtt2ass help convert
Usage:
vtt2ass convert INPUT
Options:
-o, [--output=OUTPUT] # Output directory of the converted file
-t, [--title=TITLE] # Specify a title for you file. If the input is a directory, all files will share the same title.
-s, [--font-size=N] # Specify a font size for the subtitles
# Default: 52
-f, [--font-family=FONT_FAMILY] # Specify a font family for the subtitles
# Default: Open Sans Semibold
-c, [--css=CSS] # Specify a CSS file path for Hidive subs
-l, [--line-offset=N] # Specify a line offset for the main dialog (e.g. 50 lowers the text line by 50px of the total height)
# Default: 0
-w, [--width=N] # Specify the video width
# Default: 1920
-h, [--height=N] # Specify the video height
# Default: 1080
-q, [--quiet], [--no-quiet] # Don't output to the console
Run the VTT to ASS conversion for the specified file(s)
- Convert command
$ vtt2ass convert ./path/to/input/ -o ./path/to/output/ -l 50 -q
- Version command shows the application version
$ vtt2ass version
0.3.3
Contributions are welcome. Create an Issue on Gitlab and link it with a Pull Request of the changes made. The changes needs to pass the ruby tests.
$ rake test
To build a gem file for local installation:
$ git clone https://gitlab.com/dkb-weeblets/vtt2ass.git
$ cd vtt2ass/
$ gem build vtt2ass.gemspec
To install the gem file:
$ gem install ./vtt2ass-0.3.5.gem
Licensed under the MIT Licence. For more information read the LICENSE.txt
file.
If you want to support me, consider buying me a coffee.