EvilEngine/FLY: Difference between revisions

From Heavy Iron Modding
Content added Content deleted
Battlepedia>Wowaname
m (add decimal representation to number)
Battlepedia>AaronRules5
(Fixed up the Flythrough keyframe C structure.)
Line 10: Line 10:


<source lang=cpp>
<source lang=cpp>
struct zFlyKey
struct flyKeyFrame
{
{
UInt32 frameNumber;
int frame;
float matrix[12];
float cameraNormalizedLeft[3];
float aperture[2];
float cameraNormalizedUp[3];
float cameraNormalizedBackward[3];
float focal;
float cameraPosition[3];
float unknown[3];
};
};
</source>
</source>


* '''frame''' usually starts at either 1 or 0, and increments by 1 with each point.
* '''matrix'''
** index 0-2 is the right (reversed) vector
** index 3-5 is the up vector
** index 6-8 is the at (reversed) vector
** index 9-11 is the position
* '''aperture'''
* '''focal'''
[[Category:Asset]]
[[Category:Asset]]

Revision as of 07:25, 11 August 2020

FLY
Flythrough
TypeBinary

A Flythrough defines a path for the camera to move around a level. It is made up of individual points, each point defining the transform for the camera at a specified time. The time is measured in frames. 30 frames = 1 second.

Format

Flythroughs are stored in little-endian. There is no header, it is simply made up of the following struct which repeats until the end of the file. The total length in frames is the frame number of the last struct in the file. Each entry is 64 (0x40 hex) bytes long.

struct flyKeyFrame
{
	UInt32 frameNumber;
	float cameraNormalizedLeft[3];
        float cameraNormalizedUp[3];
        float cameraNormalizedBackward[3];
	float cameraPosition[3];
	float unknown[3];
};