From 270499d66041f6442bae0f324d0957e4d2859aa3 Mon Sep 17 00:00:00 2001 From: PZ157 <3619242020@qq.com> Date: Wed, 15 Nov 2023 19:20:12 +0800 Subject: [PATCH] =?UTF-8?q?bugfix,=20ai=E4=BC=98=E5=8C=96?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- character/sp2.js | 15 ++++++++++++--- character/tw.js | 4 ++-- 2 files changed, 14 insertions(+), 5 deletions(-) diff --git a/character/sp2.js b/character/sp2.js index 64a4ff12c..16331a173 100644 --- a/character/sp2.js +++ b/character/sp2.js @@ -5529,7 +5529,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){ ai:{ effect:{ target:function(card,player,target,current,isLink){ - if(isLink||!player.isPhaseUsing()) return; + if(isLink||typeof card!=='object'||!player.isPhaseUsing()) return; var num; var evt=_status.event.getParent('useCard'),evt2=_status.event.getParent('phaseUse'); if(evt.card==card){ @@ -5541,8 +5541,17 @@ game.import('character',function(lib,game,ui,get,ai,_status){ return evt.getParent('phaseUse')==evt2; }).length; if(num<0||num>1) return; - if(num==0&&get.tag(card,'damage')) return 'zerotarget'; - if(num==1&&get.color(card)=='black') return 'zeroplayertarget'; + if(num===0&&get.tag(card,'damage')){ + if(target.hasSkillTag('filterDamage',null,{ + player:player, + card:card + })||!player.hasSkillTag('damageBonus',true,{ + target:target, + card:card + })) return 'zerotarget'; + return [0.5,0,0.5,0]; + } + if(num===1&&get.color(card)=='black') return 'zeroplayertarget'; }, }, }, diff --git a/character/tw.js b/character/tw.js index ce0aaca15..5cb3b4060 100644 --- a/character/tw.js +++ b/character/tw.js @@ -13712,11 +13712,11 @@ game.import('character',function(lib,game,ui,get,ai,_status){ effect:{ target:function(card,player,target){ if(typeof card=='object'&&target.storage.gx_chongyingshenfu_effect&&target.getStorage('gx_chongyingshenfu_effect').includes(card.name)&&!target.hasSkillTag('unequip2')&& - get.itemtype(player)!=='player'||!player.hasSkillTag('jueqing',false,target)&&!player.hasSkillTag('unequip',false,{ + (get.itemtype(player)!=='player'||!player.hasSkillTag('jueqing',false,target)&&!player.hasSkillTag('unequip',false,{ name:card.name, target:target, card:card, - })){ + }))){ if(player&&player.hasSkillTag('damageBonus',true,{ target:target, card:card