Jump to content
Search In
  • More options...
Find results that contain...
Find results in...

Load Obj Models


drok0920
 Share

Recommended Posts

For entities you need your own obj model loader/renderer.

For items/blocks you need to put your model and material(.obj and .mtl files) in an appropriate models subfolder in your assets, point to that model through a blockstates file for example(if you are using forge's blockstates for items) and you are done. There are a few thing you need to know:

1. When specifying an obj model to be used you must include the obj extension in the path too.

2. You must call OBJLoader.INSTANCE.addDomain(modid) with your modid as a parameter before the models are loaded.

Here(and the resources folder) is an example provided by forge itself.

  • Like 2
Link to comment
Share on other sites

Pretty much, although I've never done it through the item.json model and I do not know if it is possible. You can still have obj models for items as forge can use blockstates files to define item models.

And you should probably call it not in your preinit but in your ModelRegistryEvent or at least in your client proxy. but yeah, that's pretty much it.

Link to comment
Share on other sites

Blockstates for items: blockstates files, model loading (yep, it is the same stuff I've already linked as that code uses blockstates for items(to be fair it uses them for itemblocks but there is no difference whatsoever for other items too)). The idea is - when you are loading a model for an item forge will first look in the models/item folder to find the model file, and if it can't find any it will look in your blockstates folder for the blockstates file. The syntax is absolutely the same and everything functions as you would expect it to, just for items instead of blocks.

ModelRegistryEvent

Link to comment
Share on other sites

Ok i have tried to implement this to no avail.  Any idea what im doing wrong?

 

Spoiler

ak47.json:

{
    "forge_marker": 1,
    "defaults": {
        "textures": {
            "#Material": "progressiveg:ak47_oak" //the identifier must be a name of a material defined by the "model" obj's .mtl file
        },
        "model": "progressiveg:ak47_0.obj"
     },
    "variants": {
        "normal": [{
            "textures": {
                "#Material": "progressiveg:ak47_oak" //the identifier must be a name of a material defined by the "model" obj's .mtl file
            }
        }],
        "oak_1": [{
            "textures": {
                "#Material": "progressiveg:ak47_oak" //the identifier must be a name of a material defined by the "model" obj's .mtl file
        }
        }]
    }
}


{
    "forge_marker": 1,
    "defaults": {
        "textures": {
			"#Material": "progressiveg:ak47_oak" //the identifier must be a name of a material defined by the "model" obj's .mtl file
        },
        "model": "progressiveg:ak47_0.obj"
     },
    "variants": {
        "normal": [{
			"textures": {
				"#Material": "progressiveg:ak47_oak" //the identifier must be a name of a material defined by the "model" obj's .mtl file
			}
		}],
        "oak_1": [{
            "textures": {
				"#Material": "progressiveg:ak47_oak" //the identifier must be a name of a material defined by the "model" obj's .mtl file
        }
        }]
    }
}

 

ModRegistryEvent:


@SubscribeEvent
    public static void registerModels(ModelRegistryEvent event)
    {
        OBJLoader.INSTANCE.addDomain("progressiveg");
        Item[] woodItems = {
            ModItems.ak47
        };
        for (Item item : woodItems) {
        	ModelLoader.setCustomModelResourceLocation(item, 0, new ModelResourceLocation(item.getRegistryName(), "normal"));
        	ModelLoader.setCustomModelResourceLocation(item, 1, new ModelResourceLocation(item.getRegistryName(), "oak_1"));
        }
    }

 

 

And i attached a picture of my asset folders and what it looks like in game.

 

folderLayout.PNG

ingame.png

Link to comment
Share on other sites

Caused by: java.lang.RuntimeException: OBJLoader.Parser: Exception parsing line #232: `f 66/1/1 67/2/1 65/3/1`

Your model's face definition is invalid. 

Caused by: java.lang.NullPointerException

    at net.minecraftforge.client.model.obj.OBJModel$Material.access$100(OBJModel.java:595) ~[OBJModel$Material.class:?]

Looks like something went wrong with the material, it might be null. Post your obj file somewhere so I can check if it is correct.

Link to comment
Share on other sites

1 minute ago, drok0920 said:

also does it matter if faces are triangulated or not?

I am not sure, I'll try it out later.

 

L #230 : usemtl None

You need to provide an actual material for the object in your model editor.

Also should there not be an object definition(o name) at the beggining of the file right after the material file definition?  

 

It seems that you've made your model incorrectly in your model editor.

Link to comment
Share on other sites

  • 1 year later...
  • 4 months later...

@drok0920 I know this post was made a long time ago but I am also having similar errors to yours in this post...can you please tell me what did you change in your files to get from the black and purple cube in the middle of the screen to the 3d model you wanted??

That might help me out. I've gone through this post 4 times and the links provided in it and still cant fix that issue.

 

If you can help me...Thank you! :)

Edited by Thegametutor101
Link to comment
Share on other sites

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
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.

 Share



  • Recently Browsing

    No registered users viewing this page.

  • Posts

    • 1.14 is no longer supported on this forum. Please update to a modern version of Minecraft to receive support.
    • So I create my server and everything goes well, until I run the run.bat file which contains java -Xmx3072M -Xms3072M -jar forgeserver.jar nogui PAUSE I run that and then I get this out of the commands prompt Desktop\forge 1.14.4 server>java -Xmx3072M -Xms3072M -jar forgeserver.jar nogui 2021-10-15 17:55:54,519 main WARN Advanced terminal features are not available in this environment ←[32m[17:55:54] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher running: args [--gameDir, ., --launchTarget, fmlserver, --fml.forgeVersion, 28.2.0, --fml.mcpVersion, 20190829.143755, --fml.mcVersion, 1.14.4, --fml.forgeGroup, net.minecraftforge, nogui] ←[m←[32m[17:55:54] [main/INFO] [cp.mo.mo.Launcher/MODLAUNCHER]: ModLauncher 4.1.0+62+5bfa59b starting: java version 15.0.2 by Oracle Corporation ←[m←[32m[17:55:54] [main/INFO] [ne.mi.fm.lo.FixSSL/CORE]: Added Lets Encrypt root certificates as additional trust ←[mException in thread "main" ←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]: java.lang.NoClassDefFoundError: jdk/nashorn/api/scripting/NashornScriptEngineFactory ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.coremod.CoreModEngine.loadCoreMod(CoreModEngine.java:48) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.coremod.CoreModProvider.addCoreMod(CoreModProvider.java:12) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:183) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1625) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReferencePipeline$Head.forEach(ReferencePipeline.java:658) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReferencePipeline$7$1.accept(ReferencePipeline.java:274) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:195) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReferencePipeline$3$1.accept(ReferencePipeline.java:195) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.ArrayList$ArrayListSpliterator.forEachRemaining(ArrayList.java:1625) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:150) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:173) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:497) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.fml.loading.LoadingModList.addCoreMods(LoadingModList.java:88) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.fml.loading.moddiscovery.ModDiscoverer.discoverMods(ModDiscoverer.java:125) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.fml.loading.FMLLoader.beginModScan(FMLLoader.java:208) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.fml.loading.FMLServiceProvider.runScan(FMLServiceProvider.java:105) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at cpw.mods.modlauncher.TransformationServiceDecorator.runScan(TransformationServiceDecorator.java:111) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at cpw.mods.modlauncher.TransformationServicesHandler.lambda$runScanningTransformationServices$8(TransformationServicesHandler.java:115) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReferencePipeline$7$1.accept(ReferencePipeline.java:271) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.HashMap$ValueSpliterator.forEachRemaining(HashMap.java:1766) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:484) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:474) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReduceOps$ReduceOp.evaluateSequential(ReduceOps.java:913) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at java.base/java.util.stream.ReferencePipeline.collect(ReferencePipeline.java:578) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at cpw.mods.modlauncher.TransformationServicesHandler.runScanningTransformationServices(TransformationServicesHandler.java:116) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at cpw.mods.modlauncher.TransformationServicesHandler.initializeTransformationServices(TransformationServicesHandler.java:63) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at cpw.mods.modlauncher.Launcher.run(Launcher.java:75) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at cpw.mods.modlauncher.Launcher.main(Launcher.java:65) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.server.ServerMain$Runner.runLauncher(ServerMain.java:63) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.server.ServerMain$Runner.access$100(ServerMain.java:60) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1048]:       at net.minecraftforge.server.ServerMain.main(ServerMain.java:57) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]: Caused by: java.lang.ClassNotFoundException: jdk.nashorn.api.scripting.NashornScriptEngineFactory ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]:       at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:606) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]:       at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:168) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]:       at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522) ←[m←[32m[17:55:55] [main/INFO] [STDERR/]: [java.lang.ThreadGroup:uncaughtException:1057]:       ... 35 more ←[m
    • 1.12 is no longer supported on this forum. Please update to a modern version of Minecraft to receive support.
    • What version of Minecraft are you using? Have you bothered to look at the food method for hints?
  • Topics

  • Who's Online (See full list)

×
×
  • Create New...

Important Information

By using this site, you agree to our Privacy Policy.