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

[1.15.1] How to import OBJ files as block models


MaxHyper
 Share

Recommended Posts

I know 1.15 is still quite new, but has anybody figured out how to use .obj files as models? Since 1.15 changed the whole rendering system solutions for 1.14 do not work.
The main issue is that OBJLoader.INSTANCE.addDomain() no longer exists.
Thanks in advance.

  • Like 1
Link to comment
Share on other sites

You don't need to do that call anymore, it just works™️ if you reference the model from your blockstate json

  • Like 1

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

On 1/9/2020 at 11:00 PM, Cadiboo said:

You don't need to do that call anymore, it just works™️ if you reference the model from your blockstate json

Okay ive been trying for a while and havent been able to figure it out. When i reference the obj file from the blockstate i get an error where its adding ".json" to the end on its own. 

[00:19:43] [Server-Worker-6/WARN] [minecraft/ModelBakery]: Unable to load model: 'brassnsteam:block/obj/pipe_core_valve.obj' referenced from: brassnsteam:iron_pipe#center=true,down=true,east=true,north=true,south=true,up=true,waterlogged=true,west=true: java.io.FileNotFoundException: brassnsteam:models/block/obj/pipe_core_valve.obj.json

Is there nothing i need to do in the code? Messing with the blockstate only seems to not be enough. 

Edited by MaxHyper
  • Like 1
Link to comment
Share on other sites

4 hours ago, MaxHyper said:

Okay ive been trying for a while and havent been able to figure it out. When i reference the obj file from the blockstate i get an error where its adding ".json" to the end on its own. 


[00:19:43] [Server-Worker-6/WARN] [minecraft/ModelBakery]: Unable to load model: 'brassnsteam:block/obj/pipe_core_valve.obj' referenced from: brassnsteam:iron_pipe#center=true,down=true,east=true,north=true,south=true,up=true,waterlogged=true,west=true: java.io.FileNotFoundException: brassnsteam:models/block/obj/pipe_core_valve.obj.json

Is there nothing i need to do in the code? Messing with the blockstate only seems to not be enough. 

Edited 4 hours ago by MaxHyper

I would like to help you, but unfortunately I do not know the answer to your problem.

New in Modding? == Still learning!

Link to comment
Share on other sites

Post your logs + BlockState json & model

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

6 hours ago, Cadiboo said:

Post your logs + BlockState json & model

The only log I have that is meaningful is the line on my previous comment. 

 

Here's the blockstate, the obj part is only the second bit.

{
  "multipart": [
    {   "when": { "center": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core" }
    },
    {
      "apply": { "model": "brassnsteam:block/pipes/attachments/pipe_core_valve.obj" }
    },

    {   "when": { "north": true, "south": true, "east": false, "west": false,"up": false, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_straight" }
    },
    {   "when": { "north": false, "south": false, "east": true, "west": true,"up": false, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_straight" , "y": 90 }
    },
    {   "when": { "north": false, "south": false, "east": false, "west": false,"up": true, "down": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_straight" , "x": 270 }
    },
    {   "when": { "north": true, "south": false, "east": true, "west": false, "up": false, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" },
      "_comment" : "NE"
    },
    {   "when": { "north": true, "south": false, "east": false, "west": true, "up": false, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "y": 270 },
      "_comment" : "NW"
    },
    {   "when": { "north": true, "south": false, "east": false, "west": false, "up": true, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 270, "y": 270 },
      "_comment" : "NU"
    },
    {   "when": { "north": true, "south": false, "east": false, "west": false, "up": false, "down": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 90, "y": 270 },
      "_comment" : "ND"
    },
    {   "when": { "north": false, "south": true, "east": true, "west": false,"up": false, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "y": 90 },
      "_comment" : "SE"
    },
    {   "when": { "north": false, "south": true, "east": false, "west": true, "up": false, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "y": 180 },
      "_comment" : "SW"
    },
    {   "when": { "north": false, "south": true, "east": false, "west": false,"up": true, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 270, "y": 90 },
      "_comment" : "SU"
    },
    {   "when": { "north": false, "south": true, "east": false, "west": false,"up": false, "down": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 90, "y": 90 },
      "_comment" : "SD"
    },
    {   "when": { "north": false, "south": false, "east": true, "west": false,"up": true, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 270 },
      "_comment" : "EU"
    },
    {   "when": { "north": false, "south": false, "east": true, "west": false,"up": false, "down": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 90 },
      "_comment" : "ED"
    },
    {   "when": { "north": false, "south": false, "east": false, "west": true,"up": true, "down": false },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 270, "y": 180 },
      "_comment" : "WU"
    },
    {   "when": { "north": false, "south": false, "east": false, "west": true,"up": false, "down": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_core_corner" , "x": 90, "y": 180 },
      "_comment" : "WD"
    },


    {   "when": { "north": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_side" }
    },
    {   "when": { "east": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_side", "y": 90 }
    },
    {   "when": { "south": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_side", "y": 180 }
    },
    {   "when": { "west": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_side", "y": 270 }
    },
    {   "when": { "up": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_side", "x": 270 }
    },
    {   "when": { "down": true },
      "apply": { "model": "brassnsteam:block/pipes/iron/pipe_side", "x": 90 }
    }
  ]
}

Not sure what you mean by posting the model since its an obj, but heres its location: (rightmost file)

image.png.593678c6aeb0369b7fec2183f23533b7.png

 

Edited by MaxHyper
Link to comment
Share on other sites

I think that all you need to do is remove the ".obj" from

"apply": { "model": "brassnsteam:block/pipes/attachments/pipe_core_valve.obj" }

and it should work.

About Me

Spoiler

My Discord - Cadiboo#8887

My WebsiteCadiboo.github.io

My ModsCadiboo.github.io/projects

My TutorialsCadiboo.github.io/tutorials

Versions below 1.14.4 are no longer supported on this forum. Use the latest version to receive support.

When asking support remember to include all relevant log files (logs are found in .minecraft/logs/), code if applicable and screenshots if possible.

Only download mods from trusted sites like CurseForge (minecraft.curseforge.com). A list of bad sites can be found here, with more information available at stopmodreposts.org

Edit your own signature at www.minecraftforge.net/forum/settings/signature/ (Make sure to check its compatibility with the Dark Theme)

Link to comment
Share on other sites

17 hours ago, Cadiboo said:

I think that all you need to do is remove the ".obj" from


"apply": { "model": "brassnsteam:block/pipes/attachments/pipe_core_valve.obj" }

and it should work.

Nope, its still looking for a .json
Id like to point out that the other file named pipe_core_valve.json in the picture i sent was just a test and is unrelated.

Link to comment
Share on other sites

  • 4 weeks later...

Using .obj files seems to have changed a lot, I am assuming that 1.15 has removed the ForgeLoader for blockstates, as the multipart system really covers everything it did (except for loading .obj).

 

The new way to load models:

Your blockstate should use the vanilla method (without".obj" on the model name) e.g.:

{
  "variants": {
    "": {
      "model": "MODID:block/MODEL"
    }
  }
}

 

Every model, in the "models/block" path, now needs, MODEL.json, MODEL.obj, MODEL.mtl.

In your new MODEL.json file you need to tell it to use the OBJLoader from forge, and give the full resource path to your ".obj" file, eg:

{
  "loader": "forge:obj",
  "model": "MODID:models/block/MODEL.obj",
  "flip-v": true
}

 

 

The options you can include in the new MODEL.json file are:

{
	"loader": "forge:obj",  //to inform the resource loader to use OBJLoader
	"model": <<resource path to .obj file>>,
	"detectCullableFaces": true|false,
	"diffuseLighting": true|false,
	"flip-v": true|false,
	"ambientToFullbright": true|false,
	"materialLibraryOverride": <<resource path to material library if you need different materials on the same .obj>>,
}

 

Remember to update the paths for your textures in the .mlt file to use resource paths (without ".png").

 

  • Like 1
Link to comment
Share on other sites

  • 2 weeks later...
  • 1 month later...

That's work for me, just imported on the json files, just the uv's are messed up, i'm registered the block normally without any function to import models or textures
on Forge 1.15.2 and mapping 20200408-1.15.1


model.json

{
  "parent": "forge:item/default",
  "loader": "forge:composite",
  "parts": {
    "part1": {
      "loader": "forge:obj",
      "model": "MOD_ID:models/block/mesh/model.obj"
      "textures": {
        "#YourMaterialName": "MOD_ID:blocks/modeltexture"
      }
    }
  }
}

 

blockstate.json

{
  "variants": {
    "": {"model":  "MOD_ID:block/model"}
  }
}

 

item.json
 

{
  "parent": "MOD_ID:block/model"
}

 

model.mtl

# Blender MTL File: 'mdoel.blend'
# Material Count: 1

newmtl YourMaterialName
Ns 225.000000
Ka 1.000000 1.000000 1.000000
Kd 0.800000 0.800000 0.800000
Ks 0.500000 0.500000 0.500000
Ke 0.000000 0.000000 0.000000
Ni 1.450000
d 1.000000
illum 2
map_Kd MOD_ID:blocks/texture
map_d MOD_ID:blocks/texture


 

Edited by Uollf
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.
Note: Your post will require moderator approval before it will be visible.

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

    • Hi, so I was making an item that sends info to the server to do some work, and I want the server to send the client back the results? How do I do that? Here is my code:   The snippet that sends the packet to the server SimpleChannelNetwork.CHANNEL.sendToServer(new CreateStructureCompass("fortress"));   The file that manage the traffic package io.github.bossmania.NetherandEndMaps.core.network; import io.github.bossmania.NetherandEndMaps.NetherandEndMaps; import io.github.bossmania.NetherandEndMaps.core.network.message.CreateStructureCompass; import net.minecraft.util.ResourceLocation; import net.minecraftforge.fml.network.NetworkRegistry; import net.minecraftforge.fml.network.simple.SimpleChannel; public class SimpleChannelNetwork { public static final String NETWORK_VERSION = "0.1.0"; public static final SimpleChannel CHANNEL = NetworkRegistry.newSimpleChannel( new ResourceLocation(NetherandEndMaps.MOD_ID, "network"), () -> NETWORK_VERSION, version -> version.equals(NETWORK_VERSION), version -> version.equals(NETWORK_VERSION)); public static void init() { CHANNEL.registerMessage(0, CreateStructureCompass.class ,CreateStructureCompass::encode, CreateStructureCompass::decode, CreateStructureCompass::handle); } }   the code that handle the packet receive and where I want the server to send back a packet to the client package io.github.bossmania.NetherandEndMaps.core.network.message; import java.util.function.Supplier; import io.github.bossmania.NetherandEndMaps.common.items.TemporaryItem; import net.minecraft.entity.player.ServerPlayerEntity; import net.minecraft.item.ItemStack; import net.minecraft.network.PacketBuffer; import net.minecraft.util.math.BlockPos; import net.minecraft.world.gen.feature.structure.Structure; import net.minecraft.world.server.ServerWorld; import net.minecraftforge.fml.network.NetworkEvent; import net.minecraft.item.Item; import net.minecraft.item.ItemGroup; public class CreateStructureCompass { public String structureType; public CreateStructureCompass() { } //create the constructor and store the structureType public CreateStructureCompass(String structureType) { this.structureType = structureType; } //encode the message public static void encode(CreateStructureCompass message, PacketBuffer buffer) { buffer.writeString(message.structureType); } //decode the message public static CreateStructureCompass decode(PacketBuffer buffer) { return new CreateStructureCompass(buffer.readString()); } //execute function when message is sent to server public static void handle(CreateStructureCompass message, Supplier<NetworkEvent.Context> contextSupplier) { NetworkEvent.Context context = contextSupplier.get(); context.enqueueWork(() -> { //get the player and the server ServerPlayerEntity player = context.getSender(); ServerWorld SEWorld = player.getServerWorld(); //get the location of the structure BlockPos structureLocation = SEWorld.func_241117_a_(Structure.FORTRESS, player.getPosition(),100, false); //this is where I want the server to send structureLocation back to the player }); context.setPacketHandled(true); } }  
    • I cannot get an instance of MC Forge to run with either the vanilla launcher or GDLauncher, yet vanilla MC and Fabric MC work fine in both.  I am running the latest versions of everything, and no 1.18-compatible version of Forge will launch even though they all install without fail. Using the vanilla launcher I get exit code 0 and the following logs: Debug log Latest log With GDLauncher I get the following console output:  
    • In 1.15 and before, you could get the item being held/dragged by the cursor using PlayerInventory#getItemStack. This no longer seems to be the case. How do we do this now?
    • I created a particle using  public class NukeParticle extends BasicParticleType implements IParticleData { public NukeParticle(boolean alwaysShow) { super(alwaysShow); } @Override public BasicParticleType getType() { return ParticleTypes.LARGE_SMOKE; } @Override public String getParameters() { return ParticleTypes.LARGE_SMOKE.getParameters(); } } and when I register it using  public class ParticlesReg { public static final RegistryObject<NukeParticle> YELLOW_PART = Regist.PARTICLES.register("yellow_particle", ()-> new NukeParticle(true)); public static void Register() { } } it just seems to crash anyone got an idea to what is going on the crash log is  ---- Minecraft Crash Report ---- // Shall we play a game? Time: 12/3/21 4:19 PM Description: Rendering overlay java.lang.IllegalStateException: Redundant texture list for particle lndfmod:yellow_particle at net.minecraft.client.particle.ParticleManager.loadTextureLists(ParticleManager.java:217) ~[forge:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A} at net.minecraft.client.particle.ParticleManager.lambda$null$0(ParticleManager.java:169) ~[forge:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A} at java.util.concurrent.CompletableFuture$AsyncRun.run(CompletableFuture.java:1640) ~[?:1.8.0_311] {} at java.util.concurrent.CompletableFuture$AsyncRun.exec(CompletableFuture.java:1632) ~[?:1.8.0_311] {} at java.util.concurrent.ForkJoinTask.doExec(ForkJoinTask.java:289) ~[?:1.8.0_311] {} at java.util.concurrent.ForkJoinPool$WorkQueue.runTask(ForkJoinPool.java:1067) ~[?:1.8.0_311] {} at java.util.concurrent.ForkJoinPool.runWorker(ForkJoinPool.java:1703) ~[?:1.8.0_311] {} at java.util.concurrent.ForkJoinWorkerThread.run(ForkJoinWorkerThread.java:172) ~[?:1.8.0_311] {} A detailed walkthrough of the error, its code path and all known details is as follows: --------------------------------------------------------------------------------------- -- Head -- Thread: Render thread Stacktrace: at net.minecraft.client.renderer.GameRenderer.updateCameraAndRender(GameRenderer.java:495) ~[forge:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A} -- Overlay render details -- Details: Overlay name: net.minecraft.client.gui.ResourceLoadProgressGui Stacktrace: at net.minecraft.client.renderer.GameRenderer.updateCameraAndRender(GameRenderer.java:495) ~[forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-recomp.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A} at net.minecraft.client.Minecraft.runGameLoop(Minecraft.java:1002) ~[forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-recomp.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A} at net.minecraft.client.Minecraft.run(Minecraft.java:612) ~[forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-recomp.jar:?] {re:classloading,pl:accesstransformer:B,pl:runtimedistcleaner:A} at net.minecraft.client.main.Main.main(Main.java:184) ~[forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-recomp.jar:?] {re:classloading,pl:runtimedistcleaner:A} at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[?:1.8.0_311] {} at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[?:1.8.0_311] {} at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[?:1.8.0_311] {} at java.lang.reflect.Method.invoke(Method.java:498) ~[?:1.8.0_311] {} at net.minecraftforge.userdev.FMLUserdevClientLaunchProvider.lambda$launchService$0(FMLUserdevClientLaunchProvider.java:52) ~[forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-recomp.jar:?] {} at cpw.mods.modlauncher.LaunchServiceHandlerDecorator.launch(LaunchServiceHandlerDecorator.java:37) [modlauncher-8.0.9.jar:?] {} at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:54) [modlauncher-8.0.9.jar:?] {} at cpw.mods.modlauncher.LaunchServiceHandler.launch(LaunchServiceHandler.java:72) [modlauncher-8.0.9.jar:?] {} at cpw.mods.modlauncher.Launcher.run(Launcher.java:82) [modlauncher-8.0.9.jar:?] {} at cpw.mods.modlauncher.Launcher.main(Launcher.java:66) [modlauncher-8.0.9.jar:?] {} at net.minecraftforge.userdev.LaunchTesting.main(LaunchTesting.java:105) [forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-recomp.jar:?] {} -- System Details -- Details: Minecraft Version: 1.16.4 Minecraft Version ID: 1.16.4 Operating System: Windows 10 (amd64) version 10.0 Java Version: 1.8.0_311, Oracle Corporation Java VM Version: Java HotSpot(TM) 64-Bit Server VM (mixed mode), Oracle Corporation Memory: 1848128352 bytes (1762 MB) / 3042443264 bytes (2901 MB) up to 7622623232 bytes (7269 MB) CPUs: 12 JVM Flags: 1 total; -XX:HeapDumpPath=MojangTricksIntelDriversForPerformance_javaw.exe_minecraft.exe.heapdump ModLauncher: 8.0.9+86+master.3cf110c ModLauncher launch target: fmluserdevclient ModLauncher naming: mcp ModLauncher services: /mixin-0.8.2.jar mixin PLUGINSERVICE /eventbus-4.0.0.jar eventbus PLUGINSERVICE /forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-launcher.jar object_holder_definalize PLUGINSERVICE /forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-launcher.jar runtime_enum_extender PLUGINSERVICE /accesstransformers-3.0.1.jar accesstransformer PLUGINSERVICE /forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-launcher.jar capability_inject_definalize PLUGINSERVICE /forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-launcher.jar runtimedistcleaner PLUGINSERVICE /mixin-0.8.2.jar mixin TRANSFORMATIONSERVICE /forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16.3-launcher.jar fml TRANSFORMATIONSERVICE FML: 35.1 Forge: net.minecraftforge:35.1.37 FML Language Providers: javafml@35.1 minecraft@1 Mod List: client-extra.jar |Minecraft |minecraft |1.16.4 |ENQUEUE_IM|a1:d4:5e:04:4f:d3:d6:e0:7b:37:97:cf:77:b0:de:ad:4a:47:ce:8c:96:49:5f:0a:cf:8c:ae:b2:6d:4b:8a:3f forge-1.16.4-35.1.37_mapped_snapshot_20201028-1.16|Forge |forge |35.1.37 |ENQUEUE_IM|NOSIGNATURE main |The Ladon Fr*** Mod 1.16.4 |lndfmod |NONE |SIDED_SETU|NOSIGNATURE Crash Report UUID: 734f5cd3-7a52-470e-ab9e-c51bffee2944 Launched Version: MOD_DEV Backend library: LWJGL version 3.2.2 build 10 Backend API: NVIDIA GeForce GTX 1080/PCIe/SSE2 GL version 4.6.0 NVIDIA 510.10, NVIDIA Corporation GL Caps: Using framebuffer using OpenGL 3.0 Using VBOs: Yes Is Modded: Definitely; Client brand changed to 'forge' Type: Client (map_client.txt) Graphics mode: fancy Resource Packs: Current Language: English (US) CPU: 12x Intel(R) Core(TM) i7-8700K CPU @ 3.70GHz  
  • Topics

  • Who's Online (See full list)

×
×
  • Create New...

Important Information

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