* DungeonData rework Back to fields, serializes better, just make new layers dumby. * wawawewa * Fix this * Fixes * review * thanks fork * fix
55 lines
1.6 KiB
C#
55 lines
1.6 KiB
C#
using System.Threading.Tasks;
|
|
using Content.Shared.Procedural;
|
|
using Content.Shared.Procedural.DungeonGenerators;
|
|
using Content.Shared.Procedural.PostGeneration;
|
|
using Robust.Shared.Map;
|
|
using Robust.Shared.Random;
|
|
|
|
namespace Content.Server.Procedural.DungeonJob;
|
|
|
|
public sealed partial class DungeonJob
|
|
{
|
|
/// <summary>
|
|
/// <see cref="ReplaceTileDunGen"/>
|
|
/// </summary>
|
|
private async Task GenerateTileReplacementDunGen(ReplaceTileDunGen gen, List<Dungeon> dungeons, HashSet<Vector2i> reservedTiles, Random random)
|
|
{
|
|
var replacements = new List<(Vector2i Index, Tile Tile)>();
|
|
|
|
foreach (var dungeon in dungeons)
|
|
{
|
|
foreach (var node in dungeon.AllTiles)
|
|
{
|
|
if (reservedTiles.Contains(node))
|
|
continue;
|
|
|
|
foreach (var layer in gen.Layers)
|
|
{
|
|
var value = layer.Noise.GetNoise(node.X, node.Y);
|
|
|
|
if (value < layer.Threshold)
|
|
continue;
|
|
|
|
Tile tile;
|
|
|
|
if (random.Prob(gen.VariantWeight))
|
|
{
|
|
tile = _tileDefManager.GetVariantTile(_prototype.Index(layer.Tile), random);
|
|
}
|
|
else
|
|
{
|
|
tile = new Tile(_prototype.Index(layer.Tile).TileId);
|
|
}
|
|
|
|
replacements.Add((node, tile));
|
|
break;
|
|
}
|
|
|
|
await SuspendDungeon();
|
|
}
|
|
|
|
_maps.SetTiles(_gridUid, _grid, replacements);
|
|
}
|
|
}
|
|
}
|