From ab19d04c3e48254318351662987d42753a3204d9 Mon Sep 17 00:00:00 2001 From: InvalidArgument3 Date: Tue, 11 Jun 2024 17:33:51 -0500 Subject: [PATCH 1/5] ignore explosion damage (this is dumb) --- .../AsteroidEntities/AsteroidEntity.cs | 12 +++++++++++- .../Scripts/DynamicAsteroids/AsteroidSettings.cs | 2 +- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs index d9e20b8b..c0ac5ff8 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs @@ -203,6 +203,16 @@ public void OnDestroy() public bool DoDamage(float damage, MyStringHash damageSource, bool sync, MyHitInfo? hitInfo = null, long attackerId = 0, long realHitEntityId = 0, bool shouldDetonateAmmo = true, MyStringHash? extraInfo = null) { + // Define the explosion damage type + var explosionDamageType = MyStringHash.GetOrCompute("Explosion"); + + // Check if the damage source is explosion + if (damageSource == explosionDamageType) + { + Log.Info($"Ignoring explosion damage for asteroid. Damage source: {damageSource.String}"); + return false; // Ignore the damage + } + _integrity -= damage; Log.Info($"DoDamage called with damage: {damage}, damageSource: {damageSource.String}, attackerId: {attackerId}, realHitEntityId: {realHitEntityId}, new integrity: {_integrity}"); @@ -269,7 +279,7 @@ private void Init(Vector3D position, float size, Vector3D initialVelocity, Aster } Size = size; - _integrity = AsteroidSettings.BaseIntegrity * Size; + _integrity = AsteroidSettings.BaseIntegrity + Size; Log.Info($"Attempting to load model: {ModelString}"); diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs index 7edb9989..f7004adc 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs @@ -24,7 +24,7 @@ public static class AsteroidSettings public static double PlatinumWeight = 0.01; public static double UraniniteWeight = 0.01; - public static float BaseIntegrity = 1f; + public static float BaseIntegrity = 1000f; public static float MinAsteroidSize = 50f; public static float MaxAsteroidSize = 250f; public static float MinSubChunkSize = 5f; From 54d5c616a38859b718325a615d7b1dba640bfb89 Mon Sep 17 00:00:00 2001 From: InvalidArgument3 Date: Tue, 11 Jun 2024 18:13:19 -0500 Subject: [PATCH 2/5] disabling explosion damage "works" but is not a solution --- .../AsteroidEntities/AsteroidEntity.cs | 13 ++++++------- .../Scripts/DynamicAsteroids/AsteroidSettings.cs | 3 ++- 2 files changed, 8 insertions(+), 8 deletions(-) diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs index c0ac5ff8..9846aa86 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs @@ -207,11 +207,11 @@ public bool DoDamage(float damage, MyStringHash damageSource, bool sync, MyHitIn var explosionDamageType = MyStringHash.GetOrCompute("Explosion"); // Check if the damage source is explosion - if (damageSource == explosionDamageType) - { - Log.Info($"Ignoring explosion damage for asteroid. Damage source: {damageSource.String}"); - return false; // Ignore the damage - } + //if (damageSource == explosionDamageType) + //{ + // Log.Info($"Ignoring explosion damage for asteroid. Damage source: {damageSource.String}"); + // return false; // Ignore the damage + //} _integrity -= damage; Log.Info($"DoDamage called with damage: {damage}, damageSource: {damageSource.String}, attackerId: {attackerId}, realHitEntityId: {realHitEntityId}, new integrity: {_integrity}"); @@ -339,8 +339,7 @@ private void CreatePhysics() Physics.Enabled = true; Physics.Activate(); } - - + private Vector3D RandVector() { var theta = MainSession.I.Rand.NextDouble() * 2.0 * Math.PI; diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs index f7004adc..e86113ec 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidSettings.cs @@ -11,6 +11,7 @@ public static class AsteroidSettings public static int AsteroidVelocityBase = 0; public static double VelocityVariability = 0; public static double AngularVelocityVariability = 0; + //TODO: DespawnRangeFromPlayer public static double IceWeight = 0.80; public static double StoneWeight = 0.11; @@ -24,7 +25,7 @@ public static class AsteroidSettings public static double PlatinumWeight = 0.01; public static double UraniniteWeight = 0.01; - public static float BaseIntegrity = 1000f; + public static float BaseIntegrity = 1f; public static float MinAsteroidSize = 50f; public static float MaxAsteroidSize = 250f; public static float MinSubChunkSize = 5f; From a66d493c33db2fed8bd76ad9732c0aaa3c234699 Mon Sep 17 00:00:00 2001 From: InvalidArgument3 Date: Tue, 11 Jun 2024 18:30:18 -0500 Subject: [PATCH 3/5] make asteroid sub-chunks count toward the total --- .../AsteroidEntities/AsteroidEntity.cs | 10 +++++++++- .../AsteroidEntities/AsteroidSpawner.cs | 2 +- .../Data/Scripts/DynamicAsteroids/MainSession.cs | 2 +- 3 files changed, 11 insertions(+), 3 deletions(-) diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs index 9846aa86..c6966fd0 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidEntity.cs @@ -123,6 +123,9 @@ public void SplitAsteroid() MyAPIGateway.Multiplayer.SendMessageToOthers(32000, removalMessageBytes); } + // Remove from asteroid list + MainSession.I._spawner._asteroids.Remove(this); + Close(); return; } @@ -136,6 +139,9 @@ public void SplitAsteroid() var subChunk = CreateAsteroid(newPos, newSize, newVelocity, Type); subChunk.Physics.AngularVelocity = newAngularVelocity; + // Add sub-chunks to the asteroid list + MainSession.I._spawner._asteroids.Add(subChunk); + // Send a network message to clients if (MyAPIGateway.Utilities.IsDedicated || !MyAPIGateway.Session.IsServer) { @@ -153,10 +159,12 @@ public void SplitAsteroid() MyAPIGateway.Multiplayer.SendMessageToOthers(32000, removalMessageBytes); } + // Remove from asteroid list + MainSession.I._spawner._asteroids.Remove(this); + Close(); } - private int GetRandomDropAmount(AsteroidType type) { switch (type) diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs index 6890aab8..8ff7f7a0 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs @@ -8,7 +8,7 @@ namespace DynamicAsteroids.AsteroidEntities { - internal class AsteroidSpawner + public class AsteroidSpawner { public List _asteroids; private const double MinDistanceFromVanillaAsteroids = 1000; // 1 km diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/MainSession.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/MainSession.cs index 04b4a0dc..7b119896 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/MainSession.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/MainSession.cs @@ -19,7 +19,7 @@ public class MainSession : MySessionComponentBase public Random Rand = new Random(); - private AsteroidSpawner _spawner = new AsteroidSpawner(); + public AsteroidSpawner _spawner = new AsteroidSpawner(); #region Base Methods From 2c172072a0771134b9a8d7a5acee650e7849ea7a Mon Sep 17 00:00:00 2001 From: InvalidArgument3 Date: Tue, 11 Jun 2024 18:57:04 -0500 Subject: [PATCH 4/5] Update AsteroidSpawner.cs --- .../AsteroidEntities/AsteroidSpawner.cs | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs index 8ff7f7a0..e54e3b67 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs @@ -59,15 +59,12 @@ public void UpdateTick() { Vector3D playerPosition = player.GetPosition(); - if (!AsteroidSettings.PlayerCanSeeRings(playerPosition)) - { - continue; - } - foreach (var asteroid in _asteroids.ToArray()) { - if (Vector3D.DistanceSquared(asteroid.PositionComp.GetPosition(), playerPosition) > - AsteroidSettings.AsteroidSpawnRadius * AsteroidSettings.AsteroidSpawnRadius * 1.1) + double distanceSquared = Vector3D.DistanceSquared(asteroid.PositionComp.GetPosition(), playerPosition); + + // Remove asteroids that are outside the spherical spawn radius + if (distanceSquared > AsteroidSettings.AsteroidSpawnRadius * AsteroidSettings.AsteroidSpawnRadius) { Log.Info($"Removing asteroid at {asteroid.PositionComp.GetPosition()} due to distance from player"); _asteroids.Remove(asteroid); From 5a37831c09edc055f94723c09aa0687f134bad64 Mon Sep 17 00:00:00 2001 From: InvalidArgument3 Date: Tue, 11 Jun 2024 18:57:12 -0500 Subject: [PATCH 5/5] Update AsteroidSpawner.cs --- .../AsteroidEntities/AsteroidSpawner.cs | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs index e54e3b67..15c87497 100644 --- a/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs +++ b/Dynamic Asteroids/Data/Scripts/DynamicAsteroids/AsteroidEntities/AsteroidSpawner.cs @@ -79,13 +79,26 @@ public void UpdateTick() } int asteroidsSpawned = 0; + int spawnAttempts = 0; + int maxAttempts = 50; // Limit the number of attempts to find valid positions + while (_asteroids.Count < AsteroidSettings.MaxAsteroidCount && asteroidsSpawned < 10) { + if (spawnAttempts >= maxAttempts) + { + Log.Info("Reached maximum spawn attempts, breaking out of loop to prevent freeze"); + break; + } + Vector3D newPosition; do { newPosition = playerPosition + RandVector() * AsteroidSettings.AsteroidSpawnRadius; - } while (Vector3D.DistanceSquared(newPosition, playerPosition) < MinDistanceFromPlayer * MinDistanceFromPlayer); + spawnAttempts++; + } while (Vector3D.DistanceSquared(newPosition, playerPosition) < MinDistanceFromPlayer * MinDistanceFromPlayer && spawnAttempts < maxAttempts); + + if (spawnAttempts >= maxAttempts) + break; Vector3D newVelocity; if (!AsteroidSettings.CanSpawnAsteroidAtPoint(newPosition, out newVelocity))