This commit is contained in:
libccy 2018-08-10 23:48:28 +08:00
parent 8b7cd78596
commit b4f0a9e1c9
9 changed files with 383 additions and 76 deletions

View File

@ -953,10 +953,10 @@ game.import('card',function(lib,game,ui,get,ai,_status){
}, },
filterTarget:function(card,player,target){ filterTarget:function(card,player,target){
if(player==target) return false; if(player==target) return false;
return (target.countCards('hej')>0); return target.countGainableCards(player,'hej')>0;
}, },
content:function(){ content:function(){
if(target.countCards('hej')){ if(target.countGainableCards(player,'hej')){
player.gainPlayerCard('hej',target,true); player.gainPlayerCard('hej',target,true);
} }
}, },
@ -1043,7 +1043,7 @@ game.import('card',function(lib,game,ui,get,ai,_status){
if(js.length){ if(js.length){
var jj=js[0].viewAs?{name:js[0].viewAs}:js[0]; var jj=js[0].viewAs?{name:js[0].viewAs}:js[0];
if(jj.name=='guohe'||js.length>1||get.effect(target,jj,target,player)<0){ if(jj.name=='guohe'||js.length>1||get.effect(target,jj,target,player)<0){
return 2; return 3;
} }
} }
if(target.getEquip('baiyin')&&target.isDamaged()&& if(target.getEquip('baiyin')&&target.isDamaged()&&
@ -1127,8 +1127,6 @@ game.import('card',function(lib,game,ui,get,ai,_status){
gain:1, gain:1,
use:1, use:1,
useSha:1, useSha:1,
multitarget:1,
multineg:1,
loseCard:1, loseCard:1,
} }
} }

View File

@ -47,7 +47,9 @@ game.import('character',function(lib,game,ui,get,ai,_status){
yuanshao:['yanwen'], yuanshao:['yanwen'],
menghuo:['zhurong'], menghuo:['zhurong'],
sp_zhugeliang:['pangtong'], sp_zhugeliang:['pangtong'],
sunce:['zhouyu','taishici','daqiao'] sunce:['zhouyu','taishici','daqiao'],
zuoci:['yuji'],
xunyu:['xunyou'],
}, },
characterFilter:{ characterFilter:{
zuoci:function(mode){ zuoci:function(mode){

View File

@ -61,7 +61,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
perfectPair:{ perfectPair:{
xiahoudun:['xiahouyuan'], xiahoudun:['xiahouyuan'],
zhenji:['caopi'], zhenji:['caopi'],
caocao:['xuzhu','dianwei'], caocao:['xuzhu','dianwei','bianfuren'],
huangzhong:['weiyan'], huangzhong:['weiyan'],
zhugeliang:['huangyueying'], zhugeliang:['huangyueying'],
liubei:['guanyu','zhangfei','ganfuren'], liubei:['guanyu','zhangfei','ganfuren'],
@ -71,7 +71,8 @@ game.import('character',function(lib,game,ui,get,ai,_status){
sunquan:['zhoutai'], sunquan:['zhoutai'],
lvbu:['diaochan'], lvbu:['diaochan'],
machao:['madai','mayunlu'], machao:['madai','mayunlu'],
zhangliao:['zangba'] zhangliao:['zangba'],
ganning:['lingtong'],
}, },
skill:{ skill:{
hujia:{ hujia:{

View File

@ -8054,6 +8054,9 @@ game.import('character',function(lib,game,ui,get,ai,_status){
var player=_status.event.player; var player=_status.event.player;
var recover=0,lose=1,players=game.filterPlayer(); var recover=0,lose=1,players=game.filterPlayer();
for(var i=0;i<players.length;i++){ for(var i=0;i<players.length;i++){
if(players[i].hp==1&&get.damageEffect(players[i],player,player)>0&&!players[i].hasSha()){
return (button.link[2]=='juedou')?2:-1;
}
if(!players[i].isOut()){ if(!players[i].isOut()){
if(players[i].hp<players[i].maxHp){ if(players[i].hp<players[i].maxHp){
if(get.attitude(player,players[i])>0){ if(get.attitude(player,players[i])>0){

View File

@ -1510,6 +1510,7 @@ window.noname_asset_list=[
'image/card/zong.png', 'image/card/zong.png',
'image/character/baiwuchang.jpg', 'image/character/baiwuchang.jpg',
'image/character/beimihu.jpg', 'image/character/beimihu.jpg',
'image/character/bianfuren.jpg',
'image/character/bulianshi.jpg', 'image/character/bulianshi.jpg',
'image/character/buzhi.jpg', 'image/character/buzhi.jpg',
'image/character/caifuren.jpg', 'image/character/caifuren.jpg',

View File

@ -11425,28 +11425,36 @@
} }
var directh=true; var directh=true;
for(var i=0;i<event.position.length;i++){ for(var i=0;i<event.position.length;i++){
if(event.position[i]=='h'&&target.countCards('h')){ if(event.position[i]=='h'){
event.dialog.addText('手牌区');
var hs=target.getCards('h'); var hs=target.getCards('h');
hs.randomSort(); if(hs.length){
if(event.visible||target.isUnderControl(true)){ event.dialog.addText('手牌区');
event.dialog.add(hs); hs.randomSort();
if(event.visible||target.isUnderControl(true)){
event.dialog.add(hs);
directh=false;
}
else{
event.dialog.add([hs,'blank']);
}
}
}
else if(event.position[i]=='e'){
var es=target.getCards('e');
if(es.length){
event.dialog.addText('装备区');
event.dialog.add(es);
directh=false; directh=false;
} }
else{ }
event.dialog.add([hs,'blank']); else if(event.position[i]=='j'){
var js=target.getCards('j');
if(js.length){
event.dialog.addText('判定区');
event.dialog.add(js);
directh=false;
} }
} }
else if(event.position[i]=='e'&&target.countCards('e')){
event.dialog.addText('装备区');
event.dialog.add(target.getCards('e'));
directh=false;
}
else if(event.position[i]=='j'&&target.countCards('j')){
event.dialog.addText('判定区');
event.dialog.add(target.getCards('j'));
directh=false;
}
} }
if(event.dialog.buttons.length==0){ if(event.dialog.buttons.length==0){
event.finish(); event.finish();
@ -11498,6 +11506,19 @@
}, },
discardPlayerCard:function(){ discardPlayerCard:function(){
"step 0" "step 0"
if(event.directresult){
event.result={
buttons:[],
cards:event.directresult.slice(0),
links:event.directresult.slice(0),
targets:[],
confirm:'ok',
bool:true
};
event.cards=event.directresult.slice(0);
event.goto(2);
return;
}
if(!event.dialog) event.dialog=ui.create.dialog('hidden'); if(!event.dialog) event.dialog=ui.create.dialog('hidden');
else if(!event.isMine){ else if(!event.isMine){
event.dialog.style.display='none'; event.dialog.style.display='none';
@ -11595,7 +11616,7 @@
event.dialog.close(); event.dialog.close();
"step 2" "step 2"
event.resume(); event.resume();
if(event.result.bool&&event.result.buttons&&!game.online){ if(event.result.bool&&event.result.links&&!game.online){
if(event.logSkill){ if(event.logSkill){
if(typeof event.logSkill=='string'){ if(typeof event.logSkill=='string'){
player.logSkill(event.logSkill); player.logSkill(event.logSkill);
@ -11609,17 +11630,34 @@
cards.push(event.result.links[i]); cards.push(event.result.links[i]);
} }
event.result.cards=event.result.links.slice(0); event.result.cards=event.result.links.slice(0);
if(event.boolline){ event.cards=cards;
player.line(target,'green'); }
} "step 3"
var next=target.discard(cards); if(event.boolline){
player.line(target,'green');
}
if(!event.chooseonly){
var next=target.discard(event.cards);
if(event.delay===false){ if(event.delay===false){
next.delay=event.delay; next.set('delay',false);
} }
} }
}, },
gainPlayerCard:function(){ gainPlayerCard:function(){
"step 0" "step 0"
if(event.directresult){
event.result={
buttons:[],
cards:event.directresult.slice(0),
links:event.directresult.slice(0),
targets:[],
confirm:'ok',
bool:true
};
event.cards=event.directresult.slice(0);
event.goto(2);
return;
}
if(!event.dialog) event.dialog=ui.create.dialog('hidden'); if(!event.dialog) event.dialog=ui.create.dialog('hidden');
else if(!event.isMine){ else if(!event.isMine){
event.dialog.style.display='none'; event.dialog.style.display='none';
@ -11656,7 +11694,7 @@
} }
} }
else if(event.position[i]=='e'){ else if(event.position[i]=='e'){
var es=target.getGainableCards('e'); var es=target.getGainableCards(player,'e');
if(es.length){ if(es.length){
event.dialog.addText('装备区'); event.dialog.addText('装备区');
event.dialog.add(es); event.dialog.add(es);
@ -11664,7 +11702,7 @@
} }
} }
else if(event.position[i]=='j'){ else if(event.position[i]=='j'){
var js=target.getGainableCards('j'); var js=target.getGainableCards(player,'j');
if(js.length){ if(js.length){
event.dialog.addText('判定区'); event.dialog.addText('判定区');
event.dialog.add(js); event.dialog.add(js);
@ -11760,7 +11798,12 @@
if(event.boolline){ if(event.boolline){
player.line(target,'green'); player.line(target,'green');
} }
player.gain(event.cards,target); if(!event.chooseonly){
var next=player.gain(event.cards,target);
if(event.delay===false){
next.set('delay',false);
}
}
}, },
showHandcards:function(){ showHandcards:function(){
"step 0" "step 0"
@ -12704,32 +12747,25 @@
event.num=0; event.num=0;
event.cardlist=[]; event.cardlist=[];
'step 1' 'step 1'
player.gainPlayerCard(targets[num],event.position,true).set('boolline',false).set('chooseonly',true);
'step 2'
var current=targets[num]; var current=targets[num];
var card; var card=null;
if(cards){ if(result.bool){
card=cards[num]; card=result.cards[0];
}
else{
card=current.getCards(event.position).randomGet();
} }
if(card){ if(card){
if(typeof event.animation=='string'){
current['$'+event.animation](card,player);
}
else{
current.$giveAuto(card,player);
}
current.lose(card,ui.special).set('type','gain'); current.lose(card,ui.special).set('type','gain');
} }
event.cardlist[num]=card||null; event.cardlist[num]=card||null;
event.num++; event.num++;
if(event.num<targets.length){ if(event.num<targets.length){
event.redo(); event.goto(1);
} }
else{ else{
event.num=0; event.num=0;
} }
'step 2' 'step 3'
var current=targets[num]; var current=targets[num];
var card=event.cardlist[num]; var card=event.cardlist[num];
if(card){ if(card){
@ -12745,7 +12781,7 @@
if(event.num<targets.length){ if(event.num<targets.length){
event.redo(); event.redo();
} }
'step 2' 'step 4'
if(!event.delayed) game.delay(); if(!event.delayed) game.delay();
}, },
gain:function(){ gain:function(){
@ -16313,18 +16349,12 @@
},this,cards); },this,cards);
return this; return this;
}, },
gainMultiple:function(targets,position,animation){ gainMultiple:function(targets,position){
var next=game.createEvent('gainMultiple',false); var next=game.createEvent('gainMultiple',false);
next.setContent('gainMultiple'); next.setContent('gainMultiple');
next.player=this; next.player=this;
next.targets=targets; next.targets=targets;
next.animation=animation; next.position=position||'h';
if(Array.isArray(position)){
next.cards=position;
}
else{
next.position=position||'h';
}
return next; return next;
}, },
gain:function(){ gain:function(){

View File

@ -7,6 +7,10 @@ window.noname_update={
files:[ files:[
'card/standard.js', 'card/standard.js',
'character/shenhua.js', 'character/shenhua.js',
'game/game.js' 'character/standard.js',
'character/yijiang.js',
'game/asset.js',
'game/game.js',
'mode/guozhan.js'
] ]
}; };

Binary file not shown.

After

Width:  |  Height:  |  Size: 50 KiB

View File

@ -270,9 +270,230 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
gz_liqueguosi:['male','qun',4,['xiongsuan']], gz_liqueguosi:['male','qun',4,['xiongsuan']],
gz_zuoci:['male','qun',3,['gzhuashen','gzxinsheng']], gz_zuoci:['male','qun',3,['gzhuashen','gzxinsheng']],
gz_bianfuren:['female','wei',3,['wanwei','yuejian']],
gz_xunyou:['male','wei',3,['gzqice','zhiyu']],
} }
}, },
skill:{ skill:{
gzqice:{
enable:'phaseUse',
usable:1,
audio:2,
filter:function(event,player){
return player.countCards('h')>0
},
group:'gzqice_change',
subSkill:{
change:{
trigger:{player:'useCardAfter'},
filter:function(event,player){
return event.skill=='gzqice_backup'&&player.hasViceCharacter();
},
check:function(event,player){
return get.rank(player.name2,true)<=5;
},
prompt:'是否变更副将?',
popup:false,
content:function(){
player.changeVice();
}
}
},
chooseButton:{
dialog:function(){
var list=[
'taoyuan','wugu','juedou','huogong','jiedao','tiesuo','guohe','shunshou','wuzhong','wanjian','nanman',
'xietianzi','shuiyanqijunx','lulitongxin','lianjunshengyan','chiling','diaohulishan'
];
for(var i=0;i<list.length;i++){
list[i]=['锦囊','',list[i]];
}
return ui.create.dialog([list,'vcard']);
},
filter:function(button,player){
var card={name:button.link[2]};
var info=get.info(card);
var num=player.countCards('h');
if(get.tag(card,'multitarget')&&get.select(info.selectTarget)[1]==-1){
if(game.countPlayer(function(current){
return player.canUse(card,current)
})>num){
return false;
}
}
else if(info.changeTarget){
var giveup=true;
var list=game.filterPlayer(function(current){
return player.canUse(card,current);
});
for(var i=0;i<list.length;i++){
var targets=[list[i]];
info.changeTarget(player,targets);
if(targets.length<=num){
giveup=false;break;
}
}
if(giveup){
return false;
}
}
return lib.filter.filterCard(card,player,_status.event.getParent());
},
check:function(button){
if(['chiling','xietianzi','lianjunshengyan'].contains(button.link[2])) return 0;
var player=_status.event.player;
var players=game.filterPlayer();
var shunshou=false;
for(var i=0;i<players.length;i++){
if(!players[i].isOut()){
if(players[i].hp==1&&get.damageEffect(players[i],player,player)>0&&!players[i].hasSha()){
return (button.link[2]=='juedou')?2:-1;
}
if(player.canUse('shunshou',players[i])&&get.attitude(player,players[i])<0){
shunshou=true;
}
if(players[i].countCards('j')&&get.attitude(player,players[i])>2){
guohe=true;
}
}
}
if(guohe) return (button.link[2]=='guohe')?1.5:-1;
if(shunshou) return (button.link[2]=='shunshou')?1:-1;
return (button.link[2]=='wuzhong')?1:-1;
},
backup:function(links,player){
return {
filterCard:true,
selectCard:-1,
selectTarget:function(){
var select=get.select(get.info(get.card()).selectTarget);
var nh=_status.event.player.countCards('h');
if(select[1]>nh){
select[1]=nh;
}
return select;
},
filterTarget:function(card,player,target){
var info=get.info(card);
if(info.changeTarget){
var targets=[target];
info.changeTarget(player,targets);
if(targets.length>player.countCards('h')){
return false;
}
}
return lib.filter.filterTarget(card,player,target);
},
audio:2,
popname:true,
viewAs:{name:links[0][2]},
}
},
prompt:function(links,player){
return '将全部手牌当作'+get.translation(links[0][2])+'使用';
}
},
ai:{
order:1,
result:{
player:function(player){
var num=0;
var cards=player.getCards('h');
if(cards.length>=3&&player.hp>=3) return 0;
for(var i=0;i<cards.length;i++){
num+=Math.max(0,get.value(cards[i],player,'raw'));
}
num/=cards.length;
num*=Math.min(cards.length,player.hp);
return 12-num;
}
},
threaten:1.6,
}
},
wanwei:{
trigger:{target:['discardPlayerCardBegin','gainPlayerCardBegin']},
direct:true,
filter:function(event,player){
return event.player!=player&&!event.directresult;
},
content:function(){
'step 0'
player.choosePlayerCard(player,get.prompt('wanwei'),trigger.position).set('ai',function(button){
return 20-get.value(button.link);
});
'step 1'
if(result.bool){
player.logSkill('wanwei');
trigger.directresult=result.links.slice(0);
trigger.untrigger();
}
}
},
yuejian:{
trigger:{global:'phaseDiscardBegin'},
init:function(player){
player.storage.yuejian={};
},
filter:function(event,player){
if(player.sameIdentityAs(event.player)){
var targets=player.storage.yuejian[event.player.playerid];
if(targets){
for(var i=0;i<targets.length;i++){
if(event.player.differentIdentityFrom(targets[i],player==event.player)){
return false;
}
}
}
return true;
}
return false;
},
content:function(){
trigger.player.addTempSkill('yuejian_num');
},
logTarget:'player',
check:function(event,player){
return event.player.needsToDiscard()&&event.player.isDamaged();
},
frequent:true,
group:['yuejian_count','yuejian_clear'],
subSkill:{
num:{
mod:{
maxHandcard:function(player,num){
return num+player.maxHp-player.hp;
}
}
},
count:{
trigger:{global:'useCard'},
filter:function(event,player){
if(event.player.identity!='unknown'&&!player.sameIdentityAs(event.player)){
return false;
}
return _status.currentPhase==event.player;
},
silent:true,
content:function(){
if(!player.storage.yuejian[trigger.player.playerid]){
player.storage.yuejian[trigger.player.playerid]=[];
}
player.storage.yuejian[trigger.player.playerid].addArray(trigger.targets);
}
},
clear:{
trigger:{global:'phaseAfter'},
silent:true,
filter:function(event,player){
return player.storage.yuejian[event.player.playerid]?true:false;
},
content:function(){
delete player.storage.yuejian[trigger.player.playerid];
}
}
}
},
gzxinsheng:{ gzxinsheng:{
trigger:{player:'damageEnd'}, trigger:{player:'damageEnd'},
frequent:true, frequent:true,
@ -3124,7 +3345,14 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
gz_jun_liubei:'君刘备', gz_jun_liubei:'君刘备',
gz_jun_zhangjiao:'君张角', gz_jun_zhangjiao:'君张角',
gz_liqueguosi:'李傕郭汜', gz_liqueguosi:'李傕郭汜',
gz_bianfuren:'卞夫人',
gzqice:'奇策',
gzqice_info:'出牌阶段限一次你可以将所有手牌当任意一张普通锦囊牌使用你不能以此法使用目标数超过X的牌X为你的手牌数然后你可以变更副将。',
wanwei:'挽危',
wanwei_info:'当你因被其他角色获得或弃置而失去牌时,你可以改为自己选择失去的牌',
yuejian:'约俭',
yuejian_info:'与你势力相同角色的弃牌阶段开始时,若其本回合未使用指定过其他势力的角色为目标,则该角色本回合手牌上限等同于其体力上限',
xiongsuan:'凶算', xiongsuan:'凶算',
xiongsuan_info:'限定技出牌阶段你可以弃置一张手牌并选择与你势力相同的一名角色对其造成1点伤害然后你摸三张牌。若该角色有已发动的限定技则你选择其中一个限定技此回合结束后视为该限定技未发动过。', xiongsuan_info:'限定技出牌阶段你可以弃置一张手牌并选择与你势力相同的一名角色对其造成1点伤害然后你摸三张牌。若该角色有已发动的限定技则你选择其中一个限定技此回合结束后视为该限定技未发动过。',
gzhuashen:'化身', gzhuashen:'化身',
@ -3434,9 +3662,26 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
} }
}, },
player:{ player:{
differentIdentityFrom:function(target,self){
if(this==target) return false;
if(self){
if(target.identity=='unknown') return false;
if(target.identity=='ye'||this.identity=='ye') return true;
if(this.identity=='unknown'){
var identity=lib.character[this.name1][1];
if(this.wontYe()) return identity!=target.identity;
return true;
}
}
else{
if(this.identity=='unknown'||target.identity=='unknown') return false;
if(this.identity=='ye'||target.identity=='ye') return true;
}
return this.identity!=target.identity;
},
sameIdentityAs:function(target){ sameIdentityAs:function(target){
if(this==target) return true; if(this==target) return true;
if(target.identity=='unknown'||target.identity=='ye') return false; if(target.identity=='unknown'||target.identity=='ye'||this.identity=='ye') return false;
if(this.identity=='unknown'){ if(this.identity=='unknown'){
var identity=lib.character[this.name1][1]; var identity=lib.character[this.name1][1];
if(this.wontYe()) return identity==target.identity; if(this.wontYe()) return identity==target.identity;
@ -3616,6 +3861,27 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
game.log(this,'移除了'+(num?'副将':'主将'),'#b'+name); game.log(this,'移除了'+(num?'副将':'主将'),'#b'+name);
this.reinit(name,to,false); this.reinit(name,to,false);
this.showCharacter(num,false); this.showCharacter(num,false);
_status.characterlist.add(name);
},
changeVice:function(){
if(!this.hasViceCharacter()) return this;
var group=lib.character[this.name1][1];
var name;
_status.characterlist.randomSort();
for(var i=0;i<_status.characterlist.length;i++){
name=_status.characterlist[i];
if(lib.character[name][1]==group) break;
}
if(name){
_status.characterlist.remove(name);
_status.characterlist.add(this.name2);
game.log(this,'将副将变更为','#g'+get.translation(name));
if(this.isUnseen(1)){
this.showCharacter(1,false,true);
}
this.reinit(this.name2,name,false);
}
return this;
}, },
hasMainCharacter:function(){ hasMainCharacter:function(){
return this.name1.indexOf('gz_shibing')!=0; return this.name1.indexOf('gz_shibing')!=0;
@ -3623,7 +3889,7 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
hasViceCharacter:function(){ hasViceCharacter:function(){
return this.name2.indexOf('gz_shibing')!=0; return this.name2.indexOf('gz_shibing')!=0;
}, },
showCharacter:function(num,log){ showCharacter:function(num,log,notrigger){
if(num==0&&!this.isUnseen(0)){ if(num==0&&!this.isUnseen(0)){
return; return;
} }
@ -3717,28 +3983,30 @@ game.import('mode',function(lib,game,ui,get,ai,_status){
} }
},this,this.name,this.sex,num,this.identity); },this,this.name,this.sex,num,this.identity);
this.identityShown=true; this.identityShown=true;
var initdraw=parseInt(get.config('initshow_draw'));
if(!_status.initshown&&!_status.overing&&initdraw&&this.isAlive()&&_status.mode!='mingjiang'){
this.popup('首亮');
game.log(this,'首先明置武将,得到奖励');
game.log(this,'摸了'+get.cnNumber(initdraw)+'张牌');
this.draw(initdraw).log=false;
_status.initshown=true;
}
for(var i=0;i<skills.length;i++){ for(var i=0;i<skills.length;i++){
this.hiddenSkills.remove(skills[i]); this.hiddenSkills.remove(skills[i]);
this.addSkill(skills[i]); this.addSkill(skills[i]);
} }
this.checkConflict(); this.checkConflict();
if(!this.isUnseen(2)&&!this._mingzhied){ if(!notrigger){
this._mingzhied=true; var initdraw=parseInt(get.config('initshow_draw'));
if(this.singleHp){ if(!_status.initshown&&!_status.overing&&initdraw&&this.isAlive()&&_status.mode!='mingjiang'){
this.doubleDraw(); this.popup('首亮');
game.log(this,'首先明置武将,得到奖励');
game.log(this,'摸了'+get.cnNumber(initdraw)+'张牌');
this.draw(initdraw).log=false;
_status.initshown=true;
} }
if(this.perfectPair()){ if(!this.isUnseen(2)&&!this._mingzhied){
var next=game.createEvent('guozhanDraw'); this._mingzhied=true;
next.player=this; if(this.singleHp){
next.setContent('zhulian'); this.doubleDraw();
}
if(this.perfectPair()){
var next=game.createEvent('guozhanDraw');
next.player=this;
next.setContent('zhulian');
}
} }
} }
}, },