|
|
Line 1: |
Line 1: |
- | <br />
| + | OtL2xm Thank you ever so for you blog article.Really looking forward to read more. Cool. |
- | | + | |
- | <center><font class="big" size="+2">'''Getting started'''</font><br /><br /> It is advised that you install the Beats of Rage edit pack in a subdirectory of your Beats of Rage installation. <br /><br />[[Image:install.png]]<br /><br /> This way, you can make your own mods for the game in the most effective way:<br /> You can test your mod by running '''bor.exe''' in the '''bor_mod''' directory.<br /> You can easily create your own pack file directly into the directory in which your copy of Beats of Rage is installed. <br /><br /><br /><br /><font class="big" size="+2">'''General remarks'''</font><br /><br /> When your custom pack file is finished, you may run your mod by using the following syntax:<br />'''bor.exe -pak mymod.pak''' where mymod.pak is the name of your pack file.<br /> Please note that you need at least version 1.0024 to use alternative pack files. <br /><br /> The Beats of Rage program does not distinguish between slashes and backslashes, so in all text files you may use either one (data\\sounds\\pop.wav is the same as data/sounds/pop.wav). <br /><br /> Also do '''not''' use long file names in your Beats of Rage mod, since it is a DOS game. So use a maximum of 8 characters in file names. <br /><br /><br /><br /> </center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center><font class="big" size="+2">'''Creating a character'''</font><br /><br /><br />'''<font class="big" size="+1">Step 1. Creating Gifs </font> '''<br /><br /><u>Grabbing frames</u><br /> In order to make a new character you need sprites for your character. On the internet many ripped sprites can be found, however these are often modified and manhandled. You'll probably get better sprites if you grab them yourself. Also this ensures you can get the sprites you need. <br /> The best program to do this is probably neorage, because you can easily select layers and change the background colour in the shots factory (so you can make good grabs of characters with black in their outfit). <br /><br />[[Image:shots.png]]<br />neorageX shots factory<br /><br /> Off course other emulators work also work. For instance Kawaks has a shots factory (Tools, shots factory) and can change the background clour (video, set background color). <br /><br /><u>Editing frames</u><br /> When you've got the character frames of your fancy, you need to process the large images (about 320x240 when grabbed from a Neo Geo) to sprites. <br /> Remember that you give frames of the same animation (e.g. an attack) the same width and height, this makes it easier in a later stage. For instance when creating an attack for Ralf, you need to make sure that frame 1 is large enough so that Ralf's outstretched arm is still visible in frame 2.<br /><br />[[Image:punch1.png]]<br />Frame 1<br />[[Image:punch2.png]]<br />Frame 2<br /><br /> Notice that the pink colour is used as the transparent colour. The exact properties of this colour are R:252 G:0 B:255 or #FC00FF. <br /><br /><u>Saving frames</u><br /> When you have cropped the frames to the right size, you need to save them as gifs, using the BOR palette (data/pal.act). In Photoshop 5.5 you do it like this: <br /> 1. Go to File "Save as", select CompuServe GIF (*.GIF)<br /> Do '''not''' use long file names, but a maximum of 8 characters.<br /><br /> 2. Go to Palette and choose "Custom"<br />[[Image:palette1.png]]<br /><br /> 3. A colour table pops up, here you press load. Select data/pal.act and press load. Also set Dither to none. <br />[[Image:palette2.png]]<br /><br /> 4. The BOR palette was loaded. You should see this: <br />[[Image:loadedpal.png]]<br /><br />Now press ok, and ok again.<br /><br /> 5. Now you are asked to choose between normal and interlaced row orders. Choose normal. Now your frame has been saved.<br /><br /> Once you have loaded your palette, you can choose previous palette the next frame you save. [[Image:palette3.png]]<br /><br /><br /><br /><br />'''<font class="big" size="+1">Step 2. Assigning properties to your character </font>'''<br /><br /><u>Default properties </u><br /> All character properties are found in the character.txt. For Ralf this text file is located at data\\chars\\ralf\\ralf.txt.<br /> You can write comments in this text file by writing a "#" before your comment. With the number sign the computer will not process this text as a command. Also useful is that you can both use the "/" and the "\\" in the file locations. <br /><br /> At the top of the file you'll find the following properties: <br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | name Ralf
| + | |
- | | align="left" valign="middle" | Standard name for this character.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | health 55
| + | |
- | | align="left" valign="middle" | Standard health for this character is 55.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | speed 7
| + | |
- | | align="left" valign="middle" | Standard speed for this character is 7. Increase this number to make the character walk faster.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | type enemy
| + | |
- | | align="left" valign="middle" | Write "enemy" to make an enemy, "player" for a hero, "obstacle" for boxes etc., "item" for items (apple, 1up etc.), and "none" for things as stream.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | shadow 4
| + | |
- | | align="left" valign="middle" | Shadow size is 4. Increase the number for a bigger shadow. Maximum shadow size is 6, and 0 for no shadow.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | icon data/chars/ralf/icon.gif
| + | |
- | | align="left" valign="middle" | Location of the icon image (the image next to the health gauge).
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | diesound data/sounds/die1.wav
| + | |
- | | align="left" valign="middle" | Location of the sound the character makes when he dies.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | remap data/chars/ralf/idle1.gif data/chars/ralf/map1.gif
| + | |
- | | align="left" valign="middle" | This function lets you have alternative character colours. The first file points to the image with the original colours. The second file points to <u> the same frame </u> but with alternative colours.
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /><u>Animation</u><br /> Next the actual animations will be constructed. There are a number of different animations. <br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | anim idle
| + | |
- | | align="left" valign="middle" | The animation for standing still.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim walk
| + | |
- | | align="left" valign="middle" | Err, well... walking.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim pain
| + | |
- | | align="left" valign="middle" | When your character gets hurt.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim fall
| + | |
- | | align="left" valign="middle" | When the character gets knocked down, he falls.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim rise
| + | |
- | | align="left" valign="middle" | And getting up again.
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /><u>Things you need to know about animations</u><br /> When creating animations it's best to look carefully at existing characters, and how they work. Here is a rundown of all the properties the animations can have. <br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | loop 1
| + | |
- | | align="left" valign="middle" | Use 1 for repeating animations, such as walking and idle. Use 0 for single animations that don't repeat until you press the button again, such as attacks.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | offset 39 121
| + | |
- | | align="left" valign="middle" | The offset is the place where the character will stand and the shadow is placed. This is a single point in the frame. Here x-coordinate=39 and y=121.
| + | |
- | |}
| + | |
- | | + | |
- | <br />[[Image:offset.png]]<br />The offset is depicted here as a white pixel. This pixel is only here to demonstrate the offset point. Do not put a pixel in the actual frame!<br /><br /> An easy way to find the coordinates in Photoshop is to look at the info box. <br />[[Image:info.png]]<br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | <br /><br />
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | bbox 22 23 34 99
| + | |
- | | align="left" valign="middle" | The bbox is the area where the character can be hit. The first 2 numbers (22 and 23) are the x and y coordinates of the topleft point of the area. The third number (34) is the width of the bbox, and the fourth (99) is the height.
| + | |
- | |}
| + | |
- | | + | |
- | <br />[[Image:bbox.png]]<br />The bbox is depicted here as a white box. This box is only here to demonstrate the bbox. Do not put a white box in the actual frame!<br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | delay 10
| + | |
- | | align="left" valign="middle" | The speed in which the frames follow each other, the delay is given in 100ths of a second. Increase the delay to slow down the animation.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | sound data/sounds/maxboom.wav
| + | |
- | | align="left" valign="middle" | Characters can also make sounds during animations. The sound will play a soon a the animation reaches the point where the sound is declared.
| + | |
- | |}
| + | |
- | | + | |
- | <br /> The offset, bbox, attack and delay remain active for all following frames until they are changed. <br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | frame data/chars/ralf/idle1.gif
| + | |
- | | align="left" valign="middle" | The locations of the actual frames. Put these in the right order.
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /><u>Attacks</u><br /> Each enemy can have up to three normal attacks plus a throw, uppercut, special, and jumpattack. A normal attack is called "anim attack1" (or 2 or 3 of course).<br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | range 0 70
| + | |
- | | align="left" valign="middle" | If a hero is within this range the character can perform this attack. The range is given in pixels and is measured from the offset point.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | attack 56 17 47 21 10 0
| + | |
- | | align="left" valign="middle" | The first 2 numbers (56 17) give the x and y coordinates of the attack box. Number three and four (47 21) are the width and height of the box. The fifth number (10) is the strength of the attack. Increase this number for a heavier attack. The sixth number (0) is used to define whether the hero falls down after the attack. Use 1 for fall down, and 0 (or leave it out) not to have the hero fall down. <br /> Set the attack to 0 0 0 0 0 0 when the attack frames are over.
| + | |
- | |}
| + | |
- | | + | |
- | <br />[[Image:attack.png]]<br />The attack box is depicted here as a white box. This box is only here to demonstrate the attack area. Do not put a white box in the actual frame!<br /><br /><br /><u>Uppercut, throw, and special attacks</u><br /> The uppercut (anim upper) works a normal attack, but it does not have a range. It will start automatically when a hero jumps. The throw (anim throw) also works as a normal attack, but it will happen when a hero walk into the enemy.<br /> The special does have a range, but it will only happen when a hero holds the character for a certain amount of time, so the enemy character can escape its hold.<br /><br /> The jumpattack (anim jumpattack) works as a normal attack, but the character jumps during the attack. This will happen automatically when you use "anim jumpattack". <br /><br /> There is yet one more attack. The shoot attack, which is really a normal attack, but you shoot something. Take Rugal for example; he can shoot a wave. To have this work you must write "<u>load Shot</u>" in the top partition of the character text, in this case Rugal.txt. (Or load knife, if you want a knife). <br /> You also have to define a shootframe in the actual attack animation.<br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | <br />
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | shootframe 5
| + | |
- | | align="left" valign="middle" | In this attack the character will shoot a wave/knife in the 5th frame in the animation. Place this in the Character.txt
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /> Because the shot is a new entity it has its own animation frames and text file. These can be found under data\\chars\\misc\\shot.txt and data\\chars\\misc\\knife.txt <br /><br /><u> Heroes </u><br /> The heroes/players work basically the same as the enemies, they just have some extra animations.<br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | anim get
| + | |
- | | align="left" valign="middle" | Animation to pick up items.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim special
| + | |
- | | align="left" valign="middle" | This is the special attack the costs a bit of health. Don't give this animation a bbox, because you need to be invincible for a period.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim freespecial
| + | |
- | | align="left" valign="middle" | This is the forward, forward+punch special
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim jump
| + | |
- | | align="left" valign="middle" | This is the jump. Don't give this animation an attack, because heroes can jump without attacking.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim jumpattack
| + | |
- | | align="left" valign="middle" | This is the attack that knocks enemies on the ground during a jump. Notice that you are already in the air at this point, so you don't need any animation for jumping off the ground.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim jumpattack2
| + | |
- | | align="left" valign="middle" | This is the air attack that leaves your enemies standing. Notice that you are already in the air at this point, so you don't need any animation for jumping off the ground.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim grab
| + | |
- | | align="left" valign="middle" | The animation for holding an enemy, you're not actually throwing yet.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim grabattack
| + | |
- | | align="left" valign="middle" | The animation for pummelling an enemy while holding him.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim grabattack2
| + | |
- | | align="left" valign="middle" | The animation for pummelling an enemy and knocking him on the ground.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim throw
| + | |
- | | align="left" valign="middle" | Throw your enemy!
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | anim land
| + | |
- | | align="left" valign="middle" | Heroes have an extra animation for safe landings.
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /><br />'''<font class="big" size="+1">Step 3. Models.txt </font>'''<br /> In order to actually put your character in the game you must first let BOR know the character should be loaded. This is done in the <u>data/models.txt </u>. Use the phrase "load" for heroes. These will always be loaded.<br /><br />''' Example '''<br />''load Kula data/chars/kula/kula.txt ''<br /><br /><br /> Use the phrase "know" for all other entities, such as enemies, items etc. These will only be loaded if they actally appear in the level. <br /><br />''' Example '''<br />''know Ralf data/chars/ralf/ralf.txt''<br /><br /> Don't forget to make the knives, shots etc. be known in the models.txt. <br /><br /><br /><br /> </center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center>'''<font class="big" size="+2">Editing levels</font>'''<br /><br />'''<font class="big" size="+1">1. Putting the graphics and music in a level </font> '''<br /><br /> Define the following properties at the beginning of the level file. <br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | music data/music/saviour.bor
| + | |
- | | align="left" valign="middle" | Give the command music and the location of the music. This music will be played, and looped during the level. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | bossmusic data/music/1boss.bor
| + | |
- | | align="left" valign="middle" | The bossmusic will start to play when a boss is spawned. If you don't use bossmusic the regular level music will keep playing. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | hole [scrollpos]
| + | |
- | | align="left" valign="middle" | A hole will be made at the defined scrollposition at the bottom of the level. (More about the scrollpos at the end of chapter 2). '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | endhole 1
| + | |
- | | align="left" valign="middle" | The level will end with a hole from top to bottom when all the level is out of panels, as defined in the "order". Useful for elevators. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | background [path]
| + | |
- | | align="left" valign="middle" |
| + | |
- | Specify the location of the background image to use in the level. This should be a 256-colour image. The first 128 colours in the palette (index 0-127) should be equal to those of the global palette (more info on this subject can be found on the [http://www.senileteam.com/boredit/html/characters.html character page]). The other colours (index 128-255) may be used at your discretion (except if you use neon panels, see below). <br /><br /> The width of the background image should be a ''multiple of four'' for the image to align properly! So, 200 is a valid width, but 201 is not. <br /><br /> The background image's height may be anything between 1 and 240. <br /><br /> Example:<br /> background data/bgs/bridge/harbor.gif <br /><br />'''Mandatory'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | water data/bgs/boat2/water.gif 15
| + | |
- | | align="left" valign="middle" | Define an image to use as water. This image will be placed directly under the background image (see above). If "rock" is enabled (see below), the water surface will be drawn as a plane (as in level 3). If not, it will be warped with a sine (as in level 4). You may also define the strength of the sine deformation. 15 is a good value. ''' Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | rock 1
| + | |
- | | align="left" valign="middle" | The entire level will move slightly up and down, just like a boat :) ''' Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | panel [path] [path] [path]
| + | |
- | | align="left" valign="middle" | Specify the images to use as "panels". These are the sections that make up a level.<br /><br /> A panel is normally 244 pixels high, and can have just about any width. It is advised, however, to use a width of 100 or 200 pixels. This way you can easily determine the width of your entire level by counting the panels.<br /><br /> If you're making a boat level, panels should be 256 pixels high because the level will move up and down a bit. <br /> All panels in the same level should have the same dimensions. <br /> Panels are drawn as sprites, i.e. the first colour in your palette (index 0) will be transparent.<br /><br /> You may specify three paths:<br /> The first one defines the image to be displayed in ''normal'' mode.<br /> The second one defines the image to be displayed in ''neon'' mode.<br /> The third one defines the image to be displayed in ''screen'' mode.<br /> It is advised to prevent overlapping of the three images, as it is a waste of CPU time.<br /><br /> Images displayed in ''neon'' mode will be remapped as follows: colour index 128 through 135 will be cycled two steps, three times per second. You can use this to create blinking lights. To use the ''neon'' effect properly, you'll need to have some understanding of working with palettes and palette rotation. <br /><br /> Images displayed in ''screen'' mode will appear translucent. It is implemented in the same way as Photoshop's screen mode: Black is fully transparent, and white is fully opaque. You may use this to create stuff like windows or coronas. <br /><br /> If you do not want to use a specific kind of panel, enter "none" as the path (without the quotation marks). <br /><br /> The maximum number of panels per level is 26. <br /><br /> Example: panel data/bgs/bridge/bridge10.gif none none <br /><br />'''Mandatory'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | order abcd
| + | |
- | | align="left" valign="middle" | The order in which the panels appear in the level. This also defines the width of the level. The maximum length of the order is 1000. However, you cannot specify that many characters on a single line (about 100 max). So if you want to make a very big level, distribute the order over multiple lines, like so:<br /><br /> order abcd<br /> order efgh<br /> order abcd<br /> order ijkl<br /><br />'''Mandatory'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | frontpanel data/bgs/street/f00.gif
| + | |
- | | align="left" valign="middle" | Like the aforementioned panels, only much simpler. You cannot specify any front panels to be displayed with any effects. Front panels will be displayed in front of all other sprites (except the status window). The maximum number of front panels is 26. <br /><br />'''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | direction [direction]
| + | |
- | | align="left" valign="middle" | You may specify a direction for levels to scroll in. Valid directions are ''up, down, left'' and ''right.'' Up and down are used for elevators, obviously. By default, levels scroll to the right. <br /><br />'''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | mirror [0/1]
| + | |
- | | align="left" valign="middle" | When mirror mode is enabled, the program will draw copies of all objects between the panels and the background. You may use this to create mirrors on the walls (as seen in level 6). <br /><br />'''Optional'''
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br />'''<font class="big" size="+1">2. Putting the enemies in. </font> '''<br /><br /> After creating the backgrounds for your level, you can start putting in the enemies, objects, and items. There are a number of things you can do in a level. We'll first start with adding enemies, objects, and items. When a property for a "character" is used, remember that this also applies for objects and items. <br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | spawn [id]
| + | |
- | | align="left" valign="middle" | Command to spawn a character, object or item in a level. The id is the characters name a defined in the ''character.txt''. '''Mandatory'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | alias [name]
| + | |
- | | align="left" valign="middle" | Change the displayed name. If you don't use this the name defined in the ''character.txt'' will be used. Names consisting of more parts must be connected with an underscore (e.g. Timmy_Turner) ''' Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | map [num]
| + | |
- | | align="left" valign="middle" | This changes the colourmap for this character, as defined in the ''character.txt''. E.g. Ralf has 3 remap colours. If you don't define the map, it will take the standard colour. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | health [num]
| + | |
- | | align="left" valign="middle" | This changes the health of the character. When it is not used, the standard health for this character will be used. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | item [id]
| + | |
- | | align="left" valign="middle" | Only obstacles can contain items, and only one item. However items can also be spawned without an obstable. Simply state "spawn 1up" (for instance). '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | 2pitem [id]
| + | |
- | | align="left" valign="middle" | You can also have items that will only be spawned when 2 players play simultaniously. use 2pitem for this. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | boss [0/1]
| + | |
- | | align="left" valign="middle" | Use 1 for a boss, and 0 for a regular enemy (or leave it out). You can have multiple bosses, but once a boss has been defeated the level ends. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | flip [0/1]
| + | |
- | | align="left" valign="middle" | 0 = face left, 1 = face right. With this you can flip a character horizontaly, only useful for objects. '''Optional'''
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | coords [num] [num]
| + | |
- | | align="left" valign="middle" | These are the coordinates at wich the character will spawn relative to scroll posistion. The first number is the x coordinate, the second number is the y coordinate of the screen. So to spawn a character in the top left of the screen you need coords 0 160. Between x coordinates 0 and 320 an enemy will fall out of the air (objects and items suddenly appear). To have a character walk into the screen you must use a x coordinate of about 350 (to let him walk in from the right) of -30 (to let him walk in from the left). Use a larger x coordinate for biker-k's (e.g. 400), because of their speed. '''Mandatory'''
| + | |
- | |}
| + | |
- | | + | |
- | <br />[[Image:coords.png]]<br />The coordinates in BOR.<br /><br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | at [scrollpos]
| + | |
- | | align="left" valign="middle" | Use this to give the position in the level when the character should be spawned. The number can range from 0 to the end of the level. E.g when the scrollpos is 700 the character will be spawned after the hero walked through a little over 2 screens. '''Mandatory'''
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br />''' Example of a spawned character'''<br />
| + | |
- | | + | |
- | {| width="150"
| + | |
- | | width="200" align="left" valign="middle" | '' spawn ralf <br /> alias Timmy_Turner <br /> map 1 <br /> health 45 <br /> coords -30 210 <br /> at 700 <br />''<br /><br />
| + | |
- | |}
| + | |
- | | + | |
- | '''<font class="big" size="+1">3. Other commands </font> '''<br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | wait <br /> at [scrollpos]
| + | |
- | | align="left" valign="middle" | This blocks scrolling until all enemies, that were spawned prior to the wait, are defeated.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | group [min] [max] <br /> at [scrollpos]
| + | |
- | | align="left" valign="middle" | If the number of enemies drops below [min], more enemies will be spawned (if possible). No more than [max] enemies will be present. So, to make enemies appear in groups of four, use this: group 1 4. To make them appear normally, use this: group 100 100. <br /> Waits, objects and items do not count in a group AFTER they have been spawned. Before spawning, they do count. So if you work with a small group (e.g. group 1 2), a wait will only be spawned when only one enemy is left. Therefore it is best to us groups only when a wait is already active.
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br />''' Example of a <u>bad</u> grouping'''<br />
| + | |
- | | + | |
- | {| width="150"
| + | |
- | | width="200" align="left" valign="middle" | '' group 2 2 <br /> at 700 <br /><br /> spawn ralf <br /> coords -30 210 <br /> at 700 <br /><br /> spawn ralf <br /> coords 380 210 <br /> at 700 <br /><br /> spawn ralf <br /> coords 380 210 <br /> at 700 <br /><br /> wait <br /> at 700<br />''
| + | |
- | |}
| + | |
- | | + | |
- | <br /> There will always be 2 enemies present, until all are defeated. So if you don't defeat 2 enemies, the wait will not become active, and the player can keep walking. <br /><br /> So you should do it like this: <br /><br />''' Example of a <u>good</u> grouping'''<br />
| + | |
- | | + | |
- | {| width="150"
| + | |
- | | width="200" align="left" valign="middle" | '' wait <br /> at 700<br /><br /> group 2 2 <br /> at 700 <br /><br /> spawn ralf <br /> coords -30 210 <br /> at 700 <br /><br /> spawn ralf <br /> coords 380 210 <br /> at 700 <br /><br /> spawn ralf <br /> coords 380 210 <br /> at 700 <br /><br />''
| + | |
- | |}
| + | |
- | | + | |
- | <br />'''<font class="big" size="+1">4. Levels.txt </font> '''<br /><br /> In data\\levels.txt the order of the levels are defined. And here's how you do it.<br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="200" align="left" valign="middle" | set [name] <br />
| + | |
- | | align="left" valign="middle" | Start a new set of levels (e.g. "easy" or "normal").
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | file [filename] <br />
| + | |
- | | align="left" valign="middle" | Specify the location of a level file.
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | next <br />
| + | |
- | | align="left" valign="middle" | Go to next level (show "stage clear" and stuff).
| + | |
- | |-
| + | |
- | | width="200" align="left" valign="middle" | scene [filename] <br />
| + | |
- | | align="left" valign="middle" | Give the location of a scene, and it will be shown.
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /></center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center>'''<font class="big" size="+2">Editing scenes</font>'''<br /><br /> The scenes, such as the intro and ending, are simply animated gifs. Thus to add your own scenes you need a gif animator. For instance, you can download the Microsoft GIF Animator for free here: http://download.microsoft.com/msdownload/gifanimator/gifsetup.exe<br /><br /><br /> If you have an animated gif, no bigger than 320x240 pixels, place it in data\\scenes\\ <br /> However it is possible to use smaller animations. <br /> When you have placed the animation in the scenes directory you need to create a text file in the same location. In this text file you can define the music and offset for the animation (the offset is useful when using smaller animations than 320x240).<br /><br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | width="210" align="left" valign="middle" | music data/music/time.bor 1
| + | |
- | | align="left" valign="middle" | Define music, then give the location of the file. The 1 means the music will loop if it stops before the animation has ended. use 0 not to loop the music. ''The intro music is a special case, and this file must be called remix.bor. ''
| + | |
- | |-
| + | |
- | | width="210" align="left" valign="middle" | animation data/scenes/falla.gif 0 0
| + | |
- | | align="left" valign="middle" | First define that is an animation, then give the location of the file. The two number are the x and y coordinate of the topleft of the animation. Use 0 0 for animations that are 320x240, for smaller animations you can edit the coordinates to get the animation centered. Notice that you can play a number of animations in one scene.
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /> If you use a scene consisting of only one image (for instance "thank you for playing"), make sure that you give it a delay, using a gif animation program. Otherwise the image will only appear for 1/10th of a second.<br /><br /> You can also change the introscreen and character select screen. These files can be found in data/bgs/. Please note that scenes and most screens do not need to be saved with the bor palette; they can have their own palette. However, you must make the first colour (index 0) black.<br /> The exception is the character select screen, which must have the bor palette (because your characters will appear on this screen, obviously). Also, screens where text is displayed should have your font's colours in their palettes at the correct indexes. <br /><br /><br /><u>Entering the scene in the game</u><br /> You can play these scenes in BOR by typing the location of the scene.txt in the \\data\\levels.txt. <br /><br />''' Example '''<br />''scene data/scenes/ending.txt''<br /><br /><br /><br /> </center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center>'''<font class="big" size="+2">Creating BOR music files</font>'''<br /><br /> The Beats of Rage edit pack contains a program to convert WAV files to BOR files. BOR files are the standard by which Beats of Rage plays its music. In this standard, a simple ADPCM algorithm is used to compress/decompress the audio. <br /><br /><br /><br /> To create your own music files for use in you mod, you must first create a WAV file containing a loop. Save this file with the following properties: <br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | align="left" valign="top" | Format:
| + | |
- | | align="left" valign="top" | PCM
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Bit-depth:
| + | |
- | | align="left" valign="top" | 16-bit
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Channels:
| + | |
- | | align="left" valign="top" | mono
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Sample frequency:
| + | |
- | | align="left" valign="top" | 22050 (22 KHz) *
| + | |
- | |}
| + | |
- | | + | |
- | Actually, the program can play music at any frequency, but this frequency provides the best quality/size ratio. <br /><br /><br /><br /> The easiest way to convert your WAV file is probably by creating a batch file (*.BAT). To do so, simply create a text file and rename it to convert.bat (or grampa.bat or eatme.bat or whatever). <br /><br /> Enter a command into the batch file according to the following syntax:<br />'''wav2bor.exe [wav-file] [bor-file]'''<br /><br /> Example:<br /> wav2bor.exe mymusic.wav mymusic.bor <br /><br /> Now execute the batch, and your file will be converted in mere seconds. <br /><br /><br /><br /> To learn how to enter the music files into the game, read about [http://www.senileteam.com/boredit/html/levels.html levels] and [http://www.senileteam.com/boredit/html/scenes.html scenes]. <br /><br />'''Note:''' some music files are required. See the list of [http://www.senileteam.com/boredit/html/required.html required files]. <br /><br />'''Note 2:''' You may also enter an artist and title to be saved with the BOR file:<br /> wav2bor.exe [wav-file] [bor-file] [artist] [title]<br /> Replace spaces by underbars (_). At this time, this information is not displayed in the game, but this feature may be added in future releases. <br /><br /><br /><br /> </center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center>'''<font class="big" size="+2">Sound effects</font>'''<br /><br /> Sound files in Beats of Rage should be saved as WAV file, with the following properties: <br />
| + | |
- | | + | |
- | {| width="600" border="1"
| + | |
- | | align="left" valign="top" | Bit-depth:
| + | |
- | | align="left" valign="top" | 8-bit
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Channels:
| + | |
- | | align="left" valign="top" | mono
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Sample frequency:
| + | |
- | | align="left" valign="top" | Anywhere from 11025 (11 KHz) to 44100 (44 KHz) *
| + | |
- | |}
| + | |
- | | + | |
- | 11 KHz is recommended for most effects, but sometimes (i.e. when using high-pitched sounds or clear speech) you'll want to use a higher quality, in which case 22 KHz is recommended. <br /><br /><br /><br />'''Note:''' some paths to sound files are hard-coded into the Beats of Rage program. See the list of [http://www.senileteam.com/boredit/html/required.html required files]. <br /><br /><br /><br /></center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center><font class="big" size="+2">'''Required files'''</font><br /><br /> Some files must be present in your pack file for the game to function properly. They are listed below: <br /><br /> data/music/complete.bor<br /> data/music/gameover.bor<br /> data/music/menu.bor<br /> data/music/remix.bor<br /><br /> data/sounds/beat1.wav<br /> data/sounds/fall.wav<br /> data/sounds/get.wav<br /> data/sounds/money.wav<br /> data/sounds/jump.wav<br /> data/sounds/indirect.wav<br /> data/sounds/punch.wav<br /> data/sounds/1up.wav<br /> data/sounds/timeover.wav<br /> data/sounds/beep.wav<br /> data/sounds/beep2.wav<br /> data/sounds/bike.wav (if you use motorcycles)<br /><br /> data/sprites/arrow.gif<br /> data/sprites/font.gif<br /> data/sprites/font2.gif<br /> data/sprites/font3.gif<br /> data/sprites/font4.gif<br /> data/sprites/hole.gif<br /> data/sprites/shadow1.gif<br /> data/sprites/shadow2.gif<br /> data/sprites/shadow3.gif<br /> data/sprites/shadow4.gif<br /> data/sprites/shadow5.gif<br /> data/sprites/shadow6.gif<br /><br /> data/levels.txt<br /> data/models.txt<br /><br /> data/pal.act<br /><br /> data/scenes/logo.txt<br /><br /> data/bgs/logo.gif<br /> data/bgs/select.gif<br /> data/bgs/title.gif<br /> data/bgs/titleb.gif<br /><br /><br /><br /><br /> </center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center><font class="big" size="+2">'''Consoles: Dreamcast, PS2, Xbox'''</font><br /><br /> BOR is also available for the Dreamcast, ps2, and xbox. And you can play your mod on a console!<br /><br /><br />'''<font class="big" size="+1">Memory restrictions </font> '''<br /><br /> Since consoles have a certain amount of memory, there's maximum amount of data you can use for your mod if you want it to work on a console.<br /><br />
| + | |
- | | + | |
- | {| width="400" border="1" cellpadding="1"
| + | |
- | | align="left" valign="top" | Dreamcast
| + | |
- | | align="left" valign="top" | Playstation2
| + | |
- | | align="left" valign="top" | Xbox
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Memory used in official pack
| + | |
- | | align="left" valign="top" | 12 MB
| + | |
- | | align="left" valign="top" | 22 MB
| + | |
- | | align="left" valign="top" | probably 22MB
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Total memory
| + | |
- | | align="left" valign="top" | 16 Mb
| + | |
- | | align="left" valign="top" | 32 MB
| + | |
- | | align="left" valign="top" | 64 MB
| + | |
- | |-
| + | |
- | | align="left" valign="top" | Estimated max characters*
| + | |
- | | align="left" valign="top" | 36
| + | |
- | | align="left" valign="top" | 42
| + | |
- | | align="left" valign="top" | 90
| + | |
- | |}
| + | |
- | | + | |
- | The estimated maximum number of characters is a very rough one, since heroes take up more space than enemies, and the amount of animation can differ a lot between characters. Also this estimation is based on King of Fighters characters, if you use smaller or bigger characters, things change. So if you use a lot of characters, just try it out. <br /><br />'''Some words from Neill Corlett on mods for DC and PS2'''<br /><br /> 1. Memory usage is kind of tight, especially since BoR doesn't seem to free certain resources between levels. (I'm not sure of this since I didn't examine bor.c too thoroughly - because BoR is so nicely designed and modular, I didn't need to.) By the time you finish the game, the Dreamcast version is using 12MB (out of 16MB) and the PS2 version is using 22MB (out of 32MB). I don't think this is a memory leak per se, since it doesn't go up any further if you go through the game again. <br /> The behavior isn't entirely friendly if you run out of memory, either: The DC version will simply lock up, although if you're using dcload, you'll get a "Heap and stack collision" message on the console. The PS2 version will show a "Out of memory!" or similar message in the upper-left corner of the screen in the ugly DevCons font. <br /><br /> 2. The .PAK directory info is cached in memory at all times, and its total size can't be bigger than about 256K. If I remember right, it's currently 61K, so this shouldn't be a problem unless you're doing an incredibly ambitious mod. <br /><br /> 3. The console versions don't look for the "PACK" or version signature, because I thought this was unnecessary and it would just add an extra needless seek to the beginning of the file. <br /><br /> 4. I'm not entirely certain that BMP loading works; I had to redo its header routine extensively and I'm not even sure if the default BOR.PAK uses any BMPs at all. So steer clear of BMP if you can. <br /><br /> 5. The loose file structure won't work on ps2 and Dreamcast, so use a pak file in your mod for dc/ps2. <br /><br /><br /><br />'''<font class="big" size="+1"> Making a Selfbooting Dreamcast disc</font> '''<br /> special thanks to CEDRIC<br /><br />'''Step 1 '''<br /> Extract 'Selfboot', you can find it in consoles\\selfboot.exe. It must be installed in C:\\Selfboot. <br /><br />'''Step 2 '''<br /> Place your bor pak in 'Consoles\\Dreamcast\'. Rename it from mymod.pak to bor.pak<br /> In this directory you should also find a Ip.bin and 1st_read.bin. <br /><br />'''Step 3 '''<br /> Run Selfboot.exe and select the directory Consoles\\Dreamcast\\. If you use NERO click the NERO (DAO) or NERO (TAO) button to create a .nrg image (use DAO if your burner supports it). If you use DiscJuggler click the DiscJuggler button to create a .cdi image. If you want to burn with CDRecord select CDRecord, click burn to burn the audio track (make sure there is a blank CD in your CD writer), click Msinfo, click Make Iso to build the image, then click Burn to burn the second session. <br /><br />'''Step 4 '''<br /> Burn the NERO or DiscJuggler image with the appropriate program. <br /><br /><br /><br />'''<font class="big" size="+1"> Making a disc for PS2</font> '''<br /><br /> Hmm, I actually don't know how to make a booting ps2 disc, since I don't have a ps2. Perhaps the mod-chip enables you to simple put the files on a disc and and it'll work. Who knows? <br /><br /> Still, don't forget to add bor.pak to the cd. <br /><br /><br />'''<font class="big" size="+1"> Run your mod on Xbox</font> '''<br /><br /> 1. Rename your mymod.pak to BOR.PAK. <br /> 2. Upload the your BOR.PAK file to a directory on your XBox <br /> 3. Upload the DEFAULT.XBE file to the same directory on your XBox (you can find this file in Consoles\\Xbox\\) <br /> 4. Run the DEFAULT.XBE file <br /><br /><br /><br /><br /><br /><br /> </center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center><font class="big" size="+2">'''Limitations to BOR'''</font><br /><br /> To inform those who run into the limitations of BoR, or fear that they might, here are some lines from the source code. <br /><br />
| + | |
- | | + | |
- | {| width="300" cellpadding="1"
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_SPRITES
| + | |
- | | align="left" valign="top" | 2000
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_ANIMS
| + | |
- | | align="left" valign="top" | 500
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_MODELS
| + | |
- | | align="left" valign="top" | 100
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_PANELS
| + | |
- | | align="left" valign="top" | 26
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | ANI_MAX_FRAMES
| + | |
- | | align="left" valign="top" | 26
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_COLOUR_MAPS
| + | |
- | | align="left" valign="top" | 7
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_NAME_LEN
| + | |
- | | align="left" valign="top" | 20
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | LEVEL_MAX_SPAWNS
| + | |
- | | align="left" valign="top" | 300
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | LEVEL_MAX_PANELS
| + | |
- | | align="left" valign="top" | 1000
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | LEVEL_MAX_HOLES
| + | |
- | | align="left" valign="top" | 20
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_LEVELS
| + | |
- | | align="left" valign="top" | 50
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_DIFFICULTIES
| + | |
- | | align="left" valign="top" | 5
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_SOUND_CACHE
| + | |
- | | align="left" valign="top" | 64
| + | |
- | |-
| + | |
- | | align="left" valign="top" | <nowiki>#define</nowiki>
| + | |
- | | align="left" valign="top" | MAX_FILES
| + | |
- | | align="left" valign="top" | 3000
| + | |
- | |}
| + | |
- | | + | |
- | <br /><br /> The limit of 2000 sprites means that you cannot use more than a total of 2000 sprites for all character models combined. In other words, if you perform a file count on your data/chars directory, and it comes up with a number greater than 2000, you could have a problem (especially if you double-loaded some images). <br /><br /> You cannot load more than 500 animations. Same deal as with the sprites, but unfortunately you can't count them as easily as with the sprites. <br /><br /> The maximum of 100 models corresponds to the number of text files in your data/chars directory, so these can be counted quite easily. BoR uses about 40 of them in the default pack. <br /><br /> The maximum number of background panels that can be loaded is, logically, 26, since you set the order with the tokens A through Z. <br /><br /> ANI_MAX_FRAMES indicates that you can use no more than 32 frames in an animation. <br /><br /> Well, I think you get the idea for the rest of them as well. The default pack file that comes with BoR rarely uses more than half of any of these values, so you should be able to make a mod about twice the size of the original. Which is pretty big, isn't it? <br /><br /> MAX_FILES indicates that the total number of files in the packfile has a maximum of 3000. <br /><br /><br /><br /> </center>
| + | |
- | | + | |
- | <br />
| + | |
- | | + | |
- | <center>'''<font class="big" size="+2">Common mistakes</font>'''<br /><br />'''When I try to edit my mod BOR just crashes/ I don't see error messages.'''<br /> BOR is unlikely to just crash, it probably encountered an error in your mod and exits the game, displaying an error message. In some windows configurations, windows closes all finished dos programs immediately, preventing you to see the error message. To make sure you can see the error messages do the following: <br /><br /> 1. right click on bor.exe, and select properties.<br />[[Image:properties.png]]<br /><br /> 2. click on the tab 'program' and make sure that the check box 'close on exit' is <u>unchecked</u>. <br />[[Image:program.png]]<br /><br /><br />''' I made a new enemy, but when I turned him into a hero it won't work. '''<br /> A number of things may cause this problem. First a hero has more moves, which need to be in the character.txt (e.g. kula.txt). So when making a new hero, first copy an existing text file of a hero and start replacing frames with your own. This way BOR will always find all the moves it expects.<br /><br /> Also make sure the character has been given the proper 'type' in the character.txt (type player). Finally all new characters need to be declared in the models.txt. <br /><br />''' BOR won't use my gifs. '''<br /> BOR can't handle long file names, so give files a name consisting of a maximum of 8 characters (e.g. 12345678.gif).<br /><br />''' The colours of my character are displayed wrong. '''<br /> BOR uses a fixed palette for characters, so you can't use colours that are not in the palette. So next time save the gifs using the bor palette (data\\pal.act). <br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /><br /> </center>
| + | |
OtL2xm Thank you ever so for you blog article.Really looking forward to read more. Cool.