예제 #1
0
    private static void RemoveNodes(Queue <Vector3i> nodes)
    {
        Queue <Vector3i> newLights = new Queue <Vector3i>();

        while (nodes.Count > 0)
        {
            Vector3i pos = nodes.Dequeue();

            if (pos.y < 0 || pos.y >= Map.Height)
            {
                continue;
            }

            int light = MapLight.GetLight(pos.x, pos.y, pos.z) - 1;
            MapLight.SetLight(pos.x, pos.y, pos.z, LightUtils.MinLight);

            if (light <= LightUtils.MinLight)
            {
                continue;
            }

            for (int i = 0; i < 6; i++)
            {
                Vector3i nextPos = pos + Vector3i.directions[i];

                if (Map.InBounds(nextPos.x, nextPos.z))
                {
                    Block block = Map.GetBlock(nextPos.x, nextPos.y, nextPos.z);

                    if (block.IsTransparent())
                    {
                        if (MapLight.GetLight(nextPos.x, nextPos.y, nextPos.z) <= light)
                        {
                            nodes.Enqueue(nextPos);
                        }
                        else
                        {
                            newLights.Enqueue(nextPos);
                        }
                    }

                    if (block.LightEmitted() > LightUtils.MinLight)
                    {
                        newLights.Enqueue(nextPos);
                    }

                    Map.FlagChunkForUpdate(nextPos.x, nextPos.y, nextPos.z);
                }
            }
        }

        ScatterNodes(newLights, false);
    }
예제 #2
0
    public static bool SetMax(byte light, int x, int y, int z)
    {
        byte oldLight = MapLight.GetLight(x, y, z);

        if (oldLight < light)
        {
            MapLight.SetLight(x, y, z, light);
            return(true);
        }

        return(false);
    }
예제 #3
0
    public static void Recompute(Vector3i pos, Queue <Vector3i> nodes)
    {
        byte oldLight = MapLight.GetLight(pos.x, pos.y, pos.z);
        byte light    = Map.GetBlock(pos.x, pos.y, pos.z).LightEmitted();

        if (oldLight > light)
        {
            Remove(pos, nodes);
        }

        if (light > LightUtils.MinLight)
        {
            MapLight.SetLight(pos.x, pos.y, pos.z, light);
            Scatter(pos, nodes);
        }
        else
        {
            Update(pos, nodes);
        }
    }
예제 #4
0
    public static void ScatterNodes(Queue <Vector3i> nodes, bool generator)
    {
        while (nodes.Count > 0)
        {
            Vector3i pos = nodes.Dequeue();

            if (pos.y < 0 || pos.y >= Map.Height)
            {
                continue;
            }

            Block block = Map.GetBlock(pos.x, pos.y, pos.z);
            int   light = MapLight.GetLight(pos.x, pos.y, pos.z) - block.GetLightStep();

            if (light <= LightUtils.MinLight)
            {
                continue;
            }

            for (int i = 0; i < 6; i++)
            {
                Vector3i nextPos = pos + Vector3i.directions[i];

                if (Map.InBounds(nextPos.x, nextPos.z))
                {
                    block = Map.GetBlock(nextPos.x, nextPos.y, nextPos.z);

                    if (block.IsTransparent() && SetMax((byte)light, nextPos.x, nextPos.y, nextPos.z))
                    {
                        nodes.Enqueue(nextPos);
                    }

                    if (!generator)
                    {
                        Map.FlagChunkForUpdate(nextPos.x, nextPos.y, nextPos.z);
                    }
                }
            }
        }
    }