From 1756411ecb71da337fc1a26ecaf7b7fc6cbe9873 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Iv=C3=A1n=20Cea=20Fontenla?= Date: Tue, 17 Sep 2024 00:56:11 +0200 Subject: [PATCH] Improved aura weapon damage handling --- common/physics.weapon.aura.ts | 3 ++- common/types/weapon.ts | 7 ++++++- server/logic/room-controller.base.ts | 8 ++++++++ 3 files changed, 16 insertions(+), 2 deletions(-) diff --git a/common/physics.weapon.aura.ts b/common/physics.weapon.aura.ts index 7fcf84f..240ea58 100644 --- a/common/physics.weapon.aura.ts +++ b/common/physics.weapon.aura.ts @@ -31,7 +31,8 @@ export function handleAuraWeaponCollisions( type: "weaponCollision", damagedPlayerId: otherPlayer.id, playerId: player.id, - amount: otherPlayerWeaponDamage / elapsedTime, + amount: + (otherPlayerWeaponDamage * weapon.damageMultiplier) / elapsedTime, }); } diff --git a/common/types/weapon.ts b/common/types/weapon.ts index 750bd5c..555f9bd 100644 --- a/common/types/weapon.ts +++ b/common/types/weapon.ts @@ -48,12 +48,17 @@ export type AuraWeapon = BaseWeapon & { * The radius the aura extends from the player. */ radiusFromPlayer: number; + /** + * A multiplier on the damage dealt by the aura to other players. + */ + damageMultiplier: number; }; export function makeAuraWeapon(): AuraWeapon { return { type: "aura", - playerCollisionWeightMultiplier: 3, + playerCollisionWeightMultiplier: 2, radiusFromPlayer: 5, + damageMultiplier: 1.5, }; } diff --git a/server/logic/room-controller.base.ts b/server/logic/room-controller.base.ts index 96ebc80..5b24176 100644 --- a/server/logic/room-controller.base.ts +++ b/server/logic/room-controller.base.ts @@ -113,6 +113,14 @@ export class BaseRoomController implements RoomController { const damagedPlayer = this.room.players[damage.damagedPlayerId]; assert(damagedPlayer, "Damaged player not found"); + if ( + damage.type === "playerCollision" && + damagedPlayer.weapon.type === "aura" + ) { + // Players with aura weapons are immune to player collisions + continue; + } + // TODO: Ignore damage if damaged by same source in the last N milliseconds damagedPlayer.health -= damage.amount;