BeSkill.lua 79 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489
  1. local Util = require("common.Util")
  2. local CombatBuff = require("combat.CombatBuff")
  3. local CombatDefine = require("combat.CombatDefine")
  4. local CombatImpl = require("combat.CombatImpl")
  5. local Skill = require("combat.Skill")
  6. local CombatObj = require("combat.CombatObj")
  7. local RoleAttr = require("role.RoleAttr")
  8. local RoleDefine = require("role.RoleDefine")
  9. local HeroExcel = require("excel.hero").hero
  10. local SkillExcel = require("excel.skill").skill
  11. -- local BufferExcel = require("excel.buffer").buffer
  12. local FuwenExcel = require("excel.fuwen")
  13. local SkinSkillExcel = require("excel.skin").skill
  14. local BingshuLogic = require("fuwen.BingshuLogic")
  15. local ProjectLogic = require("platform.ProjectLogic")
  16. local HeroDefine = require("hero.HeroDefine")
  17. local WinnerRelicLogic = require("winnerRelic.WinnerRelicLogic")
  18. local TargetMode = require("combat.TargetMode")
  19. local HeroExclusiveWeapon = require("hero.HeroExclusiveWeapon")
  20. local tbFuwenSkillGroupID = {}
  21. local posSortBySpeed = posSortBySpeed or {}
  22. function initBeSkill(obj)
  23. obj.beSkillList = {}
  24. obj.beSkillListTemp = {}
  25. end
  26. function setBeSkillID(obj, skillID, isFuWenSkill, isRelicSkill)
  27. local skillConfig = Skill.GetFinalSkillConfig(obj, skillID)
  28. skillID = skillConfig.id
  29. if obj.beSkillListTemp[skillID] then return end
  30. --local skillConfig = SkillExcel[skillID]
  31. if skillConfig.need > obj.quality then return end
  32. if skillConfig.beSkillType == 0 then return end
  33. if skillConfig.beSkillType == BESKILL_TYPE24 then
  34. obj.beSkillListTemp[BESKILL_TYPE24] = obj.beSkillListTemp[BESKILL_TYPE24] or {}
  35. obj.beSkillListTemp[BESKILL_TYPE24][#obj.beSkillListTemp[BESKILL_TYPE24] + 1] = {
  36. skillID,
  37. skillConfig.beSkillLimit > 0 and skillConfig.beSkillLimit,skillConfig.cd[1] or 0,
  38. skillConfig.cd[2] or 0,
  39. isFuWenSkill or 0, isRelicSkill or 0}
  40. for _,skillID in ipairs(skillConfig.args) do
  41. --local skillConfig = SkillExcel[skillID]
  42. local skillConfig = Skill.GetFinalSkillConfig(obj, skillID)
  43. if not obj.beSkillListTemp[skillID] and skillConfig.need <= obj.quality then
  44. obj.beSkillList[skillConfig.beSkillType] = obj.beSkillList[skillConfig.beSkillType] or {}
  45. obj.beSkillList[skillConfig.beSkillType][#obj.beSkillList[skillConfig.beSkillType] + 1] = {
  46. skillID,
  47. skillConfig.beSkillLimit > 0 and skillConfig.beSkillLimit,skillConfig.cd[1] or 0,
  48. skillConfig.cd[2] or 0,
  49. isFuWenSkill or 0, isRelicSkill or 0}
  50. obj.beSkillListTemp[skillID] = 1
  51. end
  52. end
  53. else
  54. obj.beSkillList[skillConfig.beSkillType] = obj.beSkillList[skillConfig.beSkillType] or {}
  55. obj.beSkillList[skillConfig.beSkillType][#obj.beSkillList[skillConfig.beSkillType] + 1] = {
  56. skillID,
  57. skillConfig.beSkillLimit > 0 and skillConfig.beSkillLimit,skillConfig.cd[1] or 0,
  58. skillConfig.cd[2] or 0,
  59. isFuWenSkill or 0, isRelicSkill or 0}
  60. obj.beSkillListTemp[skillID] = 1
  61. end
  62. end
  63. function setBeSkill(obj, config, skinConf, monsterOutConfig)
  64. local temp = {}
  65. local confBeskillID = skinConf and skinConf.beSkillList or config.beSkillList
  66. for _,skillID in ipairs(confBeskillID) do
  67. setBeSkillID(obj,skillID)
  68. end
  69. -- 加载 赋能技能 这个策划说放到最后
  70. if config.bePvPSkillList and CombatImpl.isPVP == 1 then
  71. for _,skillID in ipairs(config.bePvPSkillList) do
  72. setBeSkillID(obj, skillID)
  73. end
  74. end
  75. -- 怪物组附加的被动技能
  76. if monsterOutConfig then
  77. for _, skillID in ipairs(monsterOutConfig) do
  78. setBeSkillID(obj,skillID)
  79. end
  80. end
  81. -- 符文被动技能
  82. -- 符文技能效果这里 如果有多个同类型的技能 效果不叠加 只取最高等级的那个技能的效果
  83. if obj.fuwen or obj.bingshu then
  84. local hasFuwenBeSkill = nil
  85. Util.initTable(tbFuwenSkillGroupID)
  86. if obj.fuwen then
  87. for i = 1, 2 do
  88. local fuwenGrid = obj.fuwen[i]
  89. if fuwenGrid and fuwenGrid.skill then
  90. for j = 1, #fuwenGrid.skill do
  91. local fuwenSkillID = fuwenGrid.skill[j]
  92. local fuwenSkillConfig = FuwenExcel.skill[fuwenSkillID]
  93. local fuwenGroupID = fuwenSkillConfig.groupID
  94. if fuwenSkillConfig.fuwenBeSkill ~= 0 then
  95. hasFuwenBeSkill = true
  96. if tbFuwenSkillGroupID[fuwenGroupID] then
  97. if tbFuwenSkillGroupID[fuwenGroupID] < fuwenSkillID then
  98. tbFuwenSkillGroupID[fuwenGroupID] = fuwenSkillID
  99. end
  100. else
  101. tbFuwenSkillGroupID[fuwenGroupID] = fuwenSkillID
  102. end
  103. end
  104. end
  105. end
  106. end
  107. end
  108. if obj.bingshu then
  109. for i = 1, BingshuLogic.BINGSHU_MAXCNT do
  110. local bingshuGrid = obj.bingshu[i]
  111. if bingshuGrid then
  112. local skillID = bingshuGrid.skillID
  113. local skillConfig = FuwenExcel.skill[skillID]
  114. local groupID = skillConfig.groupID
  115. hasFuwenBeSkill = true
  116. if (tbFuwenSkillGroupID[groupID] or 0) < skillID then
  117. tbFuwenSkillGroupID[groupID] = skillID
  118. end
  119. end
  120. end
  121. end
  122. if hasFuwenBeSkill == true then
  123. for groupID, skillIDTemp in pairs(tbFuwenSkillGroupID) do
  124. local fuwenSkillConfig = FuwenExcel.skill[skillIDTemp]
  125. local fuwenBeSkillID = fuwenSkillConfig.fuwenBeSkill
  126. fuwenBeSkillID = obj.fuwenStrengthenSkillList and obj.fuwenStrengthenSkillList[fuwenBeSkillID] or fuwenBeSkillID
  127. setBeSkillID(obj,fuwenBeSkillID, 1)
  128. end
  129. end
  130. end
  131. --遗物被动技能
  132. if obj.relic and nil ~= _G.next(obj.relic) then
  133. local nRelicID = obj.relic.relicID
  134. local star = obj.relic.star
  135. local nSkillID = WinnerRelicLogic.WinnerRelic_GetSkillID(nRelicID, star)
  136. if 0 < nSkillID then
  137. setBeSkillID(obj, nSkillID, 0, 1)
  138. local tSkilConfig = SkillExcel and SkillExcel[nSkillID]
  139. if tSkilConfig and tSkilConfig.otherArgs and tSkilConfig.otherArgs.skillList then
  140. for k,v in ipairs(tSkilConfig.otherArgs.skillList) do
  141. local config = SkillExcel[v]
  142. if config and config.id then
  143. setBeSkillID(obj, config.id, 0, 1)
  144. end
  145. end
  146. end
  147. end
  148. end
  149. -- 神威灵装被动技能
  150. if obj.artifactsBeSkillList then
  151. for _, skillId in ipairs(obj.artifactsBeSkillList) do
  152. setBeSkillID(obj, skillId)
  153. end
  154. end
  155. end
  156. function setPetBeSkill(obj)
  157. --if obj
  158. --local skillConfig = SkillExcel[1999]
  159. local skillConfig = Skill.GetSkillConfig(1999)
  160. if skillConfig then
  161. obj.beSkillList = obj.beSkillList or {}
  162. obj.beSkillList[skillConfig.beSkillType] = obj.beSkillList[skillConfig.beSkillType] or {}
  163. obj.beSkillList[skillConfig.beSkillType][#obj.beSkillList[skillConfig.beSkillType] + 1] = {1999,skillConfig.beSkillLimit > 0 and skillConfig.beSkillLimit,skillConfig.cd[1] or 0,skillConfig.cd[2] or 0}
  164. end
  165. end
  166. --被动技能类型
  167. BESKILL_TYPE1 = 1 --普攻附带
  168. BESKILL_TYPE2 = 2 --被击触发
  169. BESKILL_TYPE3 = 3 --自身生命低于参数
  170. BESKILL_TYPE4 = 4 --自己暴击触发
  171. BESKILL_TYPE5 = 5 --受到技能伤害
  172. BESKILL_TYPE6 = 6 --自己攻击被格挡
  173. BESKILL_TYPE7 = 7 --受到暴击触发
  174. BESKILL_TYPE8 = 8 --自己格挡触发(其他单位对自己发动攻击,自己触发格挡)
  175. BESKILL_TYPE9 = 9 --敌方英雄触发格挡
  176. BESKILL_TYPE10 = 10 --自己受持续状态伤害
  177. BESKILL_TYPE11 = 11 --自己受控制类状态
  178. BESKILL_TYPE12 = 12 --场上有英雄被添加燃烧状态
  179. BESKILL_TYPE13 = 13 -- 我方英雄施放主动技能
  180. BESKILL_TYPE14 = 14 -- 我方英雄暴击
  181. BESKILL_TYPE15 = 15 -- 自己死亡
  182. BESKILL_TYPE16 = 16 --我方英雄死亡
  183. BESKILL_TYPE17 = 17 --敌方英雄死亡
  184. BESKILL_TYPE18 = 18 --有英雄死亡
  185. BESKILL_TYPE19 = 19 --回合开始
  186. BESKILL_TYPE20 = 20 --回合结束
  187. BESKILL_TYPE23 = 23 --激活就生效(计入面板属性)
  188. BESKILL_TYPE24 = 24 --技能包
  189. BESKILL_TYPE25 = 25 --替换初始普攻
  190. BESKILL_TYPE26 = 26 --激活就生效(进入战斗前算。不计入面板属性)
  191. BESKILL_TYPE27 = 27 --魔兽回能量被动
  192. BESKILL_TYPE28 = 28 --自身触发格挡次数
  193. BESKILL_TYPE29 = 29 --有人受到缠绕时
  194. BESKILL_TYPE30 = 30 --使生命低于x时
  195. BESKILL_TYPE31 = 31 --任意英雄释放主动技能
  196. BESKILL_TYPE32 = 32 --战斗开始时触发
  197. BESKILL_TYPE33 = 33 --复活时触发
  198. BESKILL_TYPE34 = 34 --使用主动技能时
  199. BESKILL_TYPE35 = 35 --自身击杀敌人时
  200. BESKILL_TYPE36 = 36 --攻击回合结束时触发
  201. BESKILL_TYPE37 = 37 --物攻后触发
  202. BESKILL_TYPE38 = 38 --法攻后触发
  203. BESKILL_TYPE39 = 39 --攻击附带 (普攻 主动 都算)
  204. BESKILL_TYPE40 = 40 --攻击前根据条件判断是否触发(小战斗回合,针对每个对象单独判断)
  205. BESKILL_TYPE41 = 41 --实际扣血前触发
  206. BESKILL_TYPE42 = 42 --由其他英雄的buff触发
  207. BESKILL_TYPE43 = 43 --被某个技能打死
  208. BESKILL_TYPE44 = 44 --自己暴击+反击触发
  209. BESKILL_TYPE45 = 45 --计算伤害时触发
  210. BESKILL_TYPE46 = 46 --攻击附带 (普攻 主动 连击 反击都算)
  211. BESKILL_TYPE47 = 47 --每回合叠加属性
  212. BESKILL_TYPE48 = 48 --死亡英雄伤害率
  213. BESKILL_TYPE49 = 49 --加血变成减血
  214. BESKILL_TYPE50 = 50 --每回合触发 降低对方首次攻击目标伤害率
  215. BESKILL_TYPE51 = 51 --场上有英雄被添加诅咒状态
  216. BESKILL_TYPE52 = 52 --场上有英雄被攻击
  217. BESKILL_TYPE53 = 53 --场上有英雄有特定被动技能 友军普攻触发
  218. BESKILL_TYPE54 = 54 --场上有英雄特定buff 伤害加成
  219. BESKILL_TYPE55 = 55 --场上有英雄指定buff层数 额外伤害加成
  220. BESKILL_TYPE56 = 56 --场上有英雄特定bufer且概率产生
  221. BESKILL_TYPE57 = 57 --特定buff被引爆消除时 触发的效果
  222. BESKILL_TYPE58 = 58 --指定技能暴击
  223. BESKILL_TYPE59 = 59 --没有暴击触发一个效果
  224. BESKILL_TYPE60 = 60 --暴击加成
  225. BESKILL_TYPE61 = 61 --技能未击杀目标时触发
  226. BESKILL_TYPE62 = 62 --回合开始生命值触发
  227. BESKILL_TYPE63 = 63 --回合开始生命值触发
  228. BESKILL_TYPE64 = 64 --冰冻buffer被击碎
  229. BESKILL_TYPE65 = 65 --场上有英雄有特定被动技能 友军普攻暴击触发
  230. BESKILL_TYPE66 = 66 --敌方死亡特定buff触发
  231. BESKILL_TYPE67 = 67 --血量低于多少跟受控制触发
  232. BESKILL_TYPE68 = 68 --血族英雄特殊处理
  233. BESKILL_TYPE69 = 69 --血族英雄特殊处理
  234. BESKILL_TYPE70 = 70 --增加的属性激活就生效(计入面板属性)并且概率连击
  235. BESKILL_TYPE71 = 71 --回合开始 在其他buff添加结束
  236. BESKILL_TYPE72 = 72 -- 不施放技能,只用来做其他效果的判断条件
  237. BESKILL_TYPE73 = 73 --使用技能(包括普攻技能)命中敌方且造成伤害
  238. NO_CHECK_FANJI_LIST = {
  239. [BESKILL_TYPE3] = 1,
  240. [BESKILL_TYPE15] = 1,
  241. [BESKILL_TYPE16] = 1,
  242. [BESKILL_TYPE17] = 1,
  243. [BESKILL_TYPE18] = 1,
  244. [BESKILL_TYPE35] = 1,
  245. [BESKILL_TYPE36] = 1,
  246. [BESKILL_TYPE37] = 1,
  247. [BESKILL_TYPE38] = 1,
  248. [BESKILL_TYPE44] = 1,
  249. [BESKILL_TYPE46] = 1,
  250. [BESKILL_TYPE73] = 1,
  251. }
  252. NO_CHECK_COMBO_LIST = {
  253. [BESKILL_TYPE1] = 1,
  254. [BESKILL_TYPE3] = 1,
  255. [BESKILL_TYPE14] = 1,
  256. [BESKILL_TYPE16] = 1,
  257. [BESKILL_TYPE17] = 1,
  258. [BESKILL_TYPE18] = 1,
  259. [BESKILL_TYPE35] = 1,
  260. [BESKILL_TYPE34] = 1,
  261. [BESKILL_TYPE25] = 1,
  262. [BESKILL_TYPE46] = 1,
  263. [BESKILL_TYPE37] = 1,
  264. [BESKILL_TYPE38] = 1,
  265. [BESKILL_TYPE43] = 1,
  266. [BESKILL_TYPE15] = 1,
  267. [BESKILL_TYPE73] = 1,
  268. }
  269. local function checkLimit(data)
  270. if data[2] and data[2] <= 0 then
  271. return
  272. end
  273. if data[4] > 0 and data[3] > CombatImpl.round then
  274. return
  275. end
  276. return true
  277. end
  278. local function canUse(obj,data)
  279. if obj.isPet then
  280. return true
  281. end
  282. --被动技能次数限制判断
  283. if not checkLimit(data) then
  284. return
  285. end
  286. --local skillConfig = SkillExcel[data[1]]
  287. local skillConfig = Skill.GetSkillConfig(data[1])
  288. if not NO_CHECK_FANJI_LIST[skillConfig.beSkillType] and CombatImpl.isFanji then
  289. return
  290. end
  291. if not NO_CHECK_COMBO_LIST[skillConfig.beSkillType] and CombatImpl.comboType > 0 then
  292. return
  293. end
  294. local bNotFeng = nil
  295. -- boss 被动不能被封印
  296. -- 世界boss模式下 boss不受feng状态影响
  297. if CombatImpl.fightMode[1] == CombatDefine.FIGHT_MODE3 then
  298. if obj.type == CombatDefine.COMBAT_OBJ_TYPE3 then
  299. bNotFeng = true
  300. end
  301. end
  302. if not bNotFeng and CombatBuff.isStatus(obj,{"banBeSkill","feng"}) then
  303. return
  304. end
  305. data[3] = data[3] + data[4]
  306. local beSkillArgs = skillConfig.beSkillArgs
  307. local ret = true
  308. --被动技能触发条件判断
  309. if beSkillArgs[1] then
  310. if beSkillArgs[1] == "hp" then
  311. local hp = obj.hp
  312. local hpMax = CombatObj.getHpMax(obj)
  313. if hp > hpMax * beSkillArgs[2]/10000 then
  314. ret = false
  315. end
  316. elseif beSkillArgs[1] == "hpOrControl" then
  317. ret = false
  318. local hp = obj.hp
  319. local hpMax = CombatObj.getHpMax(obj)
  320. if hp <= hpMax * beSkillArgs[2]/10000 then
  321. ret = true
  322. end
  323. if CombatBuff.isAtControl(obj) then
  324. ret = true
  325. end
  326. elseif beSkillArgs[1] == "fanji" then
  327. local r = math.random(0,10000)
  328. if r > beSkillArgs[2] then
  329. return
  330. end
  331. elseif beSkillArgs[1] == "pos" then
  332. local pos = obj.pos
  333. ret = false
  334. if beSkillArgs[2] then
  335. for i = 1,#beSkillArgs[2] do
  336. if pos == beSkillArgs[2][i] then
  337. ret = true
  338. break
  339. end
  340. end
  341. end
  342. elseif beSkillArgs[1] == "noBuffCmd" then
  343. return not CombatBuff.isStatus(obj,beSkillArgs[2])
  344. elseif beSkillArgs[1] == "attackerBuffCmd" then
  345. local isStatus,cmd = CombatBuff.isStatus(obj,beSkillArgs[2])
  346. return isStatus
  347. elseif beSkillArgs[1] == "myjob" then
  348. ret = false
  349. for k,v in ipairs(beSkillArgs[2]) do
  350. if v == obj.job then
  351. ret = true
  352. break
  353. end
  354. end
  355. elseif beSkillArgs[1] == "sideLimit" then
  356. for k,v in ipairs(beSkillArgs[2]) do
  357. local useCnt = CombatImpl.getBeSkillSideUse(obj.pos,v[1])
  358. if useCnt >= v[2] then
  359. return
  360. end
  361. end
  362. elseif beSkillArgs[1] == "firstAttackOrder" then
  363. local side = obj.side
  364. if side then
  365. local isFirstAttack = CombatImpl.firstAttack[side]
  366. if beSkillArgs[2] == 1 then
  367. return isFirstAttack
  368. else
  369. return not isFirstAttack
  370. end
  371. end
  372. end
  373. end
  374. if ret and data[2] then
  375. data[2] = data[2] - 1
  376. end
  377. if skillConfig.cmd == "hp" then
  378. local hp = obj.hp
  379. local targetMode = skillConfig.args[3]
  380. --英雄血量为0时不能加血
  381. if (hp <= 0 or CombatBuff.isStatus(obj,{"revive"})) and targetMode and targetMode[1] == 10 then
  382. ret = false
  383. end
  384. end
  385. return ret
  386. end
  387. --被攻击触发,需要判断攻击者状态的被动技能
  388. local function canUseOnHit(obj,data)
  389. if not obj then
  390. return true
  391. end
  392. --local skillConfig = SkillExcel[data[1]]
  393. local skillConfig = Skill.GetSkillConfig(data[1])
  394. local beSkillArgs = skillConfig.beSkillArgs
  395. local condCmd = beSkillArgs[1]
  396. if condCmd == "job" then
  397. for _,job in ipairs(beSkillArgs[2]) do
  398. if obj.job == job then
  399. return true
  400. end
  401. end
  402. return false
  403. elseif condCmd == "buffCmd" then
  404. return CombatBuff.isStatus(obj,beSkillArgs[2])
  405. elseif condCmd == "targetHp" then
  406. local hp = obj.hp
  407. local checkHp = CombatObj.getHpMax(obj) * beSkillArgs[3] / 10000
  408. if beSkillArgs[2] == 1 and hp > checkHp then
  409. return true
  410. elseif beSkillArgs[2] == 2 and hp < checkHp then
  411. return true
  412. end
  413. else
  414. return true
  415. end
  416. end
  417. local function isCanRevive(obj, attacker , data)
  418. -- local skillConfig = SkillExcel[data[1]]
  419. local skillConfig = Skill.GetSkillConfig(data[1])
  420. if skillConfig.cmd == "shengling" or
  421. skillConfig.cmd == "revive" then
  422. if skillConfig.cmd == "shengling" and CombatImpl.checkSideResult(obj.pos) == true then -- 如果是队伍最后一个死亡的不释放 圣灵复活
  423. return false
  424. end
  425. if CombatBuff.canRevive(obj) ~= true then
  426. return false
  427. end
  428. if skillConfig.cmd == "shengling" then
  429. if CombatBuff.isStatus(obj,{"revive"}) then
  430. return false
  431. end
  432. end
  433. if attacker and attacker.beSkillList then
  434. for k,skillList in pairs(attacker.beSkillList) do
  435. for j,v in pairs(skillList) do
  436. --local config = SkillExcel[v[1]]
  437. local config = Skill.GetSkillConfig(data[1])
  438. if config and skillConfig.cmd == "shengling" and config.cmd == "noShengling" then --击杀方有 不准圣灵复活被动
  439. return false
  440. elseif config and config.cmd == "noRevive" then -- 击杀方 有不准复活的
  441. if #config.args > 0 then
  442. local canNum = config.args[1]
  443. local random = math.random(1, 10000)
  444. if random > canNum then -- noRevive 概率不生效
  445. return true
  446. else
  447. return false
  448. end
  449. end
  450. return true
  451. end
  452. end
  453. end
  454. end
  455. end
  456. return true
  457. end
  458. -- 连击检测
  459. local function comboCheck(targetObj, side)
  460. if Skill.GroupSkillCnt ~= 1 then return end--技能包首次技能攻击才能触发
  461. if CombatImpl.isFanji or CombatImpl.comboType > 0 then return end
  462. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  463. local obj = CombatImpl.objList[pos]
  464. if obj and obj.beSkillList then
  465. for _, skillInfo in ipairs(obj.beSkillList[BESKILL_TYPE72] or {}) do
  466. local skillCfg = Skill.GetSkillConfig(skillInfo[1])
  467. if skillCfg and skillCfg.cmd == "comboProb" then
  468. local targetType = skillCfg.beSkillArgs[2] or 0
  469. local targetList = skillCfg.beSkillArgs[3]
  470. if targetType <= 0 or not targetList then
  471. return
  472. end
  473. local bl = false
  474. if targetType == 1 then -- 职业
  475. if table.find(targetList, targetObj.job) then
  476. bl = true
  477. end
  478. elseif targetType == 2 then -- 种族
  479. if table.find(targetList, targetObj.camp) then
  480. bl = true
  481. end
  482. end
  483. if not bl then return end
  484. local comboProbVal = skillCfg.beSkillArgs[1] or 0
  485. local randval = math.random(0, 10000)
  486. if comboProbVal >= randval then
  487. CombatImpl.comboList[#CombatImpl.comboList + 1] = {targetObj, 1}
  488. end
  489. end
  490. end
  491. end
  492. end
  493. end
  494. function onSkillID(obj,skillID)
  495. --local skillConfig = SkillExcel[skillID]
  496. local skillConfig = Skill.GetSkillConfig(skillID)
  497. if skillConfig.type == CombatDefine.SKILL_TYPE1 and obj.beSkillList[BESKILL_TYPE25] then
  498. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE25]) do
  499. if canUse(obj,v) then
  500. --local conf = SkillExcel[v[1]]
  501. local conf = Skill.GetSkillConfig(v[1])
  502. return conf.args[1]
  503. end
  504. end
  505. end
  506. return skillID
  507. end
  508. local function use(attacker,targets,data,newFrame, packBuff, hitObj)
  509. if canUse(attacker,data) and canUseOnHit(targets and targets[1],data) then
  510. --print("beskill realuse:",attacker.pos,data[1])
  511. --local skillConfig = SkillExcel[data[1]]
  512. local skillConfig = Skill.GetSkillConfig(data[1])
  513. local ret, arg2
  514. -- 二次元连击触发帧不新加帧
  515. if ProjectLogic.isSsecy() and skillConfig.cmd == "combo" then
  516. newFrame = false
  517. end
  518. if packBuff then
  519. CombatImpl.afterBuff()
  520. end
  521. if Skill.CMD[skillConfig.cmd] then
  522. if newFrame or CombatImpl.isSkillFrameEmpty() then
  523. --进入战斗时,未加入任何战斗帧触发被动技能时,先添加被动技能的战斗帧,可以在这个战斗帧上挂被动技能引发的额外作用
  524. CombatImpl.addFrame()
  525. CombatImpl.setSkillID(attacker, data[1])
  526. end
  527. ret, arg2 = Skill.CMD[skillConfig.cmd](attacker,skillConfig,targets, hitObj)
  528. end
  529. --判断是否加喊话
  530. local isAddSkillFrame = CombatBuff.onUseBeSkill(attacker, skillConfig, targets, ret, nil, arg2)
  531. if skillConfig.contentType > 0 then
  532. if isAddSkillFrame then
  533. CombatImpl.addSaySkill(attacker,skillConfig)
  534. elseif ret or skillConfig.beSkillType == BESKILL_TYPE26 or
  535. skillConfig.beSkillType == BESKILL_TYPE23 or
  536. skillConfig.beSkillType == BESKILL_TYPE4 or
  537. skillConfig.beSkillType == BESKILL_TYPE44 then
  538. if CombatImpl.isSkillFrameEmpty() then
  539. CombatImpl.addFrame()
  540. CombatImpl.setSkillID(attacker, data[1])
  541. end
  542. CombatImpl.setSaySkill(attacker.pos,skillConfig.id,skillConfig.contentType)
  543. end
  544. end
  545. CombatImpl.addBeSkillPosUse(attacker.pos,data[1])
  546. else
  547. -- print("[beskill - use] 直接返回了1 id = "..data[1])
  548. end
  549. end
  550. function onHit(attacker,targets,skillID)
  551. if attacker.isPet or attacker.isElf then
  552. return
  553. end
  554. --local useSkillConfig = SkillExcel[skillID]
  555. local useSkillConfig = Skill.GetSkillConfig(skillID)
  556. if useSkillConfig.type == CombatDefine.SKILL_TYPE2 then
  557. --[[for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  558. local obj = CombatImpl.objList[pos]
  559. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE13] then
  560. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE13]) do
  561. use(obj,targets,v)
  562. end
  563. end
  564. end]]
  565. if attacker.beSkillList[BESKILL_TYPE34] then
  566. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE34]) do
  567. --local skillConfig = SkillExcel[v[1]]
  568. local skillConfig = Skill.GetSkillConfig(v[1])
  569. local beSkillArgs = skillConfig.beSkillArgs
  570. if beSkillArgs[1] == "attackerBuffCmd" and beSkillArgs[2][1] == "shayi" then
  571. local shayiCnt = CombatBuff.getBuffCnt(attacker,"shayi")
  572. if shayiCnt > 0 then
  573. for i = 1,shayiCnt do
  574. use(attacker,targets,v,true)
  575. CombatImpl.instantFrameBuffer(attacker,v[1])
  576. end
  577. end
  578. CombatBuff.delShayi(attacker)
  579. elseif beSkillArgs[1] == "qusanNeedCmd" then
  580. local canUse = false
  581. for h,need in ipairs(beSkillArgs[2]) do
  582. if need == useSkillConfig.cmd then
  583. canUse = true
  584. break
  585. end
  586. end
  587. if canUse == true then
  588. use(attacker,targets,v,true)
  589. end
  590. elseif beSkillArgs[1] == "jiekongNeedCmd" then
  591. local canUse = false
  592. for h,need in ipairs(beSkillArgs[2]) do
  593. if need == useSkillConfig.cmd then
  594. canUse = true
  595. break
  596. end
  597. end
  598. if canUse == true then
  599. use(attacker,targets,v,true)
  600. end
  601. elseif beSkillArgs[1] == "skillID" then
  602. local canUse = false
  603. for _, targetSkill in ipairs(beSkillArgs[2]) do
  604. if skillID == targetSkill then
  605. canUse = true
  606. break
  607. end
  608. end
  609. if canUse == true then
  610. use(attacker,targets,v,true)
  611. end
  612. else
  613. use(attacker,targets,v)
  614. end
  615. end
  616. end
  617. end
  618. --非攻击性主动技能不处理被击被动技能
  619. if CombatObj.getValue(attacker,RoleDefine.HURT_COMBAT_NOW) <= 0 then
  620. if (useSkillConfig.type == CombatDefine.SKILL_TYPE1 or useSkillConfig.type == CombatDefine.SKILL_TYPE2) then
  621. if attacker.beSkillList[BESKILL_TYPE39] then
  622. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE39]) do
  623. use(attacker,targets,v)
  624. end
  625. end
  626. if attacker.beSkillList[BESKILL_TYPE70] then
  627. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE70]) do
  628. use(attacker,targets,v)
  629. end
  630. end
  631. end
  632. return
  633. end
  634. if useSkillConfig.type == CombatDefine.SKILL_TYPE1 and attacker.beSkillList[BESKILL_TYPE1] then
  635. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE1]) do
  636. use(attacker,targets,v)
  637. end
  638. end
  639. if useSkillConfig.type == CombatDefine.SKILL_TYPE2 and attacker.beSkillList[BESKILL_TYPE61] then
  640. local canUseSkill = true
  641. for index = 1, #targets do
  642. local target = targets[index]
  643. if target.hp <=0 then
  644. canUseSkill = false
  645. end
  646. end
  647. if canUseSkill then
  648. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE61]) do
  649. --local skillConfig = SkillExcel[v[1]]
  650. local skillConfig = Skill.GetSkillConfig(v[1])
  651. local beSkillArgs = skillConfig.beSkillArgs
  652. if beSkillArgs[1] == "skillID" then
  653. local canUse = false
  654. for _,v in ipairs(beSkillArgs[2]) do
  655. if skillID == v then
  656. canUse = true
  657. break
  658. end
  659. end
  660. if canUse then
  661. use(attacker,{},v)
  662. end
  663. end
  664. end
  665. end
  666. end
  667. if (useSkillConfig.type == CombatDefine.SKILL_TYPE1 or useSkillConfig.type == CombatDefine.SKILL_TYPE2 or useSkillConfig.type == CombatDefine.SKILL_TYPE3) then
  668. if attacker.beSkillList[BESKILL_TYPE39] then
  669. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE39]) do
  670. use(attacker,targets,v)
  671. end
  672. end
  673. if attacker.beSkillList[BESKILL_TYPE46] then
  674. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE46]) do
  675. use(attacker,targets,v)
  676. end
  677. end
  678. if attacker.beSkillList[BESKILL_TYPE70] then
  679. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE70]) do
  680. use(attacker,targets,v)
  681. end
  682. end
  683. end
  684. local isDefendSideGedang = false
  685. local baojiDefender = {}
  686. for _,target in ipairs(targets) do
  687. if target.beSkillList[BESKILL_TYPE2] then
  688. for _,v in ipairs(target.beSkillList[BESKILL_TYPE2]) do
  689. use(target,{attacker},v)
  690. -- print("當前受到攻擊,觸發被動技能11111111111111ssssssssss1111111111111111",skillID)
  691. --table.print_lua_table(v)
  692. end
  693. end
  694. -- 友军受击
  695. for _,pos in ipairs(CombatDefine.SIDE2POS[target.side]) do
  696. local obj = CombatImpl.objList[pos]
  697. if obj and obj.pos ~= target.pos and obj.beSkillList[BESKILL_TYPE52] then
  698. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE52]) do
  699. use(target,{attacker},v)
  700. end
  701. end
  702. end
  703. if useSkillConfig.type == CombatDefine.SKILL_TYPE2 and target.beSkillList[BESKILL_TYPE5] then
  704. for _,v in ipairs(target.beSkillList[BESKILL_TYPE5]) do
  705. use(target,{attacker},v)
  706. end
  707. end
  708. if target.isGedang then
  709. isDefendSideGedang = true
  710. if target.beSkillList[BESKILL_TYPE8] then
  711. for _,v in ipairs(target.beSkillList[BESKILL_TYPE8]) do
  712. use(target,{attacker},v)
  713. end
  714. end
  715. if attacker.beSkillList[BESKILL_TYPE6] then
  716. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE6]) do
  717. use(attacker,{target},v)
  718. end
  719. end
  720. --目标触发格挡次数
  721. if target.beSkillList[BESKILL_TYPE28] then
  722. for _, v in ipairs(target.beSkillList[BESKILL_TYPE28]) do
  723. --local skillConfig = SkillExcel[v[1]]
  724. local skillConfig = Skill.GetSkillConfig(v[1])
  725. local beSkillArgs = skillConfig.beSkillArgs
  726. if beSkillArgs[1] == "gedang" then
  727. target.isGedangCnt = target.isGedangCnt or 0
  728. local geDangLimit = beSkillArgs[2]
  729. if target.isGedangCnt >= geDangLimit then
  730. target.isGedangCnt = 0
  731. use(target,{attacker},v)
  732. end
  733. end
  734. end
  735. end
  736. end
  737. local chanRao = CombatBuff.isChanRao(target)
  738. if chanRao then
  739. if target.beSkillList[BESKILL_TYPE29] then
  740. for _,v in ipairs(target.beSkillList[BESKILL_TYPE29]) do
  741. use(target,{attacker},v)
  742. end
  743. end
  744. end
  745. if target.isBaoji then
  746. if target.beSkillList[BESKILL_TYPE7] then
  747. for _,v in ipairs(target.beSkillList[BESKILL_TYPE7]) do
  748. use(target,{attacker},v)
  749. end
  750. end
  751. baojiDefender[#baojiDefender+1] = target
  752. end
  753. -- if target.buffCmd["winner_nuhuo"] then
  754. -- local nIndex = target.buffCmd["winner_nuhuo"][1]
  755. -- local tBuffData = target.buffer[nIndex]
  756. -- if tBuffData.cnt < 10 then
  757. -- tBuffData.cnt = tBuffData.cnt + 1
  758. -- end
  759. -- end
  760. end
  761. local side = attacker.side
  762. local defendSide = side == CombatDefine.ATTACK_SIDE and CombatDefine.DEFEND_SIDE or CombatDefine.ATTACK_SIDE
  763. local target = targets[1]
  764. if target and target.side == defendSide and CombatObj.getValue(attacker,RoleDefine.HURT_COMBAT_NOW) > 0 then
  765. if attacker.beSkillList[BESKILL_TYPE73] then
  766. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE73]) do
  767. use(attacker,targets,v)
  768. end
  769. end
  770. end
  771. --普通技能触发
  772. if useSkillConfig.type == CombatDefine.SKILL_TYPE1 then
  773. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  774. local obj = CombatImpl.objList[pos]
  775. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE53] then
  776. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE53]) do
  777. use(attacker,targets,v)
  778. end
  779. end
  780. end
  781. end
  782. --主动技能触发
  783. if useSkillConfig.type == CombatDefine.SKILL_TYPE2 then
  784. for _,pos in ipairs(CombatDefine.SIDE2POS[0]) do
  785. local obj = CombatImpl.objList[pos]
  786. local objSide = pos <= 6 and CombatDefine.ATTACK_SIDE or CombatDefine.DEFEND_SIDE
  787. --触发自己这方的
  788. if side == objSide then
  789. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE13] then
  790. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE13]) do
  791. use(obj,targets,v)
  792. end
  793. end
  794. end
  795. --触发任意一方
  796. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE31] then
  797. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE31]) do
  798. use(obj,targets,v)
  799. end
  800. end
  801. end
  802. end
  803. if not attacker.isBaoji then
  804. --指定技能没有暴击
  805. if attacker.beSkillList[BESKILL_TYPE59] then
  806. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE59]) do
  807. --local skillConfig = SkillExcel[v[1]]
  808. local skillConfig = Skill.GetSkillConfig(v[1])
  809. local beSkillArgs = skillConfig.beSkillArgs
  810. if beSkillArgs[1] == "skillID" then
  811. local canUse = false
  812. for _,v in ipairs(beSkillArgs[2]) do
  813. if skillID == v then
  814. canUse = true
  815. break
  816. end
  817. end
  818. if canUse then
  819. use(attacker,{},v)
  820. end
  821. end
  822. end
  823. end
  824. end
  825. if attacker.isBaoji then
  826. --普通暴击技能触发
  827. if useSkillConfig.type == CombatDefine.SKILL_TYPE1 then
  828. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  829. local obj = CombatImpl.objList[pos]
  830. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE65] then
  831. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE65]) do
  832. use(attacker,targets,v)
  833. end
  834. end
  835. end
  836. end
  837. if attacker.beSkillList[BESKILL_TYPE4] then
  838. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE4]) do
  839. use(attacker,baojiDefender,v)
  840. end
  841. end
  842. if attacker.beSkillList[BESKILL_TYPE44] and CombatImpl.isFanji then
  843. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE44]) do
  844. use(attacker,baojiDefender,v)
  845. end
  846. end
  847. --指定技能暴击
  848. if attacker.beSkillList[BESKILL_TYPE58] then
  849. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE58]) do
  850. --local skillConfig = SkillExcel[v[1]]
  851. local skillConfig = Skill.GetSkillConfig(v[1])
  852. local beSkillArgs = skillConfig.beSkillArgs
  853. if beSkillArgs[1] == "skillID" then
  854. local canUse = false
  855. for _,v in ipairs(beSkillArgs[2]) do
  856. if skillID == v then
  857. canUse = true
  858. break
  859. end
  860. end
  861. if canUse then
  862. use(attacker,baojiDefender,v)
  863. end
  864. end
  865. end
  866. end
  867. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  868. local obj = CombatImpl.objList[pos]
  869. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE14] then
  870. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE14]) do
  871. use(obj,targets,v)
  872. end
  873. end
  874. end
  875. end
  876. if isDefendSideGedang then
  877. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  878. local obj = CombatImpl.objList[pos]
  879. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE9] then
  880. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE9]) do
  881. use(obj,targets,v)
  882. end
  883. end
  884. end
  885. end
  886. comboCheck(attacker, side)
  887. end
  888. function onHp(obj, hurt, attackPos)
  889. if obj.beSkillList[BESKILL_TYPE3] then
  890. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE3]) do
  891. use(obj,{},v)
  892. end
  893. end
  894. if obj.beSkillList[BESKILL_TYPE67] then
  895. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE67]) do
  896. use(obj,{},v)
  897. end
  898. end
  899. local attacker = CombatImpl.objList[attackPos]
  900. if attacker and attacker.beSkillList[BESKILL_TYPE30] and obj.pos ~= attackPos then
  901. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE30]) do
  902. --local skillConfig = SkillExcel[v[1]]
  903. local skillConfig = Skill.GetSkillConfig(v[1])
  904. local beSkillArgs = skillConfig.beSkillArgs
  905. obj.paramData.isbeSkillByHp = obj.paramData.isbeSkillByHp or 0
  906. if beSkillArgs[1] then
  907. if beSkillArgs[1] == "tohp" then
  908. local hp = obj.hp
  909. local hpMax = CombatObj.getHpMax(obj)
  910. if hp > hpMax * beSkillArgs[2]/10000 then
  911. obj.paramData.isbeSkillByHp = 0 --恢复到上限
  912. else
  913. if obj.isbeSkillByHp == 0 then
  914. obj.paramData.isbeSkillByHp = 1 --达到下限
  915. end
  916. end
  917. elseif beSkillArgs[1] == "hurthpper" then
  918. local hpMax = CombatObj.getHpMax(obj)
  919. local percent = -hurt/hpMax
  920. if percent > beSkillArgs[2]/10000 then -- 伤害超过目标生命值上限X%时
  921. use(attacker,{obj},v)
  922. end
  923. elseif beSkillArgs[1] == "speed" then
  924. local atkSpeed = CombatImpl.getValue(attacker,RoleDefine.SPEED)
  925. local defSpeed = CombatImpl.getValue(obj,RoleDefine.SPEED)
  926. if atkSpeed > defSpeed then
  927. use(attacker,{obj},v)
  928. end
  929. end
  930. end
  931. --使用技能
  932. if obj.paramData.isbeSkillByHp == 1 then
  933. use(attacker,{obj},v)
  934. obj.paramData.isbeSkillByHp = 2
  935. end
  936. end
  937. end
  938. end
  939. -- 选择合适的复活技能
  940. function selectReviceSkill(obj, attacker)
  941. local reviveSkillList = {}
  942. local len = 0
  943. for k, v in ipairs(obj.beSkillList[BESKILL_TYPE15]) do
  944. local skillID = v[1]
  945. local isFuwenSkill = v[5]
  946. --local skillConfig = SkillExcel[skillID]
  947. local skillConfig = Skill.GetSkillConfig(skillID)
  948. if skillConfig.cmd == "revive" then
  949. --有可使用的主动复活技能
  950. local state = isCanRevive(obj, attacker, v)
  951. if state and isFuwenSkill == 0 then
  952. if checkLimit(v) then
  953. len = len + 1
  954. reviveSkillList[k] = 1
  955. break
  956. end
  957. end
  958. end
  959. end
  960. -- 没有再取符文技能的复活
  961. if len == 0 then
  962. for k, v in ipairs(obj.beSkillList[BESKILL_TYPE15]) do
  963. local skillID = v[1]
  964. local isFuwenSkill = v[5]
  965. --local skillConfig = SkillExcel[skillID]
  966. local skillConfig = Skill.GetSkillConfig(skillID)
  967. if skillConfig.cmd == "revive" then
  968. local state = isCanRevive(obj, attacker, v)
  969. if state and isFuwenSkill == 1 then
  970. --被动技能次数限制判断
  971. if checkLimit(v) then
  972. reviveSkillList[k] = 1
  973. break
  974. end
  975. end
  976. end
  977. end
  978. end
  979. return reviveSkillList
  980. end
  981. function onDie(obj, hurt, attackPos)
  982. if obj.hp > 0 then
  983. return
  984. end
  985. local side = obj.side
  986. local attacker = CombatImpl.objList[attackPos]
  987. if obj.dieSkill then
  988. if attacker and attacker.beSkillList[BESKILL_TYPE43] then
  989. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE43]) do
  990. --local skillConfig = SkillExcel[v[1]]
  991. local skillConfig = Skill.GetSkillConfig(v[1])
  992. for _,v1 in ipairs(skillConfig.beSkillArgs) do
  993. if v1 == obj.dieSkill then
  994. use(attacker,{obj},v)
  995. break
  996. end
  997. end
  998. end
  999. end
  1000. end
  1001. local defendSide = side == CombatDefine.ATTACK_SIDE and CombatDefine.DEFEND_SIDE or CombatDefine.ATTACK_SIDE
  1002. for _,posData in ipairs(posSortBySpeed[side]) do
  1003. local pos = posData[1]
  1004. local target = CombatImpl.objList[pos]
  1005. if target and target.hp > 0 then
  1006. if target.beSkillList[BESKILL_TYPE16] then
  1007. for _,v in ipairs(target.beSkillList[BESKILL_TYPE16]) do
  1008. use(target,{obj},v)
  1009. end
  1010. end
  1011. if target.beSkillList[BESKILL_TYPE18] then
  1012. for _,v in ipairs(target.beSkillList[BESKILL_TYPE18]) do
  1013. use(target,{obj},v)
  1014. end
  1015. end
  1016. end
  1017. end
  1018. for _,posData in ipairs(posSortBySpeed[defendSide]) do
  1019. local pos = posData[1]
  1020. local target = CombatImpl.objList[pos]
  1021. if target and target.hp > 0 then
  1022. if target.beSkillList[BESKILL_TYPE17] then
  1023. for _,v in ipairs(target.beSkillList[BESKILL_TYPE17]) do
  1024. use(target,{obj},v)
  1025. end
  1026. end
  1027. if target.beSkillList[BESKILL_TYPE18] then
  1028. for _,v in ipairs(target.beSkillList[BESKILL_TYPE18]) do
  1029. use(target,{obj},v)
  1030. end
  1031. end
  1032. end
  1033. end
  1034. if attacker and attacker.beSkillList and attacker.beSkillList[BESKILL_TYPE30] and obj.pos ~= attackPos then
  1035. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE30]) do
  1036. if obj.isbeSkillByHp == nil or
  1037. obj.isbeSkillByHp == 0 then
  1038. use(attacker,{},v)
  1039. end
  1040. end
  1041. end
  1042. if attacker and attacker.beSkillList and attacker.beSkillList[BESKILL_TYPE35] then
  1043. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE35]) do
  1044. use(attacker,{obj},v)
  1045. end
  1046. end
  1047. if obj.beSkillList[BESKILL_TYPE15] then
  1048. -- 选择其中一个使用
  1049. local reviceSkillList = selectReviceSkill(obj, attacker)
  1050. for k, v in ipairs(obj.beSkillList[BESKILL_TYPE15]) do
  1051. local skillID = v[1]
  1052. --local skillConfig = SkillExcel[skillID]
  1053. local skillConfig = Skill.GetSkillConfig(skillID)
  1054. if skillConfig.cmd == "revive" then
  1055. if reviceSkillList[k] then
  1056. use(obj,{},v)
  1057. -- break
  1058. end
  1059. else
  1060. use(obj,{},v)
  1061. end
  1062. end
  1063. end
  1064. for _,pos in ipairs(CombatDefine.SIDE2POS[defendSide]) do
  1065. local defendobj = CombatImpl.objList[pos]
  1066. if defendobj and defendobj.hp > 0 and defendobj.beSkillList[BESKILL_TYPE66] then
  1067. for _,v in ipairs(defendobj.beSkillList[BESKILL_TYPE66]) do
  1068. --local skillConfig = SkillExcel[v[1]]
  1069. local skillConfig = Skill.GetSkillConfig(v[1])
  1070. if skillConfig and skillConfig.otherArgs.tdBuffCmd then
  1071. if obj.bufferCmd[skillConfig.otherArgs.tdBuffCmd] then
  1072. use(defendobj,{},v)
  1073. end
  1074. end
  1075. end
  1076. end
  1077. end
  1078. end
  1079. function onAddBuffer(obj,buffer)
  1080. --local conf = BufferExcel[buffer.id]
  1081. local conf = CombatBuff.GetBuffConfig(buffer.id)
  1082. local attacker = CombatImpl.objList[buffer.attackPos]
  1083. if not attacker then -- 非英雄
  1084. return
  1085. end
  1086. local cmd = conf.cmd
  1087. if cmd == "hurt" or cmd == "liuxue"or cmd == "liuxue2" or cmd == "zhongdu" or cmd == "ranshao" then
  1088. if obj.beSkillList[BESKILL_TYPE10] then
  1089. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE10]) do
  1090. use(obj,{attacker},v)
  1091. end
  1092. end
  1093. end
  1094. if cmd == "bingdong" or cmd == "jiansu" then
  1095. for _,pos in ipairs(CombatDefine.SIDE2POS[attacker.side]) do
  1096. local target = CombatImpl.objList[pos]
  1097. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE63] then
  1098. for _,v in ipairs(target.beSkillList[BESKILL_TYPE63]) do
  1099. use(target,{obj},v)
  1100. end
  1101. end
  1102. end
  1103. end
  1104. if CombatBuff.isControlCmd(cmd) then
  1105. if obj.beSkillList[BESKILL_TYPE11] then
  1106. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE11]) do
  1107. use(obj,{attacker},v)
  1108. end
  1109. end
  1110. if obj.beSkillList[BESKILL_TYPE67] then
  1111. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE67]) do
  1112. use(obj,{attacker},v, true, true)
  1113. end
  1114. end
  1115. end
  1116. if cmd == "ranshao" then
  1117. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1118. local target = CombatImpl.objList[pos]
  1119. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE12] then
  1120. for _,v in ipairs(target.beSkillList[BESKILL_TYPE12]) do
  1121. local beSkillUseCnt = CombatImpl.getBeSkillUse(target,obj.pos,v[1])--特殊条件特殊处理:同一英雄在同一时间被施加多次燃烧状态时只触发一次
  1122. if beSkillUseCnt == 0 then
  1123. use(target,{obj},v)
  1124. CombatImpl.addBeSkillUse(target,obj.pos,v[1])
  1125. end
  1126. end
  1127. end
  1128. end
  1129. end
  1130. if cmd == "zuzhou" then
  1131. for _,pos in ipairs(CombatDefine.SIDE2POS[attacker.side]) do
  1132. local target = CombatImpl.objList[pos]
  1133. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE51] then
  1134. for _,v in ipairs(target.beSkillList[BESKILL_TYPE51]) do
  1135. use(target,{obj},v)
  1136. end
  1137. end
  1138. end
  1139. end
  1140. if cmd == "revive" then
  1141. if obj.beSkillList[BESKILL_TYPE33] then
  1142. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE33]) do
  1143. use(obj,{attacker},v)
  1144. end
  1145. end
  1146. end
  1147. end
  1148. function onDelBingDongBuffer(obj, buffer)
  1149. --local conf = BufferExcel[buffer.id]
  1150. local conf = CombatBuff.GetBuffConfig(buffer.id)
  1151. local attacker = CombatImpl.objList[buffer.attackPos]
  1152. if not attacker then
  1153. return
  1154. end
  1155. if conf.cmd == "bingdong" then
  1156. for _, pos in ipairs(CombatDefine.SIDE2POS[attacker.side]) do
  1157. local target = CombatImpl.objList[pos]
  1158. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE64] then
  1159. for _,v in ipairs(target.beSkillList[BESKILL_TYPE64]) do
  1160. use(target,{obj},v)
  1161. end
  1162. end
  1163. end
  1164. end
  1165. end
  1166. --援军上阵触发
  1167. function onBackupBegin(obj)
  1168. if not obj then return end
  1169. if CombatDefine.isBackup(obj) ~= CombatDefine.BACKUP_TYPE2 then return end
  1170. -- 备份的被动技能上阵
  1171. if obj.backUpSkillList then
  1172. obj.beSkillList = obj.backUpSkillList
  1173. obj.backUpSkillList = nil
  1174. end
  1175. -- 出站计算属性
  1176. if obj.beSkillList[BESKILL_TYPE26] then
  1177. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE26]) do
  1178. if canUse(obj,v) then
  1179. --local skillConfig = SkillExcel[v[1]]
  1180. local skillConfig = Skill.GetSkillConfig(v[1])
  1181. if skillConfig.cmd == "attr" then
  1182. for _,v1 in ipairs(skillConfig.args) do
  1183. obj.sysAttr[v1[1]] = obj.sysAttr[v1[1]] +v1[2]
  1184. end
  1185. obj.isSysAttrChange = true
  1186. elseif skillConfig.cmd == "normalTarget" then
  1187. use(obj,{},v)
  1188. end
  1189. end
  1190. end
  1191. end
  1192. table.sort(posSortBySpeed[CombatDefine.ATTACK_SIDE],posSpeedCmp)
  1193. table.sort(posSortBySpeed[CombatDefine.DEFEND_SIDE],posSpeedCmp)
  1194. --援军出战触发
  1195. if obj and obj.beSkillList[BESKILL_TYPE32] then
  1196. for k,v in ipairs(obj.beSkillList[BESKILL_TYPE32]) do
  1197. use(obj,{},v)
  1198. end
  1199. end
  1200. --上场技能
  1201. CombatDefine.BACKUP_BUFF_SKILL[2] = 1
  1202. use(obj,{}, CombatDefine.BACKUP_BUFF_SKILL)
  1203. end
  1204. function onRoundBegin(round)
  1205. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1206. local target = CombatImpl.objList[pos]
  1207. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE19] then
  1208. for _,v in ipairs(target.beSkillList[BESKILL_TYPE19]) do
  1209. --table.print_lua_table(v)
  1210. -- print("beskill = onRoundBegin 开始使用技能 ID = "..v[1])
  1211. use(target,{},v)
  1212. end
  1213. end
  1214. -- 生命值触发
  1215. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE62] then
  1216. for _,v in ipairs(target.beSkillList[BESKILL_TYPE62]) do
  1217. --local skillConfig = SkillExcel[v[1]]
  1218. local skillConfig = Skill.GetSkillConfig(v[1])
  1219. local beSkillArgs = skillConfig.beSkillArgs
  1220. if beSkillArgs[1] == 1 then
  1221. local hpMax = CombatObj.getHpMax(target)
  1222. local percent = target.hp/hpMax
  1223. if percent > beSkillArgs[2]/10000 then
  1224. use(target,{},v)
  1225. end
  1226. end
  1227. if beSkillArgs[1] == 2 then
  1228. local hpMax = CombatObj.getHpMax(target)
  1229. local percent = target.hp/hpMax
  1230. if percent < beSkillArgs[2]/10000 then
  1231. use(target,{},v)
  1232. end
  1233. end
  1234. end
  1235. end
  1236. end
  1237. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1238. local target = CombatImpl.objList[pos]
  1239. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE47] then
  1240. for _,v in ipairs(target.beSkillList[BESKILL_TYPE47]) do
  1241. --local skillConfig = SkillExcel[v[1]]
  1242. local skillConfig = Skill.GetSkillConfig(v[1])
  1243. if skillConfig.cmd == "attr" then
  1244. for _,v1 in ipairs(skillConfig.args) do
  1245. target.sysAttr[v1[1]] = target.sysAttr[v1[1]] +v1[2]
  1246. end
  1247. CombatObj.calcAttr(target)
  1248. CombatImpl.addFrame()
  1249. CombatImpl.setSkillID(target, v[1])
  1250. CombatImpl.setSaySkill(target.pos,skillConfig.id,skillConfig.contentType)
  1251. end
  1252. end
  1253. end
  1254. end
  1255. if round and round == 1 then
  1256. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1257. local obj = CombatImpl.objList[pos]
  1258. if obj and obj.beSkillList[BESKILL_TYPE32] then
  1259. for k,v in ipairs(obj.beSkillList[BESKILL_TYPE32]) do
  1260. use(obj,{},v)
  1261. end
  1262. end
  1263. end
  1264. end
  1265. -- 在最后加
  1266. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1267. local target = CombatImpl.objList[pos]
  1268. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE71] then
  1269. for _,v in ipairs(target.beSkillList[BESKILL_TYPE71]) do
  1270. -- print("[onRoundBegin] 开始加类型71的被动技能 pos = "..pos)
  1271. local skillConfig = Skill.GetSkillConfig(v[1])
  1272. if skillConfig and skillConfig.args then
  1273. -- local nLen = skillConfig.args[1]
  1274. -- for i = 1, nLen, 1 do
  1275. use(target,{},v)
  1276. -- end
  1277. end
  1278. end
  1279. end
  1280. end
  1281. end
  1282. function beforeFanji(obj, hitObj, isEnd)
  1283. if not obj or obj.isPet or obj.isElf then
  1284. return
  1285. end
  1286. if obj and obj.hurtType == CombatDefine.PHY_HURT_TYPE then
  1287. if obj and obj.beSkillList and obj.beSkillList[BESKILL_TYPE37] then
  1288. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE37]) do
  1289. -- use(obj,{},v)
  1290. use(obj, {}, v, nil, nil, hitObj)
  1291. end
  1292. end
  1293. else
  1294. if obj and obj.beSkillList and obj.beSkillList[BESKILL_TYPE38] then
  1295. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE38]) do
  1296. use(obj,{},v)
  1297. end
  1298. end
  1299. end
  1300. end
  1301. function onRoundEnd(isRoundEnd)
  1302. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1303. local obj = CombatImpl.objList[pos]
  1304. if obj and obj.beSkillList[BESKILL_TYPE36] then
  1305. if pos == 1 then
  1306. end
  1307. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE36]) do
  1308. use(obj,{},v)
  1309. end
  1310. end
  1311. end
  1312. if isRoundEnd then
  1313. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1314. local target = CombatImpl.objList[pos]
  1315. if target and target.hp > 0 and target.beSkillList[BESKILL_TYPE20] then
  1316. for _,v in ipairs(target.beSkillList[BESKILL_TYPE20]) do
  1317. use(target,{},v)
  1318. end
  1319. end
  1320. end
  1321. end
  1322. end
  1323. function posSpeedCmp(a,b)
  1324. if a[2] > b[2] then
  1325. return true
  1326. elseif a[2] < b[2] then
  1327. return false
  1328. else
  1329. return a[1] < b[1]
  1330. end
  1331. end
  1332. -- 计算遗物特殊属性部分
  1333. local function BeSkill_RelicAttribute(ReleaserObj, tSkillInfo)
  1334. local nSkillID = tSkillInfo[1]
  1335. local tSkilConfig = Skill.GetSkillConfig(nSkillID)
  1336. if not tSkilConfig then
  1337. -- print("[BeSkill_RelicAttribute] 不存在技能配置 nSkillID = "..nSkillID)
  1338. return
  1339. end
  1340. local winnerID = ReleaserObj and ReleaserObj.relic and ReleaserObj.relic.relicID or 0
  1341. local winnerStar = ReleaserObj and ReleaserObj.relic and ReleaserObj.relic.star or 0
  1342. if 0 >= winnerID or 0 >= winnerStar then
  1343. return
  1344. end
  1345. -- 特殊处理防御为0, 加标识
  1346. if tSkilConfig.otherArgs.selefDefense then
  1347. ReleaserObj.relicAttr.bSpecialDef = true
  1348. end
  1349. -- 是否增加args属性
  1350. local bAddArgs = true
  1351. if tSkilConfig.otherArgs.winnerfiveraces then
  1352. bAddArgs = false
  1353. end
  1354. local targets = TargetMode.getTargets(ReleaserObj, tSkilConfig.targetMode)
  1355. if #targets > 0 and true == bAddArgs then
  1356. for _, obj in ipairs(targets) do
  1357. -- 加固定值属性
  1358. for _, v in ipairs(tSkilConfig.args) do
  1359. if not obj.relicAttr.FixedAttr[v[1]] then
  1360. obj.relicAttr.FixedAttr[v[1]] = 0
  1361. end
  1362. obj.relicAttr.FixedAttr[v[1]] = obj.relicAttr.FixedAttr[v[1]] + v[2]
  1363. end
  1364. end
  1365. else
  1366. -- print("[BeSkill_RelicAttribute] 获取不到对应的技能目标对象")
  1367. end
  1368. local nSide = ReleaserObj.side
  1369. local tCamp = {}
  1370. -- 检查
  1371. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1372. local obj = CombatImpl.objList[pos]
  1373. if obj and obj.side and nSide == obj.side then
  1374. local nCamp = obj.camp
  1375. if nCamp then
  1376. tCamp[nCamp] = 1
  1377. end
  1378. end
  1379. end
  1380. local bAllCamp = true
  1381. for i = CombatDefine.CAMP_TYPE1, CombatDefine.CAMP_TYPE5, 1 do
  1382. if not tCamp[i] then
  1383. bAllCamp = false
  1384. break
  1385. end
  1386. end
  1387. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1388. local obj = CombatImpl.objList[pos]
  1389. if obj and obj.side and nSide == obj.side then
  1390. -- 处理百分比值
  1391. -- 治疗
  1392. if tSkilConfig.otherArgs.jobZhiliao then
  1393. --table.print_lua_table(tSkilConfig.otherArgs.jobZhiliao)
  1394. if CombatBuff.isJob(obj, {CombatDefine.JOB_TYPE4}) then
  1395. -- local extraRate = WinnerRelicLogic.WinnerRelic_GetRateAttack(winnerID, winnerStar)
  1396. if not obj.relicAttr.ProAttr[RoleDefine.ZAOCHENG_HP_ADD_RATE] then
  1397. obj.relicAttr.ProAttr[RoleDefine.ZAOCHENG_HP_ADD_RATE] = 0
  1398. end
  1399. local nValue = tSkilConfig.otherArgs.jobZhiliao[2]
  1400. -- print("BeSkill_RelicAttribute 治療 nValue = ".. nValue)
  1401. obj.relicAttr.ProAttr[RoleDefine.ZAOCHENG_HP_ADD_RATE] = obj.relicAttr.ProAttr[RoleDefine.ZAOCHENG_HP_ADD_RATE] + nValue
  1402. if obj.relicAttr.ProAttr[RoleDefine.ZAOCHENG_HP_ADD_RATE] then
  1403. -- print("[BeSkill_RelicAttribute] 治療加成 為 nNewValue = "..obj.relicAttr.ProAttr[RoleDefine.ZAOCHENG_HP_ADD_RATE] )
  1404. else
  1405. -- print("[BeSkill_RelicAttribute] 不存在 nNewValue" )
  1406. end
  1407. end
  1408. end
  1409. -- 免伤 百分比
  1410. if tSkilConfig.otherArgs.jobMianshang then
  1411. if CombatBuff.isJob(obj, {CombatDefine.JOB_TYPE1}) then
  1412. --local extraRate = WinnerRelicLogic.WinnerRelic_GetRateDef(winnerID, winnerStar)
  1413. if not obj.relicAttr.ProAttr[RoleDefine.JIANSHANG_RATE] then
  1414. obj.relicAttr.ProAttr[RoleDefine.JIANSHANG_RATE] = 0
  1415. end
  1416. local nValue = tSkilConfig.otherArgs.jobMianshang[2]
  1417. -- print("BeSkill_RelicAttribute 免伤 nValue = ".. nValue)
  1418. obj.relicAttr.ProAttr[RoleDefine.JIANSHANG_RATE] = obj.relicAttr.ProAttr[RoleDefine.JIANSHANG_RATE] + nValue
  1419. -- print("[BeSkill_RelicAttribute] 免傷加成 為 nValue = "..nValue.." nNewValue = "..obj.relicAttr.ProAttr[RoleDefine.JIANSHANG_RATE])
  1420. end
  1421. end
  1422. -- 防御增加固定值
  1423. if tSkilConfig.otherArgs.jobDefense then
  1424. if CombatBuff.isJob(obj, {CombatDefine.JOB_TYPE4, CombatDefine.JOB_TYPE1}) then
  1425. if winnerID > 0 and winnerStar > 0 then
  1426. local extraRate = WinnerRelicLogic.WinnerRelic_GetRateAttack(winnerID, winnerStar)
  1427. if not obj.relicAttr.FixedAttr[RoleDefine.DEF] then
  1428. obj.relicAttr.FixedAttr[RoleDefine.DEF] = 0
  1429. end
  1430. obj.relicAttr.FixedAttr[RoleDefine.DEF] = obj.relicAttr.FixedAttr[RoleDefine.DEF] + extraRate
  1431. end
  1432. end
  1433. end
  1434. -- 攻击 百分比
  1435. if tSkilConfig.otherArgs.racialAtk then
  1436. if CombatBuff.isCamp(obj, {CombatDefine.COMBAT_TYPE27}) then
  1437. local extraRate = WinnerRelicLogic.WinnerRelic_GetRateAttack(winnerID, winnerStar)
  1438. if not obj.relicAttr.ProAttr[RoleDefine.ATK] then
  1439. obj.relicAttr.ProAttr[RoleDefine.ATK] = 0
  1440. end
  1441. obj.relicAttr.ProAttr[RoleDefine.ATK] = obj.relicAttr.ProAttr[RoleDefine.ATK] + extraRate
  1442. end
  1443. end
  1444. -- 上阵阵容为全职业,加固定值
  1445. if tSkilConfig.otherArgs.winnerfiveraces and bAllCamp == true then
  1446. for _, v in ipairs(tSkilConfig.args) do
  1447. if not obj.relicAttr.FixedAttr[v[1]] then
  1448. obj.relicAttr.FixedAttr[v[1]] = 0
  1449. end
  1450. obj.relicAttr.FixedAttr[v[1]] = obj.relicAttr.FixedAttr[v[1]] + v[2]
  1451. end
  1452. end
  1453. end
  1454. end
  1455. end
  1456. function onFightBegin()
  1457. posSortBySpeed[CombatDefine.ATTACK_SIDE] = {}
  1458. posSortBySpeed[CombatDefine.DEFEND_SIDE] = {}
  1459. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1460. local obj = CombatImpl.objList[pos]
  1461. if obj then
  1462. obj.hp = obj.hp and obj.hp or 1
  1463. end
  1464. end
  1465. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1466. local obj = CombatImpl.objList[pos]
  1467. if obj then
  1468. if obj.beSkillList[BESKILL_TYPE26] then
  1469. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE26]) do
  1470. if canUse(obj,v) then
  1471. --local skillConfig = SkillExcel[v[1]]
  1472. local skillConfig = Skill.GetSkillConfig(v[1])
  1473. if skillConfig.cmd == "attr" then
  1474. for _,v1 in ipairs(skillConfig.args) do
  1475. obj.sysAttr[v1[1]] = obj.sysAttr[v1[1]] +v1[2]
  1476. end
  1477. obj.isSysAttrChange = true
  1478. elseif skillConfig.cmd == "normalTarget" then
  1479. use(obj,{},v)
  1480. elseif skillConfig.cmd == "winnerRelicSkill" then
  1481. use(obj,{},v)
  1482. BeSkill_RelicAttribute(obj, v)
  1483. end
  1484. end
  1485. end
  1486. end
  1487. if pos <= CombatDefine.COMBAT_HERO_CNT then
  1488. posSortBySpeed[CombatDefine.ATTACK_SIDE][#posSortBySpeed[CombatDefine.ATTACK_SIDE]+1] = {pos,obj.attr and obj.attr[RoleDefine.SPEED] or 0}
  1489. elseif pos <= CombatDefine.COMBAT_HERO_CNT * 2 then
  1490. posSortBySpeed[CombatDefine.DEFEND_SIDE][#posSortBySpeed[CombatDefine.DEFEND_SIDE]+1] = {pos,obj.attr and obj.attr[RoleDefine.SPEED] or 0}
  1491. end
  1492. end
  1493. end
  1494. for pos = 1,CombatDefine.COMBAT_HERO_ALL_CNT do
  1495. local obj = CombatImpl.objList[pos]
  1496. if obj then
  1497. obj.hp = nil
  1498. end
  1499. end
  1500. table.sort(posSortBySpeed[CombatDefine.ATTACK_SIDE],posSpeedCmp)
  1501. table.sort(posSortBySpeed[CombatDefine.DEFEND_SIDE],posSpeedCmp)
  1502. end
  1503. function onCombatPetBe(round)
  1504. if round <= 1 then
  1505. return
  1506. end
  1507. for side = 1,CombatDefine.DEFEND_SIDE do
  1508. local pet = CombatImpl.petList[side]
  1509. if pet and pet.petID and pet.beSkillList[BESKILL_TYPE27] then
  1510. for _,v in ipairs(pet.beSkillList[BESKILL_TYPE27]) do
  1511. --local skillConfig = SkillExcel[v[1]]
  1512. local skillConfig = Skill.GetSkillConfig(v[1])
  1513. if skillConfig.cmd == "mp" then
  1514. use(pet,{},v)
  1515. end
  1516. end
  1517. end
  1518. end
  1519. end
  1520. -- 计算被动技能属性
  1521. local beSkillIDList = {}
  1522. function doCalcHero(obj, attrs, skinSkillID, heroConf)
  1523. for i = 1, #beSkillIDList do
  1524. beSkillIDList[i] = nil
  1525. end
  1526. heroConf = heroConf or HeroDefine.getAttrConfig(obj.id, obj.star)
  1527. local beSkillIDs = heroConf.beSkillList
  1528. local skinSkillConf = skinSkillID and SkinSkillExcel[skinSkillID]
  1529. if skinSkillConf then
  1530. beSkillIDs = skinSkillConf.beSkillList
  1531. end
  1532. local weapSkillList = HeroExclusiveWeapon.GetweaponEffectIdList(obj)
  1533. for _, skillID in ipairs(beSkillIDs) do
  1534. --local skillConfig = SkillExcel[skillID]
  1535. skillID = weapSkillList and weapSkillList[skillID] or skillID
  1536. local skillConfig = Skill.GetSkillConfig(skillID)
  1537. if skillConfig.beSkillType == BESKILL_TYPE24 and
  1538. ((not obj) or (obj.quality >= skillConfig.need)) then
  1539. for _,v in ipairs(skillConfig.args) do
  1540. beSkillIDList[#beSkillIDList + 1] = v
  1541. end
  1542. else
  1543. beSkillIDList[#beSkillIDList + 1] = skillID
  1544. end
  1545. end
  1546. for _, skillID in ipairs(beSkillIDList) do
  1547. --local skillConfig = SkillExcel[skillID]
  1548. local skillConfig = Skill.GetSkillConfig(skillID)
  1549. if skillConfig and skillConfig.cmd == "attr" and
  1550. skillConfig.beSkillType == BESKILL_TYPE23 and
  1551. ((not obj) or (obj.quality >= skillConfig.need)) then
  1552. for _, v in ipairs(skillConfig.args) do
  1553. RoleAttr.updateValue(v[1], v[2], attrs)
  1554. end
  1555. elseif skillConfig and skillConfig.cmd == "attrcomboAgain" and
  1556. skillConfig.beSkillType == BESKILL_TYPE70 and
  1557. ((not obj) or (obj.quality >= skillConfig.need)) then
  1558. for i, v in ipairs(skillConfig.args) do
  1559. if v[1] == 1 then
  1560. RoleAttr.updateValue(v[2], v[3], attrs)
  1561. end
  1562. end
  1563. end
  1564. end
  1565. end
  1566. function beforeHit(attacker,defender)
  1567. attacker.beforeHitCheck = false
  1568. if attacker.beSkillList[BESKILL_TYPE40] then
  1569. local hpMax = CombatObj.getHpMax(defender)
  1570. local hp = defender.hp
  1571. local defendHpRate = hp*10000/hpMax
  1572. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE40]) do
  1573. --local skillConfig = SkillExcel[v[1]]
  1574. local skillConfig = Skill.GetSkillConfig(v[1])
  1575. if skillConfig.cmd == "lowerLimit" then
  1576. local args = skillConfig.args
  1577. if defendHpRate < args[1] then
  1578. attacker.beforeHitCheck = true
  1579. attacker.beskill40 = attacker.beskill40 or {}
  1580. attacker.beskill40[defender.pos] = 1
  1581. end
  1582. end
  1583. end
  1584. end
  1585. end
  1586. function afterHit(attacker,target, isEnd)
  1587. if attacker.beforeHitCheck then
  1588. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE40]) do
  1589. use(attacker,{target},v)
  1590. end
  1591. end
  1592. -- beforeFanji(attacker, isEnd)
  1593. beforeFanji(attacker, target, isEnd)
  1594. end
  1595. function getOutAtkRate(attacker, defender)
  1596. local outAtkRate = 0
  1597. -- 首次攻击
  1598. local isFirstAttack = CombatImpl.firstAttack[attacker.side]
  1599. if isFirstAttack then
  1600. for _,pos in ipairs(CombatDefine.SIDE2POS[defender.side]) do
  1601. local objM = CombatImpl.objList[pos]
  1602. if objM and objM.beSkillList[BESKILL_TYPE50] then
  1603. for _,v in ipairs(objM.beSkillList[BESKILL_TYPE50]) do
  1604. --local skillConfig = SkillExcel[v[1]]
  1605. local skillConfig = Skill.GetSkillConfig(v[1])
  1606. if skillConfig and skillConfig.otherArgs.outAtkRate then
  1607. if skillConfig.otherArgs.outAtkRate >= outAtkRate then
  1608. outAtkRate = skillConfig.otherArgs.outAtkRate
  1609. end
  1610. end
  1611. end
  1612. end
  1613. end
  1614. end
  1615. return outAtkRate
  1616. end
  1617. function getOutAtkRate2(attacker, skillConfig)
  1618. local outAtkRate = 0
  1619. for _, v in ipairs(attacker.beSkillList[BESKILL_TYPE72] or {}) do
  1620. local config = Skill.GetSkillConfig(v[1])
  1621. if config.cmd == "addHurtRateByRand" then
  1622. local addHurtRate = 0
  1623. for _, skillInfo in ipairs(config.beSkillArgs[2]) do
  1624. if table.find(skillInfo[1], skillConfig.id) then
  1625. addHurtRate = skillInfo[2]
  1626. break
  1627. end
  1628. end
  1629. local randVal = math.random(0, 10000)
  1630. if randVal <= config.beSkillArgs[1] then
  1631. outAtkRate = outAtkRate + addHurtRate
  1632. end
  1633. end
  1634. end
  1635. return outAtkRate
  1636. end
  1637. function getExtraHurtRate(attacker,defender,skillConfig)
  1638. if not attacker or attacker.isPet then
  1639. return 0
  1640. end
  1641. local zhanyiRet = 0
  1642. local bodongHurtRet = 0
  1643. local zhenduiHurtRate = 0
  1644. local zhenduiLen = 0
  1645. local zhenduiList = {}
  1646. local bezhenduiList = {}
  1647. local hpHurtRate = 0
  1648. local extraSpeedHurt = 0
  1649. local firstHurt = 0
  1650. local sexHurt = 0
  1651. local campHurt = 0
  1652. local reJobHurt = 0
  1653. local buffAndHPSubHurt = 0
  1654. for k,skillList in pairs(attacker.beSkillList) do
  1655. for j,v in pairs(skillList) do
  1656. --local config = SkillExcel[v[1]]
  1657. local config = Skill.GetSkillConfig(v[1])
  1658. if config.cmd == "zhanyi" then --战意 伤害加成
  1659. local nowHp = attacker.hp
  1660. local hpMax = CombatObj.getHpMax(attacker)
  1661. local percent = math.floor( (hpMax - nowHp )/hpMax * 100)
  1662. if percent >= 1 then
  1663. zhanyiRet = zhanyiRet + (percent * config.args[2])
  1664. end
  1665. elseif config.cmd == "fuwenAKH" then
  1666. for i = 1,#config.otherArgs do
  1667. zhenduiLen = zhenduiLen + 1
  1668. zhenduiList[config.otherArgs[i][1]] = zhenduiList[config.otherArgs[i][1]] or 0
  1669. zhenduiList[config.otherArgs[i][1]] = zhenduiList[config.otherArgs[i][1]] + config.otherArgs[i][2]
  1670. end
  1671. elseif config.cmd == "hurtBodong" then
  1672. if canUse(attacker, v) then
  1673. local minRet = config.args[1]
  1674. local maxRet = config.args[2]
  1675. local randomRet = math.random(minRet, maxRet)
  1676. bodongHurtRet = bodongHurtRet + randomRet - 10000
  1677. end
  1678. elseif config.cmd == "hpExtraHurt" then
  1679. local hp = defender.hp
  1680. local beSkillArgs = config.beSkillArgs
  1681. local checkHp = CombatObj.getHpMax(defender) * beSkillArgs[3] / 10000
  1682. if beSkillArgs[2] == 1 and hp > checkHp then
  1683. hpHurtRate = beSkillArgs[4]
  1684. elseif beSkillArgs[2] == 2 and hp < checkHp then
  1685. hpHurtRate = beSkillArgs[4]
  1686. end
  1687. elseif config.cmd == "extraSpeedHurt" then
  1688. extraSpeedHurt = config.args[1]
  1689. elseif config.cmd == "firstAttackHurt" then
  1690. if canUse(attacker, v) then
  1691. firstHurt = config.args[1]
  1692. end
  1693. elseif config.cmd == "buffAndHPSub" then
  1694. local nowHp = defender.hp
  1695. local hpMax = CombatObj.getHpMax(defender)
  1696. local percent = math.floor((hpMax - nowHp )/hpMax * 100) --已损失血量百分比
  1697. local condCfg = config.args
  1698. local condRate = condCfg[1]
  1699. if percent >= condRate then
  1700. local condStatusList = condCfg[2] or {}
  1701. local objNowSatus = CombatBuff.getStatus(defender)
  1702. for _, buffCmd in pairs(condStatusList) do
  1703. if objNowSatus[buffCmd] then
  1704. buffAndHPSubHurt = condCfg[3] or 0
  1705. break
  1706. end
  1707. end
  1708. end
  1709. elseif config.cmd == "hpSubHurtAdd" then
  1710. local nowHp = attacker.hp
  1711. local hpMax = CombatObj.getHpMax(attacker)
  1712. local percent = math.floor((hpMax - nowHp )/hpMax * 100) --已损失血量百分比
  1713. local condCfg = config.beSkillArgs
  1714. local condRate = condCfg[1]
  1715. if percent >= condRate then
  1716. hpHurtRate = hpHurtRate + condCfg[2]
  1717. end
  1718. end
  1719. end
  1720. end
  1721. for k,skillList in pairs(defender.beSkillList) do
  1722. for j,v in pairs(skillList) do
  1723. --local conf = SkillExcel[v[1]]
  1724. local conf = Skill.GetSkillConfig(v[1])
  1725. if conf then
  1726. if conf.cmd == "befuwenAKH" then
  1727. for i = 1,#conf.otherArgs do
  1728. zhenduiLen = zhenduiLen + 1
  1729. bezhenduiList[conf.otherArgs[i][1]] = bezhenduiList[conf.otherArgs[i][1]] or 0
  1730. bezhenduiList[conf.otherArgs[i][1]] = bezhenduiList[conf.otherArgs[i][1]] + conf.otherArgs[i][2]
  1731. end
  1732. -- 受性别增伤
  1733. elseif conf.cmd == "sexHurt" then
  1734. if attacker.sex == conf.args[1] then
  1735. sexHurt = sexHurt + conf.args[2]
  1736. end
  1737. -- 受阵营增伤
  1738. elseif conf.cmd == "campHurt" then
  1739. if attacker.camp == conf.args[1] then
  1740. campHurt = campHurt + conf.args[2]
  1741. end
  1742. -- 受职业增伤
  1743. elseif conf.cmd == "reJobHurt" then
  1744. if attacker.job == conf.args[1] then
  1745. reJobHurt = reJobHurt + conf.args[2]
  1746. end
  1747. end
  1748. end
  1749. end
  1750. end
  1751. if zhenduiLen > 0 then
  1752. local bAdd = 0
  1753. for k,skillList in pairs(defender.beSkillList) do
  1754. for j,v in pairs(skillList) do
  1755. --local conf = SkillExcel[v[1]]
  1756. local conf = Skill.GetSkillConfig(v[1])
  1757. local isFuWenSkill = v[5]
  1758. if conf.cmd and conf.cmd ~= "" and zhenduiList[conf.cmd] then
  1759. -- 符文技能只生效一个
  1760. if isFuWenSkill == 1 then
  1761. if bAdd == 0 then
  1762. zhenduiHurtRate = zhenduiHurtRate + zhenduiList[conf.cmd]
  1763. bAdd = 1
  1764. end
  1765. else
  1766. zhenduiHurtRate = zhenduiHurtRate + zhenduiList[conf.cmd]
  1767. end
  1768. end
  1769. end
  1770. end
  1771. bAdd = 0
  1772. for k,skillList in pairs(attacker.beSkillList) do
  1773. for j,v in pairs(skillList) do
  1774. --local conf = SkillExcel[v[1]]
  1775. local conf = Skill.GetSkillConfig(v[1])
  1776. local isFuWenSkill = v[5]
  1777. if conf.cmd and conf.cmd ~= "" and bezhenduiList[conf.cmd] then
  1778. if isFuWenSkill == 1 then
  1779. if bAdd == 0 then
  1780. zhenduiHurtRate = zhenduiHurtRate + bezhenduiList[conf.cmd]
  1781. bAdd = 1
  1782. end
  1783. else
  1784. zhenduiHurtRate = zhenduiHurtRate + bezhenduiList[conf.cmd]
  1785. end
  1786. end
  1787. end
  1788. end
  1789. end
  1790. --特殊buff 对血族的加成
  1791. local campHurtRate = 0
  1792. local campRate = nil
  1793. local buffCmd = nil
  1794. local camp = nil
  1795. for _,pos in ipairs(CombatDefine.SIDE2POS[attacker.side]) do
  1796. obj = CombatImpl.objList[pos]
  1797. if obj and obj.hp > 0 then
  1798. if obj.beSkillList[BESKILL_TYPE68] then
  1799. local beSkillList = obj.beSkillList[BESKILL_TYPE68][1]
  1800. --local skillConfig = SkillExcel[beSkillList[1]]
  1801. local skillConfig = Skill.GetSkillConfig(beSkillList[1])
  1802. if skillConfig then
  1803. camp = skillConfig.otherArgs.calcCamp[1]
  1804. buffCmd = skillConfig.otherArgs.calcCamp[2]
  1805. campRate = skillConfig.otherArgs.calcCamp[3]
  1806. break
  1807. end
  1808. end
  1809. end
  1810. end
  1811. if buffCmd and campRate and attacker.camp == camp then
  1812. local campHurtCnt = 0
  1813. for _,pos in ipairs(CombatDefine.SIDE2POS[defender.side]) do
  1814. obj = CombatImpl.objList[pos]
  1815. if obj and obj.hp > 0 then
  1816. local isStatus1, cmd1, ind1 = CombatBuff.isStatus(obj, buffCmd)
  1817. if isStatus1 then
  1818. campHurtCnt = campHurtCnt + 1
  1819. end
  1820. end
  1821. end
  1822. if campHurtCnt > 0 then
  1823. campHurtRate = campHurtCnt * campRate
  1824. end
  1825. end
  1826. local extraHurtRate = zhanyiRet + zhenduiHurtRate + bodongHurtRet + hpHurtRate + extraSpeedHurt + firstHurt + sexHurt + campHurt + reJobHurt + campHurtRate + buffAndHPSubHurt
  1827. if attacker.beSkillList[BESKILL_TYPE40] and attacker.beforeHitCheck then
  1828. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE40]) do
  1829. --local skillConfig = SkillExcel[v[1]]
  1830. local skillConfig = Skill.GetSkillConfig(v[1])
  1831. if skillConfig.cmd == "extraHurt" then
  1832. local args = skillConfig.args
  1833. extraHurtRate = extraHurtRate + args[1]
  1834. end
  1835. end
  1836. end
  1837. return extraHurtRate
  1838. end
  1839. --
  1840. function getExtraHurt(attacker, target, tUseskillConfig)
  1841. local extraHurt = 0
  1842. if attacker.beSkillList[BESKILL_TYPE55] then
  1843. local beSkillList = attacker.beSkillList[BESKILL_TYPE55][1]
  1844. --local skillConfig = SkillExcel[beSkillList[1]]
  1845. local skillConfig = Skill.GetSkillConfig(beSkillList[1])
  1846. local buffCmd = target.bufferCmd[skillConfig.otherArgs.buffCmdHurtRate[1]]
  1847. local rate = skillConfig.otherArgs.buffCmdHurtRate[2] / 10000
  1848. if buffCmd then
  1849. local buffCnt = #buffCmd
  1850. local buffIndex = buffCmd[buffCnt]
  1851. local buffer = target.buffer[buffIndex]
  1852. --local conf = BufferExcel[buffer.id]
  1853. local conf = CombatBuff.GetBuffConfig(buffer.id)
  1854. local hurt = buffer.arg[1]
  1855. extraHurt = extraHurt + hurt * rate * buffCnt
  1856. end
  1857. end
  1858. return extraHurt
  1859. end
  1860. -- 根据杀气buff获得额外属性加成
  1861. function GetExtraAttrByShaQi(attacker, targetAttrId)
  1862. local attrVal = 0
  1863. if not attacker then
  1864. return attrVal
  1865. end
  1866. -- for _, skillList in pairs(attacker.beSkillList) do
  1867. -- for _, v in pairs(skillList) do
  1868. -- local config = Skill.GetSkillConfig(v[1])
  1869. -- if config.cmd == "shaqi" then
  1870. -- local buffNum = CombatBuff.getBuffCnt(attacker, config.cmd)
  1871. -- if buffNum <= 0 then
  1872. -- return attrVal
  1873. -- end
  1874. -- for _, attrTb in ipairs(config.args) do
  1875. -- if attrTb[1] == targetAttrId then
  1876. -- attrVal = (attrTb[2] or 0) * buffNum
  1877. -- break
  1878. -- end
  1879. -- end
  1880. -- end
  1881. -- end
  1882. -- end
  1883. local buffNum = CombatBuff.getBuffCnt(attacker, "shaqi")
  1884. if buffNum <= 0 then
  1885. return attrVal
  1886. end
  1887. local attrArr
  1888. for i=1, attacker.buffer[0] do
  1889. local buffer = attacker.buffer[i]
  1890. local conf = CombatBuff.GetBuffConfig(buffer.id)
  1891. if conf.cmd == "shaqi" then
  1892. attrArr = conf.args
  1893. break
  1894. end
  1895. end
  1896. if not attrArr then
  1897. return attrVal
  1898. end
  1899. for _, attrTb in ipairs(attrArr) do
  1900. if attrTb[1] == targetAttrId then
  1901. attrVal = (attrTb[2] or 0) * buffNum
  1902. break
  1903. end
  1904. end
  1905. return attrVal
  1906. end
  1907. --
  1908. function getRandomBuffCmd(attacker, target, cmd)
  1909. local side = attacker.side
  1910. local mathRandom = math.random
  1911. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  1912. local obj = CombatImpl.objList[pos]
  1913. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE56] then
  1914. local beSkillList = obj.beSkillList[BESKILL_TYPE56][1]
  1915. --local skillConfig = SkillExcel[beSkillList[1]]
  1916. local skillConfig = Skill.GetSkillConfig(beSkillList[1])
  1917. local buffCmdRand = skillConfig.otherArgs.buffCmdRand
  1918. if buffCmdRand and cmd == buffCmdRand[1] then
  1919. local random = mathRandom(1, 10000)
  1920. if random <= buffCmdRand[2] then
  1921. return true
  1922. end
  1923. end
  1924. end
  1925. end
  1926. end
  1927. function getHurtPercentRate(attacker, defender, hurt, tUseskillConfig)
  1928. local rate = 0
  1929. for k,skillList in pairs(defender.beSkillList) do
  1930. for j,v in pairs(skillList) do
  1931. --local conf = SkillExcel[v[1]]
  1932. local conf = Skill.GetSkillConfig(v[1])
  1933. if conf and conf.cmd == "behurtRet" then
  1934. local canUse = true
  1935. if conf.beSkillArgs and #conf.beSkillArgs > 0 then
  1936. if conf.beSkillArgs[1] == "hurthpper" then
  1937. local hpMax = CombatObj.getHpMax(defender)
  1938. local percent = hurt/hpMax
  1939. if percent < conf.beSkillArgs[2]/10000 then -- 伤害超过目标生命值上限X%时
  1940. canUse = false
  1941. end
  1942. end
  1943. end
  1944. if canUse == true then
  1945. local random = math.random(1, 10000)
  1946. if random <= conf.args[2] then
  1947. rate = rate + conf.args[1]
  1948. end
  1949. end
  1950. end
  1951. end
  1952. end
  1953. if tUseskillConfig.type == CombatDefine.SKILL_TYPE1 then
  1954. if attacker.beSkillList[BESKILL_TYPE1] then
  1955. for _, v in pairs(attacker.beSkillList[BESKILL_TYPE1]) do
  1956. local nSkillID = v[1]
  1957. --local skillConfig = SkillExcel[nSkillID]
  1958. local skillConfig = Skill.GetSkillConfig(nSkillID)
  1959. if skillConfig and skillConfig.hurtRate and skillConfig.hurtRate[1] then
  1960. local fRate = skillConfig.hurtRate[1]
  1961. rate = rate + fRate
  1962. --print("[getExtraHurt] 获取到的普工伤害加成概率 fRate = "..fRate.." 总加成 rate = "..rate)
  1963. end
  1964. end
  1965. end
  1966. end
  1967. return rate
  1968. end
  1969. function getBufferExtraHurt(attacker,bufferID,cmd)
  1970. local rate = 0
  1971. for _,skillList in pairs(attacker.beSkillList) do
  1972. for k,v in pairs(skillList) do
  1973. --local conf = SkillExcel[v[1]]
  1974. local conf = Skill.GetSkillConfig(v[1])
  1975. local otherArgs = conf.otherArgs
  1976. if bufferID and otherArgs.bufferExtraHurt then
  1977. for k1,v1 in ipairs(otherArgs.bufferExtraHurt[1]) do
  1978. if bufferID == v1 then
  1979. rate = rate + otherArgs.bufferExtraHurt[2]
  1980. end
  1981. end
  1982. end
  1983. if cmd and otherArgs.bufferCmdExtraHurt then
  1984. for k1,v1 in ipairs(otherArgs.bufferCmdExtraHurt[1]) do
  1985. if cmd == v1 then
  1986. rate = rate + otherArgs.bufferCmdExtraHurt[2]
  1987. end
  1988. end
  1989. end
  1990. end
  1991. end
  1992. return rate
  1993. end
  1994. function getExtraHurtRateEx(attacker, defender)
  1995. local rate = 0
  1996. -- 死亡数伤害率
  1997. if attacker.beSkillList[BESKILL_TYPE48] then
  1998. for _,v in ipairs(attacker.beSkillList[BESKILL_TYPE48]) do
  1999. --local skillConfig = SkillExcel[v[1]]
  2000. local skillConfig = Skill.GetSkillConfig(v[1])
  2001. if skillConfig and skillConfig.otherArgs.deathHurt then
  2002. local side = defender.side
  2003. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  2004. local obj = CombatImpl.objList[pos]
  2005. if obj and obj.hp <=0 then
  2006. if rate == 0 then
  2007. rate = skillConfig.otherArgs.deathHurt
  2008. else
  2009. rate = rate + 10000
  2010. end
  2011. end
  2012. end
  2013. end
  2014. end
  2015. end
  2016. return rate
  2017. end
  2018. --
  2019. function getBuffChixuHurt(attacker, cmd)
  2020. if not attacker then return 0 end
  2021. local hurt = 0
  2022. local side = attacker.side
  2023. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  2024. local objM = CombatImpl.objList[pos]
  2025. if objM and objM.hp > 0 and objM.beSkillList[BESKILL_TYPE54] then
  2026. for _,v in ipairs(objM.beSkillList[BESKILL_TYPE54]) do
  2027. --local skillConfig = SkillExcel[v[1]]
  2028. local skillConfig = Skill.GetSkillConfig(v[1])
  2029. if skillConfig and skillConfig.otherArgs[cmd] then
  2030. hurt = hurt + skillConfig.otherArgs[cmd]
  2031. end
  2032. end
  2033. end
  2034. end
  2035. return hurt / 10000
  2036. end
  2037. --
  2038. function handlerBuff(attacker, target, arg, cmd)
  2039. if not attacker then return end
  2040. for _,pos in ipairs(CombatDefine.SIDE2POS[attacker.side]) do
  2041. local obj = CombatImpl.objList[pos]
  2042. if obj and obj.hp > 0 and obj.beSkillList[BESKILL_TYPE57] then
  2043. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE57]) do
  2044. attacker.args = arg
  2045. use(attacker, {target}, v, false)
  2046. end
  2047. end
  2048. end
  2049. end
  2050. function beforeMinusHp(obj, value)
  2051. if value <= 0 then return end
  2052. --敌对阵营 有对象有 49号被动技能 加血变成减血
  2053. local side = obj.side == CombatDefine.ATTACK_SIDE and CombatDefine.DEFEND_SIDE or CombatDefine.ATTACK_SIDE
  2054. for _,pos in ipairs(CombatDefine.SIDE2POS[side]) do
  2055. local objM = CombatImpl.objList[pos]
  2056. if objM and objM.hp > 0 and objM.beSkillList[BESKILL_TYPE49] then
  2057. value = value * (-1)
  2058. break
  2059. end
  2060. end
  2061. return value
  2062. end
  2063. function beforeUpdateHp(obj,sum)
  2064. if sum <= 0 and obj.beSkillList[BESKILL_TYPE41] then
  2065. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE41]) do
  2066. --local skillConfig = SkillExcel[v[1]]
  2067. local skillConfig = Skill.GetSkillConfig(v[1])
  2068. if skillConfig.cmd == "miansi" and canUse(obj,v) then
  2069. use(obj,{},v)
  2070. return true
  2071. end
  2072. end
  2073. end
  2074. end
  2075. function onCheckBuffer(obj,attacker,value)
  2076. local ret = value
  2077. if obj.beSkillList[BESKILL_TYPE42] then
  2078. for _,v in ipairs(obj.beSkillList[BESKILL_TYPE42]) do
  2079. --local skillConfig = SkillExcel[v[1]]
  2080. local skillConfig = Skill.GetSkillConfig(v[1])
  2081. if canUse(obj,v) then
  2082. local newFrame = true
  2083. if skillConfig.cmd == "baohu" then
  2084. obj.baohuHurt = value * skillConfig.args[1] / 10000
  2085. if obj.hp < -obj.baohuHurt then
  2086. obj.baohuHurt = -obj.hp
  2087. end
  2088. ret = value - obj.baohuHurt
  2089. newFrame = false
  2090. end
  2091. use(obj,{attacker},v, newFrame)
  2092. break
  2093. end
  2094. end
  2095. end
  2096. return ret
  2097. end
  2098. function getStatusBaoji(attacker, defender)
  2099. local baoji = 0
  2100. local firstBaoji = 0
  2101. for k, skillList in pairs(attacker.beSkillList) do
  2102. for j, v in pairs(skillList) do
  2103. --local config = SkillExcel[v[1]]
  2104. local config = Skill.GetSkillConfig(v[1])
  2105. if config.cmd == "firstAttackHurt" then
  2106. if canUse(attacker, v) then
  2107. firstBaoji = config.args[2] or 0
  2108. end
  2109. end
  2110. end
  2111. end
  2112. if attacker.beSkillList[BESKILL_TYPE60] then
  2113. for _, v in ipairs(attacker.beSkillList[BESKILL_TYPE60]) do
  2114. --local skillConfig = SkillExcel[v[1]]
  2115. local skillConfig = Skill.GetSkillConfig(v[1])
  2116. if skillConfig and skillConfig.otherArgs.addStatusBaoji then
  2117. local status = CombatBuff.getStatus(defender)
  2118. local isStatus = false
  2119. for k, v in ipairs(skillConfig.otherArgs.addStatusBaoji[1]) do
  2120. if status[v] then
  2121. isStatus = true
  2122. break
  2123. end
  2124. end
  2125. if isStatus then
  2126. baoji = baoji + skillConfig.otherArgs.addStatusBaoji[2]
  2127. end
  2128. end
  2129. end
  2130. end
  2131. if attacker.beSkillList[BESKILL_TYPE69] and attacker.notBaoJi then
  2132. for _, v in ipairs(attacker.beSkillList[BESKILL_TYPE69]) do
  2133. --local skillConfig = SkillExcel[v[1]]
  2134. local skillConfig = Skill.GetSkillConfig(v[1])
  2135. if skillConfig and skillConfig.otherArgs.addNotBaoji then
  2136. baoji = baoji + skillConfig.otherArgs.addNotBaoji
  2137. end
  2138. end
  2139. end
  2140. return baoji + firstBaoji
  2141. end
  2142. function getStatusPojia(attacker, defender)
  2143. local poJia = 0
  2144. -- 对指定状态破甲加成 走的技能状态属性
  2145. if attacker.beSkillList[BESKILL_TYPE60] then
  2146. for _, v in ipairs(attacker.beSkillList[BESKILL_TYPE60]) do
  2147. --local skillConfig = SkillExcel[v[1]]
  2148. local skillConfig = Skill.GetSkillConfig(v[1])
  2149. if skillConfig.otherArgs.addStatusPoJia then
  2150. local status = CombatBuff.getStatus(defender)
  2151. local isStatus = false
  2152. for k, v in ipairs(skillConfig.otherArgs.addStatusPoJia[1]) do
  2153. if status[v] then
  2154. isStatus = true
  2155. break
  2156. end
  2157. end
  2158. if isStatus then
  2159. poJia = poJia + skillConfig.otherArgs.addStatusPoJia[2]
  2160. end
  2161. end
  2162. end
  2163. end
  2164. return poJia
  2165. end
  2166. -- 是否不会被反击
  2167. function isNoFanji(obj)
  2168. if obj.beSkillList[BESKILL_TYPE72] then
  2169. for _, v in ipairs(obj.beSkillList[BESKILL_TYPE72]) do
  2170. local skillConfig = Skill.GetSkillConfig(v[1])
  2171. if skillConfig.cmd == "noFanji" then
  2172. return true
  2173. end
  2174. end
  2175. end
  2176. return false
  2177. end
  2178. -- 获取与神威灵装"真伤附加"效果相对的"真伤减免"
  2179. function GetTrueDamegeOffset(obj)
  2180. if obj.beSkillList[BESKILL_TYPE72] then
  2181. for _, v in ipairs(obj.beSkillList[BESKILL_TYPE72]) do
  2182. local skillConfig = Skill.GetSkillConfig(v[1])
  2183. if skillConfig.cmd == "trueDamegeOffset" then
  2184. local offsetInfo = {}
  2185. offsetInfo[1] = skillConfig.beSkillArgs[1]
  2186. offsetInfo[2] = skillConfig.beSkillArgs[2]
  2187. return offsetInfo
  2188. end
  2189. end
  2190. end
  2191. end
  2192. -- 触发格挡后额外减伤
  2193. function GetGeDangExtraDef(obj)
  2194. if obj.beSkillList[BESKILL_TYPE72] then
  2195. for _, v in ipairs(obj.beSkillList[BESKILL_TYPE72]) do
  2196. local skillConfig = Skill.GetSkillConfig(v[1])
  2197. if skillConfig.cmd == "gedangExtraDef" then
  2198. return skillConfig.beSkillArgs[1]
  2199. end
  2200. end
  2201. end
  2202. return 0
  2203. end
  2204. -- 伤害翻倍
  2205. function GetBeSkillHurtMul(obj)
  2206. if obj.beSkillList[BESKILL_TYPE72] then
  2207. for _, v in ipairs(obj.beSkillList[BESKILL_TYPE72]) do
  2208. local skillConfig = Skill.GetSkillConfig(v[1])
  2209. if skillConfig.cmd == "physicalDamageMul" and obj.hurtType == CombatDefine.PHY_HURT_TYPE then
  2210. return math.random(skillConfig.beSkillArgs[1], skillConfig.beSkillArgs[2])
  2211. end
  2212. if skillConfig.cmd == "magicDamageMul" and obj.hurtType == CombatDefine.MAGIC_HURT_TYPE then
  2213. return math.random(skillConfig.beSkillArgs[1], skillConfig.beSkillArgs[2])
  2214. end
  2215. end
  2216. end
  2217. end
  2218. -- 回血翻倍
  2219. function GetBeSkillRestoretHPMul(obj)
  2220. local mul = 1
  2221. if obj.beSkillList[BESKILL_TYPE72] then
  2222. for _, v in ipairs(obj.beSkillList[BESKILL_TYPE72]) do
  2223. local skillConfig = Skill.GetSkillConfig(v[1])
  2224. if skillConfig.cmd == "restoreHPMul" then
  2225. local r = math.random(1,10000)
  2226. if r <= (skillConfig.beSkillArgs[2] or 0) then
  2227. mul = skillConfig.beSkillArgs[1] or 1
  2228. end
  2229. return mul
  2230. end
  2231. end
  2232. end
  2233. return mul
  2234. end