Obj loader: fix vertices shared between faces having the same attributed (uvs/normals).
This commit is contained in:
parent
12e6fe9db7
commit
51653fb9b7
1 changed files with 9 additions and 7 deletions
|
@ -51,7 +51,6 @@ import net.minecraftforge.common.property.IUnlistedProperty;
|
||||||
import net.minecraftforge.fml.common.FMLLog;
|
import net.minecraftforge.fml.common.FMLLog;
|
||||||
|
|
||||||
import org.apache.commons.lang3.tuple.Pair;
|
import org.apache.commons.lang3.tuple.Pair;
|
||||||
import org.apache.logging.log4j.Level;
|
|
||||||
|
|
||||||
import com.google.common.base.Charsets;
|
import com.google.common.base.Charsets;
|
||||||
import com.google.common.base.Function;
|
import com.google.common.base.Function;
|
||||||
|
@ -302,9 +301,10 @@ public class OBJModel implements IRetexturableModel, IModelCustomData
|
||||||
norm = Integer.parseInt(splitSlash[i][1]);
|
norm = Integer.parseInt(splitSlash[i][1]);
|
||||||
norm = norm < 0 ? this.normals.size() - 1 : norm - 1;
|
norm = norm < 0 ? this.normals.size() - 1 : norm - 1;
|
||||||
|
|
||||||
this.vertices.get(vert).setNormal(this.normals.get(norm));
|
Vertex newV = new Vertex(new Vector4f(this.vertices.get(vert).getPos()), material);
|
||||||
|
newV.setNormal(this.normals.get(norm));
|
||||||
|
|
||||||
v.add(this.vertices.get(vert));
|
v.add(newV);
|
||||||
// n.add(this.normals.get(norm));
|
// n.add(this.normals.get(norm));
|
||||||
}
|
}
|
||||||
else if (splitData[i].contains("/"))
|
else if (splitData[i].contains("/"))
|
||||||
|
@ -321,10 +321,11 @@ public class OBJModel implements IRetexturableModel, IModelCustomData
|
||||||
norm = norm < 0 ? this.normals.size() - 1 : norm - 1;
|
norm = norm < 0 ? this.normals.size() - 1 : norm - 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
this.vertices.get(vert).setTextureCoordinate(this.texCoords.get(texCoord));
|
Vertex newV = new Vertex(new Vector4f(this.vertices.get(vert).getPos()), material);
|
||||||
this.vertices.get(vert).setNormal(splitSlash[i].length > 2 ? this.normals.get(norm) : null);
|
newV.setTextureCoordinate(this.texCoords.get(texCoord));
|
||||||
|
newV.setNormal(splitSlash[i].length > 2 ? this.normals.get(norm) : null);
|
||||||
|
|
||||||
v.add(this.vertices.get(vert));
|
v.add(newV);
|
||||||
// t.add(this.texCoords.get(texCoord));
|
// t.add(this.texCoords.get(texCoord));
|
||||||
// if (splitSlash[i].length > 2) n.add(this.normals.get(norm));
|
// if (splitSlash[i].length > 2) n.add(this.normals.get(norm));
|
||||||
}
|
}
|
||||||
|
@ -335,7 +336,8 @@ public class OBJModel implements IRetexturableModel, IModelCustomData
|
||||||
vert = Integer.parseInt(splitSlash[i][0]);
|
vert = Integer.parseInt(splitSlash[i][0]);
|
||||||
vert = vert < 0 ? this.vertices.size() - 1 : vert - 1;
|
vert = vert < 0 ? this.vertices.size() - 1 : vert - 1;
|
||||||
|
|
||||||
v.add(this.vertices.get(vert));
|
Vertex newV = new Vertex(new Vector4f(this.vertices.get(vert).getPos()), material);
|
||||||
|
v.add(newV);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue