This commit is contained in:
libccy 2016-12-05 10:45:27 +08:00
parent bb33cea287
commit a91a9efd18
5 changed files with 209 additions and 61 deletions

View File

@ -75,17 +75,17 @@ character.hearth={
// hs_nzoth:['male','shu',4,['nuyan']], // hs_nzoth:['male','shu',4,['nuyan']],
hs_walian:['male','shu',4,['wzhanyi']], hs_walian:['male','shu',4,['wzhanyi']],
// hs_pengpeng:['male','qun',4,['zhadan']], // hs_pengpeng:['male','qun',4,['zhadan']],
// hs_yashaji:['male','wei',3,[]],
// hs_wolazi:['male','wei',3,[]], // hs_wolazi:['male','wei',3,[]],
// hs_tanghangu:['male','wei',3,[]], // hs_tanghangu:['male','wei',3,[]],
// hs_aya:['male','wei',3,[]], // hs_aya:['male','wei',3,[]],
// hs_barnes:['male','wei',3,[]], // hs_barnes:['male','wei',3,[]],
// hs_nuogefu:['male','wei',3,[]], // hs_nuogefu:['male','wei',3,[]],
// hs_kazhakusi:['male','wei',3,[]], hs_kazhakusi:['male','shu',3,['lianjin']],
// hs_lazi:['male','wei',3,[]], // hs_lazi:['male','wei',3,[]],
// hs_shaku:['male','wei',3,[]], hs_shaku:['male','wei',3,['shouji']],
// hs_laxiao:['male','wei',3,[]], hs_laxiao:['male','qun',3,['guimou','yingxi']],
// hs_yashaji:['male','wei',3,[]],
// hs_xiangyaqishi:['male','wei',3,[]], // hs_xiangyaqishi:['male','wei',3,[]],
}, },
perfectPair:{ perfectPair:{
@ -95,6 +95,120 @@ character.hearth={
hs_malfurion:['hs_malorne'], hs_malfurion:['hs_malorne'],
}, },
skill:{ skill:{
lianjin:{
enable:'phaseUse',
usable:2,
filterCard:true,
check:function(card){
return 7-ai.get.value(card);
},
content:function(){
'step 0'
var list=get.inpile('trick');
list=list.randomGets(3);
for(var i=0;i<list.length;i++){
list[i]=['锦囊','',list[i]];
}
var dialog=ui.create.dialog('选择一张锦囊牌加入你的手牌',[list,'vcard'],'hidden');
player.chooseButton(dialog,true);
'step 1'
if(result.buttons){
player.gain(game.createCard(result.buttons[0].link[2]),'draw');
}
},
ai:{
order:9,
result:{
player:1
}
}
},
shouji:{
group:['shouji_begin','shouji_miss'],
subSkill:{
begin:{
trigger:{player:'shaBegin'},
frequent:true,
filter:function(event){
return event.target.num('h')>0;
},
content:function(){
player.gain(game.createCard(trigger.target.get('h').randomGet()),'draw');
}
},
miss:{
trigger:{player:'shaMiss'},
frequent:true,
filter:function(event){
return event.target.num('e')>0;
},
content:function(){
player.gain(game.createCard(trigger.target.get('e').randomGet()),'draw');
}
}
}
},
yingxi:{
trigger:{player:'phaseEnd'},
direct:true,
filter:function(event,player){
return !player.getStat('damage')&&player.num('he',{color:'black'})>0;
},
content:function(){
'step 0'
player.chooseCardTarget({
prompt:get.prompt('yingxi'),
filterCard:{color:'black'},
filterTarget:function(card,player,target){
return lib.filter.targetEnabled({name:'sha'},player,target);
},
position:'he',
ai1:function(card){
return 8-ai.get.value(card);
},
ai2:function(target){
return ai.get.effect(target,{name:'sha'},player,player);
}
});
'step 1'
if(result.bool){
player.logSkill('yingxi',event.target);
player.useCard({name:'sha'},result.cards,result.targets);
}
},
},
guimou:{
trigger:{player:'damageEnd'},
check:function(event,player){
return ai.get.attitude(player,event.source)<=0;
},
filter:function(event,player){
return event.source&&event.source.isAlive()&&event.source.num('h')>0;
},
content:function(){
var card=trigger.source.get('h').randomGet();
if(card){
player.gain(card);
if(get.color(card)=='black'){
trigger.source.$give(card,player);
event.redo();
}
else{
trigger.source.$give(1,player);
}
game.delay(0.5);
}
},
ai:{
effect:{
target:function(card,player,target){
if(player.hasSkill('jueqing')) return [1,-2];
if(!target.hasFriend()) return false;
if(get.tag(card,'damage')) return [1,0,0,-1];
}
}
}
},
peiyu:{ peiyu:{
enable:'phaseUse', enable:'phaseUse',
filterCard:true, filterCard:true,
@ -2201,20 +2315,7 @@ character.hearth={
trigger:{player:'phaseUseBegin'}, trigger:{player:'phaseUseBegin'},
forced:true, forced:true,
content:function(){ content:function(){
'step 0' player.gain(game.createCard(get.inpile('trick').randomGet()),'draw');
var list=[];
for(var i in lib.card){
if(!lib.translate[i+'_info']) continue;
if(lib.card[i].mode&&lib.card[i].mode.contains(lib.config.mode)==false) continue;
if(lib.card[i].type=='trick') list.push(['锦囊','',i]);
}
list=list.randomGets(3);
var dialog=ui.create.dialog('选择一张锦囊牌加入你的手牌',[list,'vcard'],'hidden');
player.chooseButton(dialog,true);
'step 1'
if(result.buttons){
player.gain(game.createCard(result.buttons[0].link[2]),'gain2');
}
} }
}, },
lingzhou:{ lingzhou:{
@ -4688,6 +4789,14 @@ character.hearth={
hs_laxiao:'拉希奥', hs_laxiao:'拉希奥',
hs_yashaji:'亚煞极', hs_yashaji:'亚煞极',
lianjin:'炼金',
lianjin_info:'出牌阶段限两次你可以弃置一张手牌并从3张随机锦囊牌中选择一张加入手牌',
shouji:'收集',
shouji_info:'每当你使用一张杀,你可以获得一张目标随机手牌的复制;每当你的杀被闪避,你可以获得一张目标随机装备牌的复制',
guimou:'鬼谋',
guimou_info:'每当你受到一次伤害,你可以获得伤害来源的一张手牌,若此牌是黑色,你展示此牌并重复此过程',
yingxi:'影袭',
yingxi_info:'回合结束阶段,若你本回合未造成伤害,你可以将一张黑色牌当作杀对任意一名角色使用',
peiyu:'培育', peiyu:'培育',
peiyu_info:'出牌阶段,你可以弃置一张牌令一名没有图腾的角色获得一个随机图腾,或令一名有图腾的角色替换一个图腾;你死亡时,其他角色失去以此法获得的图腾', peiyu_info:'出牌阶段,你可以弃置一张牌令一名没有图腾的角色获得一个随机图腾,或令一名有图腾的角色替换一个图腾;你死亡时,其他角色失去以此法获得的图腾',
wzhanyi:'战意', wzhanyi:'战意',
@ -4834,7 +4943,7 @@ character.hearth={
liehun_info:'锁定技,回合结束阶段,你获得手牌中所有非基本牌的复制', liehun_info:'锁定技,回合结束阶段,你获得手牌中所有非基本牌的复制',
malymowang:'魔网', malymowang:'魔网',
malymowang2:'魔网', malymowang2:'魔网',
malymowang_info:'锁定技,你的锦囊牌造成的伤害+1出牌阶段开始时观看随机3张锦囊牌并将其中一张加入你的手牌', malymowang_info:'锁定技,你的锦囊牌造成的伤害+1出牌阶段开始时随机获得一张锦囊牌',
lingzhou:'灵咒', lingzhou:'灵咒',
lingzhou_info:'每当你使用一张锦囊牌,可令一名角色摸一张牌或回复一点体力', lingzhou_info:'每当你使用一张锦囊牌,可令一名角色摸一张牌或回复一点体力',
mieshi:'灭世', mieshi:'灭世',

View File

@ -117,6 +117,9 @@ character.yijiang={
} }
return false; return false;
}, },
ai:{
threaten:1.5
},
content:function(){ content:function(){
'step 0' 'step 0'
var goon=true; var goon=true;
@ -165,7 +168,7 @@ character.yijiang={
audio:false, audio:false,
content:function(){ content:function(){
if(!player.storage.xinsidi3&&player.storage.xinsidi4.isAlive()){ if(!player.storage.xinsidi3&&player.storage.xinsidi4.isAlive()){
player.useCard({name:'sha'},player.storage.xinsidi4); player.storage.xinsidi4.useCard({name:'sha'},player);
} }
delete player.storage.xinsidi2; delete player.storage.xinsidi2;
delete player.storage.xinsidi3; delete player.storage.xinsidi3;

View File

@ -1995,31 +1995,31 @@
} }
}, },
}, },
hsmod:{ // hsmod:{
enable:{ // enable:{
name:'开启', // name:'开启',
init:false, // init:false,
restart:true, // restart:true,
onclick:function(bool){ // onclick:function(bool){
if(bool){ // if(bool){
lib.config.plays.add('hsmod'); // lib.config.plays.add('hsmod');
} // }
else{ // else{
lib.config.plays.remove('hsmod'); // lib.config.plays.remove('hsmod');
} // }
game.saveConfig('plays',lib.config.plays); // game.saveConfig('plays',lib.config.plays);
} // }
}, // },
hide:{ // hide:{
name:'隐藏此扩展', // name:'隐藏此扩展',
clear:true, // clear:true,
onclick:function(){ // onclick:function(){
this.innerHTML='此扩展将在重启后隐藏'; // this.innerHTML='此扩展将在重启后隐藏';
lib.config.hiddenPlayPack.add('hsmod'); // lib.config.hiddenPlayPack.add('hsmod');
game.saveConfig('hiddenPlayPack',lib.config.hiddenPlayPack); // game.saveConfig('hiddenPlayPack',lib.config.hiddenPlayPack);
} // }
}, // },
}, // },
}, },
mode:{ mode:{
identity:{ identity:{
@ -6877,16 +6877,27 @@
return; return;
} }
if(event.isMine()){ if(event.isMine()){
event.controlbar=ui.create.control(event.controls); if(event.dialogcontrol){
if(event.dialog){ event.dialog=ui.create.dialog(event.prompt||'选择一项','hidden');
if(Array.isArray(event.dialog)){ for(var i=0;i<event.controls.length;i++){
event.dialog=ui.create.dialog.apply(this,event.dialog); var item=event.dialog.add('<div class="popup" style="width:calc(100% - 10px);display:inline-block">'+event.controls[i]+'</div>');
item.firstChild.listen(ui.click.dialogcontrol);
item.firstChild.link=event.controls[i];
} }
event.dialog.open(); event.dialog.open();
} }
else if(event.prompt){ else{
event.dialog=ui.create.dialog(event.prompt); event.controlbar=ui.create.control(event.controls);
} if(event.dialog){
if(Array.isArray(event.dialog)){
event.dialog=ui.create.dialog.apply(this,event.dialog);
}
event.dialog.open();
}
else if(event.prompt){
event.dialog=ui.create.dialog(event.prompt);
}
}
game.pause(); game.pause();
game.countChoose(); game.countChoose();
event.choosing=true; event.choosing=true;
@ -6907,6 +6918,7 @@
} }
else event.result.control=event.controls[event.choice]; else event.result.control=event.controls[event.choice];
} }
event.result.index=event.controls.indexOf(event.result.control);
event.choosing=false; event.choosing=false;
_status.imchoosing=false; _status.imchoosing=false;
if(event.dialog&&event.dialog.close) event.dialog.close(); if(event.dialog&&event.dialog.close) event.dialog.close();
@ -9948,7 +9960,10 @@
var next=game.createEvent('chooseControl'); var next=game.createEvent('chooseControl');
next.controls=[]; next.controls=[];
for(var i=0;i<arguments.length;i++){ for(var i=0;i<arguments.length;i++){
if(typeof arguments[i]=='string'){ if(arguments[i]=='dialogcontrol'){
next.dialogcontrol=true;
}
else if(typeof arguments[i]=='string'){
next.controls.push(arguments[i]); next.controls.push(arguments[i]);
} }
else if(get.objtype(arguments[i])=='array'){ else if(get.objtype(arguments[i])=='array'){
@ -30292,6 +30307,16 @@
game.resume(); game.resume();
} }
}, },
dialogcontrol:function(){
_status.event.result={
buttons:ui.selected.buttons.slice(0),
cards:ui.selected.cards.slice(0),
targets:ui.selected.targets.slice(0),
control:this.link,
links:get.links(ui.selected.buttons)
};
game.resume();
},
skill:function(skill){ skill:function(skill){
var info=get.info(skill); var info=get.info(skill);
var event=_status.event; var event=_status.event;

View File

@ -5,8 +5,12 @@ window.noname_update={
], ],
files:{ files:{
global:[ global:[
'game/config.js' 'game/config.js',
'mode/boss.js',
'character/yijiang.js',
'character/hearth.js',
], ],
'1.9.3':[], '1.9.3':[],
'1.9.3.1':[],
} }
} }

View File

@ -2741,6 +2741,14 @@ mode.boss={
} }
} }
}, },
boss_baonuwash:{
trigger:{player:'phaseAfter'},
forced:true,
content:function(){
game.over(game.me==game.boss);
},
temp:true,
},
boss_baonu:{ boss_baonu:{
unique:true, unique:true,
group:'boss_baonu2', group:'boss_baonu2',
@ -2756,11 +2764,10 @@ mode.boss={
_status.boss_baonuwash=true; _status.boss_baonuwash=true;
_status.event.parent.trigger('boss_baonuwash'); _status.event.parent.trigger('boss_baonuwash');
} }
else{
_status.event.player.addSkill('boss_baonuwash');
}
}); });
_status.maxShuffle=2;
_status.maxShuffleCheck=function(){
return game.me==game.boss;
}
for(var i in lib.card){ for(var i in lib.card){
if(lib.card[i].subtype=='equip1') lib.card[i].chongzhu=true; if(lib.card[i].subtype=='equip1') lib.card[i].chongzhu=true;
} }