Fixed content visibility and changed spawn creation

This commit is contained in:
=
2026-05-01 19:27:44 +02:00
parent 8a6de193a1
commit ae7c98d482
4 changed files with 21 additions and 10 deletions
+6 -1
View File
@@ -23,7 +23,12 @@ public class MoveNode : ProgramNode
{ {
robot.Position = pathPoints[0]; robot.Position = pathPoints[0];
Vector3I mapIndex = Pathfinding.GetClosestStartPoint(robot.Position); Vector3I mapIndex = Pathfinding.GetClosestStartPoint(robot.Position);
GameData.map[mapIndex.Y].tiles[mapIndex.X, mapIndex.Z].wasVisited = true; Tile tile = GameData.map[mapIndex.Y].tiles[mapIndex.X, mapIndex.Z];
if (!tile.wasVisited)
{
tile.wasVisited = true;
tile.ContentNode.Visible = true;
}
pathPoints.Remove(pathPoints[0]); pathPoints.Remove(pathPoints[0]);
if (pathPoints.Count <= 0) if (pathPoints.Count <= 0)
{ {
+2 -1
View File
@@ -88,7 +88,8 @@ public partial class Layer : Node3D
{ {
var node = new Node3D var node = new Node3D
{ {
Position = tile.Position Position = tile.Position,
Visible = false
}; };
decorationRoot.AddChild(node); decorationRoot.AddChild(node);
-1
View File
@@ -78,7 +78,6 @@ public partial class Tile
public void SpawnContent(Dictionary<string, MeshInstance3D> contentMeshes, Transform3D transform, List<Placeholder> placeholders) public void SpawnContent(Dictionary<string, MeshInstance3D> contentMeshes, Transform3D transform, List<Placeholder> placeholders)
{ {
if(!wasVisited) return;
foreach (Placeholder placeholder in placeholders) foreach (Placeholder placeholder in placeholders)
{ {
if (containsLight && placeholder.name == "light") SpawnLight(contentMeshes["light"], placeholder, transform); if (containsLight && placeholder.name == "light") SpawnLight(contentMeshes["light"], placeholder, transform);
+11 -5
View File
@@ -90,7 +90,7 @@ public partial class World : Node3D
{ {
Robot robot = ResourceLoader.LoadRobotPrefab().Instantiate<Robot>(); Robot robot = ResourceLoader.LoadRobotPrefab().Instantiate<Robot>();
robot.Name = $"Robot #{robots.Count + 1}"; robot.Name = $"Robot #{robots.Count + 1}";
robot.Position = map[0].tiles[0,0].Position; robot.Position = map[0].tiles[0, 0].Position;
AddChild(robot); AddChild(robot);
robots.Add(robot); robots.Add(robot);
} }
@@ -113,10 +113,16 @@ public partial class World : Node3D
map[layer] = layerNode; map[layer] = layerNode;
} }
map[0].tiles[0,0].wasVisited = true; SetupSpawn();
map[0].tiles[0,0].containsDecoration = true; }
map[0].tiles[0,0].containsLight = true;
map[0].tiles[0,0].containsResource = false; private void SetupSpawn()
{
map[0].tiles[0, 0].wasVisited = true;
map[0].tiles[0, 0].containsDecoration = true;
map[0].tiles[0, 0].containsLight = true;
map[0].tiles[0, 0].containsResource = false;
map[0].tiles[0, 0].ContentNode.Visible = true;
} }
private void HandleTileVisit(int level) private void HandleTileVisit(int level)