123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687 |
- 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 CommonAI.Data;
- namespace XmdsCommonSkill.Plugin.PassiveSkills.Remedy
- {
- /// <summary>
- /// boss通用被动 - 重击(boss的普攻几率眩晕2s)
- /// </summary>
- class Boss_90107 : XmdsPassiveSkillBase
- {
- public static readonly int ID = 90107;
- private static readonly int Buff_ID = (int)XmdsBuffBase.XmdsBuffList.YUN_XUAN;
- private int mUUID_1 = 0;
- public static XmdsSkillValue dmgValue; // 伤害系数
- public static XmdsSkillValue valueSet1; // 眩晕概率
- public static XmdsSkillValue valueSet2; // 眩晕时间
- public override int SkillID {get{return ID;}}
- protected override void OnInit(GameSkill skillInfo, XmdsVirtual owner)
- {
- // Buff3修改
- var pack3 = XmdsBuffFactory.GetInstance().GetXmdsBuffPack(Buff_ID);
- pack3.mBuffTemplate.LifeTimeMS = valueSet2.GetValue();
- var bt3 = pack3.mBuffTemplate;
- pack3.BindTemplateAndDispose();
- owner.RegistSendBuff(bt3);
- }
- protected override void OnInitOver(XmdsVirtual unit, GameSkill info)
- {
- int baseSkillID = unit.SkillHelper.GetBaseSkillID();
- if (baseSkillID > 0)
- {
- mUUID_1 = unit.RegistOnHitOther(OnHandleHitOther, new GameSkill(unit.SkillHelper.GetBaseSkillID()));
- }
- else
- {
- log.Error("Boss_90107没有普攻 : " + unit.mUnit.Info.ID);
- }
- }
- private float OnHandleHitOther(float damage, XmdsVirtual hitted, XmdsVirtual attacker, AttackSource source,
- ref XmdsVirtual.AtkResult result, DamageType damageType, GameSkill skill, ref bool isEndDispatch)
- {
- float extDamage = damage * XmdsUnitProp.PER * dmgValue.GetValue();
- if (attacker.mUnit.RandomN.Next(0, 10000) < valueSet1.GetValue())
- {
- hitted.mUnit.AddBuff(Buff_ID, attacker.mUnit);
- }
- return damage + extDamage;
- }
- protected override void OnInitSkillParam()
- {
- XmdsSkillData data = XmdsDataMgr.GetInstance().GetXmdsSkillData(ID);
- InitData(data, out dmgValue, XmdsSkillData.XmdsSkillDataKey.DmgRate);
- InitData(data, out valueSet1, XmdsSkillData.XmdsSkillDataKey.ValueSet);
- InitData(data, out valueSet2, XmdsSkillData.XmdsSkillDataKey.ValueSet2);
- }
- protected override void OnDispose(XmdsVirtual owner)
- {
- if(mUUID_1 > 0)
- {
- owner.UnRegistOnHitOther(mUUID_1);
- }
- }
- }
- }
|