Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/onyxstudios/foml
Fabric OBJ Model Loader
https://github.com/onyxstudios/foml
Last synced: about 1 month ago
JSON representation
Fabric OBJ Model Loader
- Host: GitHub
- URL: https://github.com/onyxstudios/foml
- Owner: OnyxStudios
- License: mit
- Created: 2019-08-04T20:11:11.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2020-12-31T10:35:23.000Z (about 4 years ago)
- Last Synced: 2023-03-10T10:26:28.805Z (almost 2 years ago)
- Language: Java
- Size: 187 KB
- Stars: 22
- Watchers: 8
- Forks: 4
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# FOML
Fabric OBJ Model Loader# Adding the API to your project
```
repositories {
maven {
name = "OnyxStudios"
url = "https://maven.abusedmaster.xyz"
}
}dependencies {
modCompile "dev.onyxstudios:FOML:${foml_version}"
// Includes FOML as a Jar in Jar dependency, Optional
include "dev.onyxstudios:FOML:${foml_version}"
}
```You can find current releases over at the [maven](https://maven.abusedmaster.xyz/com/github/OnyxStudios/FOML/)
# How to use
Getting started with FOML is very simple and easy to do.All you have to do is specify the OBJ model in the blockstate's file as such:
```
{
"variants": {
"": { "model": "testmod:block/test_model.obj" }
}
}
```Your OBJ model and MTL files should be placed in your models package.
To make the textures in your MTL file work you must prefix the name with your modid following the location of the texture:
the blocks/ location can be replaced with any folder in the `textures` folder, note do **not** suffix the texture with .png```
#Example MTL Filenewmtl Base
Ka 0.0000 0.0000 0.0000
Kd 1.0000 1.0000 1.0000
Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000
d 1.0000
Ns 0.0000
map_Kd MODID:blocks/test
```And that's basically it, your block show now render your OBJ model! **(Note: It is recommended to scale the model before exporting it due to the size it will be rendered as)**
### Using tint indices
To use a tint index, simply specify the index in your material definition like so:```
#Example MTL File# This material will not be tinted
newmtl Base
Ka 0.0000 0.0000 0.0000
Kd 1.0000 1.0000 1.0000
Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000
d 1.0000
Ns 0.0000
map_Kd MODID:blocks/test# This material will be tinted
newmtl Leaves
Ka 0.0000 0.0000 0.0000
Kd 1.0000 1.0000 1.0000
Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000
d 1.0000
Ns 0.0000
tintindex 0
map_Kd MODID:blocks/test
```### Using diffuse colors
Because many 3d modeling programs will have diffuse colors by default that aren't pure white, FOML will ignore the colors specified in your materials by default. You can override this to use your materials color with a simple flag:```
#Example MTL Filenewmtl Base
Ka 0.0000 0.0000 0.0000
Kd 1.0000 1.0000 1.0000
Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000
d 1.0000
Ns 0.0000
use_diffuse
map_Kd MODID:blocks/test
```### Adding a sprite
By default, FOML will use the first material defined in your .mtl file as the sprite for the block. If you would rather use something else, you can define a new material named `sprite`:```
newmtl sprite
map_Kd MODID:blocks/test
```### Using OBJ models for items
JSON-formatted vanilla item models placed in the `models/item` folder can also specify your OBJ model as its "parent" model, similar to blockstates:
```
{
"parent": "MODID:item/test.obj",
"display": {
"head": {
"rotation": [0, 0, 0],
"translation": [0, 0, 0],
"scale": [1, 1, 1]
},
"firstperson_righthand": {
"rotation": [0, 0, 0],
"translation": [0, 0, 0],
"scale": [1, 1, 1]
},
"firstperson_lefthand": {
"rotation": [0, 0, 0],
"translation": [0, 0, 0],
"scale": [1, 1, 1]
},
"gui": {
"rotation": [0, 0, 0],
"translation": [0, 0, 0],
"scale": [1, 1, 1]
},
"fixed": {
"rotation": [0, 0, 0],
"translation": [0, 0, 0],
"scale": [1, 1, 1]
}
}
}
```
And your item should now render the OBJ model with the proper transformations specified in its model file.So far, only vanilla model transformations are supported by FOML.