From 82cc6bd447a9eefa2bdc1e21e93938d95213755a Mon Sep 17 00:00:00 2001 From: wangguan <wangguan@kt007.com> Date: Thu, 17 Dec 2020 09:41:11 +0800 Subject: [PATCH] 连杀BUG --- Assets/Scripts/TowerDefense/UI/HUD/EndlessGameUI.cs | 229 +++++++++++++++++++++++++++++++++++++++------------------ 1 files changed, 156 insertions(+), 73 deletions(-) diff --git a/Assets/Scripts/TowerDefense/UI/HUD/EndlessGameUI.cs b/Assets/Scripts/TowerDefense/UI/HUD/EndlessGameUI.cs index 1183068..8c1d17c 100644 --- a/Assets/Scripts/TowerDefense/UI/HUD/EndlessGameUI.cs +++ b/Assets/Scripts/TowerDefense/UI/HUD/EndlessGameUI.cs @@ -350,6 +350,25 @@ return null; } + /// <summary> + /// 根据塔位索引位置,查找位置上是否有对应的塔防数据。 + /// </summary> + /// <param name="x"></param> + /// <param name="y"></param> + /// <returns></returns> + public int GetTowerNum() + { + int num = 0; + foreach (Tower lt in m_listTower) + { + if (lt.gridPosition.y == 0 || lt.gridPosition.y == 1) + { + num++; + } + } + return num; + } + public bool towerInList(Tower t) { return m_listTower.Contains(t); @@ -643,7 +662,7 @@ if ((m_GridPosition.x >= 0) && (m_GridPosition.y >= 0)) { - if (m_CurrentArea.isFreeAtackPos(m_GridPosition.x, m_GridPosition.y)) + if ((m_CurrentArea as TowerPlacementGridEndless).isFreeAtackPos(m_GridPosition.x, m_GridPosition.y)) { return true; } @@ -724,7 +743,7 @@ if (sTower && sTower != towerToMove) { - if (towerToMove && sTower.towerFeature == EFeatureTower.NULL && towerToMove.towerFeature == EFeatureTower.NULL && sTower.bInAttackMode && towerToMove.bInAttackMode) + if (towerToMove) return true; } } @@ -793,7 +812,9 @@ PlayUpgradeEffect(m_listTower[i]); } } + GameConfig.IsUpgradeTowerLevel = true; UpdateMinLevelArr(); + EndlessRandomTower.instance.UpdateDescDisplay(); } /// <summary> @@ -1027,18 +1048,18 @@ if (m_CurrentArea != null && m_CurrentArea is TowerPlacementGridEndless) { checkTowerPlaceTower = isFreeAttackGridOnDrag(pointerInfo); + //下面是为了设置一个虚拟的塔 if (checkTowerPlaceTower != null) { + Debug.Log(checkTowerPlaceTower.name); + if (m_CurrentTower.controller.towerFeature == EFeatureTower.NULL) { if (checkTowerPlaceTower.bInAttackMode) { //鼠标检测到了塔 (m_CurrentArea as TowerPlacementGridEndless).CheckCanPlaceUpdate(m_GridPosition.x, m_GridPosition.y, false, ""); - - m_CurrentTower.transform.position = (m_CurrentArea as TowerPlacementGridEndless).GridToWorld(m_GridPosition, m_CurrentTower.controller.dimensions); - } else { @@ -1058,24 +1079,11 @@ bInAttackModeTower.CurrentTowerLevel.SetCanPlace(true); } } + } - } - } - else if (m_CurrentTower.controller.towerFeature == EFeatureTower.Skill_Fire || m_CurrentTower.controller.towerFeature == EFeatureTower.Skill_Bomb) - { - //技能宝石没有上阵 - if (bInAttackModeTower == null) - { - bInAttackModeTower = checkTowerPlaceTower; - bInAttackModeTower.CurrentTowerLevel.SetCanPlace(true); - } - else if (bInAttackModeTower != checkTowerPlaceTower) - { - bInAttackModeTower.CurrentTowerLevel.SetCanPlace(false); - bInAttackModeTower = checkTowerPlaceTower; - bInAttackModeTower.CurrentTowerLevel.SetCanPlace(true); - } + m_CurrentTower.transform.position = (m_CurrentArea as TowerPlacementGridEndless).GridToWorld(checkTowerPlaceTower.gridPosition, m_CurrentTower.controller.dimensions); + } } else if ((m_GridPosition.x >= 0) && (m_GridPosition.y >= 0)) @@ -1123,6 +1131,101 @@ TowerPlacementGridEndless dragTowerPlacement; + public void CheckTowerPlaceNew(PointerInfo pointerInfo) + { + //return; + if (m_CurrentArea != null && m_CurrentArea is TowerPlacementGridEndless) + { + if ((m_GridPosition.x >= 0) && (m_GridPosition.y >= 0)) + { + if (m_GridPosition.y == 0 || m_GridPosition.y == 1) + { + //Debug.Log("未上阵区域,不管有没有塔,都强行吸附"); + (m_CurrentArea as TowerPlacementGridEndless).CheckCanPlaceUpdate(m_GridPosition.x, m_GridPosition.y, true, ""); + + m_CurrentTower.transform.position = (m_CurrentArea as TowerPlacementGridEndless).GridToWorld(m_GridPosition, m_CurrentTower.controller.dimensions); + + } + else if (m_GridPosition.y == 2 || m_GridPosition.y == 3) + { + //Debug.Log("已上阵区域,如果是空格子就强行吸附,先判断是否有塔"); + + checkTowerPlaceTower = isFreeAttackGridOnDrag(pointerInfo); + + if (checkTowerPlaceTower != null) + { + //Debug.Log(checkTowerPlaceTower.name); + + if (m_CurrentTower.controller.towerFeature == EFeatureTower.NULL) + { + if (checkTowerPlaceTower.bInAttackMode) + { + //鼠标检测到了塔 + (m_CurrentArea as TowerPlacementGridEndless).CheckCanPlaceUpdate(m_GridPosition.x, m_GridPosition.y, false, ""); + } + else + { + if (!towerToMove.bInAttackMode) + { + //没有上阵 + if (bInAttackModeTower == null) + { + bInAttackModeTower = checkTowerPlaceTower; + bInAttackModeTower.CurrentTowerLevel.SetCanPlace(true); + } + else if (bInAttackModeTower != checkTowerPlaceTower) + { + + bInAttackModeTower.CurrentTowerLevel.SetCanPlace(false); + bInAttackModeTower = checkTowerPlaceTower; + bInAttackModeTower.CurrentTowerLevel.SetCanPlace(true); + } + } + } + m_CurrentTower.transform.position = (m_CurrentArea as TowerPlacementGridEndless).GridToWorld(checkTowerPlaceTower.gridPosition, m_CurrentTower.controller.dimensions); + } + } + else if ((m_CurrentArea as TowerPlacementGridEndless).isFreeAtackPos(m_GridPosition.x, m_GridPosition.y)) + { + //Debug.Log("空格子"); + + (m_CurrentArea as TowerPlacementGridEndless).CheckCanPlaceUpdate(m_GridPosition.x, m_GridPosition.y, true, towerToMove.towerName); + + m_CurrentTower.transform.position = (m_CurrentArea as TowerPlacementGridEndless).GridToWorld(m_GridPosition, m_CurrentTower.controller.dimensions); + + } + else + { + + //Debug.Log($"上阵区域 m_GridPosition:{m_GridPosition.x} {m_GridPosition.y} m_CurrentTower.controller.gridPosition:{m_CurrentTower.controller.gridPosition.x} {m_CurrentTower.controller.gridPosition.y}"); + + if (m_GridPosition == towerToMove.gridPosition) + { + //Debug.Log("在原来的地方"); + + (m_CurrentArea as TowerPlacementGridEndless).CheckCanPlaceUpdate(m_GridPosition.x, m_GridPosition.y, true, towerToMove.towerName); + + m_CurrentTower.transform.position = towerToMove.position; + } + else + { + CloseCanPlace(); + + //Debug.Log("上阵区域,没有开放的塔位"); + } + } + } + } + + } + else + { + dragTowerPlacement.CloseCanPlace(); + + } + } + + /// <summary> /// 目标位置是否是可攻击属性的空塔位 /// </summary> @@ -1135,31 +1238,20 @@ Tower sTower = PickTowerInGrid(pointer); if (sTower != null) { - - // if (towerToMove && sTower.currentLevel == dragTowerLevel && sTower.towerName == towerToMove.towerName) - // { - // //说明可以合成 - // return sTower; - // } - // else - // { - // return null; - // } - if (towerToMove) { - if (towerToMove.bInAttackMode) - { - return sTower; - } - else - { - if (sTower.currentLevel == dragTowerLevel && sTower.towerName == towerToMove.towerName) - { - //说明可以合成 - return sTower; - } - } + return sTower; + // if (towerToMove.bInAttackMode) + // { + // } + // else + // { + // if (sTower.currentLevel == dragTowerLevel && sTower.towerName == towerToMove.towerName) + // { + // //说明可以合成 + // return sTower; + // } + // } } else { @@ -1188,7 +1280,6 @@ /// <param name="pointerInfo"></param> public void onEndTowerDrag(PointerInfo pointerInfo) { - bool bSkill = false; if (temporaryMat != null) { //移动虚像隐藏 @@ -1202,8 +1293,10 @@ } if (m_CurrentTower.controller.towerFeature != EFeatureTower.NULL) - bSkill = true; - + { + Debug.LogError("只能移动3种塔"); + return; + } if (GameConfig.IsNewbie) { bool isCanChange = false; @@ -1229,11 +1322,14 @@ // 判断目标位置是否有Tower且类型和等级一致,如果没有,则GhostTower删除,原Tower显示。 if (isValidateCombineTarget(pointerInfo)) { + //Debug.Log("isValidateCombineTarget"); TryPlaceTower(pointerInfo); EndlessRandomTower.instance.UpdateDescDisplay(); } - else if (isFreeAttackGrid(pointerInfo) && !bSkill) + else if (isFreeAttackGrid(pointerInfo)) { + //Debug.Log("isFreeAttackGrid:" + m_GridPosition); + if (!TryPlaceTower(pointerInfo, false)) { CancelPlaceTower(pointerInfo); @@ -1254,27 +1350,9 @@ } else if (EndlessLevelManager.instanceExists && IsSubstitute(pointerInfo)) { - CheckCanChangePos(pointerInfo); - } - // 当前是Skill塔位的状态. - else if (bSkill) - { - if (SkillPlayEndDrag(pointerInfo)) - { - // 先释放掉当前的Ghost塔防. - CancelGhostPlacement(); + //Debug.Log("IsSubstitute"); - // 删除towerToMove,确保塔防数据不再出现多个 - if (towerToMove != null) - { - delTower(towerToMove); - towerToMove.showTower(true); - towerToMove.Sell(); - towerToMove = null; - } - } - else - CancelPlaceTower(pointerInfo); + CheckCanChangePos(pointerInfo); } else CancelPlaceTower(pointerInfo); @@ -1289,7 +1367,8 @@ if (sTower == null) return false; - if (sTower.bInAttackMode == towerToMove.bInAttackMode) + Debug.Log("开始检测是否可以交换塔"); + //if (sTower.bInAttackMode == towerToMove.bInAttackMode) { IntVector2 v1 = new IntVector2(towerToMove.gridPosition.x, towerToMove.gridPosition.y); IntVector2 v2 = new IntVector2(sTower.gridPosition.x, sTower.gridPosition.y); @@ -1678,6 +1757,7 @@ { if (!isBuilding) return false; + //Debug.Log("开始造塔" + m_GridPosition); // 判断是否格子上重复放置塔防 if (!m_CurrentTower || !IsGhostAtValidPosition()) { @@ -1710,6 +1790,7 @@ CancelGhostPlacement(); return false; } + PlaceGhost(pointer); } return true; @@ -2133,7 +2214,7 @@ m_CurrentArea = placeObj.GetComponent<IPlacementArea>(); dragTowerPlacement = placeObj.GetComponent<IPlacementArea>() as TowerPlacementGridEndless; } - placeObj = GameObject.FindGameObjectWithTag("PlaceTowerOpponent"); + //placeObj = GameObject.FindGameObjectWithTag("PlaceTowerOpponent"); EventCenter.Ins.Add((int)KTGMGemClient.EventType.EndlessHeartAllLose, AllHeartLose); } @@ -2220,7 +2301,6 @@ bool successfulPurchase = EndlessLevelManager.instance.Currency.TryPurchase(cost); if (!successfulPurchase) return false; - EndlessRandomTower.instance.UpdateDescDisplay(); SetUpGhostTower(tow); //Debug.Log("设置影子塔防."); m_CurrentTower.Show(); @@ -2293,7 +2373,7 @@ //Debug.Log("没有点中或者点中了UI:" + hasHit.ToString() + "," + uiPointer.overUI.ToString()); return; } - var controller = output.collider.GetComponent<Tower>(); + Tower controller = output.collider.GetComponent<Tower>(); if (controller != null) { // 泡泡禁锢状态不允许拖动 @@ -2572,6 +2652,7 @@ return; } m_GridPosition = m_CurrentArea.WorldToGrid(raycast.point, m_CurrentTower.controller.dimensions); + //Debug.Log("修改了m_GridPosition:" + m_GridPosition); TowerFitStatus fits = m_CurrentArea.Fits(m_GridPosition, m_CurrentTower.controller.dimensions); m_CurrentTower.Show(); @@ -2622,10 +2703,12 @@ /// <exception cref="InvalidOperationException">If we're not in the correct state</exception> protected void PlaceGhost(UIPointer pointer) { - MoveGhost(pointer); + //MoveGhost(pointer); if (m_CurrentArea != null) { + //Debug.Log("开始检测PlaceGhost:" + m_GridPosition); + TowerFitStatus fits = m_CurrentArea.Fits(m_GridPosition, m_CurrentTower.controller.dimensions); if (fits == TowerFitStatus.Fits) -- Gitblit v1.9.1