XML:TXMB: Difference between revisions

617 bytes added ,  24 August 2019
copy-edit, plus how to put Humpty Dumpty back together if all you have is the end product, a TXMP and a bunch of TXMPs
(automatically loaded TXMB)
(copy-edit, plus how to put Humpty Dumpty back together if all you have is the end product, a TXMP and a bunch of TXMPs)
Line 1: Line 1:
{{XML_File_Header | type=TXMB | prev=TRSC | next=AITR | name=Texture Map Big }}
{{XML_File_Header | type=TXMB | prev=TRSC | next=AITR | name=Texture Map Big }}


 
==General information==
===general information===
{| border=0 cellspacing=10 cellpadding=0 style="float:right"
{| border=0 cellspacing=10 cellpadding=0 style="float:right"
|valign=top|
|valign=top|
Line 50: Line 49:
|}
|}


* The xml code on this page is compatible with onisplit '''v0.9.61.0'''
*The XML code on this page is compatible with OniSplit '''v0.9.61.0'''
* TXMB files are ''splash screens'' which we see at level start, and at end (one for losing the level and one for winning).
*TXMB files create the ''splash screens'' which we see at the start and end of levels (making three total: the title screen, an endscreen for losing the level, and one for winning).
* A TXMB file hold links to TXMPs which then together make a big picture.<br>This is needed because the current max resolution for a single TXMP on PC is 512x512 and on Mac 1024x1024. (9 April 2012)
*A TXMB file simply hold links to TXMPs which are assembled by Oni to display a larger picture than the maximum size of a single texture.<br>The current max resolution for a single TXMP in Windows is 512x512 and on Mac is 1024x1024 as of 2018.
* The number of columns and rows (TXMPs) is computed at runtime.<br>Probably the engine checks the horizontal dimension of the TXMPs until the desired x size is reached and then starts a new row.<br>So it should be possible to create also other TXMB resolutions and TXMP constellations.
*The arrangement of the constituent TXMPs into columns and rows is computed at runtime. Probably the engine stacks TXMPs horizontally until the value in the Width field is reached, and then starts a new row.
* They are called by BSL command "splash_screen ''image_name''".<br>They can be called whenever we like to. The game will be paused then.
*TXMBs are displayed with the BSL command "splash_screen ''image_name''". They can be called whenever we like; during their display, the game will be paused.
 
 


Example TXMB -- TXMBwin_splash_screen.xml (from level1_Final/NoGlobal)
Example TXMB TXMBwin_splash_screen.xml (from level1_Final/NoGlobal)
  <?xml version="1.0" encoding="utf-8"?>
  <?xml version="1.0" encoding="utf-8"?>
  <Oni>
  <Oni>
Line 87: Line 84:
  </Oni>
  </Oni>


==Creating a TXMB==
You can use [[Vago_(tool)|Vago]] to create a TXMB and its constituent TXMPs with the menu item "Tools">"Background Image Wizard".


Alternatively, you can create the files manually using the following process (this example makes a 640x480 TXMB):
*The actual work is to split the image into six smaller ones.
*You can use Photoshop, or else a TIFF should work with any other layer-supporting image editor.
*The six-part colored layer should help when the program cannot load a selection.
*Let's drag'n'drop our image into this [http://www.paradox.oni2.net/mods/TXMB_barebone_tif_and_psd.zip TXMB template (.psd / .tif)] and move to to the center.
*Now we can right-click, load a selection, crop and save it as "..._N" (whereas N is a number from 0 to 5).
*Let's redo crop, load another selection, save this piece, and so on.


Creating a TXMB:
===Algorithm to split an image for TXMB===
 
The following algorithm seems to work correctly in generating a 640x480 TXMB, the size that is used in vanilla Oni. The algorithm is currently used in Vago for TXMB creation. It works as follows:<br>
You can use [[Vago_(tool)|Vago]] to create TXMB and respectively their TXMP with the "background image wizard".
Try to fit 256x256 images into the TXMB's space until you aren't able to add any more images of that size, then find the remaining width/height left to complete the TXMB. Example:
 
In Vago click "Tools" menu -> "Background Image Wizard". Follow the instructions.
 
Alternatively you can create the files manually using the following process.
 
Example on creating a 640x480 TXMB:
 
* The actual work is to split the image into six smaller.
* Here's a method for Photoshop -- .tif should also work with any other layer supporting grafic programm.
* The six-part colored layer should be a help when the program cannot load a selection.
* Let's drag'n'drop our image into this [http://www.paradox.oni2.net/mods/TXMB_barebone_tif_and_psd.zip TXMB barebone (.psd / .tif)] and bring it into center position.
* Now we can right-click, load a selection, crop and save it as "..._N" (whereas N is a number from 0 to 5).
* Let's redo crop, load another selection, save this piece, and so on.
 
 
 
Algorithm to split images to fit in TXMB:
 
The following algorithm seems to work correctly and generate resolutions that are the same used in Vanilla oni. The algorithm is currently used in Vago for TXMB creation.
It works as follow:
 
Try to fit 256x256 images in the TXMB until it's possible. When you aren't able to add any more 256x256 images you add the remaining resolution left to complete the TXMB.
 
Example image 640x480:


<pre>256x256    | 256x256    | 128x256 *
<pre>256x256    | 256x256    | 128x256 *
Line 121: Line 103:
256x224 ** | 256x224 ** | 128x224* **</pre>
256x224 ** | 256x224 ** | 128x224* **</pre>


<nowiki>*</nowiki>where we add 128 which is the remaining resolution, we couldn't have added another 256 width resolution because it would overflow the TXMB 640 width
<nowiki>*</nowiki>We add an image of 128px width, because anything more would overflow the TXMB's 640px width.
 
<nowiki>**</nowiki>where we add 224 which is the remaining resolution, we couldn't have added another 256 width resolution because it would overflow the TXMB 480 height


Algorithm pseudo code:
<nowiki>**</nowiki>We add images of 224px height, because 256px height images would have overflowed the TXMB's 480px height.


<code>
Algorithm pseudo code:<br>
    function getSplitSizes(int sideSize){
function getSplitSizes(int sideSize){
        vector splitSizes;
    vector splitSizes;
        int remainingSize = sideSize;
    int remainingSize = sideSize;
        int regularSize = 256;
    int regularSize = 256;
        while (remainingSize > 0){
    while (remainingSize > 0){
            if(remainingSize - regularSize < 0){
      if(remainingSize - regularSize < 0){
                splitSizes.add(remainingSize);
          splitSizes.add(remainingSize);
                remainingSize = 0;
          remainingSize = 0;
            }
      }
            else{
      else{
                splitSizes.add(regularSize);
          splitSizes.add(regularSize);
                remainingSize = remainingSize - regularSize;
          remainingSize = remainingSize - regularSize;
            }
      }
        }
    }
        return splitSizes;
    return splitSizes;
    }</code>
}


===automatically loaded TXMB===
==Automatically-loaded TXMBs==
There are three TXMBs that Oni automatically loads by name upon specific events:
*TXMBintro_splash_screen
**Savepoint loaded
*TXMBwin_splash_screen
**Level won ("win" BSL function is called)
*TXMBfail_splash_screen
**Level failed ("lose" BSL function is called)


There are three TXMB that are automatically loaded (if they exist) by the engine on specific events:
These files are looked for in the specific level's folder. If they are not provided, the engine simply skips them.


* TXMBintro_splash_screen
==Reassembling a TXMP==
** loaded at a savepoint load
OniSplit does not offer to extract TXMBs to a single composite image made up of the individual TXMPs. It will only extract to XML a list of the TXMP names. If you have ImageMagick installed, use this command on the TXMPs to reassemble them into one large image:
* TXMBwin_splash_screen
montage -mode concatenate -tile 4x TXMPlevelXX_fail_*.png TXMPlevelXX_fail.png
** loaded when win (bsl function) is called
* TXMBfail_splash_screen
** loaded when lose (bsl function) is called


Those files are level specific. If they are not provided the engine skips them.
*The images of course need to be passed to IM in the correct order; the numerical order determined by their names will work, but only if they are named with two-digit padding (TXMPlevelXX_fail_'''00'''.png, …_'''01'''.png, etc.). Otherwise, TXMPlevelXX_fail_10.png would come right after …fail_1.png and before …fail_2.png.
*The "4" in "tile -4x" is derived from your knowing that this TXMB is 1024x1024 and the TXMPs are 256px wide, therefore the TXMB is made up of 4 columns of TXMPs.


{{XML}}
{{XML}}