Home | What IS Qodot? | Setting Up Your Project | The Game Manager Autoload | What's an Entity? | Base Classes and Property Definitions | Solid Entities | Point Entities, Part 1 | Point Entities, Part 2 | Game Configuration | Forge Game Data | Textures! | Finally. TrenchBroom. | Building the QodotMap | Helpful Resources | Frequently Asked Qodots
It's finally time to learn about the centerpiece of the Qodot plugin: the QodotMap Node.
Let's create a new scene and add a QodotMap.
There's a lot going on here. We talked about some of these options but let's just go through them all again.
-
Map File
: Fairly obvious: the location of your map file. This takes a Global Path rather than a Project Path. This means you can use a map file located outside of your project. -
Inverse Scale Factor
: We've mentioned this a couple times in previous chapters. This is the scale ratio between the map's Quake Units to Godot Units, affecting the scale at which your map is built. -
Entity FGD
: The FGD resource containing the definitions for the entities found in the selected map. -
Base Texture Dir
: The root folder where Qodot will search for brush texture names. Reread the Textures chapter for more details. -
Texture File Extensions
: Array of image file extensions to search for when generating materials. -
Worldspawn Layers
: An array of WorldspawnLayer resources. I don't recommend bothering with WorldspawnLayers since the entity system is more than enough to do all the things we'd use WorldspawnLayers for, and more efficient about it, too. -
Brush Clip Texture
: This is the location of the first texture Qodot will use for culling mesh faces on build, relative to Base Texture Dir. Collision will be retained in both Convex and Concave types. -
Face Skip Texture
: Location of the second texture Qodot will use for culling mesh faces on build, relative to Base Texture Dir. Collision for these faces is currently retained in both Convex and Concave types, but this behavior is currently planned to change in a future update. -
Texture Wads
: An array of Quake WAD files. This was largely included for Quake map compatibility but not really efficient for serious work flows. Recommend against using. -
Material File Extension
: When Qodot applies textures on map build it will first look for any premade material resources with this extension before generating a resource. Useful for assigning custom shaders to brushes, like liquid shaders. Reread the Textures chapter for more details. -
Unshaded
: Quick and dirty unshaded material generation mode. Mostly used to ignore lighting. -
Default Material
: The template material Qodot generates materials with using the brush textures as albedo. Is also used as the template for automated PBR textures. Reread the Textures chapter for more details. -
Default Material Albedo Uniform
: If the default material is a ShaderMaterial rather than StandardMaterial3D, this is the shader uniform that provides the albedo texture. -
UV Unwrap Texel Size
: Texel size for lightmaps. See the Godot docs for more information. -
Print Profiling Data
: Prints the length to completion of every build step for debugging purposes. -
Use Trenchbroom Group Hierarchy
:If true, Qodot will build a hierarchy from Trenchbroom groups, each group being a node. Otherwise, Qodot nodes will ignore Trenchbroom groups and have a flat structure.
It's supposed to take advantage of Solid Entities with the Group spawn type, but it doesn't seem to function properly. Leave unchecked for consistent results.
-
Block Until Complete
: If true, stop the Editor until the build is complete. -
Tree Attach Batched Size
: Unused. -
Set Owner Batch Size
: How many nodes to set the owner of, or add children of, at once. Higher values may lead to quicker build times, but a less responsive editor.
That's... a lot. We won't really be touching the majority of these to be honest but it's always good to know what you're looking at. Let's get started!
We'll start from the top and work our way down. For now, don't set a Map File. We'll come back to it later.
If you'll recall, we opted to set our Inverse Scale Factor to 32. Make sure we're using the custom QodtFGDFile resource we spent 80 years crafting and not the default.
Our Base Texture Dir should point to res://tb/textures/.
We can ignore Texture File Extensions since it already includes all the formats we'll need, and ignore Worldspawn Layers since we're not using them. Leave Brush Clip Texture and Face Skip Texture alone, as the assets you downloaded already provided them in those locations. Ignore Texture Wads since we won't be using them for this project.
We'll leave Material File Extension alone since the .tres format works well. I leave the decision of Unshaded to you, but I'll be leaving it off. However let's change the Default Material to the one we made during our brief stint in the Textures chapter, qodot_default.tres
. Since our default material is a StandardMaterial3D we don't need to put anything into Default Material Albedo Uniform.
We can ignore the rest of the settings. You should now have a QodotMap node that looks like this.
We are going to save this scene as a template so that we don't have to set this up again for other maps. Go ahead and save the scene in your res://maps/ folder as mapbase.tscn
.
Any time we want to create a new map, we can either instantiate this scene or duplicate it. For now we'll just go with the latter option. Duplicate the scene file and call it... well, whatever you'd like. How about marsfrogreturns.tscn
?
In your definitely-named marsfrogreturns.tscn
, go ahead and give the QodotMap node the location of the map file we made earlier. With the QodotMap selected, at the top of the Editor you should see some buttons.
-
Quick Build : Quickly builds the map without setting ownership to any nodes. Build does not persist outside of the edited scene and disappears upon testing or closing the scene file. Only intended to give a quick preview.
-
Full Build : Fully constructs the map and assigns ownership to nodes, allowing them to persist in the scene and be saved.
-
Unwrap UV2 : Unwraps the Worldspawn mesh's UV2 for lightmapping. This does not unwrap anything not merged with Worldspawn. Not to worry though, our func_geo script automatically unwraps our UV2 upon build so we don't have to worry about it.
Go ahead. Perform a Full Build.
If you did everything correctly up until this point, you should end up with something like this.
When you test it out you should notice one of the Marsfrogs has vanished. This was the one we set the appearance_flag
to Not on Normal
. You'll also hear our Sound3D play the music cue that came with the assets you downloaded earlier, the one we set by filepath.
Wait a few moments for the music cue to finish playing and the Sound3D will then call Game Manager's use_targerts
method, triggering the Marsfrog to do a little dance while also printing a message in the Output.
NOTE: While the Game Manager only calls the Utility Function's
print()
method, you can replace it with any custom UI messaging method or signal to display in-game on-screen text.
Hello world! Look at little Marsfrog go!
Incredible work! Congratulations! You've gone from nothing to successfully watching a little Marsfrog dance to the end of a silly music cue, completely mapped out in TrenchBroom!
And that's really all there is to it. Every single entity you will ever make follows these basic design ideas. It may seem a bit overwhelming to some of you, but all it takes is a little bit more practice and familiarity and it will quickly become second nature.
And before you know it, you'll have that func_door
opening by auto-generated trigger_volume
in no time at all.
Home | What IS Qodot? | Setting Up Your Project | The Game Manager Autoload | What's an Entity? | Base Classes and Property Definitions | Solid Entities | Point Entities, Part 1 | Point Entities, Part 2 | Game Configuration | Forge Game Data | Textures! | Finally. TrenchBroom. | Building the QodotMap | Helpful Resources | Frequently Asked Qodots