/zonebuilder

Fastfile Generator for IW4

Primary LanguageC++

Introduction

Zonebuilder is a tool that was designed to aid in the creation of custom assets for the Fourth Infity Ward Iteration of a certain popular FPS series.

Setup

The first step to making your custom assets is to setup your development forlder correctly. I recommend simply extracting the program directly into your game folder. This will help with most of the setup. You need a full game installation for the program to work as it requires many game files to work.

Folder Structure

This is the basic folder structure that needs to exist in your game folder. If you extracted the program directly into your game folder then this should already be set up for you. It also includes an example asset (weapon model with anims) for you to test with.
  • /zone_source
    • *.csv files
  • /zonebuilder
    • /images
    • /materials
    • /sounds
    • /fx
    • build scripts
    • any resource files needed to build fastfiles

File Formats

CSV File

CSV files are included throughout the project (and the game) and describe data through use of a very simple format shown below. ``` value1, value2, value3 value4, , value5 value6, value7, value8 ```

zone_source CSV files

Each row of this file describes an asset in the fastfile that will be built. The rows can be described 2 different ways. You can use any kind of combination of these two in a csv file.

Custom Asset

type, asset name, asset filename

Repacking Asset note: for here you need the asset loaded from a source (-s) zone

type, asset name

Material CSV files

Materials are described by CSV files even though their extension is ".txt". Their format is as follows. ``` option, value ``` These options are described in the table below.
option value description
basemat The base material to use.
colorMap color map image
normalMap normal map image
specularMap specular image
detailMap camo image

XME, XAE, and IWI

These are files that define models, animations, and images respectively. They are the files referenced in the zone's csv file when creating a custom asset. They are binary formats and not described here.

Building a custom Fastfile

Custom Fastfiles are one of the ways that you can load custom assets into the game. This process is fairly simple if you followed the setup process correctly. I will refer to paths in reference to the base folder of your game installation.

Step 1: First step is to create a .csv for your new fastfile. Using the format described above, create a csv that includes all the assets that you wish to include in your fastfile.

Step 2: Make sure all of your asset files are in their correct folders inside the /zonebuilder directory. If files aren't in here then the tool will be unable to find them.

Step 3: Run Zonebuilder. The simpelest way to do this is to simply call zonebuilder.exe fastfile where fastfile is the name of your csv. This will output a fastfile into the /zone/language folder.

Custom Models

Coming Soon...

Custom Anims

Coming Soon...

Custom Materials

Coming Soon...

Custom Sounds

In order to make a custom sound you must have a compatable sound file (mp3 or wav). The definition for the sound alias is a text file which contains JUST the filename of the sound. Sounds must be placed in the /sound subdirectory. an example of the corresponding csv line for a sound alias called "explosion3" with a sound file of "sound/explosions/expl3.wav" would be: ```sound,explosion3,sound/expl3.txt ``` and the contents of sound/expl3.txt would be: ```sound/explosions/expl3.wav ```

Command Line Options

__-s__: Load a fastfile to be used as a source zone. You can have as many source zones as you want. but be careful about overflowing asset pools. This isn't checked by the tool. *note: there is no space between the -s and the fastfile name!*

-v: This option allows you to verify a created fastfile. Prints out every asset in the fastfile.

-d: Dumps certain assets from the game to a format that can be rebuilt by this tool.

-b: Change the value of fs_basegame. Defaults to "zonebulder". Where you place all data the tool uses.