备份完成的瓦片部分

This commit is contained in:
m0_75251201
2025-07-17 19:14:51 +08:00
parent 41cc9c0c6d
commit 526e8850e4
3 changed files with 89 additions and 14 deletions

View File

@ -61,7 +61,7 @@ namespace Managers
// 创建Sprite
var sprite = Sprite.Create(texture, (Rect)spriteRect, new Vector2(0.5f, 0.5f), pixelsPerUnit);
var index = row * cols + col;
var index = (rows - row - 1) * cols + col;
sprites[name + $"_{index}"] = sprite;
}
}

View File

@ -16,27 +16,98 @@ namespace Map
void Start()
{
TileManager.Instance.Init();
var mapSize = 100;
float noiseScale = 0.1f;
for (int x = 0; x < mapSize; x++)
{
List<int> col = new();
for (int y = 0; y < mapSize; y++)
{
// 计算柏林噪声值
float noiseValue = Mathf.PerlinNoise(x * noiseScale, y * noiseScale);
if (noiseValue < 0.5f) // 小于 0.5 表示 Dirt
{
col.Add(TileManager.Instance.tileID.GetValueOrDefault("Dirt"));
}
else // 大于等于 0.5 表示 Grass
{
col.Add(TileManager.Instance.tileID.GetValueOrDefault("Grass"));
}
}
mapData.Add(col);
UpdateTexture();
}
for (int x = 0; x < 16; x++)
{
textureLevel.SetTile(new(x,-1),TileManager.Instance.tileBaseMapping.GetValueOrDefault($"GrassDirt_{x}"));
}
}
public void UpdateTexture()
{
for (int i = 0; i < mapData.Count; i++)
{
for (int j = 0; j < mapData[i].Count; j++)
{
UpdateTexture(i, j);
}
}
}
public int GetTile(int x, int y)
{
if (x < 0 || x >= mapData.Count)
{
return 0;
}
var col = mapData[x];
if (y < 0 || y >= mapData.Count)
{
return 0;
}
return col[y];
}
public void SetTile(int x, int y, string tileName)
{
SetTile(x,y,TileManager.Instance.tileID.GetValueOrDefault(tileName));
}
public void SetTile(int x, int y, int id)
{
mapData[x][y] = id;
UpdateTexture(x, y);
UpdateTexture(x, y-1);
UpdateTexture(x-1, y);
UpdateTexture(x-1, y-1);
}
/// <summary>
/// 更新对应坐标的贴图
/// </summary>
/// <param name="x"></param>
/// <param name="y"></param>
/// <returns></returns>
public void UpdateTexture(int x, int y)
{
var lt = GetTile(x, y + 1);
var rt = GetTile(x + 1, y + 1);
var lb = GetTile(x, y);
var rb = GetTile(x + 1, y);
if (TileManager.Instance.tileToTileBaseMapping.ContainsKey((lt, rt, lb, rb)))
{
textureLevel.SetTile(new(x,y),TileManager.Instance.tileToTileBaseMapping[(lt, rt, lb, rb)]);
}
}
}
public class TileManager:Utils.Singleton<TileManager>
{
public Dictionary<string,TileBase> tileBaseMapping = new();
public Dictionary<(int, int, int, int), TileBase> tileToTileBaseMapping = new();
public Dictionary<string, int> tileID = new();
public void Init()
@ -46,7 +117,7 @@ namespace Map
Managers.PackagesImageManager.Instance.Init();
var imagePack = Managers.PackagesImageManager.Instance;
var tileType = Managers.DefineManager.Instance.QueryDefinesByType<TileDef>();
for (var i = 1; i < tileType.Length; i++)
for (var i = 0; i < tileType.Length; i++)
{
tileID.Add(tileType[i].name, i);
}
@ -57,7 +128,7 @@ namespace Map
foreach (var keyVal in mappingTableDef.tileDict)
{
var key = keyVal.Key;
var val=keyVal.Value;
var val = keyVal.Value;
var parts = key.Split('_');
if (parts.Length != 4)
{
@ -67,14 +138,15 @@ namespace Map
}
if (!(tileID.TryGetValue(parts[0], out var k1) &&
tileID.TryGetValue(parts[1], out var k2) &&
tileID.TryGetValue(parts[2], out var k3) &&
tileID.TryGetValue(parts[3], out var k4)))
tileID.TryGetValue(parts[1], out var k2) &&
tileID.TryGetValue(parts[2], out var k3) &&
tileID.TryGetValue(parts[3], out var k4)))
{
var packName = Managers.DefineManager.Instance.GetDefinePackageName(mappingTableDef);
Debug.LogError($"来自{packName}定义的TileMappingTableDef键值{key}中存在未定义的瓦片名称");
continue;
}
var sprite = imagePack.GetSprite(val);
if (sprite == null)
{
@ -82,14 +154,17 @@ namespace Map
Debug.LogError($"来自{packName}定义的TileMappingTableDef键值{val}中存在未定义的图片名称");
continue;
}
if (tileToTileBaseMapping.ContainsKey((k1, k2, k3, k4)))
{
var packName = Managers.DefineManager.Instance.GetDefinePackageName(mappingTableDef);
Debug.LogWarning($"来自{packName}定义的TileMappingTableDef键值{(k1, k2, k3, k4)}存在重复索引,将忽略重复项");
continue;
}
var tile = LoadTile(sprite);
tileToTileBaseMapping.Add((k1, k2, k3, k4), tile);
tileToTileBaseMapping[(k1, k2, k3, k4)] = tile;
tileBaseMapping[val] = tile;
}
}
}

View File

@ -28,17 +28,17 @@
<!-- 0 + (2 * 4) = 8 -->
<Grass_Dirt_Dirt_Dirt value="GrassDirt_15"/>
<!-- 3 + (3 * 4) = 15 -->
<Dirt_Grass_Dirt_Grass value="GrassDirt_4"/>
<Dirt_Grass_Dirt_Grass value="GrassDirt_1"/>
<!-- 1 + (0 * 4) = 1 -->
<Grass_Dirt_Grass_Dirt value="GrassDirt_11"/>
<!-- 3 + (2 * 4) = 11 -->
<Dirt_Dirt_Grass_Grass value="GrassDirt_12"/>
<Dirt_Dirt_Grass_Grass value="GrassDirt_3"/>
<!-- 3 + (0 * 4) = 3 -->
<Grass_Grass_Dirt_Dirt value="GrassDirt_9"/>
<!-- 1 + (2 * 4) = 9 -->
<Dirt_Grass_Grass_Grass value="GrassDirt_5"/>
<!-- 1 + (1 * 4) = 5 -->
<Grass_Dirt_Grass_Grass value="GrassDirt_8"/>
<Grass_Dirt_Grass_Grass value="GrassDirt_2"/>
<!-- 2 + (0 * 4) = 2 -->
<Grass_Grass_Dirt_Grass value="GrassDirt_10"/>
<!-- 2 + (2 * 4) = 10 -->