This commit is contained in:
libccy 2017-11-07 21:00:33 +08:00
parent c7b2b60339
commit 3d581cf103
4 changed files with 135 additions and 6 deletions

View File

@ -565,7 +565,7 @@ game.import('card',function(lib,game,ui,get,ai,_status){
'step 0' 'step 0'
player.chooseToUse({name:'jinchan'},'是否对'+get.translation(trigger.card)+'使用【金蝉脱壳】?').set('ai1',function(card){ player.chooseToUse({name:'jinchan'},'是否对'+get.translation(trigger.card)+'使用【金蝉脱壳】?').set('ai1',function(card){
return _status.event.bool; return _status.event.bool;
}).set('bool',-get.effect(player,trigger.card,trigger.player,player)); }).set('bool',-get.effect(player,trigger.card,trigger.player,player)).set('respondTo',[trigger.player,trigger.card]);
trigger.jinchan=true; trigger.jinchan=true;
'step 1' 'step 1'
delete trigger.jinchan; delete trigger.jinchan;

View File

@ -1685,6 +1685,9 @@ game.import('card',function(lib,game,ui,get,ai,_status){
id:id, id:id,
id2:id2 id2:id2
}); });
if(!isJudge){
next.set('respondTo',[source,card]);
}
if(game.online){ if(game.online){
_status.event._resultid=id; _status.event._resultid=id;
game.resume(); game.resume();
@ -1809,7 +1812,10 @@ game.import('card',function(lib,game,ui,get,ai,_status){
} }
'step 8' 'step 8'
if(event.wuxieresult){ if(event.wuxieresult){
event.wuxieresult.useResult(event.wuxieresult2); var next=event.wuxieresult.useResult(event.wuxieresult2);
if(event.triggername!='phaseJudge'){
next.respondTo=[trigger.player,trigger.card];
}
} }
'step 9' 'step 9'
if(event.wuxieresult){ if(event.wuxieresult){

View File

@ -82,7 +82,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
caiyong:['male','qun',3,['bizhuan','tongbo']], caiyong:['male','qun',3,['bizhuan','tongbo']],
jikang:['male','wei',3,['qingxian','juexiang']], jikang:['male','wei',3,['qingxian','juexiang']],
qinmi:['male','wu',3,['jianzheng','zhuandui','tianbian']], qinmi:['male','wu',3,['jianzheng','zhuandui','tianbian']],
// xuezong:['male','shu',3,['funan','jiexun']], xuezong:['male','wu',3,['funan','jiexun']],
}, },
characterIntro:{ characterIntro:{
huaxiong:'董卓旗下名将,自荐抵抗山东地区反对董卓的诸侯联军于汜水关前,他先后斩杀济北相鲍信之弟鲍忠和孙坚部将祖茂、以及袁术部将俞涉和韩馥手下潘凤等人,最后关东联军派出关羽与之一对一决斗而被杀。', huaxiong:'董卓旗下名将,自荐抵抗山东地区反对董卓的诸侯联军于汜水关前,他先后斩杀济北相鲍信之弟鲍忠和孙坚部将祖茂、以及袁术部将俞涉和韩馥手下潘凤等人,最后关东联军派出关羽与之一对一决斗而被杀。',
@ -170,6 +170,119 @@ game.import('character',function(lib,game,ui,get,ai,_status){
liuchen:['liushan'], liuchen:['liushan'],
}, },
skill:{ skill:{
funan:{
trigger:{global:['respondAfter','useCardAfter']},
filter:function(event,player){
if(!event.respondTo) return false;
if(event.player==player) return false;
if(player!=event.respondTo[0]) return false;
if(get.itemtype(event.cards)!='cards') return false;
if(['h','e','j'].contains(get.position(event.cards[0]))) return false;
if(get.itemtype(event.respondTo[1])!='card') return false;
if(['h','e','j'].contains(get.position(event.respondTo[1]))) return false;
return true;
},
logTarget:'player',
check:function(event,player){
if(get.attitude(player,event.player)>=0) return true;
if(player.hasSkill('funan_jiexun')&&player.storage.funan_jiexun==event.player) return true;
if(event.cards.length>1) return true;
return get.value(event.cards[0])>get.value(event.respondTo[1]);
},
content:function(){
'step 0'
if(!player.hasSkill('funan_jiexun')||player.storage.funan_jiexun!=trigger.player){
trigger.player.gain(trigger.respondTo[1],'gain2');
trigger.player.addTempSkill('funan_use');
if(!trigger.player.storage.funan_use){
trigger.player.storage.funan_use=[];
}
trigger.player.storage.funan_use.add(trigger.respondTo[1]);
}
'step 1'
player.gain(trigger.cards,'gain2');
},
subSkill:{
jiexun:{
mark:'character',
intro:{
content:'你发动“复难”时,无须令$获得你使用的牌'
},
trigger:{global:'dieAfter'},
silent:true,
filter:function(event,player){
return player.storage.funan_jiexun==event.player;
},
onremove:true,
content:function(){
player.removeSkill('funan_jiexun');
}
},
use:{
onremove:true,
mod:{
cardEnabled:function(card,player){
if(player.storage.funan_use&&player.storage.funan_use.contains(card)){
return false;
}
}
}
}
}
},
jiexun:{
trigger:{player:'phaseEnd'},
filter:function(event,player){
return game.hasPlayer(function(current){
return current.countCards('ej',{suit:'diamond'});
});
},
init:function(player){
player.storage.jiexun=0;
},
onremove:true,
direct:true,
content:function(){
'step 0'
var num1=game.countPlayer(function(current){
return current.countCards('ej',{suit:'diamond'});
});
var num2=player.storage.jiexun;
event.num1=num1;
event.num2=num2;
var str='令目标摸'+get.cnNumber(num1)+'张牌';
if(num2){
str+=',然后弃置'+get.cnNumber(num2)+'张牌;若目标因此法弃置了所有牌,则你失去“诫训”,然后你发动“复难”时,无须令其获得你使用的牌';
}
player.chooseTarget(get.prompt('jiexun')).set('ai',function(target){
return _status.event.coeff*get.attitude(_status.event.player,target);
}).set('coeff',num1>=num2?1:-1).set('prompt2',str);
'step 1'
if(result.bool){
var target=result.targets[0];
event.target=target;
player.logSkill('jiexun',target);
target.draw(event.num1);
player.storage.jiexun++;
}
else{
event.finish();
}
'step 2'
if(event.num2){
event.target.chooseToDiscard(event.num2,true,'he');
}
else{
event.finish();
}
'step 3'
if(!event.target.countCards('he')){
player.removeSkill('jiexun');
player.storage.funan_jiexun=event.target;
player.addSkill('funan_jiexun');
}
}
},
zhuandui:{ zhuandui:{
group:['zhuandui_respond','zhuandui_use'], group:['zhuandui_respond','zhuandui_use'],
subSkill:{ subSkill:{
@ -8879,6 +8992,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
qinmi:'秦宓', qinmi:'秦宓',
caiyong:'蔡邕', caiyong:'蔡邕',
funan_jiexun:'诫训',
bizhuan:'辟撰', bizhuan:'辟撰',
bizhuan_bg:'书', bizhuan_bg:'书',
bizhuan_info:'当你使用黑桃牌后,或你成为其他角色使用黑桃牌的目标后,你可以将牌堆顶的一张牌置于武将牌上,称为“书”;你至多拥有四张“书”,你每有一张“书” ,手牌上限+1', bizhuan_info:'当你使用黑桃牌后,或你成为其他角色使用黑桃牌的目标后,你可以将牌堆顶的一张牌置于武将牌上,称为“书”;你至多拥有四张“书”,你每有一张“书” ,手牌上限+1',

View File

@ -9987,7 +9987,10 @@
if(info&&info.onrespond){ if(info&&info.onrespond){
info.onrespond(event.result,player); info.onrespond(event.result,player);
} }
player.respond(event.result.cards,event.result.card,event.animate,event.result.skill,event.source); var next=player.respond(event.result.cards,event.result.card,event.animate,event.result.skill,event.source);
if(event.parent.card&&event.parent.type=='card'){
next.set('respondTo',[event.parent.player,event.parent.card]);
}
} }
if(event.dialog&&event.dialog.close) event.dialog.close(); if(event.dialog&&event.dialog.close) event.dialog.close();
}, },
@ -11660,6 +11663,7 @@
next.card=card; next.card=card;
next.cards=cards; next.cards=cards;
next.player=player; next.player=player;
next.type='precard';
} }
else if(info.reverseOrder&&get.is.versus()&&targets.length>1){ else if(info.reverseOrder&&get.is.versus()&&targets.length>1){
var next=game.createEvent(card.name+'ContentBefore'); var next=game.createEvent(card.name+'ContentBefore');
@ -11668,6 +11672,7 @@
next.card=card; next.card=card;
next.cards=cards; next.cards=cards;
next.player=player; next.player=player;
next.type='precard';
} }
"step 2" "step 2"
if(targets[num]&&targets[num].isDead()) return; if(targets[num]&&targets[num].isDead()) return;
@ -11749,6 +11754,7 @@
next.cards=cards; next.cards=cards;
next.player=player; next.player=player;
next.preResult=event.preResult; next.preResult=event.preResult;
next.type='postcard';
} }
"step 5" "step 5"
if(event.postAi){ if(event.postAi){
@ -15255,11 +15261,14 @@
} }
if(result.card||!result.skill){ if(result.card||!result.skill){
result.used=result.card||result.cards[0]; result.used=result.card||result.cards[0];
this.useCard(result.card,result.cards,result.targets,result.skill).oncard=event.oncard; var next=this.useCard(result.card,result.cards,result.targets,result.skill);
next.oncard=event.oncard;
next.respondTo=event.respondTo;
return next;
} }
else if(result.skill){ else if(result.skill){
result.used=result.skill; result.used=result.skill;
this.useSkill(result.skill,result.cards,result.targets); return this.useSkill(result.skill,result.cards,result.targets);
} }
}, },
useCard:function(){ useCard:function(){