Simple Walkthrough
Hey there, kindlich here. So you’re trying out ContentTweaker for 1.15, huh?
Sometimes I’ll usually abbreviate ContentTweaker with CoT to spare me a few letters (it’s more an automatism from Discord already), so stay with me, okay? Then, first I recommend you also install a resource manager mod, so that the blocks/items that you have a way of adding textures and models for blocks and items later on.
ContentTweaker will try to create model files as well as a simple no-texture image in your resource folder, as long as it detects either the mod The loader or Open Loader installed. If neither of these is installed, it will only print a message to the log stating that it won’t create textures for you. At some point it will also be possible to disable the generation of textures altogether, but not in the curren Alpha/Beta build.
For the generated textures, CoT will not override files if they already exist, so you can simple replace the existing files with your own ones and CoT will not undo these changes.
Now, let’s get to it, shall we? I will give examples for some simple blocks and items. If you want to see everything these classes support, you can find the API export in the API folder right below this file in the navbar!
Loader ContentTweaker
Since CraftTweaker in 1.14+ will load while the server is up and running, we need a way to load scripts somewhere else.
That is what the #loader contenttweaker
is for!
Simply put it somewhere in (preferable the top of) your file and you’re set to go.
Remember no crafttweaker scripts are allowed in #loader contenttweaker
as they run at different phases of the laod cycle!
Blocks
For creating blocks you need to create a BlockBuilder object.
Once you have that you can set most simple properties in a builder pattern.
You could then directly call build(name)
on it and be done if you want to create a basic block.
Or you could specialize the builder using withType
and provide a specialized builder class, for example BuilderStairs or BlockBuilderPillarRotatable. Check their respective pages to see what additional features they offer. Be aware that once you do the withType call, there is no going back, so set all basic properties before that call.
Remember, whatever you do, at the end of the chain you need a build(name)
call, since otherwise nothing will happen!
Enough spoken, you want a copy/paste example, do you?
Items
For items you more or less do the same, but this time you need an ItemBuilder.
You can again, either use a build(name)
directly, or switch to a specialized version using withType
.
At the time of this writing there only exists ItemBuilderTool, though.
Remember, whatever you do, at the end of the chain you need a build(name)
call, since otherwise nothing will happen!
Enough spoken, you want a copy/paste example, do you?
Names
So, how would you go about giving items proper names?
For that, you need a lang file.
At the time of this writing CoT did not yet create that one for ya, so you will need to create it yourself.
In your resource pack, find the assets/contenttweaker
folder.
In there, create a folder named lang
if it does not yet exist, and create a file named en_us.json
in there.
I recommend always starting with the en_us one, since that is what the game will fall back to if it cannot find the name for another language. Afterwards feel free to repeat this with other lang codes as well.
In there you will have to create a Key-Value map for your entries. The keys, also called Translation keys, or in earlier versions unlocalized Name, are dependent on the name of the block/item you used, and they will look like
For the value, you can set how the item is named ingame in there. If you are unsure about the syntax, check the example below, or try a JSON Validator if you got the syntax down.
TLDR: <resoruce_pack>/assets/contenttweaker/lang/en_us.json
.