Age of Empires II: HD Edition

Age of Empires II: HD Edition

205 ratings
Ozhara's Modding Guide for AoE 2 HD
By Ozhara
This Guide describes how to install/uninstall mods, publish your own workshop mod for AoE, where to find graphic and sound files and how they work, as well as how to mod them.

If you think the guide is missing something important or a point isn't that clear - just tell me and I'll adjust the guide. :)
As you may know with version 4.0 a new workshop implementation was introduced.

Most content of this guide is still usable, but some has to be updated.

I'll do so soon! :)
0) Common Hints
In case there is anything not working as intended with AoE, you can make Steam to check if there is everything right with the games installation.
You don't need to have done something manually for a file to be 'corrupted'. This might be from your anti virus software doinfg 'stuff', a mod download having issues and all other sort of things.
This check is done by steam verifying your game data is as it should be and reseting all files that got changed back to its default.
This does only apply to official game files and no local mod files personal file copies or anything not beeing part of the default installation!

For Steam to verify your game cahce do this:
1) AoEs modding system
1.1 Installation
If you subscribe to a mod, steam downloads the mod to T:\Steam\SteamApps\workshop\content\221380\Mod_Id where Mod_Id is the mods id from its steam site url. If it does, you should be able to see an entry called 'AoE workshop content' in your steam download tab. Wait until it is finished.

When you start your game the next time, the mod shows up in the ingame mod manager. Here you can enable or disable the mod and change its priority.

If several mods do change the same file, the mod with the highest priority wins.

Not sure which mod to use?
Subscribe to several ones and switch between them by en/diabling them depending on your current mood.

1.2 Uninstallation
To uninstall a mod, just select it in the ingame mod manager and click 'unsubscribe'.
You might want to keept it for later though and just disable it for now.

1.3 A mod stopped working
If a mod was not updated to the 'new' file/folder structure introduced with patch 4.0, the mod is not compatible with AoE anymore. You can see this from a mod beeing labeled as 'old workshop' in steam and shown red in the ingame mod manager.
You can either try to contact the mods author so the mod gets updated, or you can try to get it back working manually.

My own mod manager also has a conversion functionality that can help you with this.
2) How to publish a mod to the workshop
Ok, lets do the basics first. You have some files you want to upload, a scenario for example.

2.1 Place all files in your game directory
at the place they have to be so their content shows up in your game.
This is REALLY important, as a subscribed mod extracts all contained data to exactly that folder in your game directory, you chose/uploaded it from!

2.2 Now start your game and go to the workshop:
You can also reach the workshop by going to the scenario editor and clicking the workshop button in the editors menu. For some reason larger mods did succeed the publishing for me more often when using the workshop through the scenario editor...

2.3 Choose all files your mod shall contain
such as game files, readme files and so on. The preview image you can select later:
By clicking this button, a file dialog opens where you can pick all files you want.
But this dialog doesn't support all file extensions. In case you want to publish a file whose extension is not supported, just browse to its folder and write its name down by hand. It then will be selected correctly.

2.4 Set the mods general information and publish it.
  • A) Write down the mods title.
  • B) Choose the mods type.
  • C) Here you can write down the mods description. But the length is limitated while the description directly set in the steam workshop can be much MUCH longer. So I wouldn't write it down here.
  • D) Set the visibility of the mod. In case you want to try it first in a closed beta or want to write down the description directly in steam without someone looking at it before you're ready, set it to friends or hidden. Just keep in mind, your mod will show up in the 'most recent' page at that timestamp you published it, not when you set it to public. So at days lots of mods are published, waiting too long could be bad for beeing recognized.
  • E) Click this button to choose your mods preview image. You can't set it later and only change it by updating your mod - what is very buggy, so choose the right one right now!
    In case you add additional preview screens in the workshop, this main preview image will be shown at the right and not in the normal preview section anymore.
  • F) Publish your mod - to succeed your mod, including the preview image, must be smaller then 100 MB (if it's not, you'll get error 21). And the larger it is, the more time it needs, for my larger soundtracks it was up to 45+ minutes. And the larger the mod is, the more likely it is it will fail due to server/connection errors, showing up as error 16. As I mentioned before, for me it failed less often at large mods when publishing through the scenario editor instead of the main menu.
3) Where to find graphic and sound files
If you want to mod some game files, you first have to know where they are.

3.1 For sound files, check your game\resources\_common\sound folder.

All soundtrack files are in the 'music' subfolder.
All ui related sounds like main menu, civ related game starting as well as win and loose you can find in the 'stream' subfolder.

3.2 No-terrain graphics you can find in your game\resources\_common\drs\gamedata_x2 folder.

3.3 Terrain graphics can be found in your game\resources\_common\terrain folder.
4) Modding of sound files
When looking at the sounds (as well as some other files), in some cases you'll find two files, only differing in the one having a 'x' at its beginning. That means, the file without the leading 'x' is the files variant for 'The Age of Kings', while the other one is the eXpansion file of 'The Conquerors'. In case you use 'Forgotten Empires' or another dlc, there might be another version (ending with _x2, _x3, ...) for those too. Only the last file (depending on a players used dlcs) is used.

The music for the main menu music is named xopen.mp3 and located in your game\resources\_common\sound\stream folder. The main menu music for FE is named xopen_x2.mp3, the AK one xopen_x3.mp3.
In case players with different dlcs are supposed being able to hear your replacement, you have to replace all the files. Same with win and lost sound for example.

Without mods active there is a file called music1.mp3 which contains the 'The Age of Kings' soundtrack, and about 20 named xmusic1-20.mp3 with 'The Conquerors' one in your sound\music folder. 'The Rise of the Rajas' adds 3 more files.

The 'new' sound system currently used by AoE can handle multiple soundtrack files, so the original one-file-soundtrack isn't used anymore.

AoE will play all found xmusic files in their numbered order as long as there is a higher number left and there is no gap in the files numbers. If one of those two things happens, it will go back to xmusic1.mp3 and repeat looping through the files.
Of course this means the first file has to be number 1. Without that file, you will have no sound ingame at all.

This also means, in case you use an old soundtrack mod that does not cover the multiple-track-files system, all default tracks that are not replaced will play before the mods soundtrack restarts.

So to replace the whole default soundtrack, you should add at least 23 track files to your mod.
In case I don't have enough tracks, I achieve this by adding the soundtrack multiple times and/or by adding an empty mp3 file from time to time.

There seems to be no limit, so you can add as many soundtrack files as you want. My Touhou sounbdtrack ends around xmusic150.mp3 for example.
5) Modding of terrain graphic files
The terrain files you can find in your game\resources\_common\terrain folder.
This folder contains a textures folder with multiple png images in 512x512 pixel format.

When creating a map, think of it as one layer per terrain, the png file placed side by side with itself.
By actually choosing a certain terrain at a specific area of the map, the fix terrain layer will become visible at this area.

For the ingame map is no square, but rotated and clinched, the same will happen to the png images. So your terrain images witll be rotated 45° to the left and get clinched.

You may have noticed, different terrains do blend into each other differently
, especially the borders of the ice terrain are unique.

The blending is defined in the blending files found in your terrain\blends folder.
These pngs are black and white, white for the actually placed terrain, black for the surrounding ones. The shape of the white parts edges and the grey parts define the terrains border and blending area/type. Here as an example the normal ice blending texture and the one I'm using for my space terrains to create a '3D like planet border':
Here an ingame example:
As you can see, the blending texture shows different compositions of the white and black terrain area.

Last thing on terrains is the water effect
HiddenPath implemented.
It consists of five files you can find in your game\terrain\water folder.

The files normal0 and normal1.png do look like normal maps. The wave effect is created by having one layer of the normal1 image like with the terrains, and one wit the normal0 image. The first one (normal1) can be seen beneath water terrain, the other one (normal0) moves over it from the left bottom to the right top. This moving combined with color differences (or not) at a specific pixel at a specific time, generates the general wave effect.
Same for normal3 and normal4.png.
With the AoR dlc, the wave effect got splitted up, so shallow water has its own wave effect now.

But that's not all, the water terrain itself and the wave effect do interact with the last image, the sky_hemisphere.png. This file is very special.

It's not used 'completely' as the other ones. Like them, it is rotated 45° to the left and clinched to fit the ingame tiles. But instead of being placed side by side with itself to create a layer for the whole map, this one png is stretched across the whole screen afterwards.

This is the file I'm using for my moving water V4. The red rectangle shows the visible part ingame. It's the top corner (after the rotation). Depending on your resolution (width) this area can vary (see the orange rectangle as an example).

The default image is black/white too. At areas that only have one color, no effect is visible. When not modded, there is only a small part in the upper left of the screen showing 'reflections' and waves. This is for at that area different black, white and grey shades do change quickly.

If you use a different color like green for example, the water will get a touch in that color as you can see in the cinematic water mod.

When using the same color as the water terrains like in my example, the water gets a blue touch. But the water is already blue and my sky_hemisphere image isn't just blue, but has different colored areas. This way the wave effcet is more subtle as with black and white for the color shades aren't that different.

What can cause problems are water terrains that have a structure themselve or contain a lot of different colors. This way the wave effect is less visible for it interferes with the terrains structure which breaks the wave effect. With different colors, regarding to the color of your sky_hemisphere image, it can happen only some areas show a wave effect for some terrain colors do kind of 'absorb' it.

Sadly for the implementation of this file it's not possible to give every different colored area on a water terrain a matching area on the hemisphere image.
6) Modding of no-terrain graphic files
6.1 If you want to mod no-terrain graphics, you first have to understand how these graphics are implemented.

All graphics are implemented as slp files.

These slp files you can find in your game\resources\_common\drs\gamedata_x2 folder.

A slp file contains all images (bmp) for a specific animation. So a unit for example has several slp files as it has several animations like standing, walking or attacking. A buildings image is a one-frame animation. Objects like trees have one animation for every forest type, choosing one frame for each tile randomly.

For more information about slp file naming conditions and stuff, take a look at guide to graphic objects

In the file empires2_x1_p1.dat there is a graphic object defined, pointing at a specific slp file using the numeric id the slp has as well as its object name. So both can be used for naming your modded file. I personally prefer to name slps using their graphics name, for everyone knowing the naming conditions will immediately be able to know what your file contains without the need to open or search for it or the need to memorize thousands of numbers.

For modded graphics, the game checks your game\resources\_common\slp folder for slp files using the graphics name and your game\resources\_common\drs\gamedata_x2 folder for slp files using the graphics id. If it finds a file with the same id or name a graphic object in the dat file has, this graphic will be replaced ingame.

Just in generall, files ending with '_NN' are main graphics, files ending with '_0N' are shadow graphics (some objects have a seperate shadow, showing up ingame as semi-transparent (buildings for example), others have their shadow in their main graphic, showing up as completely black (units for example)).

6.2 To edit these graphics, I recommend two free tools I'm using:

1. Advanced Genie Editor[]
2. Turtle Pack[]

Both of them are fan made as there exist no official modding tools for AoE 2.

Turtle Pack can be used for everything regarding drs and slp files beside actually drawing.
(I'll only cover the most important functions here.)

With the Genie Editor you can edit the empires2_x1_p1.dat in your game\data folder and change the games mechanic. If you want to do this - there are a lot of tutorials out there.

For now the interesting thing is to get the slp names, for extracted slps are named with their numeric id, that is used as a pointer by AoE by default. But you can also name them with their objects name now. -> Always use the objects name, this makes identifying specific slp files much more easy later on.

6.2.1 To get the right name for a slp file
do the following:

Either look it up from my guide to graphic objects, or open Advanced Genie Editor.

If you use Genie Editor you'll get a dialog where to choose/set general file locations.
You can choose from several path presets if you want to.

Important is the location of the dat file you want to open.

If you want you can also type in the path to your language files, then several unit texts will be shown as set in them in the editor.

Click on OK and the editor will open the dat file. For me the dialog shows up two times as well as the editor window. Just close/cancel the second one.

The editor looks like this:

Now select 'SLP' as the first filter, type in your slps id (in this example the Knights attacking animation) and apply the filter by checking it:
As a result you get the corresponding graphic object entry and it's name (without the file extension of course).

6.2.2 To get in contact with the graphics
you want to change, just open the slp file with Turtle Pack then:

  • A) AoE has no real collision system. Each object blocks an amount of tiles. The 'X' in the center is the center for the objects graphic. That one can be positioned where you want. Theoretically the graphic could show up 3 tiles away. It would still block its building tiles, but be shown somewhere else with no actual collision at the graphic. You can change the position by using the arrows or 'STRG + Arrow Keys'. This has/can not to be done on the graphic itself!

  • B) With this Button you can select all frames on the right. It also works with 'STRG + A' when you already have one selected. The Default is no selected frame.

  • C) All selected frames will be extracted as seperate bmps to the folder you will choose in the opening dialog.

  • D) AoE uses an indexed color palette. This means it uses no colors, but pointers to a color for every pixel. That color is defined in the palette. Therefore each image you want to import should be converted to the right palette first (It works without, but you WANT to convert it!).

    As you can see this works independant of the actual frames. You can convert whatever you want. Just choose the files by hitting the 'Add' button and choose a directory the converted bmps will be saved in. Hit start and then close the dialog (this doesn't work automatically).

    After doing so, you should replace the frames (you can do a complete new slp, add or delete frames, but the used frame count is defind in the dat file, so additional frames doesn't show and missing ones will result in empty frames beeing played. So for just changing existing visuals, just replace existing ones.):

    For the replacement, choose the new frame and set player color and transparency.

    The transparency defines which color of your bmpy shall be changed to the transparent one.

    The player color means which color you used in your bmp as player color. This is important as the AoE palette has 8 exactly defined values for every players color shades. When extracting a bmp, every pixel that is supposed to change it's color according to players color will be colored in the chosen player color (default is blue). To convert a real color back to the undefined player color one, you have to set this. If you choose red for example, no red pixel - even if it matches a red player color value - will be interpreted as player color but shown as red - for every player.

    On the other hand, every pixel that changed to a color shade of the chosen player color while converting - even if it wasn't meant to have players color - will have it ingame. And every pixel supposed to have the players color but doesn't have the right color value after converting - will not change its color ingame.

  • E) You can verify if a pixel has the right color by changing the player color on the left side of the editor. This changes all pixels marked as player color to the right color shade of the chosen player color. The chosen color is also the color used as player color when extracting a bmp.
< >
Sadokazam Jul 13 @ 4:15am 
Hi, how can i translate campaign map stories?
vob May 10 @ 9:48am 
Hi Ozhara !
A friend and I are working on a project that would require to start a game in the lobby from outside of the game (by a link for instance). We have explored few possibilities :
- make the user do the network request the game does but from outside of the game (issue : game won't necessarily expect the response and then make the user join its own game)
- using steam API (issue : doesn't seem to exist such a feature)
- create a mod that could make a "create game" request without the user clicking on the buttons
About this last possibility we have very few informations. We know some mods allow to change the main menu disposition but do you think it would be possible to add extra functionality to it ?
Thx in advance !
harooooo May 8 @ 6:23pm 
I'm having trouble with replacing frames in turtle pack 1.6. For example if i take 1 north european house and export bitmap then make just a tiny edit with paint or photoshop, like draw a red line over the roof for example, when i convert it to 256 bmp parts of the texture become transparent. How to stop the color black from turning transparent??

Here's what I'm talking about --->
Ozhara  [author] Apr 20 @ 5:30am 
Sorry to all of you that posted before Franco - I somehow managed to not see there have been new comments... :(

I'm currently working on updating the guide! :)
Ozhara  [author] Apr 20 @ 4:54am 
I have to update my guide, I know...

you need to do the following:
- Go to your AoE\mods folder
- Create a new folder named like your mod is supposed to be titled
- For each file you want to add to your mod, recreate the folder structure from inside the AoE folder inside your mod, so you can position it at the same location. So a file located in AoE\resources\_common\slp, will need to be placed in AoE\mods\Your_Mod\resources\_common\slp.
- In your mods main folder, place the thumbnail. It has to be a jpg image with the name: _preview-image.jpg.
- Run AoE and in the ingame workshop manager, select your mod. You will t hen be able to click 'publish'.
- After doing so, subscribe to your own mod - this way it will turn from unpublished to published in the ingame manager and you'll get a second entry with your subscription - you can always switch between the uploaded mod version and your local one that might have changed due to you working on it.
Ozhara  [author] Apr 20 @ 4:54am 
- Also make sure to edit the mods description file created next to the thumbnail image when uploading the mod. If you don't add the description from your mods steam page there (after the Value =), it will be reset each time you update your mod. (You might also needto resubscribe to it after an update.)
- If you ever want to rename your mod in steam, also change the mods folder name in AoE\mods, as the name is used as a reference. If you don't rename the mods folder, it will be recognizes as a new mod when changing the mods title in steam.

I'm currently updating my mod manager and will reactivate the option to create mods with it in the near future, enabling you to create your mod much more easy with only the need to configure it in my tool and then clicking the publish button in AoE. :)
Franco Apr 3 @ 8:59am 
the modding system has now changed... what should i do now?
benberk123 Oct 3, 2016 @ 10:21am 
Hey I am trying to make a mod that turns the grey player into black in the mini map and for all buildings and units. They have this mod on voobly so maybe I could just copy paste it? But do you think you could upload a mod where you tweak the players colors like darker green, blue and orange to see better in the map as well as turn grey player black
Rundelhaus Sep 27, 2016 @ 9:29am 
This is the only guide I found for AoEIIhd modding and it leaves me with so many questions.
Additionally stap 2, as Setna wrote is totally out of date.

With that many mods for this game, there must be someone able to explain things. How do all you modder know how to make stuff?

I would like a short but complete guide on those topics:
a) How do I create a new mod?
b) How do I test that mod?
c) How do I publish that mod?
*d) How do I edit anything?

Can someone explain these things, please?
Big Boss x REvolvER OcELot Sep 21, 2016 @ 7:53am 
out of date :( plz update