collab.js ~ mobile.js chooseToUse相关技能完成修改

This commit is contained in:
Spmario233 2024-03-03 10:59:30 +08:00
parent c6817e5095
commit ee4aee82aa
8 changed files with 55 additions and 55 deletions

View File

@ -101,10 +101,10 @@ game.import('character',function(lib,game,ui,get,ai,_status){
}, },
filter(event,player){ filter(event,player){
var filter=event.filterCard; var filter=event.filterCard;
if(filter({name:'sha',nature:'fire'},player,event)&&player.countCards('hes',{suit:'diamond'})) return true; if(filter(get.autoViewAs({name:'sha',nature:'fire'},'unsure'),player,event)&&player.countCards('hes',{suit:'diamond'})) return true;
if(filter({name:'shan'},player,event)&&player.countCards('hes',{suit:'club'})) return true; if(filter(get.autoViewAs({name:'shan'},'unsure'),player,event)&&player.countCards('hes',{suit:'club'})) return true;
if(filter({name:'tao'},player,event)&&player.countCards('hes',{suit:'heart'})) return true; if(filter(get.autoViewAs({name:'tao'},'unsure'),player,event)&&player.countCards('hes',{suit:'heart'})) return true;
if(filter({name:'wuxie'},player,event)&&player.countCards('hes',{suit:'spade'})) return true; if(filter(get.autoViewAs({name:'wuxie'},'unsure'),player,event)&&player.countCards('hes',{suit:'spade'})) return true;
return false; return false;
}, },
usable:20, usable:20,

View File

@ -2385,8 +2385,8 @@ game.import('character',function(lib,game,ui,get,ai,_status){
else wuxie=true; else wuxie=true;
} }
} }
if(shan&&event.filterCard({name:'shan'},player,event)) return true; if(shan&&event.filterCard(get.autoViewAs({name:'shan'},'unsure'),player,event)) return true;
if(wuxie&&event.filterCard({name:'wuxie'},player,event)) return true; if(wuxie&&event.filterCard(get.autoViewAs({name:'wuxie'},'unsure'),player,event)) return true;
return false; return false;
}, },
hiddenCard (player,name){ hiddenCard (player,name){

View File

@ -1909,6 +1909,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
if(!Array.isArray(list)||typeof num!='number'||list.length<=num) return false; if(!Array.isArray(list)||typeof num!='number'||list.length<=num) return false;
var card=get.copy(list[num]); var card=get.copy(list[num]);
delete card.isCard; delete card.isCard;
card=get.autoViewAs(card,'unsure');
if(event.filterCard(card,player,event)) return true; if(event.filterCard(card,player,event)) return true;
return false; return false;
}, },
@ -2266,10 +2267,10 @@ game.import('character',function(lib,game,ui,get,ai,_status){
for(var i of lib.inpile){ for(var i of lib.inpile){
var type=lib.skill.nsxingyun.getSixiang(i); var type=lib.skill.nsxingyun.getSixiang(i);
if(!type||list.includes(type)) continue; if(!type||list.includes(type)) continue;
if(event.filterCard({name:i},player,event)) return true; if(event.filterCard(get.autoViewAs({name:i},'unsure'),player,event)) return true;
if(i=='sha'){ if(i=='sha'){
for(var j of lib.inpile_nature){ for(var j of lib.inpile_nature){
if(event.filterCard({name:i,nature:j},player,event)) return true; if(event.filterCard(get.autoViewAs({name:i,nature:j},'unsure'),player,event)) return true;
} }
} }
} }
@ -9508,7 +9509,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
if(event.type=='wuxie'||!player.countCards('hse',{suit:'diamond'})) return false; if(event.type=='wuxie'||!player.countCards('hse',{suit:'diamond'})) return false;
for(var i=0;i<lib.inpile.length;i++){ for(var i=0;i<lib.inpile.length;i++){
var name=lib.inpile[i]; var name=lib.inpile[i];
if(name!='du'&&name!='shan'&&get.type(name)=='basic'&&event.filterCard({name:name},player,event)) return true; if(name!='du'&&name!='shan'&&get.type(name)=='basic'&&event.filterCard(get.autoViewAs({name:name},'unsure'),player,event)) return true;
} }
return false; return false;
}, },

View File

@ -2511,16 +2511,16 @@ game.import('character',function(lib,game,ui,get,ai,_status){
if(event.responded||event.shouli||event.type=='wuxie') return false; if(event.responded||event.shouli||event.type=='wuxie') return false;
if(game.hasPlayer(function(current){ if(game.hasPlayer(function(current){
return current.getCards('e',card=>get.is.attackingMount(card)).length>0; return current.getCards('e',card=>get.is.attackingMount(card)).length>0;
})&&event.filterCard({ })&&event.filterCard(get.autoViewAs({
name:'sha', name:'sha',
storage:{shouli:true}, storage:{shouli:true},
},player,event)) return true; },'unsure'),player,event)) return true;
if(game.hasPlayer(function(current){ if(game.hasPlayer(function(current){
return current.getCards('e',card=>get.is.defendingMount(card)).length>0; return current.getCards('e',card=>get.is.defendingMount(card)).length>0;
})&&event.filterCard({ })&&event.filterCard(get.autoViewAs({
name:'shan', name:'shan',
storage:{shouli:true}, storage:{shouli:true},
},player,event)) return true; },'unsure'),player,event)) return true;
return false; return false;
}, },
delay:false, delay:false,
@ -6890,13 +6890,13 @@ game.import('character',function(lib,game,ui,get,ai,_status){
//获取当前时机的卡牌选择限制 //获取当前时机的卡牌选择限制
var filter=event.filterCard; var filter=event.filterCard;
//如果当前时机能够使用/打出火杀并且角色有方片 那么可以发动技能 //如果当前时机能够使用/打出火杀并且角色有方片 那么可以发动技能
if(filter({name:'sha',nature:'fire'},player,event)&&player.countCards('hes',{suit:'diamond'})) return true; if(filter(get.autoViewAs({name:'sha',nature:'fire'},'unsure'),player,event)&&player.countCards('hes',{suit:'diamond'})) return true;
//如果当前时机能够使用/打出闪并且角色有梅花 那么可以发动技能 //如果当前时机能够使用/打出闪并且角色有梅花 那么可以发动技能
if(filter({name:'shan'},player,event)&&player.countCards('hes',{suit:'club'})) return true; if(filter(get.autoViewAs({name:'shan'},'unsure'),player,event)&&player.countCards('hes',{suit:'club'})) return true;
//如果当前时机能够使用/打出桃并且角色有红桃 那么可以发动技能 //如果当前时机能够使用/打出桃并且角色有红桃 那么可以发动技能
if(filter({name:'tao'},player,event)&&player.countCards('hes',{suit:'heart'})) return true; if(filter(get.autoViewAs({name:'tao'},'unsure'),player,event)&&player.countCards('hes',{suit:'heart'})) return true;
//如果当前时机能够使用/打出无懈可击并且角色有黑桃 那么可以发动技能 //如果当前时机能够使用/打出无懈可击并且角色有黑桃 那么可以发动技能
if(filter({name:'wuxie'},player,event)&&player.countCards('hes',{suit:'spade'})) return true; if(filter(get.autoViewAs({name:'wuxie'},'unsure'),player,event)&&player.countCards('hes',{suit:'spade'})) return true;
return false; return false;
}, },
ai:{ ai:{
@ -7029,10 +7029,10 @@ game.import('character',function(lib,game,ui,get,ai,_status){
}, },
filter(event,player){ filter(event,player){
var filter=event.filterCard; var filter=event.filterCard;
if(filter({name:'sha',nature:'fire'},player,event)&&player.countCards('hs',{suit:'diamond'})) return true; if(filter(get.autoViewAs({name:'sha',nature:'fire'},'unsure'),player,event)&&player.countCards('hs',{suit:'diamond'})) return true;
if(filter({name:'shan'},player,event)&&player.countCards('hs',{suit:'club'})) return true; if(filter(get.autoViewAs({name:'shan'},'unsure'),player,event)&&player.countCards('hs',{suit:'club'})) return true;
if(filter({name:'tao'},player,event)&&player.countCards('hs',{suit:'heart'})) return true; if(filter(get.autoViewAs({name:'tao'},'unsure'),player,event)&&player.countCards('hs',{suit:'heart'})) return true;
if(filter({name:'wuxie'},player,event)&&player.countCards('hs',{suit:'spade'})) return true; if(filter(get.autoViewAs({name:'wuxie'},'unsure'),player,event)&&player.countCards('hs',{suit:'spade'})) return true;
return false; return false;
}, },
precontent(){ precontent(){

View File

@ -8885,7 +8885,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
if(!player.hasCard((card)=>(get.type(card)!='basic'),'ehs')) return false; if(!player.hasCard((card)=>(get.type(card)!='basic'),'ehs')) return false;
for(var i of list){ for(var i of list){
var type=get.type2(i,false); var type=get.type2(i,false);
if((type=='basic'||type=='trick')&&event.filterCard({name:i},player,event)) return true; if((type=='basic'||type=='trick')&&event.filterCard(get.autoViewAs({name:i},'unsure'),player,event)) return true;
} }
return false; return false;
}, },
@ -8896,7 +8896,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
var list2=[]; var list2=[];
for(var i of list){ for(var i of list){
var type=get.type2(i,false); var type=get.type2(i,false);
if((type=='basic'||type=='trick')&&event.filterCard({name:i},player,event)) list2.push([type,'',i]); if((type=='basic'||type=='trick')&&event.filterCard(get.autoViewAs({name:i},'unsure'),player,event)) list2.push([type,'',i]);
} }
return ui.create.dialog('浮萍',[list2,'vcard']); return ui.create.dialog('浮萍',[list2,'vcard']);
}, },
@ -8912,7 +8912,6 @@ game.import('character',function(lib,game,ui,get,ai,_status){
popname:true, popname:true,
viewAs:{ viewAs:{
name:links[0][2], name:links[0][2],
isCard:true,
}, },
check:function(card){ check:function(card){
return 8-get.value(card); return 8-get.value(card);

View File

@ -235,7 +235,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
enable:'chooseToUse', enable:'chooseToUse',
filter:function(event,player){ filter:function(event,player){
for(const name of ['wuxie','huogong']){ for(const name of ['wuxie','huogong']){
if(event.filterCard({name},player,event)) return true; if(event.filterCard(get.autoViewAs({name},'unsure'),player,event)) return true;
} }
return false; return false;
}, },
@ -246,7 +246,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
viewAs:function(cards,player){ viewAs:function(cards,player){
const event=get.event(),filter=event._backup.filterCard; const event=get.event(),filter=event._backup.filterCard;
for(const name of ['wuxie','huogong']){ for(const name of ['wuxie','huogong']){
if(filter({name},player,event)) return {name}; if(filter(get.autoViewAs({name},'unsure'),player,event)) return {name};
} }
return null; return null;
}, },
@ -810,14 +810,14 @@ game.import('character',function(lib,game,ui,get,ai,_status){
})) return false; })) return false;
return get.inpileVCardList(info=>{ return get.inpileVCardList(info=>{
if(info[0]!='basic') return false; if(info[0]!='basic') return false;
return event.filterCard({name:info[2],nature:info[3]},player,event); return event.filterCard(get.autoViewAs({name:info[2],nature:info[3]},'unsure'),player,event);
}).length; }).length;
}, },
chooseButton:{ chooseButton:{
dialog(event,player){ dialog(event,player){
const vcards=get.inpileVCardList(info=>{ const vcards=get.inpileVCardList(info=>{
if(info[0]!='basic') return false; if(info[0]!='basic') return false;
return event.filterCard({name:info[2],nature:info[3]},player,event); return event.filterCard(get.autoViewAs({name:info[2],nature:info[3]},'unsure'),player,event);
}); });
return ui.create.dialog('镇胆',[vcards,'vcard']); return ui.create.dialog('镇胆',[vcards,'vcard']);
}, },
@ -1277,14 +1277,14 @@ game.import('character',function(lib,game,ui,get,ai,_status){
})) return false; })) return false;
return get.inpileVCardList(info=>{ return get.inpileVCardList(info=>{
if(info[0]!='basic') return false; if(info[0]!='basic') return false;
return event.filterCard({name:info[2],nature:info[3]},player,event); return event.filterCard(get.autoViewAs({name:info[2],nature:info[3]},'unsure'),player,event);
}).length; }).length;
}, },
chooseButton:{ chooseButton:{
dialog:function(event,player){ dialog:function(event,player){
const vcards=get.inpileVCardList(info=>{ const vcards=get.inpileVCardList(info=>{
if(info[0]!='basic') return false; if(info[0]!='basic') return false;
return event.filterCard({name:info[2],nature:info[3]},player,event); return event.filterCard(get.autoViewAs({name:info[2],nature:info[3]},'unsure'),player,event);
}); });
return ui.create.dialog('惊惧',[vcards,'vcard'],'hidden'); return ui.create.dialog('惊惧',[vcards,'vcard'],'hidden');
}, },
@ -4759,11 +4759,11 @@ game.import('character',function(lib,game,ui,get,ai,_status){
for(var name of lib.inpile){ for(var name of lib.inpile){
if(get.type2(name)!='basic') continue; if(get.type2(name)!='basic') continue;
var card={name:name}; var card={name:name};
if(event.filterCard(card,player,event)) return true; if(event.filterCard(get.autoViewAs(card,'unsure'),player,event)) return true;
if(name=='sha'){ if(name=='sha'){
for(var nature of lib.inpile_nature){ for(var nature of lib.inpile_nature){
card.nature=nature; card.nature=nature;
if(event.filterCard(card,player,event)) return true; if(event.filterCard(get.autoViewAs(card,'unsure'),player,event)) return true;
} }
} }
} }
@ -4775,19 +4775,19 @@ game.import('character',function(lib,game,ui,get,ai,_status){
var list=[]; var list=[];
for(var name of lib.inpile){ for(var name of lib.inpile){
if(name=='sha'){ if(name=='sha'){
if(event.filterCard({name:name},player,event)) list.push(['基本','','sha']); if(event.filterCard(get.autoViewAs({name},'unsure'),player,event)) list.push(['基本','','sha']);
for(var nature of lib.inpile_nature){ for(var nature of lib.inpile_nature){
if(event.filterCard({name:name,nature:nature},player,event)) list.push(['基本','','sha',nature]); if(event.filterCard(get.autoViewAs({name,nature},'unsure'),player,event)) list.push(['基本','','sha',nature]);
} }
} }
else if(get.type(name)=='basic'&&event.filterCard({name:name},player,event)) list.push(['基本','',name]); else if(get.type(name)=='basic'&&event.filterCard(get.autoViewAs({name},'unsure'),player,event)) list.push(['基本','',name]);
} }
var dialog=ui.create.dialog('念恩',[list,'vcard']); var dialog=ui.create.dialog('念恩',[list,'vcard']);
dialog.direct=true; dialog.direct=true;
return dialog; return dialog;
}, },
filter:function(button,player){ filter:function(button,player){
return _status.event.getParent().filterCard({name:button.link[2],nature:button.link[3]},player,_status.event.getParent()); return _status.event.getParent().filterCard(get.autoViewAs({name:button.link[2],nature:button.link[3]},'unsure'),player,_status.event.getParent());
}, },
check:function(button){ check:function(button){
if(_status.event.getParent().type!='phase') return 1; if(_status.event.getParent().type!='phase') return 1;
@ -5035,7 +5035,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
for(var name of lib.inpile){ for(var name of lib.inpile){
if(get.type(name)!='basic') continue; if(get.type(name)!='basic') continue;
if(player.getStorage('jsrgjixiang_used').includes(name)) continue; if(player.getStorage('jsrgjixiang_used').includes(name)) continue;
var card={name:name}; var card={name:name,isCard:true};
if(event.filterCard(card,event.player,event)) return true; if(event.filterCard(card,event.player,event)) return true;
if(name=='sha'){ if(name=='sha'){
for(var nature of lib.inpile_nature){ for(var nature of lib.inpile_nature){

View File

@ -3222,10 +3222,10 @@ game.import('character',function(lib,game,ui,get,ai,_status){
}, },
filter:function(event,player){ filter:function(event,player){
var filter=event.filterCard; var filter=event.filterCard;
if(filter({name:'sha',nature:'fire'},player,event)&&player.countCards('hes',{suit:'diamond'})) return true; if(filter(get.autoViewAs({name:'sha',nature:'fire'},'unsure'),player,event)&&player.countCards('hes',{suit:'diamond'})) return true;
if(filter({name:'shan'},player,event)&&player.countCards('hes',{suit:'club'})) return true; if(filter(get.autoViewAs({name:'shan'},'unsure'),player,event)&&player.countCards('hes',{suit:'club'})) return true;
if(filter({name:'tao'},player,event)&&player.countCards('hes',{suit:'heart'})) return true; if(filter(get.autoViewAs({name:'tao'},'unsure'),player,event)&&player.countCards('hes',{suit:'heart'})) return true;
if(filter({name:'wuxie'},player,event)&&player.countCards('hes',{suit:'spade'})) return true; if(filter(get.autoViewAs({name:'wuxie'},'unsure'),player,event)&&player.countCards('hes',{suit:'spade'})) return true;
return false; return false;
}, },
precontent:function(){ precontent:function(){
@ -3399,10 +3399,10 @@ game.import('character',function(lib,game,ui,get,ai,_status){
}, },
filter:function(event,player){ filter:function(event,player){
var filter=event.filterCard; var filter=event.filterCard;
if(filter({name:'sha',nature:'fire'},player,event)&&player.countCards('hes',{suit:'diamond'})) return true; if(filter(get.autoViewAs({name:'sha',nature:'fire'},'unsure'),player,event)&&player.countCards('hes',{suit:'diamond'})) return true;
if(filter({name:'shan'},player,event)&&player.countCards('hes',{suit:'club'})) return true; if(filter(get.autoViewAs({name:'shan'},'unsure'),player,event)&&player.countCards('hes',{suit:'club'})) return true;
if(filter({name:'tao'},player,event)&&player.countCards('hes',{suit:'heart'})) return true; if(filter(get.autoViewAs({name:'tao'},'unsure'),player,event)&&player.countCards('hes',{suit:'heart'})) return true;
if(filter({name:'wuxie'},player,event)&&player.countCards('hes',{suit:'spade'})) return true; if(filter(get.autoViewAs({name:'wuxie'},'unsure'),player,event)&&player.countCards('hes',{suit:'spade'})) return true;
return false; return false;
}, },
precontent:function(){ precontent:function(){
@ -6634,19 +6634,19 @@ game.import('character',function(lib,game,ui,get,ai,_status){
audio:2, audio:2,
enable:['chooseToUse','chooseToRespond'], enable:['chooseToUse','chooseToRespond'],
filter:function(event,player){ filter:function(event,player){
return player.getExpansions('jibing').length>0&&(event.filterCard({name:'sha'},player,event)||event.filterCard({name:'shan'},player,event)); return player.getExpansions('jibing').length>0&&(event.filterCard(get.autoViewAs({name:'sha'},'unsure'),player,event)||event.filterCard(get.autoViewAs({name:'shan'},'unsure'),player,event));
}, },
chooseButton:{ chooseButton:{
dialog:function(event,player){ dialog:function(event,player){
var dialog=ui.create.dialog('集兵','hidden'); var dialog=ui.create.dialog('集兵','hidden');
if(event.filterCard({name:'sha'},player,event)&&event.filterCard({name:'shan'},player,event)){ if(event.filterCard(get.autoViewAs({name:'sha'},'unsure'),player,event)&&event.filterCard(get.autoViewAs({name:'shan'},'unsure'),player,event)){
dialog._chooseButton=2; dialog._chooseButton=2;
var list=['sha','shan']; var list=['sha','shan'];
dialog.add([list.map(i=>{ dialog.add([list.map(i=>{
return [i,get.translation(i)]; return [i,get.translation(i)];
}),'tdnodes']); }),'tdnodes']);
} }
else dialog._cardName=event.filterCard({name:'sha'},player,event)?'sha':'shan'; else dialog._cardName=event.filterCard(get.autoViewAs({name:'sha'},'unsure'),player,event)?'sha':'shan';
dialog.add(player.getExpansions('jibing')); dialog.add(player.getExpansions('jibing'));
return dialog; return dialog;
}, },
@ -13279,7 +13279,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
},'hs')) return false; },'hs')) return false;
for(var name of lib.inpile){ for(var name of lib.inpile){
if(get.type(name)!='basic') continue; if(get.type(name)!='basic') continue;
if(event.filterCard({name:name},player,event)) return true; if(event.filterCard(get.autoViewAs({name},'unsure'),player,event)) return true;
} }
return false; return false;
}, },
@ -13288,7 +13288,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
var list=[]; var list=[];
for(var name of lib.inpile){ for(var name of lib.inpile){
if(get.type(name)!='basic') continue; if(get.type(name)!='basic') continue;
if(event.filterCard({name:name},player,event)) list.push(['基本','',name]); if(event.filterCard(get.autoViewAs({name},'unsure'),player,event)) list.push(['基本','',name]);
if(name!='sha') continue; if(name!='sha') continue;
for(var j of lib.inpile_nature){ for(var j of lib.inpile_nature){
if(event.filterCard({name:name,nature:j},player,event)) list.push(['基本','','sha',j]); if(event.filterCard({name:name,nature:j},player,event)) list.push(['基本','','sha',j]);
@ -14298,10 +14298,10 @@ game.import('character',function(lib,game,ui,get,ai,_status){
},'hs')) return false; },'hs')) return false;
for(var name of lib.inpile){ for(var name of lib.inpile){
if(get.type(name)!='basic') continue; if(get.type(name)!='basic') continue;
if(event.filterCard({name:name},player,event)) return true; if(event.filterCard(get.autoViewAs({name},'unsure'),player,event)) return true;
if(name=='sha'){ if(name=='sha'){
for(var nature of lib.inpile_nature){ for(var nature of lib.inpile_nature){
if(event.filterCard({name:'sha',nature:nature},player,event)) return true; if(event.filterCard(get.autoViewAs({name,nature},'unsure'),player,event)) return true;
} }
} }
} }
@ -14312,12 +14312,12 @@ game.import('character',function(lib,game,ui,get,ai,_status){
var list=[]; var list=[];
for(var name of lib.inpile){ for(var name of lib.inpile){
if(get.type(name)!='basic') continue; if(get.type(name)!='basic') continue;
if(event.filterCard({name:name},player,event)){ if(event.filterCard(get.autoViewAs({name},'unsure'),player,event)){
list.push(['基本','',name]); list.push(['基本','',name]);
} }
if(name=='sha'){ if(name=='sha'){
for(var nature of lib.inpile_nature){ for(var nature of lib.inpile_nature){
if(event.filterCard({name:name,nature:nature},player,event)) list.push(['基本','','sha',nature]); if(event.filterCard(get.autoViewAs({name,nature},'unsure'),player,event)) list.push(['基本','','sha',nature]);
} }
} }
} }

View File

@ -79,7 +79,7 @@ export class VCard {
if (!this.nature) this.nature = get.nature(this); if (!this.nature) this.nature = get.nature(this);
} }
} }
else if(numberOrCards === 'unsure') { else if(numberOrCards === 'unsure' && !this.isCard) {
if(!this.suit) this.suit = 'unsure'; if(!this.suit) this.suit = 'unsure';
if(!this.color) this.color = 'unsure'; if(!this.color) this.color = 'unsure';
if(!this.number) this.number = 'unsure'; if(!this.number) this.number = 'unsure';