diff options
author | chai <chaifix@163.com> | 2021-01-25 14:28:30 +0800 |
---|---|---|
committer | chai <chaifix@163.com> | 2021-01-25 14:28:30 +0800 |
commit | 6eb915c129fc90c6f4c82ae097dd6ffad5239efc (patch) | |
tree | 7dd2be50edf41f36b60fac84696e731c13afe617 /Client/Assets/Scripts/XMainClient/AttackApplyStun.cs |
+scripts
Diffstat (limited to 'Client/Assets/Scripts/XMainClient/AttackApplyStun.cs')
-rw-r--r-- | Client/Assets/Scripts/XMainClient/AttackApplyStun.cs | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/Client/Assets/Scripts/XMainClient/AttackApplyStun.cs b/Client/Assets/Scripts/XMainClient/AttackApplyStun.cs new file mode 100644 index 00000000..c9c1d808 --- /dev/null +++ b/Client/Assets/Scripts/XMainClient/AttackApplyStun.cs @@ -0,0 +1,48 @@ +using System;
+using XUtliPoolLib;
+
+namespace XMainClient
+{
+ internal class AttackApplyStun : AttackApplyState
+ {
+ public override int GetStateMask()
+ {
+ return XFastEnumIntEqualityComparer<DamageFlag>.ToInt(DamageFlag.DMGFLAG_STUN);
+ }
+
+ public override bool IsApplyState(XEntity entity)
+ {
+ XAttributes attributes = entity.Attributes;
+ double attr = attributes.GetAttr(XAttributeDefine.XAttr_Stun_Total);
+ CombatParamTable.RowData combatParam = XSingleton<XCombat>.singleton.GetCombatParam(attributes.Level);
+ double num = attr / (attr + (double)combatParam.StunBase);
+ bool flag = num > XSingleton<XGlobalConfig>.singleton.StunLimit;
+ if (flag)
+ {
+ num = XSingleton<XGlobalConfig>.singleton.StunLimit;
+ }
+ float num2 = XSingleton<XCommon>.singleton.RandomFloat(0f, 1f);
+ return (double)num2 < num;
+ }
+
+ public override bool IsDefenseState(XEntity entity)
+ {
+ XAttributes attributes = entity.Attributes;
+ double attr = attributes.GetAttr(XAttributeDefine.XAttr_StunResist_Total);
+ CombatParamTable.RowData combatParam = XSingleton<XCombat>.singleton.GetCombatParam(attributes.Level);
+ double num = attr / (attr + (double)combatParam.StunResistBase);
+ bool flag = num > XSingleton<XGlobalConfig>.singleton.StunResistLimit;
+ if (flag)
+ {
+ num = XSingleton<XGlobalConfig>.singleton.StunResistLimit;
+ }
+ float num2 = XSingleton<XCommon>.singleton.RandomFloat(0f, 1f);
+ return (double)num2 < num;
+ }
+
+ public override void ApplyState(XEntity caster, ProjectDamageResult result)
+ {
+ result.SetResult(ProjectResultType.PJRES_STUN);
+ }
+ }
+}
|