mirror of
https://github.com/eaglerforge/EaglerForgeInjector
synced 2025-07-23 14:11:16 -09:00
wip stuff
This commit is contained in:
parent
51f06875f3
commit
753b5858cf
@ -149,6 +149,7 @@ ModAPI.meta.credits("By ZXMushroom63");
|
||||
};
|
||||
globalThis.AsyncSink = AsyncSink;
|
||||
ModAPI.events.callEvent("lib:asyncsink", {});
|
||||
console.log("[AsyncSink] Loaded!");
|
||||
}
|
||||
runtimeComponent();
|
||||
ModAPI.dedicatedServer.appendCode(runtimeComponent);
|
||||
|
94
examplemods/lib.lcrender.js
Normal file
94
examplemods/lib.lcrender.js
Normal file
@ -0,0 +1,94 @@
|
||||
ModAPI.meta.title("LibCustomRender");
|
||||
ModAPI.meta.credits("By ZXMushroom63");
|
||||
ModAPI.meta.icon("");
|
||||
ModAPI.meta.description("Library to make retexturing LCI items easier. Requires AsyncSink.");
|
||||
(function LibRender() {
|
||||
function getLore(item) {
|
||||
if (item.$stackTagCompound && item.$stackTagCompound.$hasKey(ModAPI.util.str("display"), 10)) {
|
||||
var displayTag = item.$stackTagCompound.$getCompoundTag(ModAPI.util.str("display"));
|
||||
if (displayTag.$hasKey(ModAPI.util.str("Lore"), 9)) {
|
||||
var loreTag = displayTag.$getTag(ModAPI.util.str("Lore"));
|
||||
if (loreTag.$tagCount() > 0) {
|
||||
return ModAPI.util.ustr(loreTag.$getStringTagAt(0));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
function cloneBaseModel(baseModel, newTexture) {
|
||||
var newBaseModelBuilder = ModAPI.reflect.getClassByName("SimpleBakedModel$Builder").constructors[0](0, 0, ModAPI.reflect.getClassByName("ItemCameraTransforms").constructors.find(x => x.length === 0)());
|
||||
var textureProp = ModAPI.util.getNearestProperty("$texture", newBaseModel);
|
||||
}
|
||||
|
||||
ModAPI.events.newEvent("lib:libcustomrender:loaded");
|
||||
var ItemRenderer = ModAPI.minecraft.renderItem;
|
||||
var ItemModelMesher = ItemRenderer.itemModelMesher;
|
||||
var laxImgDataClass = ModAPI.reflect.getClassByName("ImageData").class;
|
||||
var makeLax1dudeImageData = ModAPI.reflect.getClassByName("ImageData").constructors.find(x => x.length === 3);
|
||||
var eaglerTextureAtlasSprite = (imageData, name) => {
|
||||
var atlas = ModAPI.reflect.getClassByName("EaglerTextureAtlasSprite").constructors[0](ModAPI.util.str(name));
|
||||
var alias = ModAPI.util.wrap(atlas);
|
||||
alias.loadSprite(ModAPI.util.makeArray(laxImgDataClass, [imageData]));
|
||||
};
|
||||
const LibCustomRender = {};
|
||||
LibCustomRender.map = {};
|
||||
LibCustomRender.addRetextureRule = (loreString, textureBuffer, baseItem) => {
|
||||
baseItem ||= "paper";
|
||||
var actualLoreStr = loreString;
|
||||
loreString = loreString.replaceAll(":", "_").toLowerCase().replace(/[^a-z_]/g, '');
|
||||
if (!(textureBuffer instanceof ImageData)) {
|
||||
return console.error("Texture for retexture rule is not an ArrayBuffer.");
|
||||
}
|
||||
if (!(typeof loreString === "string")) {
|
||||
return console.error("loreString for retexture rule is not a string.");
|
||||
}
|
||||
var baseModel = ItemModelMesher.simpleShapesCache.get(ModAPI.hooks.methods.jl_Integer_valueOf(ItemModelMesher.getIndex(ModAPI.items[baseItem].getRef(), 0)));
|
||||
LibCustomRender.map[loreString] = {
|
||||
meta_int: ModAPI.util.hashCode(loreString) % 256,
|
||||
lore: actualLoreStr,
|
||||
identifier: loreString,
|
||||
model: makeModelJSON(loreString)
|
||||
}
|
||||
var itemstack = ModAPI.reflect.getClassById("net.minecraft.item.ItemStack").constructors[5](ModAPI.items[baseItem].getRef(), 1, LibCustomRender.map[loreString].meta_int);
|
||||
LibCustomRender.map[loreString].stack = itemstack;
|
||||
ItemRenderer.registerItem0(ModAPI.items[baseItem].getRef(), LibCustomRender.map[loreString].meta_int, ModAPI.util.str(loreString));
|
||||
}
|
||||
|
||||
// override
|
||||
// public IBakedModel getItemModel(ItemStack stack) {
|
||||
// Item item = stack.getItem();
|
||||
// In ItemModelMesher.java
|
||||
|
||||
var methods = Object.keys(ModAPI.hooks.methods);
|
||||
var prefix = ModAPI.util.getMethodFromPackage("net.minecraft.client.renderer.ItemModelMesher", "getItemModel");
|
||||
var methodName = methods.find(x => x.startsWith(prefix) && ModAPI.hooks.methods[x].length === 2);
|
||||
var original = ModAPI.hooks.methods[methodName];
|
||||
var testStack = ModAPI.reflect.getClassById("net.minecraft.item.ItemStack").constructors[5](ModAPI.items.paper.getRef(), 1, 0);
|
||||
ModAPI.hooks.methods[methodName] = function (...args) {
|
||||
var item = args[1];
|
||||
var lore = item ? getLore(item) : "";
|
||||
if (!item) {
|
||||
return original.apply(this, args);
|
||||
}
|
||||
var shouldOverride = false;
|
||||
var overrideItem = null;
|
||||
var overrideModelT = null;
|
||||
var overrides = Object.values(LibCustomRender.map);
|
||||
for (let i = 0; i < overrides.length; i++) {
|
||||
const override = overrides[i];
|
||||
if (lore === override.lore) {
|
||||
shouldOverride = true;
|
||||
overrideModelT = override.model;
|
||||
overrideItem = override.stack;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (shouldOverride) {
|
||||
return overrideModelT;
|
||||
return original.apply(this, [args[0], overrideItem]);
|
||||
}
|
||||
return original.apply(this, args);
|
||||
}
|
||||
|
||||
ModAPI.events.callEvent("lib:libcustomrender:loaded", {});
|
||||
globalThis.LibCustomRender = LibCustomRender;
|
||||
})();
|
Loading…
x
Reference in New Issue
Block a user