From: FruitieX Date: Wed, 1 Sep 2010 19:27:51 +0000 (+0300) Subject: falloff on electro primary to nerf it a little, testing and early balance stats hint... X-Git-Tag: xonotic-v0.1.0preview~317^2~1^2 X-Git-Url: https://git.rm.cloudns.org/?a=commitdiff_plain;h=d9781106e436a28a7da089440b189a28c3645867;p=xonotic%2Fxonotic-data.pk3dir.git falloff on electro primary to nerf it a little, testing and early balance stats hint that it's way overpowered --- diff --git a/balance25.cfg b/balance25.cfg index 0250978c3b..8110998bd8 100644 --- a/balance25.cfg +++ b/balance25.cfg @@ -318,6 +318,9 @@ set g_balance_electro_primary_refire 0.6 set g_balance_electro_primary_animtime 0.3 set g_balance_electro_primary_ammo 2 set g_balance_electro_primary_range 0 +set g_balance_electro_primary_falloff_mindist 255 // 0.3 * radius +set g_balance_electro_primary_falloff_maxdist 850 +set g_balance_electro_primary_falloff_halflifedist 425 set g_balance_electro_secondary_damage 50 set g_balance_electro_secondary_spread 0.05 set g_balance_electro_secondary_edgedamage 0 diff --git a/balanceNexSVN.cfg b/balanceNexSVN.cfg index 0f8a8dc35c..f039f3b925 100644 --- a/balanceNexSVN.cfg +++ b/balanceNexSVN.cfg @@ -318,6 +318,9 @@ set g_balance_electro_primary_refire 0.6 set g_balance_electro_primary_animtime 0.3 set g_balance_electro_primary_ammo 2 set g_balance_electro_primary_range 0 +set g_balance_electro_primary_falloff_mindist 255 // 0.3 * radius +set g_balance_electro_primary_falloff_maxdist 850 +set g_balance_electro_primary_falloff_halflifedist 425 set g_balance_electro_secondary_damage 50 set g_balance_electro_secondary_spread 0.05 set g_balance_electro_secondary_edgedamage 0 diff --git a/balanceSamual.cfg b/balanceSamual.cfg index e70157872e..b52c31ffca 100644 --- a/balanceSamual.cfg +++ b/balanceSamual.cfg @@ -318,6 +318,9 @@ set g_balance_electro_primary_refire 0.6 set g_balance_electro_primary_animtime 0.3 set g_balance_electro_primary_ammo 2 set g_balance_electro_primary_range 0 +set g_balance_electro_primary_falloff_mindist 255 // 0.3 * radius +set g_balance_electro_primary_falloff_maxdist 850 +set g_balance_electro_primary_falloff_halflifedist 425 set g_balance_electro_secondary_damage 50 set g_balance_electro_secondary_spread 0.05 set g_balance_electro_secondary_edgedamage 0 diff --git a/balanceXonotic.cfg b/balanceXonotic.cfg index 9515b2b054..bbcee6aa1a 100644 --- a/balanceXonotic.cfg +++ b/balanceXonotic.cfg @@ -318,6 +318,9 @@ set g_balance_electro_primary_refire 0.03333333 set g_balance_electro_primary_animtime 0.03333333 set g_balance_electro_primary_ammo 7 set g_balance_electro_primary_range 800 +set g_balance_electro_primary_falloff_mindist 255 // 0.3 * radius +set g_balance_electro_primary_falloff_maxdist 850 +set g_balance_electro_primary_falloff_halflifedist 425 set g_balance_electro_secondary_damage 25 set g_balance_electro_secondary_spread 0 set g_balance_electro_secondary_edgedamage 0 diff --git a/qcsrc/server/w_electro.qc b/qcsrc/server/w_electro.qc index a98c5a9153..fa9034c136 100644 --- a/qcsrc/server/w_electro.qc +++ b/qcsrc/server/w_electro.qc @@ -226,7 +226,7 @@ void lgbeam_think() makevectors(self.owner.v_angle); - float dt; + float dt, f; dt = frametime; if not(self.owner.items & IT_UNLIMITED_WEAPON_AMMO) { @@ -243,8 +243,11 @@ void lgbeam_think() { vector force; force = w_shotdir * cvar("g_balance_electro_primary_force") + '0 0 1' * cvar("g_balance_electro_primary_force_up"); - Damage (trace_ent, self.owner, self.owner, cvar("g_balance_electro_primary_damage") * dt, WEP_ELECTRO, trace_endpos, force * dt); - Damage_RecordDamage(self.owner, WEP_ELECTRO, cvar("g_balance_electro_primary_damage") * dt); + + f = ExponentialFalloff(cvar("g_balance_electro_primary_falloff_mindist"), cvar("g_balance_electro_primary_falloff_maxdist"), cvar("g_balance_electro_primary_falloff_halflifedist"), vlen(WarpZone_UnTransformOrigin(WarpZone_trace_transform, trace_endpos) - w_shotorg)); + + Damage (trace_ent, self.owner, self.owner, cvar("g_balance_electro_primary_damage") * dt * f, WEP_ELECTRO, trace_endpos, force * dt); + Damage_RecordDamage(self.owner, WEP_ELECTRO, cvar("g_balance_electro_primary_damage") * dt * f); } W_Plasma_TriggerCombo(trace_endpos, cvar("g_balance_electro_primary_comboradius"), self.owner);