From b263bdd77e088220c0e2a8ca2fb08195e8595a9e Mon Sep 17 00:00:00 2001 From: Jarrod Doyle Date: Sun, 27 Oct 2024 12:26:01 +0000 Subject: [PATCH] Fix incorrect light table --- KeepersCompound.Lightmapper/Program.cs | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/KeepersCompound.Lightmapper/Program.cs b/KeepersCompound.Lightmapper/Program.cs index 2dadcf3..530000c 100644 --- a/KeepersCompound.Lightmapper/Program.cs +++ b/KeepersCompound.Lightmapper/Program.cs @@ -554,12 +554,19 @@ class Program private static void SetCellLightIndices(WorldRep wr, Light[] lights) { + // TODO: Move this functionality to the LGS library // We set up light indices in separately from lighting because the actual // lighting phase takes a lot of shortcuts that we don't want Parallel.ForEach(wr.Cells, cell => { cell.LightIndexCount = 0; cell.LightIndices.Clear(); + + // The first element of the light indices array is used to store how many + // actual lights are in the list. Which is just LightIndexCount - 1... + // Odd choice I know + cell.LightIndexCount++; + cell.LightIndices.Add(0); // The OG lightmapper uses the cell traversal to work out all the cells that // are actually visited. We're a lot more coarse and just say if a cell is @@ -573,6 +580,7 @@ class Program { cell.LightIndexCount++; cell.LightIndices.Add((ushort)light.lightTableIndex); + cell.LightIndices[0]++; } } });