From a68c05e4a4b81cbe21ed1a3a8d47b483b80753c9 Mon Sep 17 00:00:00 2001 From: ZXMushroom63 Date: Sun, 3 Nov 2024 18:51:53 +0800 Subject: [PATCH] make simple and advanced versions --- ...of_steve.js => block_of_steve_advanced.js} | 14 ++- examplemods/block_of_steve_simple.js | 102 ++++++++++++++++++ examplemods/dupe_hunting.js | 2 +- 3 files changed, 116 insertions(+), 2 deletions(-) rename examplemods/{block_of_steve.js => block_of_steve_advanced.js} (85%) create mode 100644 examplemods/block_of_steve_simple.js diff --git a/examplemods/block_of_steve.js b/examplemods/block_of_steve_advanced.js similarity index 85% rename from examplemods/block_of_steve.js rename to examplemods/block_of_steve_advanced.js index d2849af..561bf9e 100644 --- a/examplemods/block_of_steve.js +++ b/examplemods/block_of_steve_advanced.js @@ -15,23 +15,35 @@ function fixupBlockIds() { }); } function makeSteveBlock() { + var boolean_valueOf = ModAPI.reflect.getClassByName("Boolean").staticMethods.valueOf.method; + var testProperty = ModAPI.reflect.getClassById("net.minecraft.block.properties.PropertyBool").staticMethods.create.method(ModAPI.util.str("example_property")); var blockClass = ModAPI.reflect.getClassById("net.minecraft.block.Block"); var iproperty = ModAPI.reflect.getClassById("net.minecraft.block.properties.IProperty").class; var makeBlockState = ModAPI.reflect.getClassById("net.minecraft.block.state.BlockState").constructors.find(x => x.length === 2); var blockSuper = ModAPI.reflect.getSuper(blockClass, (x) => x.length === 2); + var creativeBlockTab = ModAPI.reflect.getClassById("net.minecraft.creativetab.CreativeTabs").staticVariables.tabBlock; var nmb_BlockSteve = function nmb_BlockSteve() { blockSuper(this, ModAPI.materials.rock.getRef()); + this.$defaultBlockState = this.$blockState.$getBaseState(); + this.$setCreativeTab(creativeBlockTab); } ModAPI.reflect.prototypeStack(blockClass, nmb_BlockSteve); nmb_BlockSteve.prototype.$isOpaqueCube = function () { return 1; } - nmb_BlockSteve.prototype.$createBlockState = function () { + nmb_BlockSteve.prototype.$createBlockState = function (t) { return makeBlockState(this, ModAPI.array.object(iproperty, 0)); } + // nmb_BlockSteve.prototype.$getMetaFromState = function (iblockstate) { + // return iblockstate.$getValue(testProperty).$booleanValue(); + // } + // nmb_BlockSteve.prototype.$getStateFromMeta = function (meta) { + // return this.$getDefaultState().$withProperty(testProperty, boolean_valueOf(meta > 0)) + // } globalThis.nmb_BlockSteve = nmb_BlockSteve; } function registerSteveClientSide() { + globalThis.testBlockImpl = ModAPI.util.wrap(new nmb_BlockSteve()); var itemClass = ModAPI.reflect.getClassById("net.minecraft.item.Item"); var blockClass = ModAPI.reflect.getClassById("net.minecraft.block.Block"); var block_of_steve = (new nmb_BlockSteve()).$setHardness(-1.0).$setStepSound(blockClass.staticVariables.soundTypeGravel).$setUnlocalizedName( diff --git a/examplemods/block_of_steve_simple.js b/examplemods/block_of_steve_simple.js new file mode 100644 index 0000000..4af0073 --- /dev/null +++ b/examplemods/block_of_steve_simple.js @@ -0,0 +1,102 @@ +//nice little utility function to fix the block identity map +function fixupBlockIds() { + var blockRegistry = ModAPI.util.wrap(ModAPI.reflect.getClassById("net.minecraft.block.Block").staticVariables.blockRegistry).getCorrective(); + var BLOCK_STATE_IDS = ModAPI.util.wrap(ModAPI.reflect.getClassById("net.minecraft.block.Block").staticVariables.BLOCK_STATE_IDS).getCorrective(); + blockRegistry.registryObjects.hashTableKToV.forEach(entry => { + if (entry) { + var block = entry.value; + var validStates = block.getBlockState().getValidStates(); + var stateArray = validStates.array || [validStates.element]; + stateArray.forEach(iblockstate => { + var i = blockRegistry.getIDForObject(block.getRef()) << 4 | block.getMetaFromState(iblockstate.getRef()); + BLOCK_STATE_IDS.put(iblockstate.getRef(), i); + }); + } + }); +} +function registerSteveClientSide() { + var creativeBlockTab = ModAPI.reflect.getClassById("net.minecraft.creativetab.CreativeTabs").staticVariables.tabBlock; + var itemClass = ModAPI.reflect.getClassById("net.minecraft.item.Item"); + var blockClass = ModAPI.reflect.getClassById("net.minecraft.block.Block"); + var constructor = blockClass.constructors.find(x=>x.length === 1); + var block_of_steve = constructor(ModAPI.materials.rock.getRef()).$setHardness(-1.0).$setStepSound(blockClass.staticVariables.soundTypeGravel).$setUnlocalizedName( + ModAPI.util.str("steve") + ).$setCreativeTab(creativeBlockTab); + blockClass.staticMethods.registerBlock0.method( + 198, + ModAPI.util.str("steve"), + block_of_steve + ); + itemClass.staticMethods.registerItemBlock0.method(block_of_steve); + ModAPI.addEventListener("lib:asyncsink", async () => { + AsyncSink.L10N.set("tile.steve.name", "Block Of Steve"); + AsyncSink.setFile("resourcepacks/AsyncSinkLib/assets/minecraft/models/block/steve.json", JSON.stringify( + { + "parent": "block/cube_all", + "textures": { + "all": "blocks/steve" + } + } + )); + AsyncSink.setFile("resourcepacks/AsyncSinkLib/assets/minecraft/models/item/steve.json", JSON.stringify( + { + "parent": "block/steve", + "display": { + "thirdperson": { + "rotation": [10, -45, 170], + "translation": [0, 1.5, -2.75], + "scale": [0.375, 0.375, 0.375] + } + } + } + )); + AsyncSink.setFile("resourcepacks/AsyncSinkLib/assets/minecraft/blockstates/steve.json", JSON.stringify( + { + "variants": { + "normal": [ + { "model": "steve" }, + ] + } + } + )); + AsyncSink.setFile("resourcepacks/AsyncSinkLib/assets/minecraft/textures/blocks/steve.png", await (await fetch( + "" + )).arrayBuffer()); + }); +} +function registerSteveServerSide() { + function fixupBlockIds() { + var blockRegistry = ModAPI.util.wrap(ModAPI.reflect.getClassById("net.minecraft.block.Block").staticVariables.blockRegistry).getCorrective(); + var BLOCK_STATE_IDS = ModAPI.util.wrap(ModAPI.reflect.getClassById("net.minecraft.block.Block").staticVariables.BLOCK_STATE_IDS).getCorrective(); + blockRegistry.registryObjects.hashTableKToV.forEach(entry => { + if (entry) { + var block = entry.value; + var validStates = block.getBlockState().getValidStates(); + var stateArray = validStates.array || [validStates.element]; + stateArray.forEach(iblockstate => { + var i = blockRegistry.getIDForObject(block.getRef()) << 4 | block.getMetaFromState(iblockstate.getRef()); + BLOCK_STATE_IDS.put(iblockstate.getRef(), i); + }); + } + }); + } + var creativeBlockTab = ModAPI.reflect.getClassById("net.minecraft.creativetab.CreativeTabs").staticVariables.tabBlock; + var blockClass = ModAPI.reflect.getClassById("net.minecraft.block.Block"); + var itemClass = ModAPI.reflect.getClassById("net.minecraft.item.Item"); + var constructor = blockClass.constructors.find(x=>x.length === 1); + ModAPI.addEventListener("bootstrap", () => { + var block_of_steve = constructor(ModAPI.materials.rock.getRef()).$setHardness(-1.0).$setStepSound(blockClass.staticVariables.soundTypeGravel).$setUnlocalizedName( + ModAPI.util.str("steve") + ).$setCreativeTab(creativeBlockTab); + blockClass.staticMethods.registerBlock0.method( + 198, + ModAPI.util.str("steve"), + block_of_steve + ); + itemClass.staticMethods.registerItemBlock0.method(block_of_steve); + fixupBlockIds(); + }); +} +registerSteveClientSide(); +fixupBlockIds(); +ModAPI.dedicatedServer.appendCode(registerSteveServerSide); \ No newline at end of file diff --git a/examplemods/dupe_hunting.js b/examplemods/dupe_hunting.js index 74f9465..023ed5b 100644 --- a/examplemods/dupe_hunting.js +++ b/examplemods/dupe_hunting.js @@ -92,7 +92,7 @@ function button_utility_script(inputArr, bindingClass, actionBindMode) { { text: "Server Close", click: () => { - var CloseWindow = ModAPI.reflect.getClassByName("C0DPacketCloseWindow").constructors.find(x => x.length === 1); + var CloseWindow = ModAPI.reflect.getClassByName("C0DPacketCloseWindow").constructors[0]; ModAPI.player.sendQueue.addToSendQueue(CloseWindow(ModAPI.player.openContainer.getCorrective().windowId)); }, x: 0,