放逐AI调整;水淹七军局内选择时增加prompt
This commit is contained in:
parent
7a0d602a68
commit
69199182c8
|
@ -481,7 +481,7 @@ game.import('card',function(lib,game,ui,get,ai,_status){
|
||||||
return 'take_damage';
|
return 'take_damage';
|
||||||
}
|
}
|
||||||
return 'discard_card';
|
return 'discard_card';
|
||||||
});
|
}).set('prompt','水淹七军').set('prompt2','请选择一项:⒈弃置装备区里的所有牌;⒉受到'+get.translation(player)+'造成的1点雷电伤害。');
|
||||||
'step 1'
|
'step 1'
|
||||||
if(result.control=='discard_card'){
|
if(result.control=='discard_card'){
|
||||||
target.discard(target.getCards('e',function(card){
|
target.discard(target.getCards('e',function(card){
|
||||||
|
|
|
@ -4744,18 +4744,27 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
||||||
"step 0"
|
"step 0"
|
||||||
player.chooseTarget('是否弃置一枚“忍”,并发动【放逐】?',function(card,player,target){
|
player.chooseTarget('是否弃置一枚“忍”,并发动【放逐】?',function(card,player,target){
|
||||||
return player!=target
|
return player!=target
|
||||||
}).ai=function(target){
|
}).set('ai',target=>{
|
||||||
if(target.hasSkillTag('noturn')) return 0;
|
if(target.hasSkillTag('noturn')) return 0;
|
||||||
if(target.isTurnedOver()){
|
var player=_status.event.player;
|
||||||
return get.attitude(player,target)-1;
|
var current=_status.currentPhase;
|
||||||
|
var dis=current?get.distance(current,target,'absolute'):1;
|
||||||
|
var draw=player.getDamagedHp();
|
||||||
|
var att=get.attitude(player,target);
|
||||||
|
if(att==0) return target.hasJudge('lebu')?Math.random()/3:Math.sqrt(get.threaten(target))/5+Math.random()/2;
|
||||||
|
if(att>0){
|
||||||
|
if(target.isTurnedOver()) return att+draw;
|
||||||
|
if(draw<4) return -1;
|
||||||
|
if(current&&target.getSeatNum()>current.getSeatNum()) return att+draw/3;
|
||||||
|
return 10*Math.sqrt(Math.max(0.01,get.threaten(target)))/(3.5-draw)+dis/(2*game.countPlayer());
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
if(player.maxHp-player.hp==1){
|
if(target.isTurnedOver()) return -att-draw;
|
||||||
return -get.attitude(player,target)-1;
|
if(draw>=5) return -1;
|
||||||
}
|
if(current&&target.getSeatNum()<=current.getSeatNum()) return -att+draw/3;
|
||||||
|
return (4.25-draw)*10*Math.sqrt(Math.max(0.01,get.threaten(target)))+2*game.countPlayer()/dis;
|
||||||
}
|
}
|
||||||
return 0;
|
});
|
||||||
}
|
|
||||||
"step 1"
|
"step 1"
|
||||||
if(result.bool){
|
if(result.bool){
|
||||||
player.removeMark('renjie',1);
|
player.removeMark('renjie',1);
|
||||||
|
|
|
@ -4680,27 +4680,35 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
||||||
preHidden:true,
|
preHidden:true,
|
||||||
content:function(){
|
content:function(){
|
||||||
"step 0"
|
"step 0"
|
||||||
player.chooseTarget(get.prompt('fangzhu'),'令一名其他角色将武将牌翻面并摸'+get.cnNumber(player.getDamagedHp())+'张牌',function(card,player,target){
|
var draw=player.getDamagedHp();
|
||||||
|
player.chooseTarget(get.prompt('fangzhu'),'令一名其他角色翻面'+(draw>0?'并摸'+get.cnNumber(draw)+'张牌':''),function(card,player,target){
|
||||||
return player!=target
|
return player!=target
|
||||||
}).setHiddenSkill('fangzhu').ai=function(target){
|
}).setHiddenSkill('fangzhu').set('ai',target=>{
|
||||||
if(target.hasSkillTag('noturn')) return 0;
|
if(target.hasSkillTag('noturn')) return 0;
|
||||||
var player=_status.event.player;
|
var player=_status.event.player;
|
||||||
if(get.attitude(_status.event.player,target)==0) return 0;
|
var current=_status.currentPhase;
|
||||||
if(get.attitude(_status.event.player,target)>0){
|
var dis=current?get.distance(current,target,'absolute'):1;
|
||||||
if(target.classList.contains('turnedover')) return 1000-target.countCards('h');
|
var draw=player.getDamagedHp();
|
||||||
if(player.getDamagedHp()<3) return -1;
|
var att=get.attitude(player,target);
|
||||||
return 100-target.countCards('h');
|
if(att==0) return target.hasJudge('lebu')?Math.random()/3:Math.sqrt(get.threaten(target))/5+Math.random()/2;
|
||||||
|
if(att>0){
|
||||||
|
if(target.isTurnedOver()) return att+draw;
|
||||||
|
if(draw<4) return -1;
|
||||||
|
if(current&&target.getSeatNum()>current.getSeatNum()) return att+draw/3;
|
||||||
|
return 10*Math.sqrt(Math.max(0.01,get.threaten(target)))/(3.5-draw)+dis/(2*game.countPlayer());
|
||||||
}
|
}
|
||||||
else{
|
else{
|
||||||
if(target.classList.contains('turnedover')) return -1;
|
if(target.isTurnedOver()) return -att-draw;
|
||||||
if(player.getDamagedHp()>=3) return -1;
|
if(draw>=5) return -1;
|
||||||
return 1+target.countCards('h');
|
if(current&&target.getSeatNum()<=current.getSeatNum()) return -att+draw/3;
|
||||||
|
return (4.25-draw)*10*Math.sqrt(Math.max(0.01,get.threaten(target)))+2*game.countPlayer()/dis;
|
||||||
}
|
}
|
||||||
}
|
});
|
||||||
"step 1"
|
"step 1"
|
||||||
if(result.bool){
|
if(result.bool){
|
||||||
player.logSkill('fangzhu',result.targets);
|
player.logSkill('fangzhu',result.targets);
|
||||||
result.targets[0].draw(player.getDamagedHp());
|
var draw=player.getDamagedHp();
|
||||||
|
if(draw>0) result.targets[0].draw(draw);
|
||||||
result.targets[0].turnOver();
|
result.targets[0].turnOver();
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
Loading…
Reference in New Issue