The Subzero Player is a media player application built using vlcj with a Swing rich-client user interface (forked from vlcj-player).
Subzero Player is not just a player, it's core functionality is to make learning a new language as easy and smooth as possible. Subzero Player has a few killer features:
- Dictionary feature: Add subtitle and watch the video file as usual with subtitles (subtitle must be manually added, not built it). When paused, there will be pop-up windows on screen with the translation of each word provided (feature can be toggled on/off)
- Ample language choice: Choose language pair from over 100 language pairs
- Second Subtitle feature: Instead of using Dictionary feature, you can add the second subtitle, which means you can have two subtitles running at the same time, e.g. one in english, second one in german. Second subtitle can only be seen when paused, so that its not too distracting. Second Subtitle feature and Dictionary feature cannot be both enabled at the same time.
- Streaming: Stream video via URL, still able to use above features. Make sure your internet connection is fast enough to avoid lags.
Generally the subzero-player tries to match the Qt interface of VLC with as many of the same features implemented as possible.
However, it is not possible to get a 100% like-for-like implementation since LibVLC, used by vlcj, exposes only a sub-set of the total functionality of VLC.
- subtitle word translation
- language pair list for subtitle translation
- second subtitle
- stream via URL
- audio player
- video player
- full-screen
- audio equalizer
- video adjustments
- title selection
- chapter navigation
- audio track selection
- video track selection
- subtitle track selection
- load external subtitle file
- change audio device
- change playback speed
- capture and display native logs
- capture and display video surface debug messages (e.g. to test mouse and keyboard events still work)
- volume controls
- mute
- zoom/scale
- aspect ratio
- crop
- always on top
- video snapshots
- redirect native output streams (on Linux)
...and a whole bunch of other nifty stuff.
There were two small libraries developed for this application: dictionary agent and subtitle agent.
Dictionary Agent is responsible for retrieving translations for a given set of words. Since there are multiple sources of dictionaries (e.g. MIT Wordnet binaries for English to English, simple text files and so on), there are different implementations of the interface, each one responsible for specific type of dictionary source. The interface can be extended and implemented for other kinds of sources in the future:
public interface DictionaryService {
Map<String, Map<String, List<String>>> retrieveDefinitions(String[] words);
}
Subtitle Agent is responsible for retrieving the list of words most recently or currently displayed on the screen. When user paused the player, current subtitle words displayed are retrieved via Subtitle Agent and passed to Dictionary Agent for translation.
Feel free to check out the source code, suggest improvements and pull requests.
This project is currently a work-in-progress. Media player is only half of the full project, a web portal needs to be implemented. Progress is tracked in Youtrack project management tool. Contact me at [email protected] to gain access to project board.
There are a lot of exciting things coming, most notably:
Winter- Web portal and user profiles via Spring MVC and Angular. User will be able to save a word by clicking on it in the media player subtitle translation window. Later user can log in their portal from browser and view list of words with translations and the context of the subtitle in which the word was used.
- Rest API backed by Spring Boot and MongoDB to receive and store data/words sent by user's media player
- Ability to search a word directly inside media player
- Enhanced front end experience on web portal to help users learn stored words
- Option to voluntarily share stored words and contexts
- If user enabled previous option, user can have access to the different contexts of the same word (e.g. same word from different movie subtitle shared by another user). Real life sentences help learn the words faster
Subzero player folder expects the following structure
- config.properties will contain users credentials encrypted, remote URLs and SFTP locations (for authentication, downloading dictionary data, sending words to user profile etc).
- lang folder will contain directories for each language pair the user has downloaded, e.g. bg-de, de-en and so on.
- Subzero folder holds main application data: - lib folder with VLC dll files and plugins - runner file, e.g. subzero.bat or subzero.sh - jar file with application and its dependency jars
Check out helper libraries developed for this application: dictionary agent and subtitle agent.
Run mvn clean install
on both.
Check out source code of subzero-player and run mvn clean install
In target folder you will get subzero-($project.version)-jar-with-dependencies.jar
Recreate the folder structure as described in Project Structure part above.
To make things easier, download this archive with ready made project structure and replace existing jar with the one built by your maven.
lang folder only contains en-en pair (english-english). Remote location to download other languages from media player's menu is not yet set
up, but will be available soon.
Some operating systems have trouble detecting VLC binaries on the classpath. Issue will be resolved.
Project was conceived when I moved to Germany in 2015 and struggled to force myself to learn the language (since my work environment was in English). Watching movies in German and looking up each word was too time consuming, I was losing focus and interesting really fast. I did not find any fun/engaging way to learn a new language at home after work. So I decided to take things in my own hands and create a media player designed to make the language learning process very smooth.
The subzero-player project is provided under the GPL, version 3 or later.
Language pair menu: switch to a new pair, download language pair if not yet downloaded, or try to redownload if dictionary is corrupt or there is a better version available.