-
Notifications
You must be signed in to change notification settings - Fork 31
Overwriting Game Resources
The overwrites.gd file is used to define resource overwrites in a separate file. In general, any file in a project can be overwritten, but we highly recommend that you only use this feature for images and audio or any other type that inherits from Resource.
We recommend the following directory structure for your overwrites:
res://
└───mods-unpacked
└───Author-ModName
├───mod_main.gd
├───manifest.json
├───overwrites.gd
└───overwrites
└───original_dir_name
└───original_file_name.png
The following steps are required to create an overwrite:
- Open the file you want to replace by right-clicking and selecting Open in File Manager.
- Create a replacement file that matches the metadata of the original file 1:1.
For example, for images, make sure that the resolution is the same. - Add the replacement file to the overwrites directory.
Ideally, structure your overwrites as shown above. - Add the required code to overwrites.gd.
Using preload
extends Node
func _init():
var overwrite_0 = preload("res://mods-unpacked/Author-ModName/overwrites/assets/images/GodotModded.png")
overwrite_0.take_over_path("res://assets/images/GodotModded.png")
Using load
Load only works if the overwrite goes into global scope at some point, otherwise Godot won't be able to find the file. No idea why. There are two ways to do this: a global variable declaration or a global Array to which the overwrites are appended. The global variable only works for a single overwrite, so this example uses the Array.
extends Node
var icons: Array # this declaration NEEDS to have global scope
const ICONS := [
"GodotModded.png",
"UpgradeIcon.png"
]
func _init():
for image in ICONS:
var icon_overwrite := load("res://mods-unpacked/Author-ModName/overwrites/assets/icons".plus_file(image))
icon_overwrite.take_over_path("res://assets/icons".plus_file(image))
icons.append(icon_overwrite) # this essentially pulls the overwrite into global scope
Instead of using an array of Strings here, you could also use the Directory class to go over each file in a folder and create and overwrite with it.
You can use Godot Mod Tool to make overwriting assets easier. If you have the plugin activated:
- right-click -> ModTool: Create Asset Overwrite on the asset you want to replace
Home ~ Setup ~ Mod Structure ~ Mod Files ~ API Methods ~ Logging