Crafting Tweaks
Minecraft Mod. Allows you to rotate, balance or clear the crafting matrix by the press of a button, in any (supported) crafting window.
See the license for modpack permissions etc.
This mod is available for both Forge and Fabric (starting Minecraft 1.17).
Forge
Fabric
Contributing
If you're interested in contributing to the mod, you can check out issues labelled as "help wanted" . These should be ready to be implemented as they are.
If you need help, feel free to join us on Discord.
IMC API (Forge)
Most crafting grids can be registered using the IMC API.
In order to register your container for Crafting Tweaks, send an IMC message as follows:
InterModComms.sendTo("craftingtweaks","RegisterProvider",()->{
CompoundNBT tagCompound=new CompoundNBT();
tagCompound.putString("ContainerClass",YourCraftingContainer.class.getName());
// tagCompound.putInteger("ValidContainerPredicate", YourContainerPredicate.class.getName());
// tagCompound.putInteger("GetGridStartFunction", YourGridStartFunction.class.getName());
// tagCompound.putInteger("GridSlotNumber", 1);
// tagCompound.putInteger("GridSize", 9);
// tagCompound.putBoolean("HideButtons", false);
// tagCompound.putBoolean("PhantomItems", false);
// tagCompound.putInteger("ButtonOffsetX", -16); // ignored if AlignToGrid is set
// tagCompound.putInteger("ButtonOffsetY", 16); // ignored if AlignToGrid is set
// ***** OR *****
// tagCompound.putString("AlignToGrid", "left");
// CompoundNBT tweakRotate = new CompoundNBT();
// tweakRotate.putBoolean("Enabled", true);
// tweakRotate.putBoolean("ShowButton", true);
// tweakRotate.putInteger("ButtonX", 0); // ignored if AlignToGrid is set
// tweakRotate.putInteger("ButtonY", 18); // ignored if AlignToGrid is set
// tagCompound.put("TweakRotate", tweakRotate);
// [...] (same structure for "TweakBalance" and "TweakClear")
return tagCompound;
});
The commented out lines are optional (the example above shows the default value).
The fields are described below:
- ContainerClass: The full class name (including package name) of your container class with the crafting grid.
- ContainerValidPredicate: (V3 or higher) The full class name (including package name) of an optional container callback; a class that implements Function<Container, Boolean> to determine whether a container is a valid crafting container
- GetGridStartFunction: (V3 or higher) The full class name (including package name) of an optional slot callback; a class t hat implements Function<Container, Integer> to determine the first slot of a crafting grid (overrides GridSlotNumber)
- GridSlotNumber: The slotNumber of the first slot in the crafting matrix (this is the index within Container.inventorySlots, NOT the index within the IInventory)
- GridSize: The size of the crafting grid (probably 9)
- HideButtons: If you don't want Crafting Tweak's buttons to show up (but you want the hotkeys to work), set this to true
- PhantomItems: If your crafting grid contains phantom items, set this to true. This will make the clear operation delete the grid instead of putting the items into the player inventory.
- ButtonOffsetX: X-Offset to apply to all tweak buttons, relative to the upper left corner of the GuiContainer. AlignToGrid will override this option.
- ButtonOffsetY: Y-Offset to apply to all tweak buttons, relative to the upper left corner of the GuiContainer. AlignToGrid will override this option.
- AlignToGrid: Can be "up", "down", "left" or "right". Will automatically position buttons next to the grid.
- TweakRotate: A tag compound containing settings for the rotate tweak (see below)
- TweakBalance: A tag compound containing settings for the balance tweak (see below)
- TweakClear: A tag compound containing settings for the clear tweak (see below)
- Tweak...: Contains the following settings for tweaks:
- Enabled: Set this to false if this tweak should be disabled for this container
- ShowButton: Set this to false if the button for this tweak should not be added
- ButtonX: X-Position of the tweak button relative to ButtonOffsetX. AlignToGrid will override this option.
- ButtonY: Y-Position of the tweak button relative to ButtonOffsetY. AlignToGrid will override this option.
Note: If you're specifying custom button positions, they should be 18 pixels apart from each other. If you simply want the buttons next to the crafting grid, use AlignToGrid. If you just want to move all buttons at once, use ButtonOffsetX/Y. The buttons are set out vertically by default.
Java API (Forge & Fabric)
If your crafting grid is more complex or doesn't follow Vanilla standards, you may need to supply a custom grid provider using the Java API.
The easiest way to add Crafting Tweaks to your development environment is to do some additions to your build.gradle file. First, register CurseForge's maven repository by adding the following lines:
repositories {
maven { url "https://www.cursemaven.com" }
}
Then, add a dependency to Crafting Tweaks:
dependencies {
compile 'curse.maven:craftingtweaks-233071:<fileId>' // for Forge; find the latest file id on CurseForge
// compile 'curse.maven:craftingtweaks-fabric-502516:<fileId>' // for Fabric; find the latest file id on CurseForge
}
Done! Run gradle to update your project and you'll be good to start developing your addon.
Registering a Crafting Grid using the Java API
The entry point for your plugin is going to be a class implementing CraftingGridProvider
.
import net.blay09.mods.craftingtweaks.api.*;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.inventory.AbstractContainerMenu;
public class YourCustomCraftingGridProvider implements CraftingGridProvider {
public YourCustomCraftingGridProvider() {
CraftingTweaksAPI.registerCraftingGridProvider(this);
}
@Override
public String getModId() {
return "yourModId";
}
@Override
public boolean requiresServerSide() {
return false; // should be true if you use things such as phantom items, where simulating clicks would now result in desired behaviour
}
@Override
public boolean handles(AbstractContainerMenu menu) {
return menu instanceof YourCustomCraftingMenu; // buildCraftingGrids will only be called if this returns true for the given menu
}
@Override
public void buildCraftingGrids(CraftingGridBuilder builder, AbstractContainerMenu menu) {
// this is where you define crafting grids
if (menu instanceof YourCustomCraftingMenu) {
builder.addGrid(1, 9); // you can register a simple default grid like this
builder.addGrid("secondary_grid", 1, 9); // you can also specify names (default: "default") if you have multiple grids in one screen
builder.addGrid(1, 9) // you can also configure the default grid further
.disableTweak(TweakType.Rotate) // e.g. by disabling certain tweaks
.disableAllTweaks() // or by disabling all tweaks, if you hate Crafting Tweaks
.hideTweakButton(TweakType.Clear) // or by hiding a certain tweak button
.hideAllTweakButtons() // or by hiding all tweak buttons
.usePhantomItems() // or by marking this grid to contain phantom items, which ensures that Crafting Tweaks doesn't perceive these items as real items
.setButtonAlignment(ButtonAlignment.TOP) // or by changing the alignment of the buttons, e.g. having them be at the top of the grid instead of at the left
.setButtonPosition(TweakType.Balance, 10, 10) // or by overriding the position of the buttons directly, ignoring alignment
.rotateHandler(/*...*/) // or by overriding the rotation handling
.balanceHandler(/*...*/) // or by overriding the balance handling
.clearHandler(/*...*/) // or by overriding the clear handling
.transferHandler(/*...*/); // or by overriding the transfer handling
builder.addCustomGrid(new CraftingGrid() { // you can also add completely custom crafting grids with your own implementations
// ...
});
}
}
}
Then instantiate that provider if Crafting Tweaks is loaded:
public class YourMod {
private void setup() {
// ...
if (isModLoaded("craftingtweaks")) { // different calls depending on whether you use Forge or Fabric
try {
Class.forName("your.mod.compat.craftingtweaks.YourCustomCraftingGridProvider").getConstructor().newInstance();
} catch (Throwable e) {
e.printStackTrace();
}
}
// ...
}
}
Registering a GUI handler for custom tweak button placement
You shouldn't really need to do this, but in case you want to handle the button placement in your screen yourself, you can define a GUI handler for it:
import net.blay09.mods.craftingtweaks.api.CraftingGrid;
import net.blay09.mods.craftingtweaks.api.CraftingTweaksAPI;
import net.blay09.mods.craftingtweaks.api.CraftingTweaksClientAPI;
import net.blay09.mods.craftingtweaks.api.GridGuiHandler;
import net.blay09.mods.craftingtweaks.client.CraftingTweaksClient;
import net.minecraft.client.gui.components.AbstractWidget;
import net.minecraft.client.gui.screens.inventory.AbstractContainerScreen;
import java.util.function.Consumer;
public class YourCustomGridGuiHandler implements GridGuiHandler {
public YourCustomGridGuiHandler() {
CraftingTweaksClientAPI.registerCraftingGridGuiHandler(this);
}
@Override
public void createButtons(AbstractContainerScreen<?> screen, CraftingGrid grid, Consumer<AbstractWidget> addWidgetFunc) {
// CraftingTweaksClientAPI.createTweakButton(/* ... */); ...
}
}
Remember to instantiate the handler (so that it gets registered) as done in the previous section.