王桃王悦ai优化

This commit is contained in:
157 2023-10-05 13:52:09 +08:00 committed by GitHub
parent d06c7ac222
commit 7fe553316a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 87 additions and 15 deletions

View File

@ -7131,6 +7131,12 @@ game.import('character',function(lib,game,ui,get,ai,_status){
huguan:{ huguan:{
audio:2, audio:2,
audioname:['wangyue'], audioname:['wangyue'],
init:function(player){
game.addGlobalSkill('huguan_all');
},
onremove:function(player){
game.removeGlobalSkill('huguan_all');
},
trigger:{global:'useCard'}, trigger:{global:'useCard'},
direct:true, direct:true,
filter:function(event,player){ filter:function(event,player){
@ -7144,9 +7150,16 @@ game.import('character',function(lib,game,ui,get,ai,_status){
content:function(){ content:function(){
'step 0' 'step 0'
player.chooseControl(lib.suit,'cancel2').set('prompt',get.prompt('huguan',trigger.player)).set('prompt2','令某种花色的手牌不计入其本回合的手牌上限').set('ai',function(){ player.chooseControl(lib.suit,'cancel2').set('prompt',get.prompt('huguan',trigger.player)).set('prompt2','令某种花色的手牌不计入其本回合的手牌上限').set('ai',function(){
var player=_status.event.player,target=_status.event.getTrigger().player; var player=_status.event.player,target=_status.event.getTrigger().player,att=get.attitude(player,target);
if(get.attitude(player,target)<=0) return 'cancel2'; if(att <= 0){
var list=lib.suit.slice(0); if (!player.hasSkill('yaopei') || player.hasAllHistory('useSkill',function(evt){
return evt.skill=='huguan'&&evt.targets.includes(target);
}) || target.needsToDiscard() - target.needsToDiscard(-target.countCards('h') / 4) > (att>-2?1.6:1)) return 'cancel2';
}
let list = lib.suit.slice(0);
if(att <= 0 && target.getStorage('huguan_add')) for(let i of target.getStorage('huguan_add')){
if (list.includes(i)) return i;
}
list.removeArray(target.getStorage('huguan_add')); list.removeArray(target.getStorage('huguan_add'));
if(list.length) return list.randomGet(); if(list.length) return list.randomGet();
return 'cancel2'; return 'cancel2';
@ -7174,6 +7187,37 @@ game.import('character',function(lib,game,ui,get,ai,_status){
}, },
intro:{content:'本回合$花色的牌不计入手牌上限'}, intro:{content:'本回合$花色的牌不计入手牌上限'},
}, },
all:{
mod:{
aiValue:function(player, card, num){
if(player && player.storage.huguan_all > 0 && get.itemtype(card) == 'card' && get.color(card, player) == 'red') return num + player.storage.huguan_all;
}
},
trigger:{
player:['phaseUseBegin', 'useCard']
},
filter:function(event, player){
if(event.name === 'useCard') return player.storage.huguan_all;
return true;
},
silent:true,
charlotte:true,
content:function(){
'step 0'
if(trigger.name === 'useCard'){
player.storage.huguan_all = 0;
event.finish();
}
'step 1'
let num = -157;
game.countPlayer(function (current){
if(current.hasSkill('huguan')) num = Math.max(num, get.attitude(_status.event.player, current));
});
if(num === -157) game.removeGlobalSkill('huguan_all');
else if(num === 0) player.storage.huguan_all = 6;
else if(num > 0) player.storage.huguan_all = 9;
}
}
}, },
}, },
yaopei:{ yaopei:{
@ -7217,15 +7261,18 @@ game.import('character',function(lib,game,ui,get,ai,_status){
return target==player||target==_status.event.getTrigger().player; return target==player||target==_status.event.getTrigger().player;
}, },
ai1:function(card){ ai1:function(card){
return 8-get.value(card); let player = _status.event.player, source = _status.event.getTrigger().player;
if(get.attitude(player, source) > 0 && (get.recoverEffect(player, player, player) > 0 || get.recoverEffect(source, player, player) > 0)) return 12 - get.value(card);
return 8 - get.value(card);
}, },
ai2:function(target){ ai2:function(target){
var player=_status.event.player,source=_status.event.getTrigger().player; let player = _status.event.player, source = _status.event.getTrigger().player;
var recoverer=(player==target?source:player); let recoverer = player === target ? source : player;
if(recoverer.isHealthy()) return (get.attitude(player,target)>0?1:0); if(recoverer.isHealthy()) return get.attitude(player, target);
if(get.recoverEffect(recoverer,player,player)>0&&get.attitude(player,target)>0) return 2; let att = get.attitude(player, recoverer), rec = get.recoverEffect(recoverer, player, player);
if(rec > 0) return Math.abs(att) + get.attitude(player, target);
return 0; return 0;
}, }
}); });
'step 1' 'step 1'
if(result.bool){ if(result.bool){
@ -7233,10 +7280,12 @@ game.import('character',function(lib,game,ui,get,ai,_status){
player.logSkill('yaopei',target); player.logSkill('yaopei',target);
player.discard(result.cards); player.discard(result.cards);
if(player==result.targets[0]){ if(player==result.targets[0]){
if(target.isDamaged()&&target.hp<player.hp&&(get.mode()!='identity'||player.identity!='nei')) player.addExpose(0.15);
target.recover(); target.recover();
player.draw(2); player.draw(2);
} }
else{ else{
if((player.isHealthy()||player.hp>target.hp)&&(get.mode()!='identity'||player.identity!='nei')) player.addExpose(0.15);
target.draw(2); target.draw(2);
player.recover(); player.recover();
} }
@ -7252,13 +7301,36 @@ game.import('character',function(lib,game,ui,get,ai,_status){
}, },
content:function(){ content:function(){
'step 0' 'step 0'
let he = player.getCards('he'),
disval = 0,
dis = 0,
spare = 30,
use = true;
for(let i of he){
let val = get.value(i, player);
if(val < 6 && get.position(i) == 'h'){
dis++;
disval += val;
}
else if(val < spare) spare = val;
}
if(!dis){
dis = 1;
disval = spare;
spare = -1;
}
let draw = Math.min(trigger.player.countCards('h'), 5 + dis - player.countCards('h'));
if(6 * draw < disval) use = false;
player.chooseToDiscard('he',get.prompt('mingluan'),'弃置任意张牌,并摸等同于'+get.translation(trigger.player)+'手牌数的牌(至多摸至五张)',[1,Infinity]).set('ai',function(card){ player.chooseToDiscard('he',get.prompt('mingluan'),'弃置任意张牌,并摸等同于'+get.translation(trigger.player)+'手牌数的牌(至多摸至五张)',[1,Infinity]).set('ai',function(card){
var player=_status.event.player; let val = get.value(card, player);
var ph=player.countCards('h'); if(val < 0 && card.name != 'du') return 30;
if(get.position(card)=='h') ph--; if(!use) return 0;
var num=Math.min(_status.event.getTrigger().player.countCards('h'),5-ph); if(ui.selected.cards.length){
if(num>0) return 3.5*num+0.01-get.value(card); if (get.position(card) != 'h') return 0;
return 0.01-get.value(card); return 6 - val;
}
if(spare < 0 || get.position(card) == 'h') return 30 - val;
return 0;
}).logSkill=['mingluan',trigger.player]; }).logSkill=['mingluan',trigger.player];
'step 1' 'step 1'
if(result.bool){ if(result.bool){