bridge-core / model-viewer

Renders Minecraft models to an existing ThreeJS scene or a canvas element
MIT License
19 stars 5 forks source link

Flipped textures on down faces #9

Open SuperLlama88888 opened 1 week ago

SuperLlama88888 commented 1 week ago

Thank you for creating such a useful library!

Sometimes, textures are facing the wrong way. I haven't investigated this issue much, but I suspect it's to do with flat cubes (i.e. 0 size in one axis).

Here is a screenshot of the issue when using model-viewer: image

However, in Minecraft (and Blockbench) it looks like this: image

Here is the model and texture in above:

{"description":{"identifier":"geometry.armor_stand.hologram","visible_bounds_offset":[0,1.5,0],"texture_width":48,"texture_height":64,"visible_bounds_width":320,"visible_bounds_height":16},"bones":[{"name":"hologram_alignment_wrapper"},{"name":"hologram_root","parent":"hologram_alignment_wrapper"},{"name":"l_0","parent":"hologram_root","pivot":[8,0,-8]},{"name":"b_0_0_0","parent":"l_0","cubes":[{"origin":[-8,0,-8],"size":[16,16,16],"uv":{"west":{"uv":[0,0],"uv_size":[16,16]},"east":{"uv":[0,0],"uv_size":[16,16]},"down":{"uv":[0,0],"uv_size":[16,16]},"up":{"uv":[0,0],"uv_size":[16,16]},"north":{"uv":[0,0],"uv_size":[16,16]},"south":{"uv":[0,0],"uv_size":[16,16]}}}]},{"name":"b_1_0_1","parent":"l_0","cubes":[{"origin":[-23,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[16,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-16,1,8]}],"rotation":[0,-90,0],"pivot":[-16,8,16]},{"name":"b_1_0_5","parent":"l_0","cubes":[{"origin":[-23,1,72],"size":[14,0,22.6274],"uv":{"down":{"uv":[30,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-16,1,72]}],"rotation":[0,-90,0],"pivot":[-16,8,80]},{"name":"b_2_0_0","parent":"l_0","cubes":[{"origin":[-39,1,-8],"size":[14,0,22.6274],"uv":{"down":{"uv":[16,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-32,1,-8]}],"rotation":[0,0,0],"pivot":[-32,8,0]},{"name":"b_2_0_1","parent":"l_0","cubes":[{"origin":[-40,0,8],"size":[16,16,16],"uv":{"west":{"uv":[0,16],"uv_size":[16,16]},"east":{"uv":[0,16],"uv_size":[16,16]},"down":{"uv":[16,16],"uv_size":[16,16]},"up":{"uv":[16,16],"uv_size":[16,16]},"north":{"uv":[0,16],"uv_size":[16,16]},"south":{"uv":[0,16],"uv_size":[16,16]}}}],"rotation":[0,0,0],"pivot":[-32,8,16]},{"name":"b_2_0_2","parent":"l_0","cubes":[{"origin":[-39,1,24],"size":[14,0,22.6274],"uv":{"down":{"uv":[16,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-32,1,24]}],"rotation":[0,180,0],"pivot":[-32,8,32]},{"name":"b_2_0_4","parent":"l_0","cubes":[{"origin":[-39,1,56],"size":[14,0,22.6274],"uv":{"down":{"uv":[30,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-32,1,56]}],"rotation":[0,0,0],"pivot":[-32,8,64]},{"name":"b_2_0_5","parent":"l_0","cubes":[{"origin":[-40,0,72],"size":[16,16,16],"uv":{"west":{"uv":[32,16],"uv_size":[16,16]},"east":{"uv":[32,16],"uv_size":[16,16]},"down":{"uv":[32,16],"uv_size":[16,16]},"up":{"uv":[32,16],"uv_size":[16,16]},"north":{"uv":[32,16],"uv_size":[16,16]},"south":{"uv":[32,16],"uv_size":[16,16]}}}]},{"name":"b_2_0_6","parent":"l_0","cubes":[{"origin":[-39,1,88],"size":[14,0,22.6274],"uv":{"down":{"uv":[30,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-32,1,88]}],"rotation":[0,180,0],"pivot":[-32,8,96]},{"name":"b_3_0_1","parent":"l_0","cubes":[{"origin":[-55,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[16,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-48,1,8]}],"rotation":[0,90,0],"pivot":[-48,8,16]},{"name":"b_3_0_5","parent":"l_0","cubes":[{"origin":[-55,1,72],"size":[14,0,22.6274],"uv":{"down":{"uv":[30,0],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-48,1,72]}],"rotation":[0,90,0],"pivot":[-48,8,80]},{"name":"b_5_0_1","parent":"l_0","cubes":[{"origin":[-87,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-80,1,8]}],"rotation":[0,-90,0],"pivot":[-80,8,16]},{"name":"b_5_0_5","parent":"l_0","cubes":[{"origin":[-87,1,72],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-80,1,72]}],"rotation":[0,-90,0],"pivot":[-80,8,80]},{"name":"b_6_0_0","parent":"l_0","cubes":[{"origin":[-103,1,-8],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-96,1,-8]}],"rotation":[0,0,0],"pivot":[-96,8,0]},{"name":"b_6_0_1","parent":"l_0","cubes":[{"origin":[-104,0,8],"size":[16,16,16],"uv":{"west":{"uv":[0,16],"uv_size":[16,16]},"east":{"uv":[0,16],"uv_size":[16,16]},"down":{"uv":[16,16],"uv_size":[16,16]},"up":{"uv":[16,16],"uv_size":[16,16]},"north":{"uv":[0,16],"uv_size":[16,16]},"south":{"uv":[0,16],"uv_size":[16,16]}}}],"rotation":[0,0,0],"pivot":[-96,8,16]},{"name":"b_6_0_2","parent":"l_0","cubes":[{"origin":[-103,1,24],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-96,1,24]}],"rotation":[0,180,0],"pivot":[-96,8,32]},{"name":"b_6_0_4","parent":"l_0","cubes":[{"origin":[-103,1,56],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-96,1,56]}],"rotation":[0,0,0],"pivot":[-96,8,64]},{"name":"b_6_0_5","parent":"l_0","cubes":[{"origin":[-104,0,72],"size":[16,16,16],"uv":{"west":{"uv":[0,16],"uv_size":[16,16]},"east":{"uv":[0,16],"uv_size":[16,16]},"down":{"uv":[16,16],"uv_size":[16,16]},"up":{"uv":[16,16],"uv_size":[16,16]},"north":{"uv":[0,16],"uv_size":[16,16]},"south":{"uv":[0,16],"uv_size":[16,16]}}}],"rotation":[0,0,0],"pivot":[-96,8,80]},{"name":"b_6_0_6","parent":"l_0","cubes":[{"origin":[-103,1,88],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-96,1,88]}],"rotation":[0,180,0],"pivot":[-96,8,96]},{"name":"b_7_0_1","parent":"l_0","cubes":[{"origin":[-119,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-112,1,8]}],"rotation":[0,90,0],"pivot":[-112,8,16]},{"name":"b_7_0_5","parent":"l_0","cubes":[{"origin":[-119,1,72],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-112,1,72]}],"rotation":[0,90,0],"pivot":[-112,8,80]},{"name":"b_9_0_1","parent":"l_0","cubes":[{"origin":[-151,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[28,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-144,1,8]}],"rotation":[0,-90,0],"pivot":[-144,8,16]},{"name":"b_9_0_5","parent":"l_0","cubes":[{"origin":[-151,1,72],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-144,1,72]}],"rotation":[0,-90,0],"pivot":[-144,8,80]},{"name":"b_10_0_0","parent":"l_0","cubes":[{"origin":[-167,1,-8],"size":[14,0,22.6274],"uv":{"down":{"uv":[28,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-160,1,-8]}],"rotation":[0,0,0],"pivot":[-160,8,0]},{"name":"b_10_0_1","parent":"l_0","cubes":[{"origin":[-168,0,8],"size":[16,16,16],"uv":{"west":{"uv":[0,16],"uv_size":[16,16]},"east":{"uv":[0,16],"uv_size":[16,16]},"down":{"uv":[16,16],"uv_size":[16,16]},"up":{"uv":[16,16],"uv_size":[16,16]},"north":{"uv":[0,16],"uv_size":[16,16]},"south":{"uv":[0,16],"uv_size":[16,16]}}}],"rotation":[0,0,0],"pivot":[-160,8,16]},{"name":"b_10_0_2","parent":"l_0","cubes":[{"origin":[-167,1,24],"size":[14,0,22.6274],"uv":{"down":{"uv":[28,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-160,1,24]}],"rotation":[0,180,0],"pivot":[-160,8,32]},{"name":"b_10_0_4","parent":"l_0","cubes":[{"origin":[-167,1,56],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-160,1,56]}],"rotation":[0,0,0],"pivot":[-160,8,64]},{"name":"b_10_0_5","parent":"l_0","cubes":[{"origin":[-168,0,72],"size":[16,16,16],"uv":{"west":{"uv":[32,16],"uv_size":[16,16]},"east":{"uv":[32,16],"uv_size":[16,16]},"down":{"uv":[32,16],"uv_size":[16,16]},"up":{"uv":[32,16],"uv_size":[16,16]},"north":{"uv":[32,16],"uv_size":[16,16]},"south":{"uv":[32,16],"uv_size":[16,16]}}}]},{"name":"b_10_0_6","parent":"l_0","cubes":[{"origin":[-167,1,88],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-160,1,88]}],"rotation":[0,180,0],"pivot":[-160,8,96]},{"name":"b_11_0_1","parent":"l_0","cubes":[{"origin":[-183,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[28,32],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-176,1,8]}],"rotation":[0,90,0],"pivot":[-176,8,16]},{"name":"b_11_0_5","parent":"l_0","cubes":[{"origin":[-183,1,72],"size":[14,0,22.6274],"uv":{"down":{"uv":[0,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-176,1,72]}],"rotation":[0,90,0],"pivot":[-176,8,80]},{"name":"b_13_0_1","parent":"l_0","cubes":[{"origin":[-215,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-208,1,8]}],"rotation":[0,-90,0],"pivot":[-208,8,16]},{"name":"b_13_0_4","parent":"l_0","cubes":[{"origin":[-216,0,56],"size":[16,16,16],"uv":{"west":{"uv":[32,16],"uv_size":[16,16]},"east":{"uv":[32,16],"uv_size":[16,16]},"down":{"uv":[32,16],"uv_size":[16,16]},"up":{"uv":[32,16],"uv_size":[16,16]},"north":{"uv":[32,16],"uv_size":[16,16]},"south":{"uv":[32,16],"uv_size":[16,16]}}}]},{"name":"b_14_0_0","parent":"l_0","cubes":[{"origin":[-231,1,-8],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-224,1,-8]}],"rotation":[0,0,0],"pivot":[-224,8,0]},{"name":"b_14_0_1","parent":"l_0","cubes":[{"origin":[-232,0,8],"size":[16,16,16],"uv":{"west":{"uv":[0,16],"uv_size":[16,16]},"east":{"uv":[0,16],"uv_size":[16,16]},"down":{"uv":[16,16],"uv_size":[16,16]},"up":{"uv":[16,16],"uv_size":[16,16]},"north":{"uv":[0,16],"uv_size":[16,16]},"south":{"uv":[0,16],"uv_size":[16,16]}}}],"rotation":[0,0,0],"pivot":[-224,8,16]},{"name":"b_14_0_2","parent":"l_0","cubes":[{"origin":[-231,1,24],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-224,1,24]}],"rotation":[0,180,0],"pivot":[-224,8,32]},{"name":"b_14_0_4","parent":"l_0","cubes":[{"origin":[-231,1,56],"size":[14,0,16],"uv":{"down":{"uv":[30,0],"uv_size":[14,16]}}}],"rotation":[0,90,0],"pivot":[-224,8,64]},{"name":"b_15_0_1","parent":"l_0","cubes":[{"origin":[-247,1,8],"size":[14,0,22.6274],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}},"rotation":[45,0,0],"pivot":[-240,1,8]}],"rotation":[0,90,0],"pivot":[-240,8,16]},{"name":"b_15_0_5","parent":"l_0","cubes":[{"origin":[-247,1,72],"size":[14,0,16],"uv":{"down":{"uv":[16,0],"uv_size":[14,16]}}}],"rotation":[0,0,0],"pivot":[-240,8,80]},{"name":"b_16_0_4","parent":"l_0","cubes":[{"origin":[-263,1,56],"size":[14,0,16],"uv":{"down":{"uv":[14,32],"uv_size":[14,16]}}}],"rotation":[0,90,0],"pivot":[-256,8,64]},{"name":"b_17_0_0","parent":"l_0","cubes":[{"origin":[-279,1,-7],"size":[15,0,15],"uv":{"down":{"uv":[28,48],"uv_size":[15,15]}}}],"rotation":[0,-90,0],"pivot":[-272,8,0]},{"name":"b_17_0_1","parent":"l_0","cubes":[{"origin":[-279,1,8],"size":[14,0,16],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}}}],"rotation":[0,0,0],"pivot":[-272,8,16]},{"name":"b_17_0_2","parent":"l_0","cubes":[{"origin":[-279,1,25],"size":[15,0,15],"uv":{"down":{"uv":[28,48],"uv_size":[15,15]}}}],"rotation":[0,180,0],"pivot":[-272,8,32]},{"name":"b_17_0_5","parent":"l_0","cubes":[{"origin":[-279,1,72],"size":[14,0,16],"uv":{"down":{"uv":[0,32],"uv_size":[14,16]}}}],"rotation":[0,0,0],"pivot":[-272,8,80]},{"name":"b_18_0_0","parent":"l_0","cubes":[{"origin":[-295,1,-8],"size":[14,0,16],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}}}],"rotation":[0,90,0],"pivot":[-288,8,0]},{"name":"b_18_0_2","parent":"l_0","cubes":[{"origin":[-295,1,24],"size":[14,0,16],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}}}],"rotation":[0,90,0],"pivot":[-288,8,32]},{"name":"b_18_0_3","parent":"l_0","cubes":[{"origin":[-296,0,40],"size":[16,16,16],"uv":{"west":{"uv":[32,16],"uv_size":[16,16]},"east":{"uv":[32,16],"uv_size":[16,16]},"down":{"uv":[32,16],"uv_size":[16,16]},"up":{"uv":[32,16],"uv_size":[16,16]},"north":{"uv":[32,16],"uv_size":[16,16]},"south":{"uv":[32,16],"uv_size":[16,16]}}}]},{"name":"b_18_0_4","parent":"l_0","cubes":[{"origin":[-295,1,56],"size":[14,0,16],"uv":{"down":{"uv":[0,48],"uv_size":[14,16]}}}],"rotation":[0,90,0],"pivot":[-288,8,64]},{"name":"b_19_0_0","parent":"l_0","cubes":[{"origin":[-311,1,-7],"size":[15,0,15],"uv":{"down":{"uv":[28,48],"uv_size":[15,15]}}}],"rotation":[0,0,0],"pivot":[-304,8,0]},{"name":"b_19_0_1","parent":"l_0","cubes":[{"origin":[-311,1,8],"size":[14,0,16],"uv":{"down":{"uv":[14,48],"uv_size":[14,16]}}}],"rotation":[0,0,0],"pivot":[-304,8,16]},{"name":"b_19_0_2","parent":"l_0","cubes":[{"origin":[-311,1,25],"size":[15,0,15],"uv":{"down":{"uv":[28,48],"uv_size":[15,15]}}}],"rotation":[0,90,0],"pivot":[-304,8,32]},{"name":"b_19_0_5","parent":"l_0","cubes":[{"origin":[-311,1,72],"size":[14,0,16],"uv":{"down":{"uv":[28,32],"uv_size":[14,16]}}}],"rotation":[0,0,0],"pivot":[-304,8,80]}]}

hologram_opacity_1

Thanks for your time!

SuperLlama88888 commented 2 days ago

This is only an issue on down faces. Using model-viewer: image In Minecraft: image