Merge pull request #881 from copcap/dev

神鲁肃更新&bugfix
This commit is contained in:
Spmario233 2024-01-29 22:42:21 +08:00 committed by GitHub
commit b7fb9a3beb
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
2 changed files with 19 additions and 14 deletions

View File

@ -100,20 +100,25 @@ game.import('character',function(lib,game,ui,get,ai,_status){
filter(event,player){ filter(event,player){
const num=player.countCards('he'); const num=player.countCards('he');
return game.hasPlayer(current=>{ return game.hasPlayer(current=>{
if(current==player) return false;
const total=current.countCards('ej'); const total=current.countCards('ej');
return total>0&&num>=total; return total>0&&num>total;
}); });
}, },
filterCard:true, filterCard:true,
selectCard:[1,Infinity], selectCard(){
return [1,Math.max(...game.filterPlayer(i=>i!=get.player()).map(i=>i.countCards('ej')))+1];
},
check(card){ check(card){
return 7-get.value(card); return 7-get.value(card);
}, },
filterTarget(card,player,target){ filterTarget(card,player,target){
return ui.selected.cards.length==target.countCards('ej')&&player!=target; const num=target.countCards('ej');
if(!num) return false;
return ui.selected.cards.length==num+1&&player!=target;
}, },
filterOk(){ filterOk(){
return ui.selected.cards.length==ui.selected.targets[0].countCards('ej'); return ui.selected.cards.length==ui.selected.targets[0].countCards('ej')+1;
}, },
position:'he', position:'he',
lose:false, lose:false,
@ -130,7 +135,8 @@ game.import('character',function(lib,game,ui,get,ai,_status){
result:{ result:{
target(player,target){ target(player,target){
let eff=0; let eff=0;
if(ui.selected.cards.length) eff-=ui.selected.cards.map(card=>get.value(card)).reduce((p,c)=>p+c,0); if(ui.selected.cards.length) eff=ui.selected.cards.map(card=>get.value(card)).reduce((p,c)=>p+c,0);
if(player.hasSkill('zhimeng')) eff*=1+get.sgnAttitude(player,target)*0.15;
const es=target.getCards('e'),js=target.getCards('j'); const es=target.getCards('e'),js=target.getCards('j');
es.forEach(card=>{ es.forEach(card=>{
eff-=get.value(card,target); eff-=get.value(card,target);
@ -245,7 +251,6 @@ game.import('character',function(lib,game,ui,get,ai,_status){
const {result}=await next; const {result}=await next;
if(!result.bool) return; if(!result.bool) return;
player.logSkill('tamo'); player.logSkill('tamo');
console.log(result.moved)
const resultList=result.moved[0].map(info=>{ const resultList=result.moved[0].map(info=>{
return parseInt(info.split('|')[0]); return parseInt(info.split('|')[0]);
}); });
@ -253,11 +258,11 @@ game.import('character',function(lib,game,ui,get,ai,_status){
const cmp=(a,b)=>{ const cmp=(a,b)=>{
return resultList.indexOf(a)-resultList.indexOf(b); return resultList.indexOf(a)-resultList.indexOf(b);
} }
for(let i of toSortPlayers){ for(let i=0;i<toSortPlayers.length;i++){
for(let j of toSortPlayers){ for(let j=0;j<toSortPlayers.length;j++){
if(cmp(i.getSeatNum(),j.getSeatNum())<0){ if(cmp(toSortPlayers[i].getSeatNum(),toSortPlayers[j].getSeatNum())<0){
toSwapList.push([i,j]); toSwapList.push([toSortPlayers[i],toSortPlayers[j]]);
[i,j]=[j,i]; [toSortPlayers[i],toSortPlayers[j]]=[toSortPlayers[j],toSortPlayers[i]];
} }
} }
} }
@ -8299,7 +8304,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
shen_lusu:'神鲁肃', shen_lusu:'神鲁肃',
shen_lusu_prefix:'神', shen_lusu_prefix:'神',
dingzhou:'定州', dingzhou:'定州',
dingzhou_info:'出牌阶段限一次。你可以交给一名角色X张牌然后你获得其装备区和判定区里的所有牌X为其装备区与判定区里的牌数之和)。', dingzhou_info:'出牌阶段限一次。你可以将X张牌交给一名场上有牌的角色然后你获得其场上的所有牌X为其场上的牌数+1)。',
tamo:'榻谟', tamo:'榻谟',
tamo_info:'游戏开始时,你可以重新分配除主公外所有角色的座次。', tamo_info:'游戏开始时,你可以重新分配除主公外所有角色的座次。',
zhimeng:'智盟', zhimeng:'智盟',

View File

@ -66,7 +66,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
return game.countPlayer(current=>lib.skill.sbquhu.filterTarget(null,player,current))>1; return game.countPlayer(current=>lib.skill.sbquhu.filterTarget(null,player,current))>1;
}, },
filterTarget(card,player,target){ filterTarget(card,player,target){
return player!=target&&target.countCards('he'); return player!=target&&target.countCards('he')>0;
}, },
selectTarget:2, selectTarget:2,
multitarget:true, multitarget:true,
@ -374,7 +374,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
player.logSkill('sbjieming',target); player.logSkill('sbjieming',target);
await target.draw(3); await target.draw(3);
num=Math.max(1,player.getDamagedHp()); num=Math.max(1,player.getDamagedHp());
const {result:{bool:bool2,cards}}=await target.chooseToDiscard('节命:是否弃置任意张牌?',`若你本次弃置的牌数小于${get.cnNumber(num)}张,${get.translation(player)}失去1点体力。`,[1,Infinity]).set('ai',card=>{ const {result:{bool:bool2,cards}}=await target.chooseToDiscard('节命:是否弃置任意张牌?',`若你本次弃置的牌数小于${get.cnNumber(num)}张,${get.translation(player)}失去1点体力。`,[1,Infinity],'he').set('ai',card=>{
if(get.event('nope')) return 0; if(get.event('nope')) return 0;
if(ui.selected.cards.length>=get.event('num')) return 0; if(ui.selected.cards.length>=get.event('num')) return 0;
return 5.5-get.value(card); return 5.5-get.value(card);