MicroDVD

MicroDVD is a subtitle file format for digital video. Its name is derived from the MicroDVD Player, a media player application designed to play DVD videos along with subtitles, originally developed by Tiamat Software. The application was first released in 2000 but development ended in 2001. Media players that support the format are able to interpret MicroDVD subtitles and mix their contents with their corresponding video files.

Specification
MicroDVD subtitle files have the .sub filename extension. These files may come along with a video file and/or created/modified by the user. Media player applications that support external subtitle files are usually responsible for locating correct .sub files.

MicroDVD subtitle files consist of multiple lines, each defining a portion of the subtitle text that must be displayed between certain given video frames. The line syntax is:

For example, if "Hello!" is to be displayed during the first 25 frames of a digital video, clip or movie, the corresponding .sub file must contain the line:

The duration of the text being displayed depends on the frame rate of the corresponding video file. For example, if the frame rate of the corresponding video file is 25 frames per seconds and the subtitle file in last example is accompanied with, "Hello!" is displayed for one second. The software the MicroDVD Player expects the subtitle file to begin with the tag [BEGIN], and end with the tag [END].

Control Codes
The available control codes and their purpose are given:

The control code  defines font style.

"Hello!" is displayed in italic.

"Hello!" is displayed in bold.

"Hello!" is underlined.

"Hello!" is stroked.

The control code  defines font name.

"Hello!" is displayed using the defined font, with the string "fontname" determining the desired font. For example:

"Hello!" is displayed in the Arial typeface.

The control code  defines font size.

"Hello!" is displayed at the defined font size, with the string "size" determining the desired size as an integer number. For example:

"Hello!" is displayed at the font size of 10.

The control code  defines font color.

"Hello!" is displayed in a defined color. The color format is: $BBGGRR (8 bits blue, 8 bits green and 8 bits red). For example:

"Hello!" is displayed in full intensity red.

Note that this is not standard RGB color model, instead the color order is reversed.

The control code  defines subtitle position relative to video.

"Hello!" is displayed at the coordinates (X,Y).

Each line in the subtitle normally displays as a single line. However, the pipe character may be used to break a single line into multiple lines. For example:

The above code displays as follows:

On the other hand,

The above code displays as follows:

In this case, it is possible to define display values of each line or the whole subtitle line. If the control code is in upper case, it affects the whole subtitle line. If the control code is in lower case, it affects only the line it is contained in. For example:

The above code will display as two lines of italic text. But,

The above code will display as two lines; the first line in italic, and the second line in bold. Note that if no more code is used after a pipe character, the following lines will retain the same formatting. Note that the subtitle positioning code  must be logically always used in uppercase.

It is also possible to use multiple codes at once. Here is an example:

"Hello!" will be displayed underlined and in bold, in red and in the DeJaVuSans font at 12 points.

The default display values for a complete subtitle file may be defined using, which will override particular line formattings. For example, the following code may be used to display all subtitle line using DeJaVuSans at 10 points and in blue:

This line of code may be placed anywhere in the subtitle file. Also note that in this case, all control codes are in uppercase. There is also a code  to define a particular character set to use:

Defines that the Greek character set should be used. This code can be used only in the {DEFAULT} line.