From d0d16cb02df4aa9ed4afd38c8e4352596ac6fd2b Mon Sep 17 00:00:00 2001 From: MaxDorob Date: Wed, 11 Oct 2023 01:55:46 +0600 Subject: [PATCH] VPE collision improvment (for recent commit) --- .../Compatibility/VanillaPsycastExpanded.cs | 21 ++++++++++++++----- 1 file changed, 16 insertions(+), 5 deletions(-) diff --git a/Source/CombatExtended/Compatibility/VanillaPsycastExpanded.cs b/Source/CombatExtended/Compatibility/VanillaPsycastExpanded.cs index dd2a1197eb..fa967ea993 100644 --- a/Source/CombatExtended/Compatibility/VanillaPsycastExpanded.cs +++ b/Source/CombatExtended/Compatibility/VanillaPsycastExpanded.cs @@ -26,11 +26,25 @@ public IEnumerable GetCompatList() } public void Install() { - //BlockerRegistry.RegisterImpactSomethingCallback(ImpactSomething); //temp commented + BlockerRegistry.RegisterImpactSomethingCallback(ImpactSomething); //temp commented + BlockerRegistry.RegisterBeforeCollideWithCallback(BeforeCollideWith); BlockerRegistry.RegisterCheckForCollisionCallback(Hediff_Overshield_InterceptCheck); BlockerRegistry.RegisterCheckForCollisionBetweenCallback(AOE_CheckIntercept); } + private static bool BeforeCollideWith(ProjectileCE projectile, Thing collideWith) + { + if (collideWith is Pawn pawn) + { + var interceptor = pawn.health.hediffSet.hediffs.FirstOrDefault(x => x.GetType() == typeof(Hediff_Overshield)) as Hediff_Overshield; + if (interceptor != null) + { + OnIntercepted(interceptor, projectile); + return true; + } + } + return false; + } private static bool ImpactSomething(ProjectileCE projectile, Thing launcher) { return Hediff_Overshield_InterceptCheck(projectile, projectile.ExactPosition.ToIntVec3(), launcher); @@ -41,11 +55,8 @@ public static bool Hediff_Overshield_InterceptCheck(ProjectileCE projectile, Int .SelectMany(x => x.health.hediffSet.hediffs) .Where(x => x.GetType() == typeof(Hediff_Overshield)).Cast()) { - var def = projectile.def; - Vector3 lastExactPos = projectile.LastPos; - var newExactPos = projectile.ExactPosition; - var result = interceptor.pawn != launcher && (interceptor.pawn.Position == cell || PreventTryColideWithPawn(projectile, interceptor.pawn, newExactPos)); + var result = interceptor.pawn != launcher && (interceptor.pawn.Position == cell); if (result) { OnIntercepted(interceptor, projectile);