MapData改为static

This commit is contained in:
daixiawu 2025-07-16 15:41:43 +08:00
parent 149095dfa3
commit feb87eb444
11 changed files with 154 additions and 154 deletions

View File

@ -452,7 +452,7 @@ namespace RuntimeData
{
var main = GameObject.Find("Main").GetComponent<Main>();
//如果既是非AI的真实mapdata又是玩家的各自
if (main.MapData == map && player.Id == map.PlayerMap.SelfPlayerId)
if (Main.MapData == map && player.Id == map.PlayerMap.SelfPlayerId)
{
var faithPanel = GameObject.Find("UICanvas/TopBarPanel/FaithPanel/Icon").transform;
var startPos = Table.Instance.GridToWorld(this);

View File

@ -682,7 +682,7 @@ namespace Logic.Action
//临时做法用来播放VFX,获取Main理应向MapData写入一个VFX的RenderMark的
var main = GameObject.Find("Main").GetComponent<Main>();
if (actionParams.MapData == main.MapData && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
if (actionParams.MapData == Main.MapData && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
{
var v1 = Table.Instance.GridToWorld(actionParams.GridData);
actionParams.MapData.GetGridDataByCityId(city.Id, out var g2);
@ -794,7 +794,7 @@ namespace Logic.Action
//如果是玩家,执行一整套播放动画的逻辑
//临时做法用来播放VFX,获取Main理应向MapData写入一个VFX的RenderMark的
var main = GameObject.Find("Main").GetComponent<Main>();
if (main.MapData == actionParams.MapData && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
if (Main.MapData == actionParams.MapData && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
{
var v1 = Table.Instance.GridToWorld(actionParams.GridData);
actionParams.MapData.GetGridDataByCityId(cityData.Id, out var g2);
@ -995,7 +995,7 @@ namespace Logic.Action
//如果是玩家,执行一整套播放动画的逻辑
//临时做法用来播放VFX,获取Main理应向MapData写入一个VFX的RenderMark的
var main = GameObject.Find("Main").GetComponent<Main>();
if (main.MapData == actionParams.MapData && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
if (Main.MapData == actionParams.MapData && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
//目前只有市场这种情况,只播放建筑建设的雾效,其他啥都不播放
if (cityExp == 0)
{
@ -1428,7 +1428,7 @@ namespace Logic.Action
//临时做法用来播放VFX,获取Main理应向MapData写入一个VFX的RenderMark的
var main = GameObject.Find("Main").GetComponent<Main>();
if (main.MapData == actionParams.MapData)// && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
if (Main.MapData == actionParams.MapData)// && actionParams.PlayerData.Id == actionParams.MapData.PlayerMap.SelfPlayerData.Id)
{
var v1 = Table.Instance.GridToWorld(gridData);
int score = GetCost() * 5;
@ -1887,7 +1887,7 @@ namespace Logic.Action
//临时做法用来播放VFX,获取Main理应向MapData写入一个VFX的RenderMark的
var main = GameObject.Find("Main").GetComponent<Main>();
if (actionParams.MapData == main.MapData)
if (actionParams.MapData == Main.MapData)
{
var v1 = Table.Instance.GridToWorld(gridData);
@ -1936,7 +1936,7 @@ namespace Logic.Action
gridData.RenderMark = true;
ret = true;
var main = GameObject.Find("Main").GetComponent<Main>();
if (actionParams.MapData == main.MapData && actionParams.MapData.PlayerMap.SelfPlayerId == playerData.Id)
if (actionParams.MapData == Main.MapData && actionParams.MapData.PlayerMap.SelfPlayerId == playerData.Id)
{
var v1 = Table.Instance.GridToWorld(gridData);
@ -1961,7 +1961,7 @@ namespace Logic.Action
//临时做法用来播放VFX,获取Main理应向MapData写入一个VFX的RenderMark的
var main = GameObject.Find("Main").GetComponent<Main>();
if (actionParams.MapData == main.MapData && actionParams.MapData.PlayerMap.SelfPlayerId == playerData.Id)
if (actionParams.MapData == Main.MapData && actionParams.MapData.PlayerMap.SelfPlayerId == playerData.Id)
{
var v1 = Table.Instance.GridToWorld(gridData);

View File

@ -89,19 +89,19 @@ namespace Logic.Editor
_main = obj.GetComponent<Main>();
if (!_main) return;
}
if (_main?.MapData == null) return;
if (Main.MapData == null) return;
EditorGUILayout.BeginHorizontal();
foreach (var player in _main.MapData.PlayerMap.PlayerDataList)
foreach (var player in Main.MapData.PlayerMap.PlayerDataList)
{
if (player.Id == _main.MapData.PlayerMap.SelfPlayerId) continue;
if (player.Id == Main.MapData.PlayerMap.SelfPlayerId) continue;
if (InspectorUtils.InspectorButtonWithTextWidth($"玩家{player.Id}")) _player = player;
}
EditorGUILayout.EndHorizontal();
var selfCity = new HashSet<CityData>();
_main.MapData.GetCityDataListByPlayerId(_main.MapData.PlayerMap.SelfPlayerId, selfCity);
Main.MapData.GetCityDataListByPlayerId(Main.MapData.PlayerMap.SelfPlayerId, selfCity);
EditorGUILayout.BeginHorizontal();
foreach (var city in _main.MapData.CityMap.CityList)
foreach (var city in Main.MapData.CityMap.CityList)
{
if (selfCity.Contains(city)) continue;
if (InspectorUtils.InspectorButtonWithTextWidth($"城市{city.Id}")) _city = city;
@ -111,7 +111,7 @@ namespace Logic.Editor
private void OnShowPlayerInfo()
{
if (_main?.MapData == null || _player == null) return;
if (Main.MapData == null || _player == null) return;
MainEditor.Instance.GetPlayerStrategy(_player.Id, out var playerStrategy, out var targetIdSet);
EditorGUILayout.BeginHorizontal();
@ -129,7 +129,7 @@ namespace Logic.Editor
EditorGUILayout.BeginVertical(_redBoxStyle);
InspectorUtils.InspectorTextWidthRich($"<b>城市信息</b>");
var selfCity = new HashSet<CityData>();
_main.MapData.GetCityDataListByPlayerId(_player.Id, selfCity);
Main.MapData.GetCityDataListByPlayerId(_player.Id, selfCity);
foreach (var city in selfCity)
{
MainEditor.Instance.GetCityStrategy(city.Id, out var strategy);
@ -144,7 +144,7 @@ namespace Logic.Editor
EditorGUILayout.BeginVertical(_redBoxStyle);
InspectorUtils.InspectorTextWidthRich($"<b>小兵信息</b>");
var selfUnits = new HashSet<UnitData>();
_main.MapData.GetUnitDataListByPlayerId(_player.Id, selfUnits);
Main.MapData.GetUnitDataListByPlayerId(_player.Id, selfUnits);
foreach (var unit in selfUnits)
{
MainEditor.Instance.GetUnitStrategy(unit.Id, unit.LegionId, _player.Id, out var strategy, out var target, out var type);
@ -158,7 +158,7 @@ namespace Logic.Editor
private void OnShowCityInfo()
{
if (_main?.MapData == null || _city == null) return;
if (Main.MapData == null || _city == null) return;
var actions = MainEditor.Instance.GetCityActions(_city.Id);
if (actions == null || actions.Count == 0) return;

View File

@ -142,13 +142,13 @@ namespace Logic
return;
Vector3 mousePosition = Camera.main.ScreenToWorldPoint(Input.mousePosition);
Vector2Int cellPosition = Table.Instance.WorldToGrid(mousePosition);
if (cellPosition.x >= _main.MapData.MapConfig.Width || cellPosition.x < 0 || cellPosition.y < 0 ||
cellPosition.y >= _main.MapData.MapConfig.Height)
if (cellPosition.x >= Main.MapData.MapConfig.Width || cellPosition.x < 0 || cellPosition.y < 0 ||
cellPosition.y >= Main.MapData.MapConfig.Height)
return;
// 获取点击的地块类型
_main.MapData.GridMap.GetGridDataByPos(cellPosition.x, cellPosition.y, out var clickedTerrain);
Main.MapData.GridMap.GetGridDataByPos(cellPosition.x, cellPosition.y, out var clickedTerrain);
// 根据点击的地形类型执行某些操作(例如,显示消息)
_main.MapInteractionLogic.OnTileClicked(_main.MapData,clickedTerrain);
_main.MapInteractionLogic.OnTileClicked(Main.MapData,clickedTerrain);
}
if (Input.GetKeyDown(KeyCode.S))
@ -158,16 +158,16 @@ namespace Logic
if (Input.GetKeyDown(KeyCode.BackQuote))
{
_main.MapData.PlayerMap.SelfPlayerData.PlayerWealth += 1000;
Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth += 1000;
}
if (Input.GetKeyDown(KeyCode.T))
{
if (Input.GetKey(KeyCode.LeftShift) || Input.GetKey(KeyCode.RightShift))
{
_main.MapData.PlayerMap.SelfPlayerData.PlayerWealth += 1000;
Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth += 1000;
foreach (TechType techType in System.Enum.GetValues(typeof(TechType)))
Main.PlayerLogic.ResearchTech(_main.MapData, _main.MapData.PlayerMap.SelfPlayerData,techType,0);
Main.PlayerLogic.ResearchTech(Main.MapData, Main.MapData.PlayerMap.SelfPlayerData,techType,0);
UIManager.Instance.TechTreeUI.TechTreeUIDataRenderMark = true;
}
else

View File

@ -53,7 +53,7 @@ namespace Logic
public void Update()
{
_gameStateDict[_curState].Update();
Main.PlayerLogic.CalcAllPlayerScore(_main.MapData);
Main.PlayerLogic.CalcAllPlayerScore(Main.MapData);
}
@ -102,17 +102,17 @@ namespace Logic
public override void Enter()
{
_curPlayer = _gameLogic.Main.MapData.PlayerMap.SelfPlayerData;
_curPlayer = Main.MapData.PlayerMap.SelfPlayerData;
Turn++;
foreach(var playerData in _gameLogic.Main.MapData.PlayerMap.PlayerDataList)
Main.PlayerLogic.StartNextTurn(_gameLogic.Main.MapData, playerData);
foreach (var unitData in _gameLogic.Main.MapData.UnitMap.UnitList)
Main.UnitLogic.StartNextTurn(_gameLogic.Main.MapData, unitData);
foreach(var playerData in Main.MapData.PlayerMap.PlayerDataList)
Main.PlayerLogic.StartNextTurn(Main.MapData, playerData);
foreach (var unitData in Main.MapData.UnitMap.UnitList)
Main.UnitLogic.StartNextTurn(Main.MapData, unitData);
_gameLogic.Main.MapData.PlayerMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.CityMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.UnitMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.GridMap.OnTurnStart(_gameLogic.Main.MapData);
Main.MapData.PlayerMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.CityMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.UnitMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.GridMap.OnTurnStart(Main.MapData);
AudioManager.Instance.InGameOnTurnStart();
@ -124,8 +124,8 @@ namespace Logic
//gameLogic.EndTurn();
//uiManager.EndTurn();
PlayerPrefs.SetInt("Archive", 1);
MapData.SaveMapData(_gameLogic.Main.MapData);
AchievementDataManager.Instance.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
MapData.SaveMapData(Main.MapData);
AchievementDataManager.Instance.OnTurnStart(Main.MapData, _curPlayer);
#if GAME_AUTO_DEBUG
_aiLogic = new AILogic();
@ -139,18 +139,18 @@ namespace Logic
_gameLogic.Main.InputLogic.LockInput();
// TODO endturn逻辑要重新梳理
Main.PlayerLogic.EndThisTurn(_gameLogic.Main.MapData, _gameLogic.Main.MapData.PlayerMap.SelfPlayerData);
Main.PlayerLogic.EndThisTurn(Main.MapData, Main.MapData.PlayerMap.SelfPlayerData);
//处理当前每一个unit的回合结束前自动行为。每一个选手回合结束自动回血是在这个阶段出发的
foreach (var unitData in _gameLogic.Main.MapData.UnitMap.UnitList)
if(_gameLogic.Main.MapData.GetPlayerDataByUnitId(unitData.Id,out var player)
foreach (var unitData in Main.MapData.UnitMap.UnitList)
if(Main.MapData.GetPlayerDataByUnitId(unitData.Id,out var player)
&& player.Id == _curPlayer.Id)
Main.UnitLogic.UnitEndTurn(_gameLogic.Main.MapData, unitData);
Main.UnitLogic.UnitEndTurn(Main.MapData, unitData);
_gameLogic.Main.MapData.PlayerMap.OnTurnEnd(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.CityMap.OnTurnEnd(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.UnitMap.OnTurnEnd(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.GridMap.OnTurnEnd(_gameLogic.Main.MapData);
Main.MapData.PlayerMap.OnTurnEnd(Main.MapData, _curPlayer);
Main.MapData.CityMap.OnTurnEnd(Main.MapData, _curPlayer);
Main.MapData.UnitMap.OnTurnEnd(Main.MapData, _curPlayer);
Main.MapData.GridMap.OnTurnEnd(Main.MapData);
}
public override void Update()
@ -165,11 +165,11 @@ namespace Logic
if (_aiLogic.AILogicState == AILogicState.Prepare)
{
_curPlayer.PlayerWealth += (int)_curPlayer.Turn / 10;
_gameLogic.Main.MapData.PlayerMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.CityMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.UnitMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.GridMap.OnTurnStart(_gameLogic.Main.MapData);
_aiLogic.StartAILogic(_gameLogic.Main.MapData, _curPlayer);
Main.MapData.PlayerMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.CityMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.UnitMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.GridMap.OnTurnStart(Main.MapData);
_aiLogic.StartAILogic(Main.MapData, _curPlayer);
}
_aiLogic.Update();
@ -197,9 +197,9 @@ namespace Logic
UIManager.Instance.AIPlayingHint.SetActive(true);
Turn++;
_aiPlayers.Clear();
foreach (var playerData in _gameLogic.Main.MapData.PlayerMap.PlayerDataList)
foreach (var playerData in Main.MapData.PlayerMap.PlayerDataList)
{
if (playerData.Id == _gameLogic.Main.MapData.PlayerMap.SelfPlayerId) continue;
if (playerData.Id == Main.MapData.PlayerMap.SelfPlayerId) continue;
_aiPlayers.Add(playerData);
}
@ -237,14 +237,14 @@ namespace Logic
// AI 难度加钱
int tt = 0;
if (_curPlayer.Turn < 10)
tt = (int)_gameLogic.Main.MapData.MapConfig.AIDiff;
_curPlayer.PlayerWealth += ((int)_curPlayer.Turn / 10) * (int)_gameLogic.Main.MapData.MapConfig.AIDiff + tt;
tt = (int)Main.MapData.MapConfig.AIDiff;
_curPlayer.PlayerWealth += ((int)_curPlayer.Turn / 10) * (int)Main.MapData.MapConfig.AIDiff + tt;
_gameLogic.Main.MapData.PlayerMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.CityMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.UnitMap.OnTurnStart(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.GridMap.OnTurnStart(_gameLogic.Main.MapData);
_aiLogic.StartAILogic(_gameLogic.Main.MapData, _curPlayer);
Main.MapData.PlayerMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.CityMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.UnitMap.OnTurnStart(Main.MapData, _curPlayer);
Main.MapData.GridMap.OnTurnStart(Main.MapData);
_aiLogic.StartAILogic(Main.MapData, _curPlayer);
}
_aiLogic.Update();
@ -253,10 +253,10 @@ namespace Logic
private void TryTurnEndCurPlayerTurn()
{
if (_curPlayer == null) return;
_gameLogic.Main.MapData.PlayerMap.OnTurnEnd(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.CityMap.OnTurnEnd(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.UnitMap.OnTurnEnd(_gameLogic.Main.MapData, _curPlayer);
_gameLogic.Main.MapData.GridMap.OnTurnEnd(_gameLogic.Main.MapData);
Main.MapData.PlayerMap.OnTurnEnd(Main.MapData, _curPlayer);
Main.MapData.CityMap.OnTurnEnd(Main.MapData, _curPlayer);
Main.MapData.UnitMap.OnTurnEnd(Main.MapData, _curPlayer);
Main.MapData.GridMap.OnTurnEnd(Main.MapData);
}
}
@ -301,7 +301,7 @@ namespace Logic
Turn++;
PlayerPrefs.SetInt("Archive", 0);
var record = _gameLogic.Main.MapData.ExportGameRecord();
var record = Main.MapData.ExportGameRecord();
GameRecordManager.Instance.AddRecord(record);
}

View File

@ -44,7 +44,7 @@ namespace Logic
//--------------------------------new data type--------------------------------
[NonSerialized] public MapConfig MapConfig;
[NonSerialized] public MapData MapData;
[NonSerialized] public static MapData MapData;
//各Logic模块的引用
//一级logicAI和input

View File

@ -30,7 +30,7 @@ namespace Logic
public void CancelAllHighlight() //专门用来应对BottomInfoUI的CloseButton的函数点击close的时候先调用这个函数通知interaction处理好信息再关闭bottominfo
{
foreach (var gridData in _main.MapData.GridMap.GridList)
foreach (var gridData in Main.MapData.GridMap.GridList)
{
gridData.CityBorderRenderMark = false;
var gridRenderer = MapRenderer.Instance.ROGridMap[gridData.Id];
@ -42,7 +42,7 @@ namespace Logic
gridRenderer.SetSelectHighlight(false);
gridRenderer.SetMoveHighlight(false);
}
foreach (var unitData in _main.MapData.UnitMap.UnitList)
foreach (var unitData in Main.MapData.UnitMap.UnitList)
{
if (!MapRenderer.Instance.ROUnitMap.ContainsKey(unitData.Id)) continue;
var unitRenderer = MapRenderer.Instance.ROUnitMap[unitData.Id];
@ -65,7 +65,7 @@ namespace Logic
return;
}
bool hasUnit = _main.MapData.GetUnitDataByGid(gridData.Id,out var unitData);
bool hasUnit = Main.MapData.GetUnitDataByGid(gridData.Id,out var unitData);
//Debug.Log(hasUnit);
var roGrid = MapRenderer.Instance.ROGridMap[gridData.Id];
//如果这次点击有unit
@ -87,7 +87,7 @@ namespace Logic
else if (roUnit.IsAttackHighlight)
{
CancelAllHighlight();
Main.UnitLogic.Attack(_main.MapData, MapRenderer.Instance.SelectUnitData, unitData);
Main.UnitLogic.Attack(Main.MapData, MapRenderer.Instance.SelectUnitData, unitData);
UIManager.Instance.BottomInfoUI.UIBottomInfoStatus = false;
}
//如果是选择角色
@ -105,7 +105,7 @@ namespace Logic
UIManager.Instance.BottomInfoUI.UIBottomInfoIsGrid = false;
UIManager.Instance.BottomInfoUI.UIBottomInfoStatusObjectId = unitData.Id;
//如果是selfplayer的unit显示可操作区域
if (Main.UnitLogic.CheckIsSelfPlayer(_main.MapData, unitData.Id))
if (Main.UnitLogic.CheckIsSelfPlayer(Main.MapData, unitData.Id))
MapRenderer.Instance.SetUnitAllMoveAttackTargetHighlight(unitData.Id);
@ -122,7 +122,7 @@ namespace Logic
else if (roGrid.IsMoveHighlight)
{
CancelAllHighlight();
Main.UnitLogic.MoveTo(_main.MapData, MapRenderer.Instance.SelectUnitData, gridData,MoveType.ActiveMove);
Main.UnitLogic.MoveTo(Main.MapData, MapRenderer.Instance.SelectUnitData, gridData,MoveType.ActiveMove);
//切换相机镜头
MapRenderer.Instance.CameraController.CameraFocusOnGrid(gridData);
UIManager.Instance.BottomInfoUI.UIBottomInfoStatus = false;
@ -149,7 +149,7 @@ namespace Logic
if (_mapData.GetCityDataByTerritoryGid(gridData.Id, out var city))
{
if(_mapData.GetGridDataByCityId(city.Id,out var gridTmp)
&& _main.MapData.PlayerMap.SelfPlayerData.Sight.CheckIsInSight(gridTmp.Id))
&& Main.MapData.PlayerMap.SelfPlayerData.Sight.CheckIsInSight(gridTmp.Id))
MapRenderer.Instance.ROGridMap[gridTmp.Id].SetBounceAnim();
}

View File

@ -225,7 +225,7 @@ namespace TH1Renderer
// 更新视野
if (_currentTargetGridData != null)
// 调用UpdateSightByRadius更新视野
Main.PlayerLogic.UpdateSightByRadius(_main.MapData, _main.MapData.PlayerMap.SelfPlayerData, _currentTargetGridData,
Main.PlayerLogic.UpdateSightByRadius(Main.MapData, Main.MapData.PlayerMap.SelfPlayerData, _currentTargetGridData,
_currentTargetGridData.Feature == TerrainFeature.Mountain? 2 : 1);
// 检查是否需要继续移动
@ -250,7 +250,7 @@ namespace TH1Renderer
// 延迟一小段时间后继续移动
Timer.Instance.TimerRegister(this, () => {
MoveExplorerToLeastVisibleDirection(_currentTargetGridData, _main.MapData.PlayerMap.SelfPlayerData);
MoveExplorerToLeastVisibleDirection(_currentTargetGridData, Main.MapData.PlayerMap.SelfPlayerData);
}, delayTime);
}
else if (_explorerMoveCount >= _explorerMaxMoves && _temporaryExplorer != null)
@ -295,7 +295,7 @@ namespace TH1Renderer
List<uint> toRemove = new List<uint>();
foreach (var roUnitId in ROUnitMap.Keys)
{
if (!_main.MapData.UnitMap.GetUnitDataByUnitId(roUnitId, out var unitData))
if (!Main.MapData.UnitMap.GetUnitDataByUnitId(roUnitId, out var unitData))
toRemove.Add(roUnitId);
}
@ -328,23 +328,23 @@ namespace TH1Renderer
//当gridMap出现新的对象时新建对象
public void RenderUpdateGridMap()
{
foreach (var gridData in _main.MapData.GridMap.GridList)
foreach (var gridData in Main.MapData.GridMap.GridList)
{
ROGridMap[gridData.Id] =
new GridRenderer(_gridPrefab, _gridRenderMap, gridData.Id, _main.MapData, _main);
new GridRenderer(_gridPrefab, _gridRenderMap, gridData.Id, Main.MapData, _main);
}
}
//当cityMap出现新的对象时新建对象
public void RenderUpdateCityMap()
{
foreach (var cityData in _main.MapData.CityMap.CityList)
foreach (var cityData in Main.MapData.CityMap.CityList)
if(!ROCityInfoMap.ContainsKey(cityData.Id))
{
//生成城镇图像
RenderUpdateCityBuildings(cityData.Id);
//生成城镇名称和人口条
ROCityInfoMap[cityData.Id] = new CityInfoRenderer(_cityInfoPrefab,_cityInfoRenderMap,cityData.Id,_main.MapData,_main);
ROCityInfoMap[cityData.Id] = new CityInfoRenderer(_cityInfoPrefab,_cityInfoRenderMap,cityData.Id,Main.MapData,_main);
cityData.CityInfoRenderMark = true;
}
}
@ -352,11 +352,11 @@ namespace TH1Renderer
//当unitMap出现新的对象时新建对象
public void RenderUpdateUnitMap()
{
foreach (var unitData in _main.MapData.UnitMap.UnitList)
foreach (var unitData in Main.MapData.UnitMap.UnitList)
if(!ROUnitMap.ContainsKey(unitData.Id))
{
//生成单位图像
ROUnitMap[unitData.Id] = new UnitRenderer(_unitPrefab,_unitRenderMap,unitData.Id,_main.MapData,_main);
ROUnitMap[unitData.Id] = new UnitRenderer(_unitPrefab,_unitRenderMap,unitData.Id,Main.MapData,_main);
}
}
@ -379,23 +379,23 @@ namespace TH1Renderer
public void RenderUpdateBorders() //更新全地图的所有边界
{
foreach (var gridData in _main.MapData.GridMap.GridList)
foreach (var gridData in Main.MapData.GridMap.GridList)
ROGridMap[gridData.Id].UpdateBorder();
}
private void RenderUpdateCityBuildings(uint cityId) //更新主城建筑的渲染
{
_main.MapData.GetGridIdByCityId(cityId, out var gridId);
Main.MapData.GetGridIdByCityId(cityId, out var gridId);
ROGridMap[gridId].RenderUpdateCityBuilding(cityId);
}
public bool SetUnitAllMoveAttackTargetHighlight(uint uid) //渲染所有可移动位置的高亮,其中可以攻击的位置要标红,如果是自己人或者敌人在移动范围内但是不在攻击范围内,则不能高亮
{
bool ret = false;
Main.UnitLogic.CalcUnitMoveInfo(_main.MapData, uid);
_main.MapData.UnitMap.GetUnitDataByUnitId(uid, out var unitData);
_main.MapData.GetGridDataByUnitId(uid, out var gridData);
_main.MapData.GetPlayerDataByUnitId(uid, out var playerData);
Main.UnitLogic.CalcUnitMoveInfo(Main.MapData, uid);
Main.MapData.UnitMap.GetUnitDataByUnitId(uid, out var unitData);
Main.MapData.GetGridDataByUnitId(uid, out var gridData);
Main.MapData.GetPlayerDataByUnitId(uid, out var playerData);
//unitLogic.DebugOutputMoveInfo();
int r = Mathf.Max((Table.Instance.UnitTypeDataAssets.GetUnitTypeInfo(unitData.UnitType,unitData.GiantType,out var info)?info.MoveRange:0) * 2,
Table.Instance.UnitTypeDataAssets.GetUnitTypeInfo(unitData.UnitType,unitData.GiantType,out var info2)?info2.AttackRange:0);
@ -414,13 +414,13 @@ namespace TH1Renderer
r = (int)(_mapData.MapConfig.Width > _mapData.MapConfig.Height ? _mapData.MapConfig.Width : _mapData.MapConfig.Height);
}
var targetGridDataList = _main.MapData.GridMap.GetAroundGridDataSet(r,r,gridData);
var targetGridDataList = Main.MapData.GridMap.GetAroundGridDataSet(r,r,gridData);
foreach(var targetGridData in targetGridDataList)
{
//如果不在视野 跳过
if (!playerData.Sight.CheckIsInSight(targetGridData.Id)) continue;
var sig = Main.UnitLogic.CheckUnitCanMoveOrAttack(_main.MapData, unitData, targetGridData);
var sig = Main.UnitLogic.CheckUnitCanMoveOrAttack(Main.MapData, unitData, targetGridData);
//如果是移动目标且unit的MP>0
if ((sig == MoveAttackType.Move || sig == MoveAttackType.MoveToPort ||
sig == MoveAttackType.MoveAshore) && unitData.MP > 0)
@ -432,18 +432,18 @@ namespace TH1Renderer
if (sig == MoveAttackType.Attack && unitData.AP > 0)
{
ret = true;
if (!_main.MapData.GetUnitDataByGid(targetGridData.Id, out var unitDataB))
if (!Main.MapData.GetUnitDataByGid(targetGridData.Id, out var unitDataB))
continue;
//如果可以杀死,做一个提示
if (Table.Instance.CalcDamage(_main.MapData, unitData, unitDataB) >= unitDataB.Health)
if (Table.Instance.CalcDamage(Main.MapData, unitData, unitDataB) >= unitDataB.Health)
{
targetGridData.VFXRenderMarkDieHintStart = true;
//0代表这是杀死提示
targetGridData.VFXRenderMarkDieHintStartParam = 0;
}
else if(Main.UnitLogic.CanCounter(_main.MapData, unitData, unitDataB) &&
Table.Instance.CalcDamage(_main.MapData, unitData, unitDataB,true) >= unitData.Health)
else if(Main.UnitLogic.CanCounter(Main.MapData, unitData, unitDataB) &&
Table.Instance.CalcDamage(Main.MapData, unitData, unitDataB,true) >= unitData.Health)
{
targetGridData.VFXRenderMarkDieHintStart = true;
//1代表这是被杀死提示
@ -458,19 +458,19 @@ namespace TH1Renderer
//返回一个Unit是否存在移动或者攻击目标
public bool CheckUnitHasMoveAttackTarget(uint uid)
{
Main.UnitLogic.CalcUnitMoveInfo(_main.MapData, uid);
_main.MapData.UnitMap.GetUnitDataByUnitId(uid, out var unitData);
_main.MapData.GetGridDataByUnitId(uid, out var gridData);
_main.MapData.GetPlayerDataByUnitId(uid, out var playerData);
Main.UnitLogic.CalcUnitMoveInfo(Main.MapData, uid);
Main.MapData.UnitMap.GetUnitDataByUnitId(uid, out var unitData);
Main.MapData.GetGridDataByUnitId(uid, out var gridData);
Main.MapData.GetPlayerDataByUnitId(uid, out var playerData);
//unitLogic.DebugOutputMoveInfo();
int r = Mathf.Max((Table.Instance.UnitTypeDataAssets.GetUnitTypeInfo(unitData.UnitType,unitData.GiantType,out var info)?info.MoveRange:0) * 2,
Table.Instance.UnitTypeDataAssets.GetUnitTypeInfo(unitData.UnitType,unitData.GiantType,out var info2)?info2.AttackRange:0);
var targetGridDataList = _main.MapData.GridMap.GetAroundGridDataSet(r,r,gridData);
var targetGridDataList = Main.MapData.GridMap.GetAroundGridDataSet(r,r,gridData);
foreach(var targetGridData in targetGridDataList)
{
//如果不在视野 跳过
if (!playerData.Sight.CheckIsInSight(targetGridData.Id)) continue;
var sig = Main.UnitLogic.CheckUnitCanMoveOrAttack(_main.MapData, unitData, targetGridData);
var sig = Main.UnitLogic.CheckUnitCanMoveOrAttack(Main.MapData, unitData, targetGridData);
//如果是移动目标且unit的MP>0
if ((sig == MoveAttackType.Move || sig == MoveAttackType.MoveToPort ||
sig == MoveAttackType.MoveAshore) && unitData.MP > 0)
@ -508,14 +508,14 @@ namespace TH1Renderer
public void CreateTemporaryExplorer(GridData gridData, float maxDuration)
{
// 获取玩家数据 - 使用领土所属关系获取
if (!_main.MapData.GetPlayerDataByTerritoryGridId(gridData.Id, out var playerData))
if (!Main.MapData.GetPlayerDataByTerritoryGridId(gridData.Id, out var playerData))
{
Debug.LogWarning("无法获取玩家数据,无法创建探索者");
return;
}
// 检查是否是自己的玩家
bool isSelfPlayer = playerData.Id == _main.MapData.PlayerMap.SelfPlayerData.Id;
bool isSelfPlayer = playerData.Id == Main.MapData.PlayerMap.SelfPlayerData.Id;
// 如果不是自己的玩家直接计算10步探索并更新视野不进行渲染
if (!isSelfPlayer)
@ -538,7 +538,7 @@ namespace TH1Renderer
Vector2Int currentPos = new Vector2Int(_currentTargetGridData.Pos.X, _currentTargetGridData.Pos.Y);
// 更新视野
Main.PlayerLogic.UpdateSightByRadius(_main.MapData, playerData, _currentTargetGridData, 1);
Main.PlayerLogic.UpdateSightByRadius(Main.MapData, playerData, _currentTargetGridData, 1);
// 保存当前位置作为上一个位置
Vector2Int prevPos = currentPos;
@ -596,7 +596,7 @@ namespace TH1Renderer
if (Table.Instance.UnitTypeDataAssets.GetUnitTypeInfo(explorerUnitType, GiantType.None, out var unitTypeInfo))
{
// 使用GetUnitSpriteByInfo方法获取精灵
if (Table.Instance.UnitTypeDataAssets.GetUnitSpriteByInfo(_main.MapData, unitTypeInfo, playerData, out var sprite))
if (Table.Instance.UnitTypeDataAssets.GetUnitSpriteByInfo(Main.MapData, unitTypeInfo, playerData, out var sprite))
{
spriteRenderer.sprite = sprite;
// 确保精灵渲染器设置正确
@ -631,8 +631,8 @@ namespace TH1Renderer
Vector2Int currentPos = new Vector2Int(startGridData.Pos.X, startGridData.Pos.Y);
// 地图尺寸
int mapWidth = (int)_main.MapData.MapConfig.Width;
int mapHeight = (int)_main.MapData.MapConfig.Height;
int mapWidth = (int)Main.MapData.MapConfig.Width;
int mapHeight = (int)Main.MapData.MapConfig.Height;
// 存储每个方向的最近未探索格子距离
float[] directionMinDistance = new float[8];
@ -654,7 +654,7 @@ namespace TH1Renderer
continue;
// 获取格子数据
if (_main.MapData.GridMap.GetGridDataByPos(x, y, out var gridData))
if (Main.MapData.GridMap.GetGridDataByPos(x, y, out var gridData))
{
// 检查是否在视野中
if (!playerData.Sight.CheckIsInSight(gridData.Id))
@ -706,7 +706,7 @@ namespace TH1Renderer
continue;
// 检查该位置是否可通行
if (!_main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out var nextGridData))
if (!Main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out var nextGridData))
continue;
// 检查地形是否可通行
@ -743,7 +743,7 @@ namespace TH1Renderer
continue;
// 检查该位置是否可通行
if (!_main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out var nextGridData))
if (!Main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out var nextGridData))
continue;
// 检查地形是否可通行
@ -770,13 +770,13 @@ namespace TH1Renderer
Vector2Int targetPos = currentPos + finalMoveDir;
// 获取目标格子数据
if (_main.MapData.GridMap.GetGridDataByPos(targetPos.x, targetPos.y, out var targetGridData))
if (Main.MapData.GridMap.GetGridDataByPos(targetPos.x, targetPos.y, out var targetGridData))
{
// 保存上一个位置
_explorerPreviousPosition = currentPos;
// 更新视野
Main.PlayerLogic.UpdateSightByRadius(_main.MapData, playerData, targetGridData, 1);
Main.PlayerLogic.UpdateSightByRadius(Main.MapData, playerData, targetGridData, 1);
// 获取移动动画时间
float moveTime = 0.5f;
@ -881,8 +881,8 @@ namespace TH1Renderer
Vector2Int currentPos = new Vector2Int(startGridData.Pos.X, startGridData.Pos.Y);
// 地图尺寸
int mapWidth = (int)_main.MapData.MapConfig.Width;
int mapHeight = (int)_main.MapData.MapConfig.Height;
int mapWidth = (int)Main.MapData.MapConfig.Width;
int mapHeight = (int)Main.MapData.MapConfig.Height;
// 存储每个方向的最近未探索格子距离
float[] directionMinDistance = new float[8];
@ -904,7 +904,7 @@ namespace TH1Renderer
continue;
// 获取格子数据
if (_main.MapData.GridMap.GetGridDataByPos(x, y, out var gridData))
if (Main.MapData.GridMap.GetGridDataByPos(x, y, out var gridData))
{
// 检查是否在视野中
if (!playerData.Sight.CheckIsInSight(gridData.Id))
@ -957,7 +957,7 @@ namespace TH1Renderer
// 检查该位置是否可通行
GridData tempNextGridData;
if (!_main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out tempNextGridData))
if (!Main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out tempNextGridData))
continue;
// 检查地形是否可通行
@ -995,7 +995,7 @@ namespace TH1Renderer
// 检查该位置是否可通行
GridData tempNextGridData;
if (!_main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out tempNextGridData))
if (!Main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out tempNextGridData))
continue;
// 检查地形是否可通行
@ -1020,7 +1020,7 @@ namespace TH1Renderer
Vector2Int targetPos = currentPos + finalMoveDir;
// 获取目标格子数据
return _main.MapData.GridMap.GetGridDataByPos(targetPos.x, targetPos.y, out nextGridData);
return Main.MapData.GridMap.GetGridDataByPos(targetPos.x, targetPos.y, out nextGridData);
}
// 新增方法:检查地形是否可通行
@ -1075,12 +1075,12 @@ namespace TH1Renderer
Vector2Int nextPos = currentPos + dirVector;
// 检查位置是否在地图范围内
if (nextPos.x < 0 || nextPos.x >= _main.MapData.MapConfig.Width ||
nextPos.y < 0 || nextPos.y >= _main.MapData.MapConfig.Height)
if (nextPos.x < 0 || nextPos.x >= Main.MapData.MapConfig.Width ||
nextPos.y < 0 || nextPos.y >= Main.MapData.MapConfig.Height)
continue;
// 获取相邻格子数据
if (!_main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out var nextGrid))
if (!Main.MapData.GridMap.GetGridDataByPos(nextPos.x, nextPos.y, out var nextGrid))
continue;
// 如果已经访问过,跳过

View File

@ -190,7 +190,7 @@ public class BottomInfoUI// : MonoBehaviour
continue;
if (actionInfo.VarientIcon)
{
timg.sprite = Table.Instance.QueryActionIconSprite(actionId,_main.MapData.PlayerMap.SelfPlayerData);
timg.sprite = Table.Instance.QueryActionIconSprite(actionId,Main.MapData.PlayerMap.SelfPlayerData);
//timg.SetNativeSize();
//childAction.Find("Image").localScale = new Vector3(0.3f, 0.3f, 0.3f);
//childAction.Find("Image").localPosition = new Vector3(0f, -40f, 0f);
@ -223,13 +223,13 @@ public class BottomInfoUI// : MonoBehaviour
GameObject.Destroy(child.gameObject);
//如果预览的是grid或者city
if (UIBottomInfoIsGrid && _main.MapData.GridMap.GetGridDataByGid(UIBottomInfoStatusObjectId,out var gridData))
if (UIBottomInfoIsGrid && Main.MapData.GridMap.GetGridDataByGid(UIBottomInfoStatusObjectId,out var gridData))
{
//现获取对应的playerData
_main.MapData.GetPlayerDataByTerritoryGridId(UIBottomInfoStatusObjectId, out var player);
Main.MapData.GetPlayerDataByTerritoryGridId(UIBottomInfoStatusObjectId, out var player);
//如果是city
if (_main.MapData.GetCityDataByGid(gridData.Id, out var cityData))
if (Main.MapData.GetCityDataByGid(gridData.Id, out var cityData))
{
@ -415,7 +415,7 @@ public class BottomInfoUI// : MonoBehaviour
//如果是unit
else
{
_main.MapData.UnitMap.GetUnitDataByUnitId(UIBottomInfoStatusObjectId,out var unitData);
Main.MapData.UnitMap.GetUnitDataByUnitId(UIBottomInfoStatusObjectId,out var unitData);
//筹备unit预览格子
GameObject clone = GameObject.Instantiate(MapRenderer.Instance.ROUnitMap[UIBottomInfoStatusObjectId].GetROUnit() as GameObject);
clone.transform.SetParent(_unitPreviewArea.transform);
@ -516,10 +516,10 @@ public class BottomInfoUI// : MonoBehaviour
CommonActionId fakeActionId = clickedItem.GetComponent<ActionIdMono>().ActionId;
//如果钱不够,退出
if (Table.Instance.QueryActionCost(fakeActionId) > _main.MapData.PlayerMap.SelfPlayerData.PlayerWealth)
if (Table.Instance.QueryActionCost(fakeActionId) > Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth)
return;
//如果没科技,退出
if (!_main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckActionCan(fakeActionId))
if (!Main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckActionCan(fakeActionId))
return;
UnitData unitData = null;
CityData cityData = null;
@ -533,28 +533,28 @@ public class BottomInfoUI// : MonoBehaviour
if (fakeActionId.ActionType == CommonActionType.TrainUnit)
{
//如果是城市训练单位
if(_main.MapData.GetCityDataByGid(UIBottomInfoStatusObjectId,out cityData))
if(Main.MapData.GetCityDataByGid(UIBottomInfoStatusObjectId,out cityData))
{
//城市满人口
if (_main.MapData.CheckIfCityFullPopulation(cityData)) return;
if (Main.MapData.CheckIfCityFullPopulation(cityData)) return;
mainObjectType = MainObjectType.City;
}
else if (_main.MapData.GetCityDataByTerritoryGid(UIBottomInfoStatusObjectId, out cityData))
else if (Main.MapData.GetCityDataByTerritoryGid(UIBottomInfoStatusObjectId, out cityData))
{
//城市满人口
if (_main.MapData.CheckIfCityFullPopulation(cityData)) return;
if (Main.MapData.CheckIfCityFullPopulation(cityData)) return;
}
}
_main.MapData.GridMap.GetGridDataByGid(UIBottomInfoStatusObjectId,out gridData);
Main.MapData.GridMap.GetGridDataByGid(UIBottomInfoStatusObjectId,out gridData);
}
else
{
_main.MapData.UnitMap.GetUnitDataByUnitId(UIBottomInfoStatusObjectId,out unitData);
Main.MapData.UnitMap.GetUnitDataByUnitId(UIBottomInfoStatusObjectId,out unitData);
mainObjectType = MainObjectType.Unit;
}
CommonActionParams actionParams = new CommonActionParams(_mapData,
_main.MapData.PlayerMap.SelfPlayerData,unitData,cityData,gridData,null,null,mainObjectType);
Main.MapData.PlayerMap.SelfPlayerData,unitData,cityData,gridData,null,null,mainObjectType);
//Debug.Log($"{actionId.ActionType},{actionId.WonderType},{actionId.ResourceType},{actionId.FeatureType},{actionId.UnitType},{actionId.Vegetation}");
//如果成功执行,隐藏当前面板
@ -604,7 +604,7 @@ public class BottomInfoUI// : MonoBehaviour
if (UIBottomInfoIsGrid)
{
//如果科技未解锁
if (!_main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckActionCan(tActionId))
if (!Main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckActionCan(tActionId))
{
starImage.gameObject.SetActive(false);
textUIComponent.gameObject.SetActive(false);
@ -613,9 +613,9 @@ public class BottomInfoUI// : MonoBehaviour
CityData cityData;
//如果是一个满员城市在grid上生产单位要额外判断一下这个是不是生产单位的行为
if (!_main.MapData.GetCityDataByGid(UIBottomInfoStatusObjectId,out cityData)){
if(_main.MapData.GetCityDataByTerritoryGid(UIBottomInfoStatusObjectId,out cityData)
&& _main.MapData.CheckIfCityFullPopulation(cityData)
if (!Main.MapData.GetCityDataByGid(UIBottomInfoStatusObjectId,out cityData)){
if(Main.MapData.GetCityDataByTerritoryGid(UIBottomInfoStatusObjectId,out cityData)
&& Main.MapData.CheckIfCityFullPopulation(cityData)
&& tActionId.ActionType == CommonActionType.TrainUnit)
{
textUIComponent.color = Color.gray;
@ -625,7 +625,7 @@ public class BottomInfoUI// : MonoBehaviour
}
}
//如果是一个满员城市在市中心生产单位(不用在判断是不是生产单位了)
else if (_main.MapData.CheckIfCityFullPopulation(cityData))
else if (Main.MapData.CheckIfCityFullPopulation(cityData))
{
textUIComponent.color = Color.gray;
backImage.sprite = ActionBGUnavailable;
@ -633,7 +633,7 @@ public class BottomInfoUI// : MonoBehaviour
textUIComponent.gameObject.SetActive(false);
}
//如果钱不够
if (_main.MapData.PlayerMap.SelfPlayerData.PlayerWealth < actionLogic.GetCost())
if (Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth < actionLogic.GetCost())
{
textUIComponent.color = Color.red;
backImage.sprite = ActionBGExpensive;
@ -650,7 +650,7 @@ public class BottomInfoUI// : MonoBehaviour
{
starImage.gameObject.SetActive(true);
textUIComponent.gameObject.SetActive(true);
if (_main.MapData.PlayerMap.SelfPlayerData.PlayerWealth < actionLogic.GetCost())
if (Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth < actionLogic.GetCost())
{
textUIComponent.color = Color.red;
backImage.sprite = ActionBGExpensive;
@ -728,7 +728,7 @@ public class BottomInfoUI// : MonoBehaviour
_debugGrid.SetActive(true);
_debugUnit.SetActive(false);
_debugCity.SetActive(false);
if (!_main.MapData.GridMap.GetGridDataByGid(UIBottomInfoStatusObjectId, out var gridData))
if (!Main.MapData.GridMap.GetGridDataByGid(UIBottomInfoStatusObjectId, out var gridData))
return;
_debugGrid.transform.Find("BuildingLevelValue").GetComponent<TextMeshProUGUI>().text = gridData.buildingLevel.ToString();
@ -740,7 +740,7 @@ public class BottomInfoUI// : MonoBehaviour
_debugCity.SetActive(false);
// 获取单位数据
if (!_main.MapData.UnitMap.GetUnitDataByUnitId(UIBottomInfoStatusObjectId, out var unitData))
if (!Main.MapData.UnitMap.GetUnitDataByUnitId(UIBottomInfoStatusObjectId, out var unitData))
return;
// 填充单位类型信息

View File

@ -133,7 +133,7 @@ public class TechTreeUI
btn.onClick.AddListener(() => SetTechCheckPanelShowHide(true,techType));
//Debug.Log(techType);
//如果该科技已经学习
if (_main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckIfHasTech(techType))
if (Main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckIfHasTech(techType))
{
Image img = techNode.transform.Find("Background").GetComponent<Image>();
img.sprite = ResourceCache.Instance.SpriteCache.TechCompleteBackground;
@ -155,7 +155,7 @@ public class TechTreeUI
}
else
//如果该科技未解锁
if (_main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckIfTechUnsee(techType))
if (Main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckIfTechUnsee(techType))
{
Image img = techNode.Find("Background").GetComponent<Image>();
img.sprite = ResourceCache.Instance.SpriteCache.TechLockedBackground;
@ -164,17 +164,17 @@ public class TechTreeUI
for (int i = 1; i <= techInfo.techActions.Count; i++)
techNode.transform.Find($"ImageGroup/Circle{i}")?.GetComponent<Image>().gameObject.SetActive(false);
}
else //if(_main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckIfTechCanLearn(techType))
else //if(Main.MapData.PlayerMap.SelfPlayerData.TechTree.CheckIfTechCanLearn(techType))
//如果该科技可以学习
{
TextMeshProUGUI costTxt = techNode.Find("costNumber").GetComponent<TextMeshProUGUI>();
//计算目前该tech的学习成本=科技基础cost * 城市数 + 4
var img = techNode.Find("Background").GetComponent<Image>();
img.sprite = ResourceCache.Instance.SpriteCache.TechAvailableBackground;
int tmpCost = (_main.MapData.GetCityCount(_main.MapData.PlayerMap.SelfPlayerData.Id)
int tmpCost = (Main.MapData.GetCityCount(Main.MapData.PlayerMap.SelfPlayerData.Id)
* techInfo.CostLevel + 4);
costTxt.text = tmpCost.ToString();
if (tmpCost > _main.MapData.PlayerMap.SelfPlayerData.PlayerWealth)
if (tmpCost > Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth)
costTxt.color = Color.red;
else costTxt.color = Color.white;
costTxt.gameObject.SetActive(true);
@ -219,10 +219,10 @@ public class TechTreeUI
public void RenderUpdateTechCheckPanel(MapData mapData)
{
TechInfo techInfo = Table.Instance.TechDataAssets.GetTechInfo(_techTypeChoose);
PlayerData selfPlayer = _main.MapData.PlayerMap.SelfPlayerData;
PlayerData selfPlayer = Main.MapData.PlayerMap.SelfPlayerData;
ROTechCheckPanel.SetActive(true);
//记录一下目前点击的techNo和费用以供点击Research时判断使用
_techNoChooseCost = (_main.MapData.GetCityCount(selfPlayer.Id) * techInfo.CostLevel + 4);
_techNoChooseCost = (Main.MapData.GetCityCount(selfPlayer.Id) * techInfo.CostLevel + 4);
TextMeshProUGUI title = ROTechCheckPanel.transform.Find("Title").GetComponent<TextMeshProUGUI>();
TextMeshProUGUI cost = ROTechCheckPanel.transform.Find("Title").transform.Find("costNumber").GetComponent<TextMeshProUGUI>();
@ -330,9 +330,9 @@ public class TechTreeUI
{
//钱不够就不能研发。这种情况理应不会发生
if (_main.MapData.PlayerMap.SelfPlayerData.PlayerWealth < _techNoChooseCost)
if (Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth < _techNoChooseCost)
return;
Main.PlayerLogic.ResearchTech(_main.MapData,_main.MapData.PlayerMap.SelfPlayerData,_techTypeChoose,_techNoChooseCost);
Main.PlayerLogic.ResearchTech(Main.MapData,Main.MapData.PlayerMap.SelfPlayerData,_techTypeChoose,_techNoChooseCost);
SetTechCheckPanelShowHide(false);
RenderUpdateTechTreeData();
UIManager.Instance.TopBarUI.RenderMark = true;

View File

@ -73,9 +73,9 @@ public class TopBarUI
_showTurnHint = false;
ShowTurnHint();
}
_money.text = _main.MapData.PlayerMap.SelfPlayerData.PlayerWealth +
" <color=yellow>+ " + Main.PlayerLogic.GetPlayerStarsPerTurn(_main.MapData, _main.MapData.PlayerMap.SelfPlayerData.Id) + "</color>";
_faith.text = _main.MapData.PlayerMap.SelfPlayerData.PlayerScore.ToString();
_turn.text = _main.MapData.PlayerMap.SelfPlayerData.Turn + "/30";
_money.text = Main.MapData.PlayerMap.SelfPlayerData.PlayerWealth +
" <color=yellow>+ " + Main.PlayerLogic.GetPlayerStarsPerTurn(Main.MapData, Main.MapData.PlayerMap.SelfPlayerData.Id) + "</color>";
_faith.text = Main.MapData.PlayerMap.SelfPlayerData.PlayerScore.ToString();
_turn.text = Main.MapData.PlayerMap.SelfPlayerData.Turn + "/30";
}
}