Attempt to fix fullbright lighting.

Fix lightmap value calculation.
This commit is contained in:
David Quintana 2020-01-11 05:13:41 +01:00
parent d5b94aa9c8
commit 2c054fca76
7 changed files with 46 additions and 55 deletions

View file

@ -107,8 +107,10 @@ public interface IForgeVertexBuilder
default int applyBakedLighting(int lightmapCoord, ByteBuffer data) { default int applyBakedLighting(int lightmapCoord, ByteBuffer data) {
int bl = LightTexture.func_228450_a_(lightmapCoord); int bl = LightTexture.func_228450_a_(lightmapCoord);
int sl = LightTexture.func_228454_b_(lightmapCoord); int sl = LightTexture.func_228454_b_(lightmapCoord);
bl = Math.max(bl, Short.toUnsignedInt(data.getShort(26))); int blBaked = Short.toUnsignedInt(data.getShort(24)) >> 4;
sl = Math.max(sl, Short.toUnsignedInt(data.getShort(24))); int slBaked = Short.toUnsignedInt(data.getShort(26)) >> 4;
bl = Math.max(bl, blBaked);
sl = Math.max(sl, slBaked);
return LightTexture.func_228451_a_(bl, sl); return LightTexture.func_228451_a_(bl, sl);
} }

View file

@ -51,6 +51,7 @@ import java.util.stream.Collectors;
public class OBJModel implements IMultipartModelGeometry<OBJModel> public class OBJModel implements IMultipartModelGeometry<OBJModel>
{ {
private static Vector4f COLOR_WHITE = new Vector4f(1, 1, 1, 1);
private static Vec2f[] DEFAULT_COORDS = { private static Vec2f[] DEFAULT_COORDS = {
new Vec2f(0, 0), new Vec2f(0, 0),
new Vec2f(0, 1), new Vec2f(0, 1),
@ -337,7 +338,7 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
return Optional.ofNullable(parts.get(name)); return Optional.ofNullable(parts.get(name));
} }
private Pair<BakedQuad,Direction> makeQuad(int[][] indices, int tintIndex, Vector4f colorTint, Vector4f ambientColor, boolean isFullbright, TextureAtlasSprite texture, TransformationMatrix transform) private Pair<BakedQuad,Direction> makeQuad(int[][] indices, int tintIndex, Vector4f colorTint, Vector4f ambientColor, TextureAtlasSprite texture, TransformationMatrix transform)
{ {
boolean needsNormalRecalculation = false; boolean needsNormalRecalculation = false;
for (int[] ints : indices) for (int[] ints : indices)
@ -364,10 +365,18 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
BakedQuadBuilder builder = new BakedQuadBuilder(texture); BakedQuadBuilder builder = new BakedQuadBuilder(texture);
builder.setQuadTint(tintIndex); builder.setQuadTint(tintIndex);
builder.setApplyDiffuseLighting(!isFullbright);
int fakeLight = (int)((ambientColor.getX() + ambientColor.getY() + ambientColor.getZ()) * 15 / 3.0f); boolean diffuse = true;
Vec2f uv2 = new Vec2f(((float) fakeLight * 0x20) / 0xFFFF, ((float) fakeLight * 0x20) / 0xFFFF);
Vec2f uv2 = new Vec2f(0,0);
if (ambientToFullbright)
{
int fakeLight = (int) ((ambientColor.getX() + ambientColor.getY() + ambientColor.getZ()) * 15 / 3.0f);
uv2 = new Vec2f((fakeLight << 4) / 32767.0f, (fakeLight << 4) / 32767.0f);
//uv2 = new Vec2f(0, (fakeLight << 4) / 32767.0f);
//uv2 = new Vec2f((fakeLight << 4) / 32767.0f, 0);
builder.setApplyDiffuseLighting(diffuse = (fakeLight > 0));
}
boolean hasTransform = !transform.isIdentity(); boolean hasTransform = !transform.isIdentity();
// The incoming transform is referenced on the center of the block, but our coords are referenced on the corner // The incoming transform is referenced on the center of the block, but our coords are referenced on the corner
@ -377,11 +386,11 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
{ {
int[] index = indices[Math.min(i,indices.length-1)]; int[] index = indices[Math.min(i,indices.length-1)];
Vector3f pos0 = positions.get(index[0]); Vector3f pos0 = positions.get(index[0]);
Vector4f position = new Vector4f(pos0.getX(), pos0.getY(), pos0.getZ(), 1); Vector4f position = new Vector4f(pos0);
Vec2f texCoord = index.length >= 2 && texCoords.size() > 0 ? texCoords.get(index[1]) : DEFAULT_COORDS[i]; Vec2f texCoord = index.length >= 2 && texCoords.size() > 0 ? texCoords.get(index[1]) : DEFAULT_COORDS[i];
Vector3f norm0 = !needsNormalRecalculation && index.length >= 3 && normals.size() > 0 ? normals.get(index[2]) : faceNormal; Vector3f norm0 = !needsNormalRecalculation && index.length >= 3 && normals.size() > 0 ? normals.get(index[2]) : faceNormal;
Vector3f normal = norm0; Vector3f normal = norm0;
Vector4f color = index.length >= 4 && colors.size() > 0 ? colors.get(index[3]) : new Vector4f(1, 1, 1, 1); Vector4f color = index.length >= 4 && colors.size() > 0 ? colors.get(index[3]) : COLOR_WHITE;
if (hasTransform) if (hasTransform)
{ {
normal = norm0.func_229195_e_(); normal = norm0.func_229195_e_();
@ -393,6 +402,7 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
color.getY() * colorTint.getY(), color.getY() * colorTint.getY(),
color.getZ() * colorTint.getZ(), color.getZ() * colorTint.getZ(),
color.getW() * colorTint.getW()); color.getW() * colorTint.getW());
if (!diffuse) normal = new Vector3f(0,0,0);
putVertexData(builder, position, texCoord, normal, tintedColor, uv2, texture); putVertexData(builder, position, texCoord, normal, tintedColor, uv2, texture);
pos[i] = position; pos[i] = position;
norm[i] = normal; norm[i] = normal;
@ -525,11 +535,10 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
TextureAtlasSprite texture = spriteGetter.apply(ModelLoaderRegistry.resolveTexture(mat.diffuseColorMap, owner)); TextureAtlasSprite texture = spriteGetter.apply(ModelLoaderRegistry.resolveTexture(mat.diffuseColorMap, owner));
int tintIndex = mat.diffuseTintIndex; int tintIndex = mat.diffuseTintIndex;
Vector4f colorTint = mat.diffuseColor; Vector4f colorTint = mat.diffuseColor;
boolean isFullbright = ambientToFullbright && mesh.isFullbright();
for (int[][] face : mesh.faces) for (int[][] face : mesh.faces)
{ {
Pair<BakedQuad, Direction> quad = makeQuad(face, tintIndex, colorTint, mat.ambientColor, isFullbright, texture, modelTransform.func_225615_b_()); Pair<BakedQuad, Direction> quad = makeQuad(face, tintIndex, colorTint, mat.ambientColor, texture, modelTransform.func_225615_b_());
if (quad.getRight() == null) if (quad.getRight() == null)
modelBuilder.addGeneralQuad(quad.getLeft()); modelBuilder.addGeneralQuad(quad.getLeft());
else else
@ -543,11 +552,6 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
{ {
return meshes.stream().map(mesh -> ModelLoaderRegistry.resolveTexture(mesh.mat.diffuseColorMap, owner)).collect(Collectors.toSet()); return meshes.stream().map(mesh -> ModelLoaderRegistry.resolveTexture(mesh.mat.diffuseColorMap, owner)).collect(Collectors.toSet());
} }
public boolean hasAnyFullBright()
{
return meshes.stream().anyMatch(ModelMesh::isFullbright);
}
} }
public class ModelGroup extends ModelObject public class ModelGroup extends ModelObject
@ -582,12 +586,6 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
combined.addAll(part.getTextures(owner, modelGetter, missingTextureErrors)); combined.addAll(part.getTextures(owner, modelGetter, missingTextureErrors));
return combined; return combined;
} }
@Override
public boolean hasAnyFullBright()
{
return super.hasAnyFullBright() || parts.values().stream().anyMatch(ModelObject::hasAnyFullBright);
}
} }
private class ModelMesh private class ModelMesh
@ -603,11 +601,6 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
this.mat = currentMat; this.mat = currentMat;
this.smoothingGroup = currentSmoothingGroup; this.smoothingGroup = currentSmoothingGroup;
} }
public boolean isFullbright()
{
return mat != null && TransformationHelper.epsilonEquals(mat.ambientColor, new Vector4f(1,1,1,1), 1/256f);
}
} }
public static class ModelSettings public static class ModelSettings

View file

@ -24,6 +24,8 @@ import net.minecraft.block.BlockState;
import net.minecraft.block.FourWayBlock; import net.minecraft.block.FourWayBlock;
import net.minecraft.block.material.Material; import net.minecraft.block.material.Material;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.RenderType;
import net.minecraft.client.renderer.RenderTypeLookup;
import net.minecraft.client.renderer.model.ItemCameraTransforms; import net.minecraft.client.renderer.model.ItemCameraTransforms;
import net.minecraft.client.renderer.texture.AtlasTexture; import net.minecraft.client.renderer.texture.AtlasTexture;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
@ -32,6 +34,10 @@ import net.minecraft.item.*;
import net.minecraft.state.StateContainer; import net.minecraft.state.StateContainer;
import net.minecraft.state.properties.BlockStateProperties; import net.minecraft.state.properties.BlockStateProperties;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.shapes.ISelectionContext;
import net.minecraft.util.math.shapes.VoxelShape;
import net.minecraft.world.IBlockReader;
import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.client.event.RenderGameOverlayEvent; import net.minecraftforge.client.event.RenderGameOverlayEvent;
import net.minecraftforge.client.model.ModelLoader; import net.minecraftforge.client.model.ModelLoader;
@ -42,6 +48,7 @@ import net.minecraftforge.common.util.NonNullLazy;
import net.minecraftforge.eventbus.api.IEventBus; import net.minecraftforge.eventbus.api.IEventBus;
import net.minecraftforge.fml.RegistryObject; import net.minecraftforge.fml.RegistryObject;
import net.minecraftforge.fml.common.Mod; import net.minecraftforge.fml.common.Mod;
import net.minecraftforge.fml.event.lifecycle.FMLClientSetupEvent;
import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext; import net.minecraftforge.fml.javafmlmod.FMLJavaModLoadingContext;
import net.minecraftforge.registries.DeferredRegister; import net.minecraftforge.registries.DeferredRegister;
import net.minecraftforge.registries.ForgeRegistries; import net.minecraftforge.registries.ForgeRegistries;
@ -71,6 +78,12 @@ public class NewModelLoaderTest
BlockStateProperties.HORIZONTAL_FACING, context.getPlacementHorizontalFacing() BlockStateProperties.HORIZONTAL_FACING, context.getPlacementHorizontalFacing()
); );
} }
@Override
public VoxelShape getShape(BlockState state, IBlockReader worldIn, BlockPos pos, ISelectionContext context)
{
return Block.makeCuboidShape(2,2,2,14,14,14);
}
} }
); );

View file

@ -1,17 +1,10 @@
{ {
"parent": "forge:item/default", "parent": "forge:item/default",
"loader": "forge:composite",
"parts": {
"part1": {
"loader": "forge:obj", "loader": "forge:obj",
"model": "new_model_loader_test:models/item/sugar_glider.obj", "model": "new_model_loader_test:models/item/sugar_glider.obj",
"ambientToFullbright": true, "ambientToFullbright": true,
"textures": { "textures": {
"qr": "minecraft:block/oak_planks" "qr": "minecraft:block/oak_planks",
}
}
},
"textures": {
"particle": "block/oak_planks" "particle": "block/oak_planks"
} }
} }

View file

@ -1,7 +1,8 @@
newmtl None newmtl None
Ns 0 Ns 0
Ka 1.0000 1.0000 1.0000 Ka 0 0 0
Kd 0.8 0.8 0.8 Kd 0.8 0.8 0.8
Ks 0.8 0.8 0.8 Ks 0.8 0.8 0.8
d 1 d 1
illum 2 illum 2
map_Kd minecraft:block/coal_ore

View file

@ -1,16 +1,5 @@
{ {
"parent": "forge:item/default", "parent": "new_model_loader_test:block/obj_block",
"loader": "forge:composite",
"parts": {
"part1": {
"loader": "forge:obj",
"model": "new_model_loader_test:models/item/sugar_glider.obj",
"ambientToFullbright": true,
"textures": {
"qr": "new_model_loader_test:item/qr"
}
}
},
"textures": { "textures": {
"particle": "block/oak_planks" "particle": "block/oak_planks"
}, },

View file

@ -1,6 +1,6 @@
# Rhino # Rhino
newmtl New material 001 (1) newmtl New material 001 (1)
Ka 0.0000 0.0000 0.0000 Ka 0.5 0.5 0.5
Kd 0.4588 0.3333 0.1882 Kd 0.4588 0.3333 0.1882
Ks 1.0000 1.0000 1.0000 Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000 Tf 0.0000 0.0000 0.0000
@ -9,7 +9,7 @@ Ns 0
map_Kd #qr map_Kd #qr
newmtl New material 001 newmtl New material 001
Ka 0.0000 0.0000 0.0000 Ka 0.5 0.5 0.5
Kd 0.6745 0.5216 0.3412 Kd 0.6745 0.5216 0.3412
Ks 1.0000 1.0000 1.0000 Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000 Tf 0.0000 0.0000 0.0000
@ -18,7 +18,7 @@ Ns 0
map_Kd #qr map_Kd #qr
newmtl Default newmtl Default
Ka 0.0000 0.0000 0.0000 Ka 0.5 0.5 0.5
Kd 1.0000 1.0000 1.0000 Kd 1.0000 1.0000 1.0000
Ks 1.0000 1.0000 1.0000 Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000 Tf 0.0000 0.0000 0.0000
@ -27,7 +27,7 @@ Ns 0
map_Kd #qr map_Kd #qr
newmtl New material 002 newmtl New material 002
Ka 0.0000 0.0000 0.0000 Ka 0.5 0.5 0.5
Kd 0.4118 0.4118 0.4118 Kd 0.4118 0.4118 0.4118
Ks 1.0000 1.0000 1.0000 Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000 Tf 0.0000 0.0000 0.0000
@ -36,7 +36,7 @@ Ns 0
map_Kd #qr map_Kd #qr
newmtl New material 003 newmtl New material 003
Ka 0.0000 0.0000 0.0000 Ka 0.5 0.5 0.5
Kd 0.1490 0.1490 0.1490 Kd 0.1490 0.1490 0.1490
Ks 1.0000 1.0000 1.0000 Ks 1.0000 1.0000 1.0000
Tf 0.0000 0.0000 0.0000 Tf 0.0000 0.0000 0.0000