mirror of https://github.com/odrling/Aegisub
99 lines
3.5 KiB
Plaintext
99 lines
3.5 KiB
Plaintext
|
|
|
|
WARNING: THIS FILE IS HEAVILY OUTDATED!!!!!
|
|
|
|
|
|
Pre-Rendered Subtitles
|
|
----------------------
|
|
|
|
PRS stores either full PNG images, partial PNG images (through a number of
|
|
blocks) or instructions to do simple modifications (translation, clearing)
|
|
to the current output.
|
|
|
|
PRS only uses 32 bit RGBA images.
|
|
|
|
The data format is binary, designed for integration into containers such as
|
|
Matroska.
|
|
|
|
PRS subtitle files can be generated by specialised software (rendering directly
|
|
to a PRS file or other container supporting PRS) or by a commandline program
|
|
taking a PRS definition file and a number of PNG images as input.
|
|
The PRS definition file is a text file describing the images to be displayed.
|
|
|
|
PRS subtitles are frame-based, that is, a PRS subtitle picture is linked to one
|
|
or more frame-numbers in the video.
|
|
|
|
All integers are 32 bit unsigned Little Endian unless otherwise specified.
|
|
|
|
|
|
PRS stand-alone file format
|
|
---------------------------
|
|
|
|
The file starts with a 32 bit magic number, formed by the ASCII string
|
|
"PRS".
|
|
The magic is followed by an integer specifying the length in bytes of the
|
|
subpicture stream name. The subpicture stream name follows immediately
|
|
after the length specifier, and is an UTF-8 encoded freeform string. (It may
|
|
contain embedded NUL characters, but this is discouraged. It is encouraged to
|
|
terminate the stream name with a NUL character.)
|
|
|
|
The header is followed by a number of image deifnitions and display commands.
|
|
Image definitions and display commands can be mixed in any way, as long as
|
|
no display command refers to an undefined image.
|
|
If an image identifier is defined twice, the later definition overrides any
|
|
earlier ones.
|
|
|
|
0x00 "PRS" (zero-terminated)
|
|
0x04 version number (32 bit unsigned)
|
|
0x08 stream name size (32 bit unsigned)
|
|
0x012 stream name string (this won't be writen if the size is 0)
|
|
|
|
|
|
Image Definition IMG
|
|
|
|
This defines an image data block. This image definition starts with the 32 bit
|
|
magic "IMG". This is followed by an integer image identifier, an integer
|
|
image byte size and the image data, encoded in the apropriate format.
|
|
|
|
0x00 "IMG" (zero-terminated)
|
|
0x04 block length (32 bit unsigned)
|
|
0x08 image identifier (32 bit unsigned)
|
|
0x0C image format (32 bit unsigned; 1 = PNG, and the only supported format for now)
|
|
0x10 image data length (32 bit unsigned)
|
|
0x14 image data
|
|
|
|
|
|
Display Command DSP
|
|
|
|
This controls when and how images are displayed on the video.
|
|
Start and end frame numbers are both inclusive.
|
|
|
|
0x00 "DSP" (zero-terminated)
|
|
0x04 block length (32 bit unsigned)
|
|
0x08 start time in miliseconds (32 bit unsigned)
|
|
0x0C end time in miliseconds (32 bit unsigned)
|
|
0x10 image identifier (32 bit unsigned)
|
|
0x1C layer (16 bit signed)
|
|
0x14 x position (16 bit signed)
|
|
0x18 y position (16 bit signed)
|
|
0x1A alpha multiplier (8 bit unsigned)
|
|
0x1B blend mode (8 bit unsigned)
|
|
|
|
Alpha multiplier:
|
|
0x00 is "invisible",0xFF is "fully visible". This value is multiplied onto
|
|
the alpha value of each pixel in the image to get the actual alpha value for
|
|
that pixel.
|
|
|
|
Blend modes:
|
|
0 none (dest*(1-alpha) + src*alpha)
|
|
1 add (dest*(1-alpha) + (src+dest)*alpha)
|
|
2 subtract (dest*(1-alpha) + (src-dest)*alpha)
|
|
3 inverse subtract (dest*(1-alpha) + (dest-src)*alpha)
|
|
4 multiply (dest*(1-alpha) + src*dest*alpha)
|
|
Values are clipped before they are multiplied with alpha.
|
|
|
|
Layers:
|
|
If picture A's layer number is larger than picture B, picture A is displayed
|
|
on top of picture B. If two pictures have the same layer number, no order is
|
|
defined. (It's recommended to use the ordering of the display commands.)
|