Introduction to modding: Difference between revisions

general polishing, consolidating links from last section into text or removing them because they are found just one link away in a more appropriate context
m (link fix)
(general polishing, consolidating links from last section into text or removing them because they are found just one link away in a more appropriate context)
Line 7: Line 7:
==Introduction to modding==
==Introduction to modding==
[[Image:No_easy_button.png|150px|right]]
[[Image:No_easy_button.png|150px|right]]
Creating or modding a game is like writing a theater play: in both cases, you have stages, actors, scripts, and music. A level is built so that when the player performs certain actions or reaches certain locations, further events are set in motion. The player is told what to do through various textual instructions, voice acting, and cinematics (cutscenes).
Creating a game is like writing a theater play: in both cases, you have ''stages'', ''actors'', ''scripts'', and ''music''. A level is built so that when the player performs certain actions or reaches certain locations on the ''stage'', further events are set in motion according to the ''script''. The player is told what to do through various textual instructions, cutscenes, and/or voice acting (more "scripts") and as he plays he interacts with [[wiktionary:artificial_intelligence|AI]]-driven ''actors''. ''Music'' will often play dynamically behind all this, changing along with the flow of events. Modifying, or "modding", a game can be simpler and easier because you might only be changing or creating some of the above elements.


Modding can be an intimidating field to get into, but taking things one step at a time, you can learn a lot about how to make games. Like learning a second language, modding your first game is always the hardest, and then you learn the common points that games share and you can more easily pick up new ones. Additionally, there are lots of different ways for someone to mod; whether your talent is art, sound, modeling or design in general, there's something for you to do, and collaborating with others to divide the work according to your abilities can lead to a memorable, rewarding creative experience. Because of the DIY nature of our work here, it's recommended that you have an interest in, or at least a high tolerance for, technical details. We do not yet have any modding solutions with a big red button that says "easy".
Nevertheless, modding can be an intimidating field to get into. But if you take things one step at a time, you can learn a lot about how to make games; in fact, many game developers start out as modders. Like learning a new language, modding your first game is always the hardest, and then you learn the common points that languages/games share, and you can more easily pick up new ones. Additionally, there are lots of different ways for someone to mod; whether your talent is art, sound, modeling or design in general, there's something for you to do, and collaborating with others to divide the work according to your abilities can lead to a memorable, rewarding creative experience.
 
Now, our community does not have the polished modding tools of the big engines like Unreal (but we're getting better). Because of the [[wiktionary:DIY|DIY]] nature of our work here, it's recommended that you have a high tolerance for technical details. We do not yet have any modding solutions with a big red button that says "easy".


==Introduction to the engine==
==Introduction to the engine==
Oni runs on an engine that was custom-written for the game. At the time development started, Bungie did not yet have a true 3D engine, and it appears that the lead coders intended their work to be reused in future Bungie titles. In the course of events, this never happened. However, as a result of this advance planning, the Oni engine (which does not have a name ''per se'') is built in an industrial, abstracted way in two major layers: (1) the BungieFrameWork (BFW), which contains general code for things like 3D graphics and scripting, and (2) the code for Oni itself, which adds stuff like the AI and the combat system.
Oni runs on an engine that was custom-written for the game and that could be built for both Windows and the Macintosh (later, PlayStation 2 support was added). At the time development started, Bungie did not yet have a true 3D engine, and Oni's lead coders intended their work to be reused in future Bungie titles, so they tried to make it well-engineered and portable. The engine consists of various "modules", sometimes with colorful names like [[wikipedia:Akira (film)|Akira]] (environment), [[wikipedia:Motoko Kusanagi|Motoko]] (graphics), and [[wikipedia:My Neighbor Totoro|Totoro]] (animation). Unfortunately, the game was rushed to release during a change of ownership, and it was not possible for the developers to release any tools or information to aid the fans in modding.


Due the non-existence of modding tools at the time of Oni’s release, fans had to tame the wild jungle of raw game data and create modding tools on their own. It took over seven years to ''unlock'' most possibilities –- and the work is still ongoing. Read the full story '''[[History_of_Oni_modding|HERE]]'''. The short version is that we can now mod almost all types of data effectively, meaning we can create entirely new levels with new characters, new scripts, new voice acting, and new music. Now we're turning our focus to making tools that are user-friendly so artists can work unimpeded.
Due the non-existence of modding tools at the time of Oni’s release, fans had to tame the wild jungle of raw game data and create modding tools on their own through reverse-engineering. It took over seven years to unlock most of the game's secrets –- and the work is still ongoing. Read the full story [[History_of_Oni_modding|HERE]]. But to make a long story short, we can now mod almost all types of data effectively, meaning we can create entirely new levels with new characters, new scripts, new voice acting, and new music. Now we're turning our focus to making tools that are user-friendly so artists can work more freely.


Altogether, we have identified 124 types of resources in the game data, however only about 88 (and a half) are used. It may sound intimidating at first, but many of the data types (often called "file types" on this wiki, and "tags" in many other game modding communities) fold into each other, such that you only need to know a few file types well, and the rest are created for you. Depending on the kind of modding you want to do, you might be able to start modding with only a little knowledge of the engine.
Altogether, we have identified 124 types of resources in the game data, however Oni only uses about 88 of these types (often called "file types" on this wiki, and "tags" in many other game modding communities). It may sound intimidating at first, but many of the data types fold into each other, such that you only need to know a few file types well, and the rest are created for you. Depending on the kind of modding you want to do, you might be able to start modding with only a little knowledge of the engine.


==Kinds of modding==
==Kinds of modding==
Line 29: Line 31:
This is where those 88 data types come into play that we mentioned earlier. Broadly speaking, the kinds of data we're talking about are: '''level geometry''' (architecture, triggers, and furniture), '''characters''' (class data, models), '''text''' (diary, objectives, subtitles, etc.), '''music''', '''voice-overs''', and '''sound effects'''. However, new levels do not require all this data to be made from scratch. You might decide to re-use a level or some of its resources, or make a new level populated with existing characters, etc.
This is where those 88 data types come into play that we mentioned earlier. Broadly speaking, the kinds of data we're talking about are: '''level geometry''' (architecture, triggers, and furniture), '''characters''' (class data, models), '''text''' (diary, objectives, subtitles, etc.), '''music''', '''voice-overs''', and '''sound effects'''. However, new levels do not require all this data to be made from scratch. You might decide to re-use a level or some of its resources, or make a new level populated with existing characters, etc.


The game data is called "binary data" because it's made of raw 0s and 1s until our tools make it into something more modder-friendly. The basic process of modding game data involves breaking the level data (a .dat file supplemented by a .raw file and also a .sep file on the Mac) into its component resources (.oni files), then converting those resources into something editable. What that editable format is depends on the kind of data you're editing. It might be plain text, XML, PNG, DAE, WAV, etc.
The game data is called "binary data" because it's made of raw 0s and 1s until our tools make it into something more modder-friendly. The basic process of modding game data involves breaking the level data (a .dat file supplemented by a .raw file and also a .sep file on the Mac) into its component resources (.oni files), then converting those resources into something editable. What that editable format is depends on the kind of data you're editing. It might be plain-text, XML, PNG, DAE, WAV, etc.


Thus, besides our community modding tools, the program(s) you need in order to mod will vary according to your modding task; you might need nothing more than a text editor, you might need a free bitmap editor, or you might need a full 3D modeling package. Thankfully, since Oni is graphically primitive, you won't need to know as much about modeling as with a modern game, and there are free modelers available (but not as good as the commercial ones).
Thus, besides our community modding tools, the program(s) you need in order to mod will vary according to your modding task; you might need nothing more than a text editor, you might need a free bitmap editor, or you might need a full 3D modeling package. Thankfully, since Oni is graphically primitive, you won't need to know as much about modeling as with a modern game, and there are free modelers available (but not as good as the commercial ones). In any case, make sure you download the [[Anniversary Edition]], which provides a modding framework and installs modding tools.


In any case, make sure you download the [[Anniversary Edition]], which provides a modding framework and installs modding tools. Go [[OBD|HERE]] to start learning about the binary data or continue reading to learn a little more about specific types of binary modding.
Go [[OBD|HERE]] to start learning about the binary data, [[XML|HERE]] to learn about the user-friendly XML modding technique, or continue reading to learn a little more about specific types of binary modding so you know what you're getting yourself into.


====Characters====
====Character models====
Characters in Oni are built with a simple 19-part skeleton. Talk about ONCCs and related data here. Mention Mod Tool, Blender, Gimp, Paint.NET.
Characters in Oni are built with a simple 19-part skeleton. ''Talk about ONCCs and related data here. Mention [[Mod Tool]], [[User:Iritscen/BlenderTutorial|Blender]]''.


====Animations====
* tutorial: [[AE:Importing_character_models|Importing character models TRBS]]
* tutorial: [[AE:Adding_spawnable_characters|Adding spawnable characters to a level CHAR]]
* tutorial: [[Adding_character_classes|Adding character classes ONCC]]
 
====Character animations====
{| border=0 cellspacing=20 cellpadding=0 style="float:right"
{| border=0 cellspacing=20 cellpadding=0 style="float:right"
| [http://i305.photobucket.com/albums/nn207/unknownfuture/Oni_Galore_Images/XSI_modding/RAICOMthrow_fw_kick.png http://i305.photobucket.com/albums/nn207/unknownfuture/Oni_Galore_Images/XSI_modding/RAICOMthrow_fw_kick_TN.png]
| [http://i305.photobucket.com/albums/nn207/unknownfuture/Oni_Galore_Images/XSI_modding/RAICOMthrow_fw_kick.png http://i305.photobucket.com/albums/nn207/unknownfuture/Oni_Galore_Images/XSI_modding/RAICOMthrow_fw_kick_TN.png]
''An "appetizer screenshot".''
''An "appetizer screenshot".''
|}
|}
Talk about OBANs and TRAMs here. Mention Mod Tool and Blender.
''Talk about OBANs and TRAMs here. Mention Mod Tool''.


====Levels====
** tutorial: tweak [[OBD_talk:TRAM|animation]]
Script commands are useless when their addressed resources don't exist. Talk about AKEVs and related data here. Mention Mod Tool, SketchUp, and Blender.


==Tools, documentations and tutorials==
: You need to add some stuff to that file to make it actually work as an animation. In particular the animation type, from/to states and varient needs to be set.
===BSL===
: For all I know this works with animations exported from Oni and modified in Softimage. If you come up with a completly new animation it should work as long as the skeleton is similar to the one used in Oni.
* introduction and database links [[BSL|HERE]]
* tutorials: [[BSL:Tutorial/Scratch]]


====Textures====
''Mention [http://www.gimp.org/ Gimp], Paint.NET''.


===OBD===
* tutorial: [[AE:Modifying textures|Modifying textures TXMP]]
====file converting in general====
* tool download: [http://www.mods.oni2.net/node/38 OniSplit]
** tool download: [http://www.mods.oni2.net/node/69 AETools - GUI for Macintosh]
** tool download: [http://www.mods.oni2.net/node/72 OniSplit GUI for Windows]
** tutorial: [[XML|basics]]


 
====Weapons====
====3D====
* tool tutorial: [[User:Iritscen/BlenderTutorial|Blender]]
* tool download: {{ModTool}}
** [[Mod_Tool|more information]] about Mod Tool
** obj export requires an [http://www.si-community.com/community/viewtopic.php?f=35&t=797 addon]
* tool tutorial: [http://oni.bungie.org/community/forum/viewtopic.php?id=1229 OCF's XSI thread]
* tool download: [http://sketchup.google.com/ SketchUp]
* tutorial: [[AE:Importing_character_models|Importing character models TRBS]]
* tutorial: [[AE:Importing_weapon_models]]
* tutorial: [[AE:Importing_weapon_models]]
* tutorial: [[SketchUp_tutorials_and_tips|SketchUp]]


====Levels====
''Talk about AKEVs and related data here. Mention Mod Tool, [[SketchUp_tutorials_and_tips|SketchUp]]''.


====Animation====
* tool download: {{ModTool}}
: You need to add some stuff to that file to make it actually work as an animation. In particular the animation type, from/to states and varient needs to be set.
: For all I know this works with animations exported from Oni and modified in Softimage. If you come up with a completly new animation it should work as long as the skeleton is similar to the one used in Oni.
: Note that the geometry that is present inside the Collada file is used to compute the "vertical extents" so it better be the same or close to the one the animation is intended for.
: The biggest problem are the attacks. While it's not difficult to add attacks to [http://oni.bungie.org/community/forum/viewtopic.php?pid=23230#p23230 the xml file], computing the necessary "extents" is not going to be easy. I guess in the end I'll have to add some command to OniSplit to do it.
: '''Edit:''' attack extents becomes automatically calculated with onisplit v0.9.55.0 and newer
* tutorial: [[AE:Authoring_custom_camera_animations]]
* tutorial: [[AE:Authoring_custom_camera_animations]]


 
====Sound and Music====
====HEX====
* Instructions on importing sounds and links to conversion tools can be found [[XML:SNDD|HERE]].
* any hex editor
* tool download: [http://www.mods.oni2.net/node/67 OniUnPacker]
** tutorial: tweak [[OBD_talk:TRAM|animation]]
* tutorial: [[AE:Adding_spawnable_characters|Adding spawnable characters to a level CHAR]]
* tutorial: [[Adding_character_classes|Adding character classes ONCC]]
 
 
====Sound====
* Instructions how to import sounds and links to conversion tools can be found [[XML:SNDD|HERE]].
 
 
====Textures====
* tool download: [http://www.gimp.org/ gimp]
* tutorial: [[AE:Modifying textures|Modifying textures TXMP]]
 


==Need some inspiration?==
==Need some inspiration?==
Line 106: Line 77:
* [[Review criticisms]]
* [[Review criticisms]]
* [[AE:Requests]]
* [[AE:Requests]]


[[Category:Modding tutorials]]
[[Category:Modding tutorials]]