123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- using CommonAI.Zone.Helper;
- using CommonAI.Zone.Instance;
- using XmdsCommonServer.Plugin;
- using XmdsCommonServer.XLS.Data;
- using XmdsCommonSkill.Plugin.Buffs;
- using System;
- using static CommonAI.Zone.Instance.InstanceUnit;
- using XmdsCommon.Plugin;
- using CommonAI.Zone;
- using XmdsCommonServer.Plugin.Units;
- using CommonAI.Zone.Formula;
- using XmdsCommonSkill.Plugin.Skills;
- using XmdsCommonServer.Plugin.XmdsSkillTemplate.DamageCalculator;
- using XmdsCommonSkill.Plugin.Skills.Magic;
- using CommonLang;
- using CommonAI.Data;
- namespace XmdsCommonSkill.Plugin.PassiveSkills.Magic
- {
- /// <summary>
- /// 小兵被动
- /// </summary>
- public class Other_100004 : XmdsPassiveSkillBase
- {
- /// 技能ID.
- public static readonly int ID = 100004;
- private int mUUID_1 = 0;
- private int timePass = 0;
- private XmdsVirtual mOwner = null;
- public override int SkillID { get { return ID; } }
- protected override void OnInit(GameSkill skillInfo, XmdsVirtual owner)
- {
- this.mOwner = owner;
- mUUID_1 = owner.RegistOnHitDamage(OnHandleHitDmage, skillInfo, true);
- }
- private float OnHandleHitDmage(float damage, XmdsVirtual hitted, XmdsVirtual attacker, AttackSource source,
- ref XmdsVirtual.AtkResult result, DamageType damageType, GameSkill skill, ref bool isEndDispatch)
- {
- return 0;
- }
- protected override void OnUpdate(int intervalMS, bool slowRefresh)
- {
- base.OnUpdate(intervalMS, slowRefresh);
- this.timePass += intervalMS;
- if(this.timePass < 2000)
- {
- return;
- }
- this.timePass = 0;
- //队伍范围内找友军
- int alliesCount = 0, enemyCount = 0;
- using (var list = ListObjectPool<InstanceUnit>.AllocAutoRelease())
- {
- this.mOwner.mUnit.Parent.getObjectsRoundRange<InstanceUnit>(
- (obj, dx, dy, dr) =>
- {
- var u = obj as InstanceUnit;
- if (u.Virtual is XmdsVirtual_Player && CMath.includeRoundPoint(dx, dy, dr, u.X, u.Y))
- {
- //己方单位.
- if (this.mOwner.IsAllies(u.Virtual as XmdsVirtual))
- {
- alliesCount++;
- }
- else
- {
- enemyCount++;
- }
- }
- return true;
- },
- this.mOwner.mUnit.X,
- this.mOwner.mUnit.Y,
- 6,
- list, this.mOwner.mUnit.AoiStatus);
- }
- if(alliesCount > 0 && enemyCount == 0)
- {
- this.mOwner.MirrorProp.MoveSpeed = 1;
- this.mOwner.SycMoveSpeed();
- }
- else
- {
- this.mOwner.MirrorProp.MoveSpeed = 0;
- this.mOwner.SycMoveSpeed();
- }
- }
- protected override void OnDispose(XmdsVirtual owner)
- {
- owner.UnRegistOnHitDamage(mUUID_1);
- }
- }
- }
|