June 26, 20205 yr Author actually @Override public ModIntNBT serializeNBT() { return new ModIntNBT(this.energy); } public class ModEnergyStorage implements ModIEnergyStorage, INBTSerializable<ModIntNBT> {
June 26, 20205 yr 8 minutes ago, TallYate said: ModIntNBT ...did you implement your own NBT class? Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable. If you think this is the case, JUST REPORT ME. Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice. Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked. DO NOT PM ME WITH PROBLEMS. No help will be given.
June 26, 20205 yr Author yes because the IntNBT constructor is private so I copy pasted it and made it public
June 26, 20205 yr Author @Override public IntNBT serializeNBT() { return IntNBT.valueOf(this.energy); } @Override public void deserializeNBT(IntNBT nbt) { this.energy = ((IntNBT)nbt).getInt(); } thanks so I'm not supposed to use a modified version?
June 26, 20205 yr 1 minute ago, TallYate said: so I'm not supposed to use a modified version? Why would you have to? It literally makes no sense that the game would have to ask you to serialize something to a given format and not have a working implementation of that format to serialize to. I'm not even sure the game would know how to serialize and deserialize your custom NBT classes properly. Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable. If you think this is the case, JUST REPORT ME. Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice. Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked. DO NOT PM ME WITH PROBLEMS. No help will be given.
June 26, 20205 yr https://github.com/TallYate/CrudeTechMod/blob/master/src/main/java/me/joshua/crudetechmod/Items/PowerArmor.java#L42 return a ICapabilitySerializable there
June 27, 20205 yr Author Override public IntNBT serializeNBT() { IntNBT nbt = null; getCapability(ModCapabilityEnergy.ENERGY, null).ifPresent(handler -> { nbt = IntNBT.valueOf(handler.getEnergyStored()); }); return nbt; } That needs a serializeNBT and deserializeNBT. Do you know how I can make the handler return the nbt? Because "nbt cannot be assigned, since it is defined in an enclosing type"
June 27, 20205 yr Author Also I can't just put return IntNBT.valueOf(handler.getEnergyStored()); in the handler because it has to return nothing (void)
June 27, 20205 yr Author @Override public ICapabilitySerializable initCapabilities(ItemStack stack, @Nullable CompoundNBT nbt) { return new ICapabilitySerializable() { protected ModEnergyStorage storage = newStorage(); protected LazyOptional<ModEnergyStorage> storageHolder = LazyOptional.of(() -> storage); public <T> LazyOptional<T> getCapability(Capability<T> cap, Direction side) { if (cap == ModCapabilityEnergy.ENERGY) { return storageHolder.cast(); } return LazyOptional.empty(); } public Integer a = null; public void setA(int x) { a = x; } @Override public IntNBT serializeNBT() { getCapability(ModCapabilityEnergy.ENERGY, null).ifPresent(handler -> { setA(handler.getEnergyStored()); }); return IntNBT.valueOf(a); } @Override public void deserializeNBT(INBT nbt) { getCapability(ModCapabilityEnergy.ENERGY, null).ifPresent(handler -> { handler.setEnergy(((IntNBT) nbt).getInt()); }); } }; } is this ok? Edited June 27, 20205 yr by TallYate more context
June 27, 20205 yr 6 hours ago, TallYate said: getCapability(ModCapabilityEnergy.ENERGY, null).ifPresent(handler -> { setA(handler.getEnergyStored()); }); return IntNBT.valueOf(a); what on earth is this YOU HAVE ACCESS OVER THE ENERGY STORAGE
June 27, 20205 yr Author @Override public IntNBT serializeNBT() { int a = 0; getCapability(ModCapabilityEnergy.ENERGY, null).ifPresent(handler -> { a = handler.getEnergyStored(); }); return IntNBT.valueOf(a); } This doesn't work so I did that bad thing. Is there a better way that you know of?
June 27, 20205 yr Dude, seriously. You have access to the underlying storage directly, there's ZERO reason to use getCap and the lazy optional. public IntNBT serializeNBT() { return IntNBT.valueOf(storage.getEnergy()); } and public void deserializeNBT(IntNBT nbt) { storage.setEnergy(nbt.getInt()); } Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable. If you think this is the case, JUST REPORT ME. Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice. Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked. DO NOT PM ME WITH PROBLEMS. No help will be given.
June 27, 20205 yr Author Thank you. Everything works now! using CapabilityManager.INSTANCE.register() is not needed right?
June 28, 20205 yr Author Thank you. Everything works now! using CapabilityManager.INSTANCE.register() is not needed right?
June 28, 20205 yr Author @Override public IntNBT serializeNBT() { int a = 0; getCapability(ModCapabilityEnergy.ENERGY, null).ifPresent(handler -> { a = handler.getEnergyStored(); }); return IntNBT.valueOf(a); } This doesn't work so I did that bad thing. Is there a better way that you know of?
June 28, 20205 yr Define "doesn't work." Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable. If you think this is the case, JUST REPORT ME. Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice. Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked. DO NOT PM ME WITH PROBLEMS. No help will be given.
June 28, 20205 yr Author Oh sorry I think the forums glitched or something because I said that earlier in the thread
June 28, 20205 yr The forums have been acting oddly, but that's quite an odd result indeed. Apparently I'm a complete and utter jerk and come to this forum just like to make fun of people, be confrontational, and make your personal life miserable. If you think this is the case, JUST REPORT ME. Otherwise you're just going to get reported when you reply to my posts and point it out, because odds are, I was trying to be nice. Exception: If you do not understand Java, I WILL NOT HELP YOU and your thread will get locked. DO NOT PM ME WITH PROBLEMS. No help will be given.
Join the conversation
You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.