diff --git a/302/Assets/Scenes/DefaultGameScene.unity b/302/Assets/Scenes/DefaultGameScene.unity index eeba3a3..24ec5d6 100644 --- a/302/Assets/Scenes/DefaultGameScene.unity +++ b/302/Assets/Scenes/DefaultGameScene.unity @@ -43759,9 +43759,9 @@ MonoBehaviour: - {fileID: 5650449145146738954, guid: 11a50fb479ce40a4698c9b8f9816f567, type: 3} - {fileID: 3233071982878084982, guid: 5156428cd2b781d4dabf6a30befa7685, type: 3} - {fileID: 5605359256125054964, guid: 48c8f10abe45bef4098efae902701f34, type: 3} - checkSpecificAnomaly: 0 + checkSpecificAnomaly: 1 checkIntersect: 0 - SpecificAnomalyNum: 0 + SpecificAnomalyNum: 22 currentAnomalyInstance: {fileID: 8678062959089499939, guid: 6aadfcd777444a24180cf51012c6e89c, type: 3} --- !u!4 &1964216256 Transform: diff --git a/302/Assets/Scripts/SpecificAnomalyManager/Anomaly22Manager.cs b/302/Assets/Scripts/SpecificAnomalyManager/Anomaly22Manager.cs index 63ede01..6348493 100644 --- a/302/Assets/Scripts/SpecificAnomalyManager/Anomaly22Manager.cs +++ b/302/Assets/Scripts/SpecificAnomalyManager/Anomaly22Manager.cs @@ -120,7 +120,7 @@ private IEnumerator TriggerRandomTileShakeAndFallWithInterval() tileScript.shakeSound = shakeSound; tileScript.TriggerShakeAndFall(); } - yield return new WaitForSeconds(0.5f); + yield return new WaitForSeconds(0.3f); } if (!isPlayerDead) // totalSeconds가 다 지날 때까지 생존 시 { @@ -133,6 +133,7 @@ private IEnumerator RestoreAllTiles() { float duration = 1f; // Duration for the animation (1 second) float elapsedTime = 0f; + // Store the original positions of all tiles Dictionary originalPositions = new Dictionary(); foreach (var tile in floorTiles) @@ -142,23 +143,38 @@ private IEnumerator RestoreAllTiles() originalPositions[tile] = tile.position; } } - // Animate the tiles back to y = 0 over the duration + + // Calculate reversed target positions + Dictionary reversedPositions = new Dictionary(); + foreach (var tile in originalPositions.Keys) + { + float targetY = (tile == platformTile) ? -0.2f * (3f / 5f) : 0.21f * (3f / 5f); + reversedPositions[tile] = new Vector3(originalPositions[tile].x, targetY, originalPositions[tile].z); + } + + // Animate the tiles back to reversed positions over the duration while (elapsedTime < duration) { elapsedTime += Time.deltaTime; - float t = elapsedTime / duration; // Normalized time [0, 1] + float t = Mathf.Clamp01(elapsedTime / duration); // Normalize t between 0 and 1 + foreach (var tile in originalPositions.Keys) { Vector3 startPos = originalPositions[tile]; - Vector3 targetPos = new Vector3(startPos.x, 0f, startPos.z); + Vector3 targetPos = reversedPositions[tile]; + tile.position = Vector3.Lerp(startPos, targetPos, t); } + yield return null; // Wait for the next frame } - // Ensure all tiles are precisely at y = 0 at the end of the animation - foreach (var tile in originalPositions.Keys) + + // Snap tiles to their exact target Y positions + foreach (var tile in reversedPositions.Keys) { - tile.position = new Vector3(tile.position.x, 0f, tile.position.z); + Vector3 finalPos = reversedPositions[tile]; + tile.position = new Vector3(tile.position.x, finalPos.y, tile.position.z); + // Remove the Anomaly22_tile component if it exists Anomaly22_tile tileScript = tile.GetComponent(); if (tileScript != null)