XML:XML Modding Lessons: Difference between revisions

wording tweaks, rearranged tutorial links
m (wording tweaks and formatting tweaks)
(wording tweaks, rearranged tutorial links)
Line 2: Line 2:
:''This article builds on the general introduction to modding found at [[Modding Oni]].''
:''This article builds on the general introduction to modding found at [[Modding Oni]].''


The '''XML''' namespace is devoted to explaining Oni's data types in plainer English than the technical documentation at [[OBD]], and provides tutorials in XML modding.
The '''XML''' namespace is devoted to explaining Oni's data types in plainer language than the technical documentation at [[OBD]] and also provides tutorials in XML-based modding.


Oni's resources could be separated into one of two categories: media (such as textures and sounds), and non-media (such as character class data). Most of the non-media data can be exported to XML. This allows much easier modding than the hex-editing of the old days (compare the two methods [[Adding_spawnable_characters|here]]). Some media resources can also be edited as "XML", referring to the fact that an XML file will be created alongside the resource's image/sound file when it is exported from the game data, and this XML companion file contains metadata about the media resource that allows [[OniSplit]] to re-import the resource when you are done editing it.
==Introduction==
Oni's resources could be separated into one of two categories: media (such as models, textures and sounds), and non-media (such as character class data). Most of the non-media data can be exported to XML. This allows much easier modding than the hex-editing of the old days (compare the two methods [[Adding_spawnable_characters|here]]). Some media resources can also be edited as "XML", referring to the fact that an XML file will be created alongside the media file when it is exported from the game data, and this XML companion file contains metadata about the media that allows [[OniSplit]] to re-import the resource properly when you are done editing it.


To learn what the different resource types do, and to see which types can be edited through XML, see the database link below. Though XML modding can generally be done with nothing more than OniSplit's command line interface and a text editor, the tutorials linked below are written with the [[Anniversary Edition]] in mind, because the AE provides modding tools (including a GUI for OniSplit), gives you a framework for testing your mod package, and globalizes more of Oni's data so it can be used in any level.
To learn what all the resource types do, and to see which types can be edited through XML, see the link to the database at the bottom of the page. Though XML modding can generally be done with nothing more than OniSplit's command line interface and a text editor, the tutorials linked below are written with the [[Anniversary Edition]] in mind, because the AE provides modding tools (including a GUI for OniSplit), gives you a framework for testing your mod package, and globalizes more of Oni's data so it can be used in any level.


==Working with XML files==
==Working with XML files==
Line 29: Line 30:
* '''Code folding''': A simple text editor (and good use of the search function) is actually enough to work with Oni's XML. But big files might be easier to handle with what programmers call "code folding". Code folding allows you to collapse tags in order to get a better sense of the overall file structure, and is found in [[wikipedia:IDE|IDEs]] like [https://visualstudio.microsoft.com Microsoft Visual Studio] (Windows) and [https://developer.apple.com/xcode/ Xcode] (Mac). Both programs are free.
* '''Code folding''': A simple text editor (and good use of the search function) is actually enough to work with Oni's XML. But big files might be easier to handle with what programmers call "code folding". Code folding allows you to collapse tags in order to get a better sense of the overall file structure, and is found in [[wikipedia:IDE|IDEs]] like [https://visualstudio.microsoft.com Microsoft Visual Studio] (Windows) and [https://developer.apple.com/xcode/ Xcode] (Mac). Both programs are free.


* '''File comparison''': For comparing two versions of an XML file to find the changes, you can use [https://winmerge.org/ WinMerge] (Windows) or FileMerge (Mac, comes with Xcode). Note that if one file has passed through Oni, the data may have been totally reordered and cannot be diff-gazed effectively.
* '''File comparison''': For comparing two versions of an XML file to find the changes, you can use [https://winmerge.org/ WinMerge] (Windows) or FileMerge (Mac, comes with Xcode). Note that if one of the two files has passed through Oni and been re-exported, the data may have been totally reordered and cannot be diff-gazed effectively.


==Hitting the learning curve==
==Starter tutorials==
;Which resource types do what in the game?
*[[XML:File types|Database of Oni's resource types]]
;How do I edit XML?
*[[XML:Basic tutorial|Basic tutorial]]
*[[XML:Basic tutorial|Basic tutorial]]
;How do I get my mod into the game?
*[[Making a patch mod]]
;How do I make more complex mods?
*[[XML:Advanced tutorial|Advanced tutorial]]
*[[XML:Advanced tutorial|Advanced tutorial]]
*[[Making a patch mod]] (read before expert tutorial)
*[[XML:Expert tutorial|Expert tutorial]]
*[[XML:Expert tutorial|Expert tutorial]]


===Popular modding types requiring XML===
==Additional tutorials==
;How do I create levels?
*[[Adding spawnable characters|Adding spawnable characters to a level]]
* [[XML:ONLV]]
*[[XML:Daodan|Adding Daodan particles to a character]]
; How do I add characters to a level?
*[[XML:TRAM#Color_trails|Adding colored contrails to combat moves]]
*[[Adding_spawnable_characters]]
*[[XML:ONLV|Creating a level]]
; How do I add Daodan to a character?
 
* [[XML:Daodan]]
==Knowledge database==
;How do I add contrails to character moves?
*[[XML:File types|XML resource type database]]
* [[XML:TRAM#Adding_colorful_trails]]


{{XML}}
{{XML}}