2012-03-23 20:30:31 +00:00
< html >
< head >
< title > .fm2< / title >
< meta http-equiv = "Content-Type" content = "text/html; charset=UTF-8" >
2012-08-08 15:00:14 +00:00
< meta name = "generator" content = "HelpNDoc Personal Edition 3.6.0.345" >
2012-03-23 20:30:31 +00:00
< link type = "text/css" rel = "stylesheet" media = "all" href = "css/reset.css" / >
< link type = "text/css" rel = "stylesheet" media = "all" href = "css/base.css" / >
< link type = "text/css" rel = "stylesheet" media = "all" href = "css/hnd.css" / >
<!-- [if lte IE 8]>
< link type = "text/css" rel = "stylesheet" media = "all" href = "css/ielte8.css" / >
<![endif]-->
2012-07-01 14:11:24 +00:00
< style type = "text/css" >
#topic_header
{
background-color: #EFEFEF;
}
< / style >
2012-03-23 20:30:31 +00:00
< script type = "text/javascript" src = "js/jquery.min.js" > < / script >
< script type = "text/javascript" src = "js/hnd.js" > < / script >
2012-08-08 15:00:14 +00:00
< script type = "text/javascript" >
2012-03-23 20:30:31 +00:00
if (top.frames.length == 0)
2012-07-01 14:11:24 +00:00
{
var sTopicUrl = top.location.href.substring(top.location.href.lastIndexOf("/") + 1, top.location.href.length);
top.location.href = "fceux.html?" + sTopicUrl;
}
2012-03-23 20:30:31 +00:00
else if (top & & top.FrameTOC & & top.FrameTOC.SelectTocItem)
2012-07-01 14:11:24 +00:00
{
top.FrameTOC.SelectTocItem("fm2");
}
2012-03-23 20:30:31 +00:00
< / script >
< / head >
< body >
< div id = "topic_header" >
< div id = "topic_header_content" >
< h1 > .fm2< / h1 >
< div id = "topic_breadcrumb" >
< a href = "Technicalinformation.html" > Technical Information< / a > › › < a href = "Movieformats.html" > Movie & Savestate formats< / a > › › < / div >
< / div >
< div id = "topic_header_nav" >
< a href = "Movieformats.html" > < img src = "img/arrow_up.png" alt = "Parent" / > < / a >
< a href = "Movieformats.html" > < img src = "img/arrow_left.png" alt = "Previous" / > < / a >
< a href = "fcm.html" > < img src = "img/arrow_right.png" alt = "Next" / > < / a >
< / div >
< div class = "clear" > < / div >
< / div >
< div id = "topic_content" >
< p > < span class = "rvts12" > FCEUX Movie File format< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > FCEUX uses a new movie file format - .fm2.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > This differs from the previous FCE Ultra movie format (.fcm) in the following ways:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > It is text based by default; allowing easy movie editing/splicing< / li >
< li > An imbedded GUID so FCEUX can tell if a savestate belongs to a movie file< / li >
< li > Movies recorded from Start (Power-on) no longer have a redundant savestate< / li >
< li > Contains mouse input for recording the Zapper & Arkanoid Paddle< / li >
< / ul >
< p > < br / > < / p >
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > < span class = "rvts16" > Format< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-26 18:40:35 +00:00
< p > FM2 consists of two parts: Header and Input Log.< / p >
2012-03-25 15:37:45 +00:00
< p > The header is always in ASCII plain text format. It consists of several key-value pairs.< / p >
< p > The input log section can be identified by it starting with a | (pipe).< / p >
< p > The input log section can be either in ASCII plain text format or in binary format.< / p >
2012-07-01 14:11:24 +00:00
< p > The input log section terminates at EOF, unless the < span class = "rvts38" > length< / span > key is specified in header.< / p >
2012-03-25 15:37:45 +00:00
< p > Newlines may be \r\n or \n.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > < span class = "rvts16" > Header< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > Key-value pairs consist of a key identifier, followed by a space separator, followed by the value text.< / p >
2012-03-25 15:37:45 +00:00
< p > Value text is always terminated by a newline, which the value text does not include.< / p >
2012-03-23 20:30:31 +00:00
< p > The value text is parsed differently depending on the type of the key.< / p >
< p > The key-value pairs may be in any order, except that the first key must be version.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > Integer keys (also used for booleans, with a 1 for true and 0 for false) must have a value that can be stored as int32:< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - version< / span > (required) - the version of the movie file format; for now it is always 3< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - emuVersion< / span > (required) - the version of the emulator used to produce the movie< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - rerecordCount< / span > (optional) - the rerecord count< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > -< span class = "rvts38" > palFlag< / span > (bool) (optional) - true if the movie uses PAL timing< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > -< span class = "rvts38" > NewPPU< / span > (bool) (optional) - true if the movie uses New PPU< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - FDS< / span > (bool) (optional) - true if movie was recorded on a Famicom Disk System (FDS) game< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - fourscore< / span > (bool) - true if a fourscore was used. If fourscore is not used, then port0 and port1 are required< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - port0 < / span > - indicates the type of input device attached to the port 0. Supported values are:< / p >
2012-03-25 15:37:45 +00:00
< p > SI_NONE = 0< / p >
2012-03-26 18:40:35 +00:00
< p > SI_GAMEPAD = 1< / p >
2012-03-25 15:37:45 +00:00
< p > SI_ZAPPER = 2< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - port1< / span > - indicates the type of input device attached to the port 1. Supported values are:< / p >
2012-03-25 15:37:45 +00:00
< p > SI_NONE = 0< / p >
2012-03-26 18:40:35 +00:00
< p > SI_GAMEPAD = 1< / p >
2012-03-23 20:30:31 +00:00
< p > SI_ZAPPER = 2< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - port2< / span > (required) - indicates the type of the FCExp port device which was attached. Supported values are:< / p >
2012-03-23 20:30:31 +00:00
< p > SIFC_NONE = 0< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - binary< / span > (bool) (optional) - true if input log is stored in binary format< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-23 16:45:36 +00:00
< p > < span class = "rvts38" > - length< / span > (optional) - movie size (number of frames in the input log). If this key is specified and the number is > = 0, the input log ends after specified number of records, and any remaining data should not be parsed. This key is used in < span class = "rvts62" > fm3< / span > format to allow storing extra data after the end of input log< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > String keys have values that consist of the remainder of the key-value pair line. As a consequence, string values cannot contain newlines.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - romFilename< / span > (required) - the name of the file used to record the movie< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - comment < / span > (optional) - simply a memo< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 36px; list-style-position: outside;" >
< li > by convention, the first token in the comment value is the subject of the comment< / li >
< li > by convention, subsequent comments with the same subject should have their ordering preserved and may be used to approximate multi-line comments< / li >
< li > by convention, the author of the movie should be stored in comment(s) with a subject of: < span class = "rvts38" > author< / span > < / li >
< / ul >
2012-03-23 20:30:31 +00:00
< p > Example:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > comment author adelikat< / li >
< / ul >
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - subtitle < / span > (optional) - a message that will be displayed on screen when movie is played back (unless Subtitles are turned off, see < a class = "rvts18" href = "MovieOptions.html" > Movie options< / a > )< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 36px; list-style-position: outside;" >
< li > by convention, subtitles begin with the word "subtitle"< / li >
< li > by convention, an integer value following the word "subtitle" indicates the frame that the subtitle will be displayed< / li >
< li > by convention, any remaining text after the integer is considered to be the string displayed< / li >
< / ul >
2012-03-23 20:30:31 +00:00
< p > Example:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > subtitle 1000 Level Two< / li >
< / ul >
2012-03-23 20:30:31 +00:00
< p > At frame 1000 the words "Level Two" will be displayed on the screen< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - guid < / span > (required) - a unique identifier for a movie, generated when the movie is created, which is used when loading a savestate to make sure it belongs to the current movie< / p >
2012-03-23 20:30:31 +00:00
< p > GUID keys have a value which is in the standard guide format: 452DE2C3-EF43-2FA9-77AC-0677FC51543B< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts65" > < br / > < / span > < / p >
2012-07-23 16:45:36 +00:00
< p > < span class = "rvts38" > - romChecksum < / span > (required) - the base64 of the hexified MD5 hash of the ROM which was used to record the movie< / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts64" > < br / > < / span > < / p >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > - savestate < / span > (optional) - a < a class = "rvts18" href = "fcs.html" > fcs< / a > savestate blob, in case a movie was recorded from savestate < / p >
2012-03-25 15:37:45 +00:00
< p > Hex string keys (used for binary blobs) have a value that is like 0x0123456789ABCDEF...< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > < span class = "rvts16" > Input log< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > The input log section consists of movie records either in the form of text lines or in the form of binary data.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
2012-07-23 16:45:36 +00:00
< p > < span class = "rvts63" > Text format (default format):< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > Every frame of the movie is represented by line of text beginning and ending with a | (pipe).< / p >
< p > The fields in the line are as follows, except when fourscore is used.< / p >
2012-07-23 16:45:36 +00:00
< p > < span class = "rvts66" > |commands|port0|port1|port2|< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-07-01 14:11:24 +00:00
< p > Field < span class = "rvts38" > commands< / span > is a variable length decimal integer which is interpreted as a bit field corresponding to miscellaneous input states which are valid at the start of the frame. Current values for this are:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > 1 = Soft Reset< / li >
< li > 2 = Hard Reset (Power)< / li >
< li > 4 = FDS Disk Insert< / li >
< li > 8 = FDS Disk Select< / li >
< / ul >
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > The format of port0, port1, port2 depends on which types of devices were attached.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > SI_GAMEPAD:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > the field consists of eight characters which constitute a bit field< / li >
< li > any character other than ' ' or '.' means that the button was pressed< / li >
< li > by convention, the following mnemonics are used in a column to remind us of which button corresponds to which column: < span class = "rvts38" > RLDUTSBA< / span > (Right, Left, Down, Up, sTart, Select, B, A)< / li >
< / ul >
< p > < br / > < / p >
2012-03-23 20:30:31 +00:00
< p > SI_ZAPPER:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > < span class = "rvts38" > XXX YYY B Q Z< / span > < / li >
< / ul >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts38" > XXX: < / span > %03d, the x position of the mouse< / p >
< p > < span class = "rvts38" > YYY: < / span > %03d, the y position of the mouse< / p >
< p > < span class = "rvts38" > B: < / span > %1d, 1 if the mouse button is pressed; 0 if not< / p >
< p > < span class = "rvts38" > Q: < / span > %1d, an internal value used by the emulator's zapper code< / p >
< p > < span class = "rvts38" > Z: < / span > %d, a variable-length decimal integer; an internal value used by the emulator's zapper code< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > SI_NONE:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > the field must be empty< / li >
< / ul >
< p > < br / > < / p >
2012-07-01 14:11:24 +00:00
< p > If a < span class = "rvts38" > fourscore< / span > is used, then port0 and port1 are irrelevant and ignored.< / p >
2012-03-26 18:40:35 +00:00
< p > The input types must all be gamepads, and each input log record must be in the following format:< / p >
2012-07-23 16:45:36 +00:00
< p > < span class = "rvts66" > |commands|RLDUTSBA|RLDUTSBA|RLDUTSBA|RLDUTSBA|port2|< / span > < / p >
2012-03-25 15:37:45 +00:00
< p > {commands, player1, player2, player3, player4, port2}< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
2012-07-23 16:45:36 +00:00
< p > < span class = "rvts63" > Binary format:< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > Input log section starts with a | (pipe).< / p >
2012-03-26 18:40:35 +00:00
< p > Every frame of the movie is represented by a record of a fixed length which can be determined by the devices on port0 and port1.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-26 18:40:35 +00:00
< p > The first byte of each record stores "commands" bit field.< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > bit 0 = Soft Reset< / li >
< li > bit 1 = Hard Reset (Power)< / li >
< li > bit 2 = FDS Disk Insert< / li >
< li > bit 3 = FDS Disk Select< / li >
< / ul >
< p > < br / > < / p >
2012-03-26 18:40:35 +00:00
< p > The remaining bytes in the record depend on which types of devices are attached to port0 and port1.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > SI_GAMEPAD:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > 1 byte added to the size of record< / li >
< li > bits of the byte represent the state of buttons (bit0 = A, bit1 = B, bit2 = Select, bit3 = sTart, bit4 = Up, bit5 = Down, bit6 = Left, bit7 = Right). If the bit is set, respective button is considered to be pressed, if the bit is clear, the button is not pressed< / li >
< / ul >
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > SI_ZAPPER:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > 12 bytes added to the size of record< / li >
< li > 1st byte - the x position of the mouse< / li >
< li > 2nd byte - the y position of the mouse< / li >
< li > 3rd byte - 1 if the mouse button is pressed; 0 if not< / li >
< li > 4th byte - an internal value used by the emulator's zapper code< / li >
< li > bytes 5-12 (uint64) - an internal value used by the emulator's zapper code< / li >
< / ul >
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > SI_NONE:< / p >
2012-08-08 15:00:14 +00:00
< ul style = "text-indent: 0px; margin-left: 24px; list-style-position: outside;" >
< li > 0 bytes added to the size of record< / li >
< / ul >
< p > < br / > < / p >
2012-07-01 14:11:24 +00:00
< p > If a < span class = "rvts38" > fourscore< / span > is used, then port0 and port1 are irrelevant and ignored. 4 bytes are added to the size of record. The bits of the 1st byte represent the state of buttons of the 1st joypad (bit0 = A, bit1 = B, bit2 = Select, bit3 = sTart, bit4 = Up, bit5 = Down, bit6 = Left, bit7 = Right); bits of the 2nd byte represent the state of buttons of the 2nd joypad, and so on.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
< hr style = "height: 1px; color : #000000; background-color : #000000; border-width : 0px;" / >
2012-07-01 14:11:24 +00:00
< p > < span class = "rvts42" > Notes:< / span > < / p >
2012-08-08 15:00:14 +00:00
< p > < span class = "rvts42" > < br / > < / span > < / p >
2012-03-25 15:37:45 +00:00
< p > A. All movies start from power-on, unless a savestate key-value is present.< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
2012-03-25 15:37:45 +00:00
< p > B. The emulator uses these framerate constants< / p >
< p > - NTSC: 1008307711 /256/65536 = 60.099822938442230224609375< / p >
< p > - PAL : 838977920 /256/65536 = 50.00698089599609375< / p >
2012-08-08 15:00:14 +00:00
< p > < br / > < / p >
< p > < br / > < / p >
< p > < br / > < / p >
< p class = "rvps2" > < span class = "rvts13" > Created with the Personal Edition of HelpNDoc: < / span > < a class = "rvts14" href = "http://www.helpndoc.com/feature-tour/iphone-website-generation" > Create iPhone web-based documentation< / a > < / p >
2012-03-23 20:30:31 +00:00
< / div >
< div id = "topic_footer" >
< div id = "topic_footer_content" >
2012< / div >
< / div >
< / body >
< / html >