Jump to content

Recommended Posts

Posted

Ok so I have spent the past 4-5 hours working on trying to make a custom sounds type. I have found out how to do it with SoundEvents that are already in the game but I want to take it 1 step farther and put in my own SoundEvents. I have a class that makes the sounds events and all but for some reason when I try and use my SoundType for example as the setSoundType of a block, the game crashes and I recieve a null pointer exception. I know they are not null because I add a println that printed both the SoundEvent and the SoundType. If anyone has any kind of insight on this problem I would love to hear it because this is making me go insane.

Posted

Would need to see your code, but custom SoundEvent objects should be registered via a registry event, similar to custom Block or Item objects.  As an example: https://github.com/TeamPneumatic/pnc-repressurized/blob/master/src/main/java/me/desht/pneumaticcraft/lib/Sounds.java (the RL() method in there is just a convenience method to get a ResourceLocation with the mod's domain).  See also https://mcforge.readthedocs.io/en/latest/effects/sounds/.

 

Note that SoundType and SoundEvent are not the same thing, but you seem to be conflating them a bit here.

  • Thanks 1
Posted

Sorry i forgot to post the code last night i will do that in a bit, i am registering the SoundEvents and the SoundTypes require SountType(double, double, SoundEvent, SoundEvent, SoundEvent, SoundEvent, SoundEvent, float, float, boolean)

Posted

To register custom sounds you also need a sounds.json in your assets/modid folder like I do here. You can read up on it's format more here, on the official minecraft wiki.

You will of course need to register the SoundEvent within the appropriate RegistryEvent similar to how I do here. Make sure your registry name matches the one you have given to the sound in the sounds.json file.

To actually obtain a reference to your SoundEvent to use it later(to play it for example) you would use ObjectHolders like I do here.

After that you should be able to play your sound just fine similar to how I do here.

 

As for your repo:

Quote

ForgeRegistries.SOUND_EVENTS.register(sound);

Don't do this. Use the registry provided to you by the event.

 

https://github.com/wsman217/Learning-Mod/blob/master/src/main/java/com/wsman217/learningmod/init/ModBlocks.java#L15

https://github.com/wsman217/Learning-Mod/blob/master/src/main/java/com/wsman217/learningmod/init/ModItems.java#L40

Don't use static initializers. Instantinate your stuff directly in the appropriate RegistryEvent.

 

https://github.com/wsman217/Learning-Mod/blob/master/src/main/java/com/wsman217/learningmod/blocks/BlockBase.java

BlockBase/ItemBase/XBase is an antipattern. There is already a BlockBase, it's called Block.

 

https://github.com/wsman217/Learning-Mod/blob/master/src/main/java/com/wsman217/learningmod/proxy/CommonProxy.java

CommonProxy makes no sense. Proxies exist to separate sided-only code. If your code is common it goes anywhere but your proxy.

 

Quote

serverSide = Reference.COMMON_PROXY_CLASS

This makes even less sense. A server proxy provides noop implementations for client-only methods or invokes methods that would crash the physical client. A common proxy by definition can't be your server proxy.

 

https://github.com/wsman217/Learning-Mod/blob/master/src/main/java/com/wsman217/learningmod/util/IHasModel.java

IHasModel is stupid. All items need models, no exception, and nothing about model registration requires access to private/protected data. Register your models in the ModelRegistryEvent directly.

 

https://github.com/wsman217/Learning-Mod/blob/master/src/main/java/com/wsman217/learningmod/sounds/SoundTypes.java#L13

And here is the cause of your issue - the dreaded static initializers. By the time this is constructed your SoundEvent is still null, hence your crash.

Posted

Ok so what I am understanding is not to use statics, the BlockBase class that is in there is completely useless, and the proxy stuff is also useless, and that the cause of the crash is because I declared some stuff as static? Sorry if I misunderstood some of that there is a lot to take in there. Thank you for taking the time to reply.

Posted
5 minutes ago, wsman217 said:

the cause of the crash is because I declared some stuff as static?

No, the cause of the crash is because the object is instantinated before your sound event is. It can be static all you want, it's the instantination that matters. Hence the name - static initializer.

7 minutes ago, wsman217 said:

he BlockBase class that is in there is completely useless

That is correct.

 

7 minutes ago, wsman217 said:

the proxy stuff is also useless

The proxy in your case is useless but in general case it isn't, you are just doing it wrong. Don't use a CommonProxy, use an interface, like an IProxy as the official docs tell you to do.

Posted

Thank you for clarifying that for me so how do I instantiate the sound event before the object. Sorry this is probably a really stupid question I am still just fairly new to modding and Java is a very large language with many things that I still don't understand.

Posted
5 minutes ago, wsman217 said:

Thank you for clarifying that for me so how do I instantiate the sound event before the object.

This question answers itself. You do so by instantinating the SoundEvent first, then the SoundType. I don't think I could explain this in a more obvious way, sorry.

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.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

Announcements



  • Recently Browsing

    • No registered users viewing this page.
  • Posts

    • The game crashed whilst unexpected error Error: net.minecraftforge.fml.ModLoadingException: Advanced Mining Dimension (mining_dimension) encountered an error during the done event phase
    • Here is the end of the log. it was way too big to put in pastebin, but I started from when I was online and everything was fine. Error should be in here: https://pastebin.com/Sdhdq593
    • Update: I stand corrected as I was able to dig up a relevant log from my earlier testing which highlights the overall issue but does not explain how to solve it. See, Diagnostic Logs for pack.mcmeta not found: https://pastebin.com/LXS8Rtna
    • Which mod was this? What are all the mods that were in use? It will help if enough information to replicate the problem is available.
    • I have been attempting to create a supplementary resource pack with Patchouli in order to add back the guidebook for Better End but unfortunately in every prototype I have made pack.mcmeta and my resource pack are not recognized. I have tested both zipped and unzipped and either way curseforge does not recognize my resource pack as existing. For testing I stripped my pack down to just the pack.mcmeta file and two empty folders labelled data and assets and I know the data folder is not the problem as firstly my first attempts just had an assets folder following Patchouli instructions and data came later in my flailing attempts to make anything in my pack work. The mcmeta file is not recognized whether or not I use this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } "language": { "en_US": { "name": "English", "region": "United States" } } } ,or this:  { "pack": { "pack_format": 15, "description": "A replacement for the BetterEnd Guide Book." } } I have made sure to only use lowercase and the pack folder is named better-end-guide. Is this some magic nonsense from me doing this manually instead of using an IDE or similar tool? Could it be because my files are by default in UTF-8 even though ANSI gives the same results? Is there a specific community secret tool I am supposed to use for zipping or specific settings? I am pulling my hair in distress. Unfortunately as there are no errors involved I lack logs to offer, if that disqualifies this thread please do not be harsh and instead if you can then please direct me to a forum with different rules and sufficiently respectful but knowledgeable as to be of assistance. Most of my experience with the programming community has been poor and so naturally I find myself wary.
  • Topics

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.