123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- using CommonAI.Zone.Instance;
- using CommonAI.Zone.Formula;
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using XmdsCommon.Plugin;
- using XmdsCommonServer.Plugin;
- using XmdsCommonServer.Plugin.XmdsSkillTemplate.Skills;
- using XmdsCommonServer.Plugin.XmdsSkillTemplate.DamageCalculator;
- using CommonLang;
- using CommonAI.Data;
- namespace XmdsCommonSkill.Plugin.Buffs
- {
-
-
-
- public class XmdsBuff_AttackRoundAddHP : XmdsBuffBase
- {
- public int totalAddHp = -1;
- public float damageToHp = 0.1f;
- public int AddHPRange = 5;
-
- private XmdsVirtual buffSender = null;
- private int mHandleUUID = 0;
- public override int GetAbilityID()
- {
- return (int)XmdsCommon.Plugin.XmdsBuffProperties.XmdsBuffAbility.Attack_RoundAddHP;
- }
- public override void CopyTo(UnitBuff other)
- {
- var ret = other as XmdsBuff_AttackRoundAddHP;
- ret.totalAddHp = this.totalAddHp;
- ret.damageToHp = this.damageToHp;
- ret.AddHPRange = this.AddHPRange;
- base.CopyTo(other);
- }
- protected override void OnBuffBegin(XmdsCommonServer.Plugin.XmdsVirtual hitter, XmdsCommonServer.Plugin.XmdsVirtual attacker, InstanceUnit.BuffState state)
- {
- this.buffSender = attacker;
-
- mHandleUUID = hitter.RegistOnHitOther(OnHandleHitOther, null);
- }
- protected override void OnBuffEnd(XmdsCommonServer.Plugin.XmdsVirtual hitter, InstanceUnit.BuffState state, bool replace)
- {
-
- hitter.UnRegistOnHitOther(mHandleUUID);
- }
-
- private float OnHandleHitOther(float damage, XmdsVirtual hitted, XmdsVirtual attacker, AttackSource source,
- ref XmdsVirtual.AtkResult result, DamageType damageType, GameSkill skill, ref bool isEndDispatch)
- {
- int AddHP = CUtils.CastInt(damage * this.damageToHp);
- if (AddHP > 0)
- {
- if(totalAddHp != -1)
- {
- AddHP = Math.Min(AddHP, totalAddHp);
- totalAddHp -= AddHP;
- if(totalAddHp <= 0)
- {
- hitted.mUnit.removeBuff(this.BindBuffID);
- }
- }
-
-
- using (var list = ListObjectPool<InstanceUnit>.AllocAutoRelease())
- {
- attacker.mUnit.Parent.getObjectsRoundRange<InstanceUnit>(
- (obj, dx, dy, dr) =>
- {
- var u = obj as InstanceUnit;
-
- if (attacker.IsAllies(u.Virtual as XmdsVirtual, true, true))
- {
- return CMath.includeRoundPoint(dx, dy, dr, u.X, u.Y);
- }
- return false;
- },
- attacker.mUnit.X,
- attacker.mUnit.Y,
- AddHPRange,
- list, attacker.mUnit.AoiStatus);
- if(list.Count > 0)
- {
- int avgAdd = Math.Max(1, AddHP / list.Count);
-
- for (int i = 0; i < list.Count; i++)
- {
- list[i].AddHP(avgAdd, attacker.mUnit);
- }
- }
- }
- }
- return damage;
- }
- protected override void OnDispose()
- {
- base.OnDispose();
- }
- }
- }
|