SketchUp to Hammer Export plugin
This article needs to be updated to include current information regarding the subject.
The SketchUp to Hammer export plugin allows you to create models in Google SketchUp and then export them to the .vmf format for use in Hammer, the world editor for the Source game engine. Hammer is used to create game levels for games such as Half Life 2, Portal, Counter-Strike, and Left 4 Dead.
How it works
First you create groups of 3D geometry in SketchUp. Each group is typically a simple "solid" form such as a box or cylinder, or anything with a convex topology. The plugin translates each group/component into a Hammer "brush". If a component is named a certain way, it will export not as a brush, but rather as an "entity" which can be a light or other prop. If you've named your materials with the game's naming convention, the specified game materials will be assigned to brush faces. The result is a .VMF file, which is a source (raw) file that can be opened directly in Hammer.
Once in Hammer, you can further edit and append game level, as well as compile or "bake" your level into a .BSP file. BSP files can be loaded and played directly by Source engine games. You can build levels in either Hammer or Sketchup, or, most probably, you'll find it handy to go back and forth, making building blocks in SketchUp, importing the pieces into Hammer, and then using cut and paste to aggregate them bit by bit into a final map using Hammer.
SketchUp is useful for making quick mockups or complex brushes, but it doesn't support all of the game features. Hammer is a full-featured game level editor, and it's where you'll want to end up doing your later stage work. This is especially true if you plan on making high-quality, releasable game levels.
If you're new to editing game levels using Source, it's recommended that you visit the Level Design documentation pages. There you'll find the best source of information on how to setup and get started using Hammer.
See the main SketchUp Source Tools page for detailed installation instructions.
You may also need a previous version of SketchUp as the available plugins have not been updated for SketchUp 2016 and beyond.
Currently you are required to manually create materials in SketchUp based on the materials you want to use from the Source Engine. The only requirement is that the name of the material match the name of the .vmt file in hammer. Include the full path, i.e. "concrete/concretewall01a".
Let's start by going through the entire map exporting process with a simple example map. You're probably itching to draw your own map right away, but it's recommended that you make sure you can export, import, compile, and run this test map first.
To Start, launch Sketchup and load the file "myfirst_su_level.skp". It is provided with the plugins and can be found in the
valve_library folder, typically found here:
C:\Program Files\Google\Google SketchUp 7\Plugins\valve_library
1. The game map is a simple box volume with a few objects inside. The large, boxy objects are drawn so that they will export to hammer as "brushes", or solid building blocks in the game. In order to make a game level that runs properly, the "habitable" volume must be fully enclosed by brushes. In this example, the front box that fully encloses the habitable space has been hidden so that we can see inside. You can unhide it if you want: From the menu bar, go to the Edit menu and select Unhide > All. The volume inside is "watertight", fully sealed from the outside space. Go ahead and click the tab at the top of the 3D window labeled "Scene 2"
2. The box with the green figure is a SketchUp object that has been named "
ENT_info_player_start". When this file is exported as a .vmf and opened in Hammer, this object will become an entity called "
info_player_start" and tell the game engine where to initially place your point of view. Go ahead and click the tab at the top of the 3D window labeled "Scene 3".
3. This is another object named "
ENT_LIGHT" it will export to the game as, you guessed it, a light. You can edit the properties of this light later when you get it inside Hammer. Click the tab labeled "Scene 4".
4. Some of the surfaces in the model have been painted with materials. Click on the Paint Bucket tool (icon) on the toolbar, and then click on the home icon of the window that pops up. This shows you materials that are being used in the scene. If you hover over the brick texture, you'll see that this material has been named "
dev/dev_brickwall012d". This corresponds to a material that shipped with Left 4 Dead. When materials are given game pathnames like this, they will come into Hammer with those material assignments.
5. Let's make sure everything is set up properly. Go ahead and, from the menu bar, select Plugins > Export VMF... When prompted, use the default name "
myfirst_su_level.vmf", and save the file somewhere convenient like your desktop.
6. Start Steam, go to the Tools tab, and launch "Left 4 Dead Authoring Tools". Click "Hammer World Editor" from the list. When Hammer launches, open the .vmf file that you exported in the previous step. Your map should appear in wireframe.
7. From Hammer's View menu, select 3D Shaded Textured Polygons The 3D Camera View in the upper left hand corner should now appear solid. We'll dive into Hammer more a bit later.
8. In the Hammer window, select File > Run Map.... Leave the default options and click OK.
9. Hammer will process the map and calculate lighting. When it's done, it will launch Left 4 Dead and open the new map. Dismiss the "Map is unplayable!" message. You should now be in game!
Next, let's add your own forms in SketchUp...
Creating your own brushes
1. Exit the game and go back to your SketchUp model. We're going to make some changes, so it's best to do a quick Save As... to a new file somewhere.
2. Click on the "Scene 2" tab to position the camera next to a good drawing surface.
5. Let's get a different perspective of this brush in 3D. Click this icon to activate the Orbit Tool and press and drag your mouse across the 3D screen. This orbits your view. view. You can also hold down your middle mouse button to orbit while in other tool modes. You may also activate it through the main menubar with Camera > Orbit.
7. Next reactivate the Push/Pull Tool and press and drag the sides of the box. This allows you to adjust it's sides. Try not to make it too big; it should be a small object inside the overall box for now.
8. Activate the Select Tool and drag a rectangle around the box from left to right. This will select all of its faces and edges. Make sure that you've selected only the box, and not the 2D figure or anything else as well. If you select from right to left, it will select anything that intersects your box, and that may include geometry behind the box by mistake. Another handy way to select the whole box alone is to triple click one of its faces.
9. From the Edit menu, select Make Group. Your box should now be grouped and highlighted. Congratulations! You've made your first game building block! This box will now appear as solid to the player when imported into the game.
10. Activate the Move Tool and click on the box. It should follow your cursor until you your mouse button a second time. Now try the same action while holding down the key. Now you're making copies... Make as many copies as you like. It's OK if they overlap one another in volume.
11. Try clicking on the small red "plus" signs that appear when you hover over the boxes with the move tool. This allows you to rotate each box along that side.You can use the Select Tool to deselect a box, or to select one or more boxes.
12. Try activating the Scale Tool from the Tools menu, and stretching the building blocks in different directions.
13. Let's go ahead and try exporting again. From the Plugins menu, select Export Hammer VMF... Again, you will be prompted for a file location. Notice that the default name of the .vmf is filled in using the name of your SketchUp file. Go ahead and save it. When you switch back to Hammer, you'll see the previous unchanged .VMF map. Go ahead and close it, then open the updated .VMF that you just saved. You should see your new changes, and if you run the map as before, you should see your changes in game.
You're now on your way to making awesome levels. There's a lot of stuff to learn when you're starting out making game content, but you can do it. If you run into stumbling blocks, remember to visit the Level Design documentation pages.
Like all Source Engine tools, Hammer has standard content folders. It's preferable that .vmf files be saved in the
sdk_content\mapsrc directory. The default location for mapsrc in Left 4 Dead is:
C:\Program Files\Valve\Steam\SteamApps\common\left 4 dead\sdk_content\mapsrc
After you've opened the .VMF file you saved from SketchUp in Hammer, it's handy to have a look around.
1. You can navigate the 3D view in the upper right corner using thekeys, similar to how you walk in the game.
2. If you tap thekey, the mouse will switch from a cursor to "look around" mode. This mimics how you look around in game and is handy to use while pressing the keys. Tap again to switch back to mouse cursor mode.
3. If your 3D view is in wireframe, you can, from the 'View' menu, select '3D Textured Shaded Polygons' You will notice that the plugin has created a green "
player_start" location as well as light entities where their SketchUp components were placed.
4. Learn more about navigating in Hammer here.
- Each individual group should have a convex topology. Concave forms will not export to Hammer properly, and you may get an "invalid solid" message. Forms such as arches must be built from many convex forms arranged together.
- When making your levels, try to build with simple building blocks. You can group many objects together to make a more complex form.
- By default, the forms you make will have a grey grid material. You can use the MaterialZoo.skp in the "valve_library" folder to grab some other materials. The name of the material in SketchUp will determine what material will be applied in Hammer.
- You can find many great videos online that can teach you to use SketchUp in just a few days.
Exporting .VMF for other Source Engine games
Source Engine games released prior to Left 4 Dead use a separate SDK (Software Development Kit) which includes their own version of Hammer. You can use the SketchUp plugin that comes with the Left 4 Dead authoring Tools to export .VMFs for these games as well. To get the SDK:
- From Steam, go to the Tools tab.
- You should see Source SDK in the list. Launch it. (Steam will install it if it hasn't been already).
- When the Source SDK launcher window comes up, it has drop down menus that allow you to author for different engine versions and games. Make sure the Current Game you have selected is one that you have installed on your 'my Games' list and that the game has been run at least once. If it doesn't show up, switch the Engine Version and then check again. If it still doesn't appear, close the launcher, run the game once, then re-open the Source SDK.
- Select the game you wish to play in from the drop-down.
- Launch the Hammer Editor application.
- The default 2D skybox texture is configured for Left 4 Dead. If you want to change it, create a sky component with the name "
SKY.name_of_texture". You should only have one of these per level.
- If you want to place an entity in you game level, create a custom component and name it "
ENT.name_of_entity". So if you want to place a zombie from Half Life 2, name the component "
ENT.npc_zombie". Name it "
ENT.weapon_physcannon" to place the physics gun. The exporter will ignore the contents of the component. All that matters is the name and the position. The entity needs to be in the game you're compiling for, and a list of options is visible in Hammer.
- The file valve_sketchup_tools_config.rb allows advanced users to configure plugin options.
- Exporting .VMF files with the outliner open can cause a crash. This is usually caused by setting
$v_vmf_export_boundingbox = truein the config file. Workaround 1: Close or minimize the outliner. Workaround 2: set
Comments and bugs
- Please send comments and feedback to firstname.lastname@example.org