My First Mod: Difference between revisions
| No edit summary | TomEdwards (talk | contribs)   (otherlang2; minor cleanup) | ||
| Line 1: | Line 1: | ||
| ==  | {{otherlang2| | ||
| de=My First mod:de| | |||
| pl=My First mod:pl| | |||
| ru=My First mod:ru| | |||
| pt=My First mod:pt| | |||
| pt-br=My First mod:pt-br| | |||
| es=My First mod:es}} | |||
| This tutorial will teach you how to create | This tutorial will teach you how to create and build your first simple Source mod. In this mod we will change the speed at which Half-Life 2's rocket travels through the world. | ||
| == Create the  | == Create the project == | ||
| For the purpose of this tutorial we will call our first  | For the purpose of this tutorial we will call our first mod, "Mymod". When you make your own mod this can be any name you wish (i.e. "Quickmod", "TreasureTroll", etc.) | ||
| Please note that in order to get the latest source-code you must [[Refresh SDK Content|refresh the SDK content]]. | Please note that in order to get the latest source-code you must [[Refresh SDK Content|refresh the SDK content]]. | ||
| To create a  | To create a mod project: | ||
| # Open the '''Source SDK''' application from Steam's '''Tools''' menu. | # Open the '''Source SDK''' application from Steam's '''Tools''' menu. | ||
| # Open '''Create A  | # Open '''Create A mod''' from the '''Utilities''' group. | ||
| # Select either ''' | # Select either '''modify Half-Life 2 Single Player''' or '''modify Half-Life 2 Multiplayer'''. | ||
| # Specify where you would like the  | # Specify where you would like the mod's project to be placed (i.e. <code>C:\Mymod</code>). | ||
| # Enter the name of your  | # Enter the name of your mod. In this example, we'll use "Mymod". | ||
| # Vista may require extra steps depending on your security settings. (see known issues below) | # Vista may require extra steps depending on your security settings. (see known issues below) | ||
| The Steam application will then copy all the relevant files to the destination directory that you specified. You now have a copy of Half-Life 2's source code at that location which you can modify. | The Steam application will then copy all the relevant files to the destination directory that you specified. You now have a copy of Half-Life 2's source code at that location which you can modify. | ||
| == Open the  | == Open the solution == | ||
| # Launch your copy of '''Microsoft Visual Studio''' | # Launch your copy of '''Microsoft Visual Studio'''. See [[Compiler choices]]. | ||
| # Select '''File->Open Solution''' from the menu and open the  | # Select '''File->Open Solution''' from the menu and open the '''Game_HL2-2005.sln''' solution located in your mod's <code>src</code> directory, select the one that matches your version of '''Microsoft Visual Studio'''.  Note the "HL2" portion of the file name will correspond to the selection you made in the mod creation step.  If you selected mod from scratch, "Scratch" will appear there instead. | ||
| == Alter the rocket's speed == | == Alter the rocket's speed == | ||
| Line 38: | Line 45: | ||
|   #define RPG_SPEED 400 |   #define RPG_SPEED 400 | ||
| By altering this number, we've told the rocket to travel at 400 units per second (or about 33 feet per second, or 10 meters per second). Previously the rocket traveled at 1500 units per second (125 ft/s, 38 m/s). The difference in speed will be very apparent when we compile and run the  | By altering this number, we've told the rocket to travel at 400 units per second (or about 33 feet per second, or 10 meters per second). Previously the rocket traveled at 1500 units per second (125 ft/s, 38 m/s). The difference in speed will be very apparent when we compile and run the mod. | ||
| == Set the active configuration == | == Set the active configuration == | ||
| Line 56: | Line 63: | ||
| == Compile the project == | == Compile the project == | ||
| Now we are ready to build the solution. Choose '''Build->Build Solution''' to begin. When the requested compilation has completed there will be a <code>server.dll</code> and <code>client.dll</code> file in the <code> | Now we are ready to build the solution. Choose '''Build->Build Solution''' to begin. When the requested compilation has completed there will be a <code>server.dll</code> and <code>client.dll</code> file in the <code>Mymod/bin</code> directory <code>(i.e. C:\Mymod\Mymod\Bin)</code>. This is the custom server and client DLL for our mod and is one of the pieces that would be distributed to end-users. | ||
| == Run the mod == | |||
| Now before you launch it's important to ensure you have something to launch. By default, new mods will use AppId 215 (Ep1) or 218 (Orange Box). This loads the correct version of [[Source SDK Base]], which is accessible to almost everyone with a Valve game and, in the case of 218/Orange Box, is kept up to date with the latest engine built. You can check or change your AppId in the game's [[The_GameInfo.txt_File_Structure|GameInfo.txt file]]. | Now before you launch it's important to ensure you have something to launch. By default, new mods will use AppId 215 (Ep1) or 218 (Orange Box). This loads the correct version of [[Source SDK Base]], which is accessible to almost everyone with a Valve game and, in the case of 218/Orange Box, is kept up to date with the latest engine built. You can check or change your AppId in the game's [[The_GameInfo.txt_File_Structure|GameInfo.txt file]]. | ||
| SDK Base provides only Half-Life 2's shared content, however. If you want to use content from a specific game, or HL2's maps, you will need to change the AppId [[Steam Application IDs|to that of the game you want to load from]]. If you want to 'mount' more than one game [[Mounting Other Content|you can do so]], but you should avoid that method unless you really need it for reasons explained on its page. | SDK Base provides only Half-Life 2's shared content, however. If you want to use content from a specific game, or HL2's maps, you will need to change the AppId [[Steam Application IDs|to that of the game you want to load from]]. If you want to 'mount' more than one game [[Mounting Other Content|you can do so]], but you should avoid that method unless you really need it for reasons explained on its page. | ||
| In the directory that you created your mod, there will be a batch file called <code>run_mod.bat</code>. Don't use the bat file to launch your mod, as it has not been updated for the SDK Base. The best way to launch your mod is to restart Steam and launch it from your Games list (where it should hopefully have appeared - if not, check your AppId) or via the debugging option in vis (read how to debug the source code). | |||
| In the directory that you created your  | |||
| Now that there's content to load, start the game up. When the engine has loaded, you'll be taken to the title screen. If you are warned about missing content, such as <code>maplist.txt</code>, ignore it.   | Now that there's content to load, start the game up. When the engine has loaded, you'll be taken to the title screen. If you are warned about missing content, such as <code>maplist.txt</code>, ignore it.   | ||
| Line 70: | Line 77: | ||
| In "Options", "Keyboard", and "Advanced", enable the Developer Console. Hit the tilde key (<b>~</b>) to bring up the [[Developer Console]]. This console will provide you with numerous tools to help you create content for the Source engine.   | In "Options", "Keyboard", and "Advanced", enable the Developer Console. Hit the tilde key (<b>~</b>) to bring up the [[Developer Console]]. This console will provide you with numerous tools to help you create content for the Source engine.   | ||
| No maps are provided with your single player mod, so copy a map from the HL2 maps with [[GCFScape]] to your mod's /maps/ directory inside of SteamApps/ | No maps are provided with your single player mod, so copy a map from the HL2 maps with [[GCFScape]] to your mod's /maps/ directory inside of SteamApps/Sourcemods. Load a map by typing "map " (including the space) into the console and select from the list (e.g. "<code>map d1_canals_01</code>") then type "<code>impulse 101</code>" to give yourself a load of weapons. | ||
| {{note|A map that you can always use and is guaranteed to work is ''sdk_shader_samples.bsp'', found in <code>steamapps\[USER ID]\half-life 2\hl2\maps</code>}} | {{note|A map that you can always use and is guaranteed to work is ''sdk_shader_samples.bsp'', found in <code>steamapps\[USER ID]\half-life 2\hl2\maps</code>}} | ||
| Line 78: | Line 85: | ||
| Select and fire the RPG to view the changes you've made. | Select and fire the RPG to view the changes you've made. | ||
| == You've built your first  | == You've built your first mod == | ||
| You’ve now  | You’ve now set up and built your first mod.   | ||
| * See [[:Category:Modding]] for articles to help you add more features to your  | * See [[:Category:Modding]] for articles to help you add more features to your mod.   | ||
| * See [[:Category:Programming]] for a listing of programmer-specific documentation.   | * See [[:Category:Programming]] for a listing of programmer-specific documentation.   | ||
| * See [[:Category: | * See [[:Category:Level Design]] for articles on populating your mod with levels. | ||
| * See [[:Category:Modeling]] for articles to help you add models to your  | * See [[:Category:Modeling]] for articles to help you add models to your mod. | ||
| [[Category:Programming]] | [[Category:Programming]] | ||
| [[Category:Tutorials]] | [[Category:Tutorials]] | ||
| [[Category:Modding]] | [[Category:Modding]] | ||
Revision as of 04:38, 16 July 2009
This tutorial will teach you how to create and build your first simple Source mod. In this mod we will change the speed at which Half-Life 2's rocket travels through the world.
Create the project
For the purpose of this tutorial we will call our first mod, "Mymod". When you make your own mod this can be any name you wish (i.e. "Quickmod", "TreasureTroll", etc.)
Please note that in order to get the latest source-code you must refresh the SDK content.
To create a mod project:
- Open the Source SDK application from Steam's Tools menu.
- Open Create A mod from the Utilities group.
- Select either modify Half-Life 2 Single Player or modify Half-Life 2 Multiplayer.
- Specify where you would like the mod's project to be placed (i.e. C:\Mymod).
- Enter the name of your mod. In this example, we'll use "Mymod".
- Vista may require extra steps depending on your security settings. (see known issues below)
The Steam application will then copy all the relevant files to the destination directory that you specified. You now have a copy of Half-Life 2's source code at that location which you can modify.
Open the solution
- Launch your copy of Microsoft Visual Studio. See Compiler choices.
- Select File->Open Solution from the menu and open the Game_HL2-2005.sln solution located in your mod's srcdirectory, select the one that matches your version of Microsoft Visual Studio. Note the "HL2" portion of the file name will correspond to the selection you made in the mod creation step. If you selected mod from scratch, "Scratch" will appear there instead.
Alter the rocket's speed
If you are editing Half-life Single-player, open file hl2_dll/weapon_rpg.cpp. Otherwise open hl2mp_dll/weapon_rpg.cpp.
Note: If you can't find the file, try looking in the server_hl2 > Source Files > HL2 DLL folder within your Solution Explorer window within Microsoft Visual Studio.
At the top of the file, find the line:
#define RPG_SPEED 1500
Change this line to read:
#define RPG_SPEED 400
By altering this number, we've told the rocket to travel at 400 units per second (or about 33 feet per second, or 10 meters per second). Previously the rocket traveled at 1500 units per second (125 ft/s, 38 m/s). The difference in speed will be very apparent when we compile and run the mod.
Set the active configuration
We'll need to set our active configuration to "Release HL2".
To do this:
- Select Build->Configuration Manager.
- Change the Active Solution Configuration drop-down list to "Release HL2"
- Select Close.
For Visual Studio 2005/2008 users:
- Select Project -> Properties (last entry in menu)
- Press Configuration Manager (upper right button)
- Change the Active Solution Configuration drop-down list to "Release"
Compile the project
Now we are ready to build the solution. Choose Build->Build Solution to begin. When the requested compilation has completed there will be a server.dll and client.dll file in the Mymod/bin directory (i.e. C:\Mymod\Mymod\Bin). This is the custom server and client DLL for our mod and is one of the pieces that would be distributed to end-users.
Run the mod
Now before you launch it's important to ensure you have something to launch. By default, new mods will use AppId 215 (Ep1) or 218 (Orange Box). This loads the correct version of Source SDK Base, which is accessible to almost everyone with a Valve game and, in the case of 218/Orange Box, is kept up to date with the latest engine built. You can check or change your AppId in the game's GameInfo.txt file.
SDK Base provides only Half-Life 2's shared content, however. If you want to use content from a specific game, or HL2's maps, you will need to change the AppId to that of the game you want to load from. If you want to 'mount' more than one game you can do so, but you should avoid that method unless you really need it for reasons explained on its page.
In the directory that you created your mod, there will be a batch file called run_mod.bat. Don't use the bat file to launch your mod, as it has not been updated for the SDK Base. The best way to launch your mod is to restart Steam and launch it from your Games list (where it should hopefully have appeared - if not, check your AppId) or via the debugging option in vis (read how to debug the source code).
Now that there's content to load, start the game up. When the engine has loaded, you'll be taken to the title screen. If you are warned about missing content, such as maplist.txt, ignore it. 
In "Options", "Keyboard", and "Advanced", enable the Developer Console. Hit the tilde key (~) to bring up the Developer Console. This console will provide you with numerous tools to help you create content for the Source engine.
No maps are provided with your single player mod, so copy a map from the HL2 maps with GCFScape to your mod's /maps/ directory inside of SteamApps/Sourcemods. Load a map by typing "map " (including the space) into the console and select from the list (e.g. "map d1_canals_01") then type "impulse 101" to give yourself a load of weapons.
 Note:A map that you can always use and is guaranteed to work is sdk_shader_samples.bsp, found in
Note:A map that you can always use and is guaranteed to work is sdk_shader_samples.bsp, found in steamapps\[USER ID]\half-life 2\hl2\maps Note:Enable cheats in the game by typing "
Note:Enable cheats in the game by typing "sv_cheats 1" in the console (~) for the "impulse 101" command to workSelect and fire the RPG to view the changes you've made.
You've built your first mod
You’ve now set up and built your first mod.
- See Category:Modding for articles to help you add more features to your mod.
- See Category:Programming for a listing of programmer-specific documentation.
- See Category:Level Design for articles on populating your mod with levels.
- See Category:Modeling for articles to help you add models to your mod.