This commit is contained in:
libccy 2018-08-13 13:06:33 +08:00
parent 8c76f62af3
commit 3ff6839c51
2 changed files with 109 additions and 37 deletions

View File

@ -9535,40 +9535,75 @@
event.callback(); event.callback();
} }
}, },
createTrigger:function(){ arrangeTrigger:function(){
"step 0" 'step 0'
if(player._hookTrigger){ var list=event.list;
for(var i=0;i<player._hookTrigger.length;i++){ if(!list.length){
var info=lib.skill[player._hookTrigger[i]].hookTrigger; event.finish();
if(info){ return;
if(info.before&&info.before(event,player,event.triggername)){ }
event.trigger('triggerBefore'); event.choice=[];
break; event.num=0;
} var filter=function(i){
if(list[i][1]==list[0][1]&&list[i][1].hasStockSkill(list[i][0],true,true,true)){
if(get.info(list[i][0]).forced){
return false;
}
return true;
}
return false;
}
var filter2=function(i){
return lib.filter.filterTrigger(event.source,list[i][1],event.triggername,list[i][0]);
}
if(filter(0)){
event.choice.push(list[0]);
for(var i=1;i<list.length;i++){
if(filter(i)){
event.choice.push(list[i]);
} }
} }
} }
"step 1" if(event.choice.length>1){
var info=get.info(event.skill); for(var i=0;i<event.choice.length;i++){
if(event.cancelled){ if(!filter2(i)){
event.finish(); event.list.splice(i--,1);
if(event.list.length<=1) break;
}
}
} }
else if(info.filter&&!info.filter(trigger,player,event.triggername)){ if(event.choice.length<=1){
event.finish(); event.goto(3);
} }
else if(event._trigger._notrigger.contains(player)&&!lib.skill.global.contains(event.skill)){ 'step 1'
event.finish(); var controls=[];
event.current=event.choice[0][1]
for(var i=0;i<event.choice.length;i++){
controls.push(event.choice[i][0]);
} }
else if(typeof info.usable=='number'&&player.hasSkill('counttrigger')&& event.current.chooseControl(controls).set('prompt','选择下一个触发的技能');
player.storage.counttrigger&&player.storage.counttrigger[event.skill]>=info.usable){ 'step 2'
event.finish(); if(result.control){
for(var i=0;i<event.list.length;i++){
if(event.list[i][0]==result.control&&event.list[i][1]==event.current){
event.num=i;break;
}
}
} }
else if(info.round&&(info.round-(game.roundNumber-player.storage[event.skill+'_roundcount'])>0)){ 'step 3'
event.finish(); var info=event.list[event.num];
if(info){
event.list.splice(event.num,1);
game.createTrigger(event.triggername,info[0],info[1],event.source);
} }
else{ event.goto(0);
},
createTrigger:function(){
"step 0"
if(lib.filter.filterTrigger(trigger,player,event.triggername,event.skill)){
var fullskills=game.expandSkills(player.getSkills().concat(lib.skill.global)); var fullskills=game.expandSkills(player.getSkills().concat(lib.skill.global));
if(!fullskills.contains(event.skill)){ if(!fullskills.contains(event.skill)){
var info=get.info(event.skill);
var hidden=player.hiddenSkills.slice(0); var hidden=player.hiddenSkills.slice(0);
game.expandSkills(hidden); game.expandSkills(hidden);
if(hidden.contains(event.skill)){ if(hidden.contains(event.skill)){
@ -9595,7 +9630,10 @@
} }
} }
} }
"step 2" else{
event.finish();
}
"step 1"
if(event.cancelled){ if(event.cancelled){
event.finish(); event.finish();
return; return;
@ -9656,7 +9694,7 @@
} }
} }
} }
"step 3" "step 2"
var info=get.info(event.skill); var info=get.info(event.skill);
if(result&&result.bool!=false){ if(result&&result.bool!=false){
if(info.autodelay&&(info.forced||!event.isMine())){ if(info.autodelay&&(info.forced||!event.isMine())){
@ -9668,7 +9706,7 @@
} }
} }
} }
"step 4" "step 3"
var info=get.info(event.skill); var info=get.info(event.skill);
if(result&&result.bool==false){ if(result&&result.bool==false){
if(info.oncancel) info.oncancel(trigger,player); if(info.oncancel) info.oncancel(trigger,player);
@ -9712,7 +9750,7 @@
} }
} }
} }
"step 5" "step 4"
if(player._hookTrigger){ if(player._hookTrigger){
for(var i=0;i<player._hookTrigger.length;i++){ for(var i=0;i<player._hookTrigger.length;i++){
var info=lib.skill[player._hookTrigger[i]].hookTrigger; var info=lib.skill[player._hookTrigger[i]].hookTrigger;
@ -21052,8 +21090,17 @@
return b[2]-a[2]; return b[2]-a[2];
}); });
if(list.length){ if(list.length){
for(var i=0;i<list.length;i++){ if(game.arrangeTrigger){
game.createTrigger(name,list[i][0],list[i][1],event); var next=game.createEvent('arrangeTrigger',false,event);
next.setContent('arrangeTrigger');
next.list=list;
next.source=event;
next.triggername=name;
}
else{
for(var i=0;i<list.length;i++){
game.createTrigger(name,list[i][0],list[i][1],event);
}
} }
} }
}, },
@ -21405,6 +21452,33 @@
filterButton:function(button){ filterButton:function(button){
return true; return true;
}, },
filterTrigger:function(event,player,name,skill){
if(player._hookTrigger){
for(var i=0;i<player._hookTrigger.length;i++){
var info=lib.skill[player._hookTrigger[i]].hookTrigger;
if(info){
if(info.block&&info.block(event,player,name)){
return false;
}
}
}
}
var info=get.info(skill);
if(info.filter&&!info.filter(event,player,name)){
return false;
}
if(event._notrigger.contains(player)&&!lib.skill.global.contains(skill)){
return false;
}
if(typeof info.usable=='number'&&player.hasSkill('counttrigger')&&
player.storage.counttrigger&&player.storage.counttrigger[skill]>=info.usable){
return false;
}
if(info.round&&(info.round-(game.roundNumber-player.storage[skill+'_roundcount'])>0)){
return false;
}
return true;
},
characterDisabled:function(i,libCharacter){ characterDisabled:function(i,libCharacter){
if(lib.character[i][4]&&lib.character[i][4].contains('forbidai')) return true; if(lib.character[i][4]&&lib.character[i][4].contains('forbidai')) return true;
if(lib.character[i][4]&&lib.character[i][4].contains('unseen')) return true; if(lib.character[i][4]&&lib.character[i][4].contains('unseen')) return true;

View File

@ -26,6 +26,9 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
} }
} }
} }
if(get.config('onlyguozhan')&&!playback){
game.arrangeTrigger=true;
}
}, },
onreinit:function(){ onreinit:function(){
var pack=lib.characterPack.mode_guozhan; var pack=lib.characterPack.mode_guozhan;
@ -1450,21 +1453,16 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
} }
}, },
disallow:{ disallow:{
trigger:{player:['triggerBefore']},
silent:true,
hookTrigger:{ hookTrigger:{
before:function(event,player,name){ block:function(event,player,name){
for(var i=0;i<player.storage.gzhuashen_trigger.length;i++){ for(var i=0;i<player.storage.gzhuashen_trigger.length;i++){
var info=player.storage.gzhuashen_trigger[i]; var info=player.storage.gzhuashen_trigger[i];
if(info[0]==event._trigger&&info[1]==name){ if(info[0]==event&&info[1]==name){
return true; return true;
} }
} }
return false; return false;
} }
},
content:function(){
trigger.cancelled=true;
} }
}, },
remove:{ remove:{