• Stars
    star
    308
  • Rank 135,712 (Top 3 %)
  • Language
    C#
  • License
    Do What The F*ck ...
  • Created over 3 years ago
  • Updated about 2 months ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

A .NET library written in C# for extracting game assets and reading game assets from Final Fantasy XIV: A Realm Reborn.

Saint Coinach

A .NET library written in C# for extracting game assets and reading game assets from Final Fantasy XIV, now with support for including the Libra Eorzea database.

Functionality

Fully implemented

  • Extraction of files from the game's SqPack files based on their friendly name (or by Int32 identifiers, if preferred).
  • Conversion of the game's textures to System.Drawing.Image objects.
  • Parsing and reading from the game's data files (*.exh and *.exd).
  • Decoding of OGG files stored in the game's pack files (some of the *.scd).
  • OO-representation of the most important game data.
  • Self-updating of the mapping between game data and their OO-representation, in case things move around inside the game's files betwen patches.

Partially implemented

  • Decoding of the string format used by the game. Will return a good string for most queries, but more advanced things like conditional texts are not supported.
  • Parsing of model data works for most models but is still incomplete.
  • Inclusion and parsing of data from the Libra Eorzea application.

To-do

  • Support for audio formats other than OGG.

Usage

Set-up

Note: When building an application using this library make sure to include a copy of SaintCoinach/SaintCoinach.History.zip in the application's directory. This should be done automatically if the project is included in the solution and referenced from there.

All important data is exposed by the class SaintCoinach.ARealmReversed, so setting up access to it is fairly straightforward.

The following is an example using the game's default installation path and English as default language:

const string GameDirectory = @"C:\Program Files (x86)\SquareEnix\FINAL FANTASY XIV - A Realm Reborn";
var realm = new SaintCoinach.ARealmReversed(GameDirectory, SaintCoinach.Ex.Language.English);

It's that simple. It is recommended, however, to check if the game has been updated since the last time, which is accomplished like this, in this example including the detection of data changes:

if (!realm.IsCurrentVersion) {
    const bool IncludeDataChanges = true;
    var updateReport = realm.Update(IncludeDataChanges);
}

ARealmReversed.Update() can also take one additional parameter of type IProgress<UpdateProgress> to which progress is reported. The returned UpdateReport contains a list of changes that were detected during the update.

Accessing data

Game files can be access directly through ARealmReversed.Packs, game data can be accessed through ARealmReversed.GameData.

Game Data (XivCollection)

Specific collections can be retrieved using the GetSheet<T>() method. Note: This only works for objects whose game data files have the same name as the class. This applies for most classes directly inside the SaintCoinach.Xiv namespace, so there should be no need to worry about it in most cases.

Special cases are exposed as properties:

  • BNpcs: This collection contains objects of type BNpc that include data of both BNpcBase and BNpcName. Note: Only available when Libra Eorzea data is available.
  • ENpcs: This collection contains objects of type ENpc that include data of both ENpcBase and ENpcResident.
  • EquipSlots: There is no actual data for specific equipment slots in the game data, but having access to them makes things more convenient, so they're available here.
  • Items: This collection combines both EventItem and Item.
  • Shops: This collection contains all types of shops.

The following is a simple example that outputs the name and colour of all Stain objects to the console:

var stains = realm.GameData.GetSheet<SaintCoinach.Xiv.Stain>();

foreach(var stain in stains) {
    Console.WriteLine("#{0}: {1} is {2}", stain.Key, stain.Name, stain.Color);
}

Notes

State of documentation

Only SaintCoinach contains documentation, and even that only in some places (anything directly in the SaintCoinach namespace as well as some things in SaintCoinach.Xiv.*), everything else is virtually void of documentation.

There should, however, be enough documentation available to know how to use the library for game data, but figuring out the internal workings might prove difficult.

SaintCoinach.Cmd

The project SaintCoinach.Cmd is a very basic console application that can be used to extract various assets. The following commands are currently supported:

  • lang: Displays or changes the language used for data files. Valid arguments are Japanese, English, German, French. If no argument is supplied the currently used language is shown.
  • raw: Exports a file from the game assets without any conversions. The argument should be the friendly name of the file.
  • image: Exports a file from the game assets as a PNG-image. The argument should be the friendly name of the image file.
  • ui: Exports one or multiple UI icons as PNG-images. The argument can either be the number of a single UI icon, or the first and last number for a range of icons seperated by a space. Valid numbers are in the interval [0, 999999].
  • exd: Exports all or a specified number of game data sheets as CSV-files. Arguments can either be empty to export all files, or a list of sheet names seperated by whitespace.
  • rawexd: Exports all or a specified number of game data sheets as CSV-files without post-processing applied. Arguments can either be empty to export all files, or a list of sheet names seperated by whitespace.
  • bgm: Exports all sound files referenced in the BGM sheet as OGG-files.

Godbert

Godbert is a simple application to display game data and 3D models from Final Fantasy XIV using the above-mentioned library.

Functionality

Fully implemented

  • Display of game data/text.
  • Rendering of equipment, including ability to dye (if the item supports it.)
  • Rendering of monsters.
  • Rendering of demi-humans (non-playable races with exchangable equipment.)

Partially implemented

  • Rendering of the game's areas. Only static and completely passive objects are displayed at the moment, anything that's more complex is not included.

To-Do

  • Add more things to show.
  • Store active language in config.

More Repositories

1

ffxiv-datamining

This repository is to serve as a place to share data mining information related to Final Fantasy XIV.
444
star
2

xivapi.com

Source code for XIVAPI.com
PHP
145
star
3

classjob-icons

A collection of really nice ClassJob icons at high resolution for FINAL FANTASY XIV
HTML
114
star
4

xivapi-js

Node.js wrapper for XIVAPI
JavaScript
78
star
5

xivapi-py

An asynchronous Python client for XIVAPI
Python
60
star
6

ffxiv-launcher

A custom built launcher for FFXIV written in Javascript on Nodejs via Electron.
JavaScript
40
star
7

xivapi-mappy

A FINAL FANTASY XIV Mapper application
C#
34
star
8

companion-php

A library for interacting with the FFXIV Companion App API
PHP
24
star
9

XIV-Character-Cards

API to create fancy cards for FFXIV characters based on their Lodestone data, hosted at https://ffxiv-character-cards.herokuapp.com.
JavaScript
19
star
10

xivapi-ruby

A Ruby library for XIVAPI
Ruby
16
star
11

vue-xivtooltips

A set of vue components to fetch and display data from xivapi
Vue
16
star
12

xivapi-php

PHP composer library that talks to xivapi.com
PHP
14
star
13

lodestone-parser

Parse lodestone for those juicy details
PHP
14
star
14

NetStone

Portable and modern .NET Lodestone API
C#
13
star
15

ffxiv-datamining-patches

A complete collection of patch information from 1.23 to the current patch
TypeScript
12
star
16

xivapi-go

Go client for xivapi
Go
9
star
17

godestone

Go scraper for The Lodestone.
Go
8
star
18

nodestone

nodestone is a node.js lodestone parser.
TypeScript
8
star
19

mogboard

Source code for MogBoard.com
CSS
7
star
20

lodestone-css-selectors

CSS selectors for The Lodestone.
5
star
21

lodestone-icons

Downloads icons from Lodestone by searching items to get those sweet HQ stuffs
JavaScript
4
star
22

angular-client

xivapi client library (service and models) for angular applications
TypeScript
4
star
23

xivapi-mappy-v2

Mappy Version 2
C#
2
star
24

xivapi-mog

Mog - The discord bot for XIVAPI
PHP
2
star
25

xivapi.com-docker

A docker environment that runs XIVAPI and Mogboard
Dockerfile
2
star
26

xivapi-tooltips

Tooltips and stuff using XIVAPI
JavaScript
2
star
27

market-app

Self contained, single site, React app that interacts with the FFXIV Companion App via XIVAPI
JavaScript
1
star
28

xivapi.com-vagrant

A vagrant environment that runs XIVAPI and Mogboard
PHP
1
star
29

xivapi-db

DB Concept
PHP
1
star