Guide:Sequenced textures in LEGO Rock Raiders: Difference between revisions

From Research Realm
Line 117: Line 117:
As this edit will change the file length, additional edits are required to prevent the LWO model from being considered invalid. There are three types of values that need to be edited, two of which will have multiple entries to be edited if multiple sequenced textures are used in the same LWO file. Each of these values is stored in the file as a four-byte [[Wikipedia:ASCII|ASCII]] word followed by a [[Wikipedia:hexadecimal|hexadecimal]] number of a certain length. These values are:<ref name="rru sequenced guide"/>
As this edit will change the file length, additional edits are required to prevent the LWO model from being considered invalid. There are three types of values that need to be edited, two of which will have multiple entries to be edited if multiple sequenced textures are used in the same LWO file. Each of these values is stored in the file as a four-byte [[Wikipedia:ASCII|ASCII]] word followed by a [[Wikipedia:hexadecimal|hexadecimal]] number of a certain length. These values are:<ref name="rru sequenced guide"/>


* <code>FORM</code> – The LWO file's "[[Wikipedia:File format#Magic number|magic number]]" found at its very beginning. Immediately following it is a four-byte value defining the length of the entire file. This value is highlighted yellow in the above image.
* <code>FORM</code> – The LWO file's "[[Wikipedia:File format#Magic number|magic number]]" found at its very beginning. Immediately following it is a four-byte value defining the length of the entire file.
* <code>SURF</code> – Used at the beginning of each surface entry in the LWO file. Immediately following it is a four-byte value defining the length of that surface entry.
* <code>SURF</code> – Used at the beginning of each surface entry in the LWO file. Immediately following it is a four-byte value defining the length of that surface entry.
* <code>TIMG</code> – Used at the beginning of each texture entry in the LWO file; these will always be nested within surface entries. Immediately following it is a two-byte value defining the length of the texture's file path, followed by the file path for the texture (or in the case of sequenced textures, the first file in the sequence). Note that ''LEGO Rock Raiders'' only cares about the actual texture file name and not its path.
* <code>TIMG</code> – Used at the beginning of each texture entry in the LWO file; these will always be nested within surface entries. Immediately following it is a two-byte value defining the length of the texture's file path, followed by the file path for the texture (or in the case of sequenced textures, the first file in the sequence). Note that ''LEGO Rock Raiders'' only cares about the actual texture file name and not its path.

Revision as of 18:40, 1 December 2024

Sequenced textures are frequently used in LEGO Rock Raiders for steam effects

This modding guide for the 1999 video game LEGO Rock Raiders details how to add sequenced textures to models in the game.

What are sequenced textures?

Chief in-game, using NEW_Captain_Point_Qtalk.lws
FACE0001.bmp (sequence), a minifigure face talking and blinking
Chief's in-game model (left) uses a sequenced texture for his face to show him speaking
A spider walking
A spider standing
Small Spider sprites

In the Windows version of LEGO Rock Raiders, sequenced textures are textures that are animated in-game using a series of bitmap files. Sequenced textures can be used in any object that uses LightWave Scene files for animations, which includes the majority of objects in the game. In the original game they are mostly used only for particle effects, such as steam, dust, and teleportation.[1] Some notable exceptions include Chief's face during mission briefings, which is animated to show him speaking, and Small Spiders, which consist of a single quad polygon and use sequenced textures in place of animated models.

Where sequenced textures can be used

Sequenced textures can be used on the following objects in LEGO Rock Raiders, grouped by their entry blocks in the Main LEGO Config File:

  • All objects that use AE files:
    • MiniFigureTypes {} – Rock Raider minifigures. Only one type is in the final game, though it is possible to add more.
    • BuildingTypes {} – Rock Raider buildings. Many of these make extensive use of sequenced textures for steam effects.
    • VehicleTypes {} – Rock Raider vehicles, though not their upgrade parts; see below.
    • RockMonsterTypes {} – Creatures such as the Rock Monster and Slimy Slug.
    • Certain MiscObjects {} entries: Barrier, Dynamite, IceCube, OohScary, Pillar (unused), SpiderWeb.
  • All Chief animations found under Advisor {} and AdvisorPositions640x480 {} (or for other resolutions, AdvisorPositionsWxH {}).
  • Most MiscObjects {} entries: BirdScarer, BoulderExplode, BoulderExplodeIce, ElectricFenceStud, Explosion, Freezer, FreezerHit, LazerHit, LavaErosionSmoke1, LavaErosionSmoke2, LavaErosionSmoke3, LavaErosionSmoke4, LaserShot, LongElectricFenceBeam, MiniTeleportUp, PathDust, Pusher, PusherHit, RechargeSparkle, ShortElectricFenceBeam, SmashPath, UpgradeEffect.
Sequenced textures can be used in brief effects as well as continuous ones, as seen in the Support Station's animations

Sequenced textures can not be used for:

  • UpgradeTypes {} – All upgrades for vehicles and buildings are LWO files added on top of the main object, and are not tied to any LWS files. (Confirm: LWS upgrades can't be used?)
  • Certain MiscObjects {} entries: Boulder, Crystal, ElectricFence, Ore, ProcessedOre. (Confirm: can LWS files be used for these? should double check trigger's disassembly)
  • World Textures {} – These are applied to flat walls generated by the game engine. Walls and floors can use models in Eye/Shoulder view, but not animations.
  • All interface images, though FLIC animation files can be used for certain interface elements instead.

Requirements

The following requirements must be met for a sequenced texture to work in LEGO Rock Raiders:[1]

  • The texture files used must be 8-bit per pixel (8bpp) BMP files, like all textures in the game.
  • The texture file names must end with numbers. The first texture in the sequence should be numbered 1, though starting with 0 or a later number is possible using method 2. The numbers should be padded to the same number of digits for all textures in the sequence; eg. 0001 being 4 digits. Numbers are usually padded 2–4 digits in the base game; in practice 2 digits should be enough, unless you are using a very long sequence.
  • The LightWave Object file using the sequenced texture must specify it as such. The LWO should link to the first file in the sequence and contain " (sequence)" at the end of the file path.
  • The LightWave Object file using the sequenced texture must be used in a LightWave Scene animation file. Ideally, the LWS should be the same number of frames in length as the sequenced texture, or a number of frames in length that is divisible by the number of frames in the sequenced texture, to ensure that the texture loops properly. This is not necessary, but any sequence frames past the end of the LWS animation will be cut off, and certain standing animations are 0 frames long and will not play any sequenced textures. (Confirm: do sequences play in-game at 25 fps, regardless of the LWS framerate settings?)

Using LightWave 3D 5

This section of the guide details how to create a sequenced texture using LightWave 3D 5. Version 5 was first released in 1995 and was updated to version 5.5 in 1997 and version 5.6 in 1998;[2] one or both of the latter two versions were used by Data Design Interactive (and by extension, Artworld UK) in the development of LEGO Rock Raiders. For this guide LightWave 3D 5.6 is being used; this version will still run on Windows 10, but users may find its interface difficult compared to later versions.

The LightWave file formats changed starting in version 6, though many later versions can still save LightWave 5 objects and 5.6 scenes. While these later versions still support sequenced textures, and can load LightWave 5 models that use sequenced textures, they will not properly save sequenced textures in the LightWave 5 format. To get around this, either save your model without sequenced textures and then load it into LightWave 5, or follow the hex editing section below.

This tutorial assumes you already have a model ready to texture. If not, and you do not want to reuse a model form the game's files, you will have to create one – this will be covered in a separate guide. You will also need to have your sequence files created, saved as 8-bit BMPs, and named properly – what these files display, as with the model, is up to you. For this guide, the model is a simple octagonal object with two colored squares, which will each display different flashing numbers – see image 1 above. Once you have your model, open LightWave 3D (the main animation part of the software; see image 2), either via the program's executable or by clicking the "Layout" button in the upper right corner of the Modeler.

In LightWave 3D, click the "Object" button in the top toolbar to open the Objects Panel (image 3). On this panel, click "Load Object" and navigate to the LWO file you want to use. You can click "Close Panel" at the bottom to close the object panel, or simply switch to a new panel. The model should now be loaded into the scene (image 5); from here you can move it or even animate it however you want.

Click the "Images" button in the top toolbar to open the Images Panel. Click "Load Sequence" and navigate to the BMP files you want to use (image 5). Select the first entry in the sequence; this should be the file numbered 1, though one numbered 0 can be selected. File 0 will be set to frame 0, which can be viewed in the animation editor but will not display when playing the animation, which will start on frame 1; this also applies to when the animation is loaded into LEGO Rock Raiders. If there is no file 0, frame 0 will show a completely black image, so including a file 0 that is a duplicate of file 1 may be helpful while editing. You can set file 0 to be the first one via hex editing though.

Once the sequence has been loaded, LightWave will automatically detect the amount of digits in the sequence number and will play all detected images in the sequence (image 6). The number of files in the sequence can be increased or decreased by adding or removing them, or the files can be edited, and LightWave will automatically change the animation without having to reload. In LightWave, the sequence will stop once it reaches the last file, and stay there until the entire animation loops back to the beginning. You can enable "Loop Sequence" and set the Sequence Loop Length to how long the sequence is to fix this. However, LEGO Rock Raiders will automatically loop the sequence regardless, and in fact appears to completely ignore this setting, so this is only to make editing easier.

Close the Images Panel and click the "Surfaces" button in the top toolbar to open the Surfaces Panel (image 7). Select the surface you want to apply the sequenced texture to. Under the Basic Parameters tab, click the "T" (texture) button to the right of the first entry, Surface Color, to open the Color Texture panel for that surface (image 8). Click the Texture Image dropdown and select the sequence you want to use.

You can adjust the image to fit on the surface the way you want, using the options in the bottom half of the panel; you will likely need to resize it (in some situations, this can be easily done using "Automatic Sizing" and may need to change the Texture Axis depending on the direction the surface is angled (in the LWO – rotating the model in the LWS will not affect this). In some situations the texture may be applied mirrored, and you will have to manually change the Texture Size (possibly fixed by setting a value to a negative number). Click "Use Texture" to close this panel.

Once you have finished applying all textures, open the Objects Panel again and save the LWO model.

If you want to save the LWS animation as well, make sure the animation's framerate is set to what you want. Editing "Last Frame" in the bottom right corner will not be enough (see if LRR reads this at all); you need to click the "Render" button in the bottom left to open the render panel and set "Render Last Frame" to what you want. (This part may need to be moved to a general LightWave tutorial). Click "File" in the top left corner and click "Save Scene" to save the animation.

Here is the model in the game. It may not fit the game's style or be very good, but the point here is to show how sequenced textures work. The left texture on the model counts from 0 to 24, while the right texture counts from 0 to 3. The framerate of the animation and sequences are both defined by the game's global timer, which runs at 25 frames per second; the framerate defined in the LWS file is ignored by the game.[1] The entire animation is 50 frames long, letting the left texture play exactly twice and the right one play twelve times. As 50 is not divisible by 4, you may notice that the right texture gets abruptly cut off when the LWS animation reaches its last frame and loops back to the beginning; this will happen to any sequenced textures that do not line up exactly with the length of the animation. As is always the case, how you avoid or take advantage of this is up to you.

Using a hex editor

An LWO file in a hex editor; the relevant values mentioned in this guide have been highlighted with different colors:
  4-byte value for FORM
  4-byte value for SURF
  2-byte value for TIMG
  11-byte  (sequence) flag
  8-byte value for IMSQ (optional)

Assuming you already have a way to save textured LightWave 5 models, adding sequenced textures with a hex editor is relatively simple. For this method you may need a basic understanding of hexadecimal numbers, or a calculator that can convert between decimal and hexadecimal numbers.[1] Any functioning hex editor should work for this; the images in this guide use XVI32, a simple and free hex editor that will run on nearly any version of Windows between Windows 95 and Windows 11.

To mark a texture as being sequenced, change its file path to end with " (sequence)" (hexadecimal: 20 28 73 65 71 75 65 6E 63 65 29). For instance, a file path originally reading C:\\Models\example\sample001.bmp would now be changed to C:\\Models\example\sample001.bmp (sequence). Make sure to include the space between the file extension and the parenthesis; note that this uses a true space (0x20) rather than a null character (0x00).[1]

As this edit will change the file length, additional edits are required to prevent the LWO model from being considered invalid. There are three types of values that need to be edited, two of which will have multiple entries to be edited if multiple sequenced textures are used in the same LWO file. Each of these values is stored in the file as a four-byte ASCII word followed by a hexadecimal number of a certain length. These values are:[1]

  • FORM – The LWO file's "magic number" found at its very beginning. Immediately following it is a four-byte value defining the length of the entire file.
  • SURF – Used at the beginning of each surface entry in the LWO file. Immediately following it is a four-byte value defining the length of that surface entry.
  • TIMG – Used at the beginning of each texture entry in the LWO file; these will always be nested within surface entries. Immediately following it is a two-byte value defining the length of the texture's file path, followed by the file path for the texture (or in the case of sequenced textures, the first file in the sequence). Note that LEGO Rock Raiders only cares about the actual texture file name and not its path.

As the  (sequence) flag is 11 bytes long, you will need to add 11 (0x0B in hexadecimal) to each of these values. For multiple sequenced textures, you will need to add 11 to each SURF and TIMG value assigned to the entries containing the sequence, and then add 11 multiplied by the number of sequences to FORM. 2 sequenced textures would be 22 extra bytes (0x16 in hexadecimal), 3 sequenced textures would be 33 extra bytes (0x21), etc.[1] Make sure to only edit the SURF and TIMG entry or entries that contain your sequenced textures.

Alternatively, you can avoid most of the above by initially changing the file name of the first BMP in the sequence to have 11 extra characters. After the texture has been applied to the model, you can open the LWO file and delete the extra characters to make space for the " (sequence)" flag, without the file length being affected. Another option is to simply add " (sequence)" to the BMP file name before adding it to the model, then edit the LWO to move the placement of .bmp.

  • Example: rename the first file in the sequence abc from abc001.bmp to abc001 (sequence).bmp, then once the LWO file has been saved edit the texture's entry will now read abc001.bmp (sequence).

Be sure to rename the BMP file to remove " (sequence)" or any other extra characters before adding the files to the game.

Optional IMSQ fix

Optional: When saving a sequence using LightWave 5, the LWO file will contain an IMSQ block after the two null characters following the texture path. LEGO Rock Raiders does not require this section to display sequenced textures, but LightWave does, and sequences added using the above hex editor method will not be loaded. If you want to make your model fully compatible with LightWave, you can add this after each sequence entry; this will add an addition 12 bytes (0x1C) per entry to FORM, SURF, and TIMG. The values following IMSQ are:

  • 2 bytes: The length in bytes of the IMSQ entry. This seems to always be 00 06.
  • 2 bytes: Frame Offset. Default is 0
  • 2 bytes: Loop Sequence and Interlaced options. 00 00 for all disabled (default), 00 01 for Loop Sequence checked, 00 02 for Interlace checked, 00 03 for both.
  • 2 bytes: the Sequence Loop Length. Default is 30 (00 1E), though you may want to change it to be the length of the sequence used.

The default hexadecimal data added would be 49 4D 53 51 00 06 00 00 00 00 00 1E. However some files in Rock Raiders have Loop Sequence enabled and the Sequence Loop Length set to a different number, likely based on the length of the sequence.

Tips

Some important tips to remember, especially if you are new to hex editing:

  • When editing values, make sure that you are overwriting the existing numbers rather than adding new ones, or the file's structure will be corrupted and it will be considered invalid.[1]
  • Remember that each hexadecimal byte is written as two digits, so you will need to add a leading zero if your value has an odd number of digits; for instance, if your calculator gives you a value of 1A4, you will need to write it in the file as 01 A4.[1]
  • All values in LWO files big-endian, so you will not have to to swap the byte order like when editing little-endian files. The latter is used in some other binary files in Rock Raiders, such as map files.

References

  1. a b c d e f g h i Sokol, Alan (December 20, 2017) [October 14, 2017]. "Animated Textures on Models". Rock Raiders United. Archived from the original on November 13, 2024.
  2. Scott, Dean A.; Vost, Ben (11 September 2024) [2002]. "LightWave History: All the versions of LightWave - so far". LightWave 3D. LightWave Digital. Archived from the original on 26 November 2024. Retrieved 30 November 2024.