mirror of
https://gitlab.com/MaddoScientisto/cirnogodot.git
synced 2026-06-09 13:05:53 +00:00
Minimap
This commit is contained in:
parent
c6a0b73ed2
commit
60f755aca5
5 changed files with 137 additions and 15 deletions
105
Scripts/UI/Minimap.cs
Normal file
105
Scripts/UI/Minimap.cs
Normal file
|
|
@ -0,0 +1,105 @@
|
|||
using Godot;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using Cirno.Scripts.Controllers;
|
||||
using Cirno.Scripts.Enums;
|
||||
|
||||
public partial class Minimap : CanvasLayer
|
||||
{
|
||||
[Export] public RogueliteRoomManager RoomManager { get; private set; }
|
||||
|
||||
private Rid _canvasItemRid;
|
||||
private Rid _parentCanvas;
|
||||
private Godot.Collections.Dictionary<Vector2I, RogueliteRoom> RoomGrid => RoomManager.RoomGrid;
|
||||
|
||||
private List<RogueliteRoom> SpawnedRooms => RoomManager.SpawnedRooms;
|
||||
|
||||
[Export] public int CellSize { get; private set; } = 16;
|
||||
[Export] public Vector2 Padding { get; private set; } = new Vector2(20, 20);
|
||||
|
||||
[Export] public float Separation = 2f;
|
||||
|
||||
private Vector2 _viewportSize;
|
||||
|
||||
public override void _Ready()
|
||||
{
|
||||
RoomManager.MapCreated += RoomManagerOnMapCreated;
|
||||
|
||||
_canvasItemRid = RenderingServer.CanvasItemCreate();
|
||||
_parentCanvas = this.GetCanvas(); //GetCanvasItem(); // Gets the RID of this Node2D's canvas
|
||||
RenderingServer.CanvasItemSetParent(_canvasItemRid, _parentCanvas);
|
||||
RenderingServer.CanvasItemSetVisible(_canvasItemRid, true);
|
||||
}
|
||||
|
||||
public override void _EnterTree()
|
||||
{
|
||||
// Get current window size to position minimap in top-right
|
||||
_viewportSize = GetViewport().GetVisibleRect().Size;
|
||||
}
|
||||
|
||||
|
||||
private void RoomManagerOnMapCreated()
|
||||
{
|
||||
RedrawMinimap();
|
||||
}
|
||||
|
||||
// public void SetRoomGrid(Dictionary<Vector2I, RogueliteRoom> roomGrid)
|
||||
// {
|
||||
// _roomGrid = roomGrid;
|
||||
// RedrawMinimap();
|
||||
// }
|
||||
|
||||
private void RedrawMinimap()
|
||||
{
|
||||
// Clear previous draw commands
|
||||
RenderingServer.CanvasItemClear(_canvasItemRid);
|
||||
|
||||
if (SpawnedRooms == null)
|
||||
return;
|
||||
|
||||
// Find bounds
|
||||
Vector2I min = new(int.MaxValue, int.MaxValue);
|
||||
Vector2I max = new(int.MinValue, int.MinValue);
|
||||
|
||||
foreach (var room in SpawnedRooms)
|
||||
{
|
||||
min = new Vector2I(Math.Min(min.X, room.GridPosition.X), Math.Min(min.Y, room.GridPosition.Y));
|
||||
max = new Vector2I(Math.Max(max.X, room.GridPosition.X + room.RoomResource.Size.X),
|
||||
Math.Max(max.Y, room.GridPosition.Y + room.RoomResource.Size.Y));
|
||||
}
|
||||
|
||||
Vector2 mapSize = (max - min) * CellSize;
|
||||
Vector2 offset = new Vector2(
|
||||
_viewportSize.X - mapSize.X - Padding.X, // padding from right
|
||||
Padding.Y // Top padding
|
||||
);
|
||||
|
||||
//Vector2 offset = Padding; // Padding
|
||||
|
||||
foreach (var room in SpawnedRooms)
|
||||
{
|
||||
Vector2I pos = room.GridPosition;
|
||||
Vector2I size = room.RoomResource.Size;
|
||||
Vector2 drawPos = offset + (new Vector2((pos.X - min.X), (pos.Y - min.Y))) * (CellSize + Separation);
|
||||
Vector2 drawSize = new Vector2(size.X, size.Y) * CellSize +
|
||||
new Vector2((size.X - 1), (size.Y - 1)) * Separation;
|
||||
//Vector2 drawSize = new Vector2(size.X, size.Y) * CellSize;
|
||||
|
||||
Color color = GetColorForRoomType(room.RoomResource.Type);
|
||||
|
||||
RenderingServer.CanvasItemAddRect(_canvasItemRid, new Rect2(drawPos, drawSize), color);
|
||||
}
|
||||
}
|
||||
|
||||
private Color GetColorForRoomType(RoomType type)
|
||||
{
|
||||
return type switch
|
||||
{
|
||||
RoomType.Boss => Colors.Red,
|
||||
RoomType.Shop => Colors.Gold,
|
||||
RoomType.Regular => Colors.Blue,
|
||||
RoomType.Starter => Colors.Green,
|
||||
_ => Colors.DimGray
|
||||
};
|
||||
}
|
||||
}
|
||||
1
Scripts/UI/Minimap.cs.uid
Normal file
1
Scripts/UI/Minimap.cs.uid
Normal file
|
|
@ -0,0 +1 @@
|
|||
uid://3v6q0p5krqn7
|
||||
Loading…
Add table
Add a link
Reference in a new issue