OpenDocument Spreadsheet files can be loaded into your game similar to .csv files. Technically, .ods files are converted to .csv files by the FlatRedBall Editor and are loaded as if they are standard CSV files.
Using .ods files offers a number of benefits over .csv files:
- They can contain formulas
- They can contain styling and formatting, such as cell colors or bold text
- They can contain dropdowns and other formatted cell types
The .ods file format does add a small amount of complexity to your projct:
- .ods files must be converted to .csv which requires installing LibreOffice
- .ods file conversion to .csv is performed by the FlatRedBall Editor if the .ods file is newer than the .csv, or if the .csv is missing. This takes a short amount of time when first opening the project.
FRB creates a class for your .ods file using the same rules as .csv files. For information about the automatic generation of data for .csv files, see the .csv page.
To add a new .ods file:
- Decide where to keep the .ods file. Usually game data such as .ods and .csv files are stored in Global Content Files
- Right-click on the desired location (such as Global Content Files) and select Add New File
- Select the ods file type
- Enter a name, such as EnemyData
- Click OK
Adding EnemyData ods file type
Confirm the conversion of .ods to .csv in the popup window by clicking OK.
Popup for confirming to use open office (soffice.exe)
The newly-created file should appear in the tree view in FRB. Notice that the file is listed as a .csv file since it is converted from .ods to .csv.
EnemyData.csv in the tree view.
You can confirm the original file is an .ods file by selecting the file and viewing its properties.
EnemyData.csv properties displays its source file and build tool (conversion executable)
FlatRedBall automatically creates a backing data class for your file which matches the name of the .ods file. For example, the following screenshot shows the EnemyData class using the default contents of the .ods.
EnemyData class automatically created in generated code
Similarly, the enemy data class is loaded in the object which contains the .ods file. Using the example from above, the EnemyData file would be loaded into GlobalContent and it can be accessed as shown in the following code:
// This assumes that the data is loaded into a List, not a Dictionary
var firstItem = GlobalContent.EnemyData[0];
var health = firstItem.Health;