Merge branch 'PR-Branch' of https://github.com/kuangshen04/noname into PR-Branch
This commit is contained in:
commit
9019cd41c1
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
|
@ -6061,7 +6061,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
onremove:function(player){
|
||||
game.countPlayer2(current=>{
|
||||
if(current.getStorage('dawu2').includes(player)){
|
||||
current.unmarkAuto('dawu2',player);
|
||||
current.unmarkAuto('dawu2',[player]);
|
||||
current.removeAdditionalSkill(`dawu_${player.playerid}`);
|
||||
}
|
||||
},true);
|
||||
|
|
|
@ -4,6 +4,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
name:'huicui',
|
||||
connect:true,
|
||||
character:{
|
||||
dc_lingcao:['male','wu','4/5',['dcdufeng']],
|
||||
yue_xiaoqiao:['female','wu',3,['dcqiqin','dcweiwan']],
|
||||
dc_dongzhao:['male','wei',3,['dcyijia','dcdingji']],
|
||||
kuaiqi:['male','wei',3,['dcliangxiu','dcxunjie']],
|
||||
|
@ -97,7 +98,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
huicui:{
|
||||
sp_baigei:['re_panfeng','xingdaorong','caoxing','re_chunyuqiong','xiahoujie','dc_caiyang','zhoushan'],
|
||||
sp_caizijiaren:['re_dongbai','re_sunluyu','heyan','zhaoyan','wangtao','wangyue','zhangxuan','tengyin','zhangyao','xiahoulingnv','dc_sunru','pangshanmin','kuaiqi'],
|
||||
sp_zhilan:['liuyong','wanniangongzhu','zhanghu','lvlingqi','tenggongzhu','panghui','dc_zhaotongzhaoguang','yuantanyuanxiyuanshang','yuechen'],
|
||||
sp_zhilan:['liuyong','wanniangongzhu','zhanghu','lvlingqi','tenggongzhu','panghui','dc_zhaotongzhaoguang','yuantanyuanxiyuanshang','yuechen','dc_lingcao'],
|
||||
sp_guixin:['re_kanze','re_chendeng','caimaozhangyun','dc_lvkuanglvxiang','dc_gaolan','yinfuren','chengui','chenjiao','dc_sp_jiaxu','qinlang','dc_dongzhao'],
|
||||
sp_daihan:['mamidi','dc_jiling','zhangxun','dc_yuejiu','wanglie','leibo','qiaorui','dongwan','yuanyin'],
|
||||
sp_jianghu:['guanning','huzhao','dc_huangchengyan','mengjie'],
|
||||
|
@ -111,6 +112,55 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
}
|
||||
},
|
||||
skill:{
|
||||
//凌操
|
||||
dcdufeng:{
|
||||
audio:2,
|
||||
trigger:{player:'phaseUseBegin'},
|
||||
forced:true,
|
||||
async content(event,trigger,player){
|
||||
const list=[];
|
||||
for(let i=1;i<6;i++){
|
||||
if(player.isDisabled(i)) continue;
|
||||
list.push('equip'+i);
|
||||
}
|
||||
list.push('cancel2');
|
||||
const next=player.chooseControl(list);
|
||||
next.set('prompt','独锋:请废除一个装备栏,或点击“取消”失去1点体力');
|
||||
next.set('ai',()=>{
|
||||
const list=get.event().list.slice(),player=get.player();
|
||||
if(player.hp<=2&&list.length>1) list.remove('cancel2');
|
||||
const listx=list.filter(subtype=>!player.getEquips(subtype).length);
|
||||
if(listx.length) return listx.randomGet();
|
||||
return list.randomGet();
|
||||
})
|
||||
next.set('list',list);
|
||||
const {result}=await next;
|
||||
if(result.control=='cancel2') await player.loseHp();
|
||||
else await player.disableEquip(result.control);
|
||||
if(!player.isIn()) return;
|
||||
const num=Math.min(player.countDisabled()+player.getDamagedHp(),player.maxHp);
|
||||
await player.draw(num);
|
||||
player.addTempSkill('dcdufeng_effect');
|
||||
player.addMark('dcdufeng_effect',num,false);
|
||||
},
|
||||
subSkill:{
|
||||
effect:{
|
||||
charlotte:true,
|
||||
onremove:true,
|
||||
intro:{
|
||||
content:'本回合攻击范围与使用【杀】的次数上限均为#',
|
||||
},
|
||||
mod:{
|
||||
attackRangeBase(player,num){
|
||||
return player.countMark('dcdufeng_effect');
|
||||
},
|
||||
cardUsable(card,player,num){
|
||||
if(card.name=='sha') return player.countMark('dcdufeng_effect');
|
||||
},
|
||||
},
|
||||
}
|
||||
},
|
||||
},
|
||||
//小乔
|
||||
dcqiqin:{
|
||||
audio:2,
|
||||
|
@ -5333,7 +5383,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
var dialog=ui.create.dialog('劝谏:令一名其他角色…','hidden');
|
||||
dialog.add([[
|
||||
['damage','对其攻击范围内的一名角色造成1点伤害'],
|
||||
['draw','将其手牌数调整至体力上限(至多摸至五张),且其本回合内不能使用手牌']
|
||||
['draw','将其手牌数调整至手牌上限(至多摸至五张),且其本回合内不能使用手牌']
|
||||
],'textbutton']);
|
||||
return dialog;
|
||||
},
|
||||
|
@ -5346,7 +5396,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
},
|
||||
prompt:function(links){
|
||||
if(links[0]=='damage') return '令一名其他角色对攻击范围内的另一名角色造成1点伤害';
|
||||
return '令一名其他角色将手牌数调整至体力上限(至多摸至五张)且本回合内不能使用手牌';
|
||||
return '令一名其他角色将手牌数调整至手牌上限(至多摸至五张)且本回合内不能使用手牌';
|
||||
},
|
||||
},
|
||||
ai:{
|
||||
|
@ -5404,15 +5454,15 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
filterTarget:function(card,player,target){
|
||||
if(target==player) return false;
|
||||
var num=target.countCards('h');
|
||||
if(num>target.maxHp) return true;
|
||||
return num<Math.min(5,target.maxHp);
|
||||
if(num>target.getHandcardLimit()) return true;
|
||||
return num<Math.min(5,target.getHandcardLimit());
|
||||
},
|
||||
filterCard:()=>false,
|
||||
selectCard:-1,
|
||||
content:function(){
|
||||
'step 0'
|
||||
player.addTempSkill('dcquanjian_draw','phaseUseAfter');
|
||||
var num1=target.countCards('h'),num2=target.maxHp;
|
||||
var num1=target.countCards('h'),num2=target.getHandcardLimit();
|
||||
var num=0;
|
||||
if(num1>num2){
|
||||
event.index=0;
|
||||
|
@ -5456,7 +5506,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
ai:{
|
||||
result:{
|
||||
target:function(player,target){
|
||||
var num1=target.countCards('h'),num2=target.maxHp;
|
||||
var num1=target.countCards('h'),num2=target.getHandcardLimit();
|
||||
if(num1>num2) return -1;
|
||||
return Math.min(5,num2)-num1;
|
||||
},
|
||||
|
@ -10458,7 +10508,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
content:function(){
|
||||
player.markAuto('dcxunji_effect',[target]);
|
||||
player.addTempSkill('dcxunji_effect',{player:'die'});
|
||||
target.markSkill('dcxunji_mark');
|
||||
target.addTempSkill('dcxunji_mark',{player:'phaseEnd'});
|
||||
},
|
||||
ai:{
|
||||
order:1,
|
||||
|
@ -10471,6 +10521,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
},
|
||||
subSkill:{
|
||||
mark:{
|
||||
mark:true,
|
||||
marktext:'嫉',
|
||||
intro:{content:'你已经被盯上了!'},
|
||||
},
|
||||
|
@ -10502,10 +10553,11 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
forced:true,
|
||||
popup:false,
|
||||
filter:function(event,player){
|
||||
return event.card&&event.card.name=='juedou'&&event.getParent().skill=='dcxunji_effect';
|
||||
return event.card&&event.card.name=='juedou'&&event.getParent().skill=='dcxunji_effect'&&event.player.isIn();
|
||||
},
|
||||
content:function(){
|
||||
player.loseHp(trigger.num);
|
||||
trigger.player.line(player);
|
||||
player.damage(trigger.num,trigger.player);
|
||||
},
|
||||
},
|
||||
},
|
||||
|
@ -11083,6 +11135,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
liuyong:['liuyong','jsrg_liuyong'],
|
||||
zhangxuan:['zhangxuan','jsrg_zhangxuan'],
|
||||
gaoxiang:['gaoxiang','jsrg_gaoxiang'],
|
||||
lingcao:['lingcao','dc_lingcao'],
|
||||
},
|
||||
translate:{
|
||||
re_panfeng:'潘凤',
|
||||
|
@ -11115,7 +11168,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
zhuangdan_info:'锁定技,其他角色的回合结束时,若你的手牌数为全场唯一最多,则你令〖裂胆〗失效直到你下回合结束。',
|
||||
dc_caiyang:'蔡阳',
|
||||
dcxunji:'寻嫉',
|
||||
dcxunji_info:'出牌阶段限一次,你可以选择一名其他角色。该角色的下个结束阶段开始时,若其于该回合内造成过伤害,则你视为对其使用一张【决斗】,且当此【决斗】对其造成伤害后,你失去等量的体力。',
|
||||
dcxunji_info:'出牌阶段限一次,你可以选择一名其他角色。该角色的下个结束阶段开始时,若其于该回合内造成过伤害,则你视为对其使用一张【决斗】,且当此【决斗】对其造成伤害后,其对你造成等量的伤害。',
|
||||
dcjiaofeng:'交锋',
|
||||
dcjiaofeng_info:'锁定技。每回合限一次,当你造成伤害时,若你本回合内未造成过其他伤害且你已损失的体力值:大于0,则你摸一张牌;大于1,则此伤害+1;大于2,则你回复1点体力。',
|
||||
zhoushan:'周善',
|
||||
|
@ -11325,7 +11378,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
dcyongbi_info:'限定技。出牌阶段,你可以将所有手牌交给一名其他男性角色。你将〖媵予〗的发动时机改为“准备阶段和结束阶段开始时”。然后若这些牌中包含的花色数:大于1,则你与其本局游戏的手牌上限+2;大于2,则当你或其于本局游戏内受到大于1的伤害时,此伤害-1。',
|
||||
dc_huangquan:'黄权',
|
||||
dcquanjian:'劝谏',
|
||||
dcquanjian_info:'出牌阶段每项各限一次。你可以选择一项流程并选择一名其他角色A:⒈令A对其攻击范围内的另一名角色B造成1点伤害。⒉令A将手牌数调整至体力上限(至多摸至五张),且其本回合内不能使用或打出手牌。然后A选择一项:⒈执行此流程。⒉本回合下次受到的伤害+1。',
|
||||
dcquanjian_info:'出牌阶段每项各限一次。你可以选择一项流程并选择一名其他角色A:⒈令A对其攻击范围内的另一名角色B造成1点伤害。⒉令A将手牌数调整至手牌上限(至多摸至五张),且其本回合内不能使用或打出手牌。然后A选择一项:⒈执行此流程。⒉本回合下次受到的伤害+1。',
|
||||
dctujue:'途绝',
|
||||
dctujue_info:'限定技。当你进入濒死状态时,你可以将所有牌交给一名其他角色。然后你回复等量的体力并摸等量的牌。',
|
||||
chengui:'陈珪',
|
||||
|
@ -11546,6 +11599,10 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
dcqiqin_info:'锁定技。①游戏开始时,你将所有手牌标记为“琴”。②你的“琴”牌不计入手牌上限。③准备阶段,你获得弃牌堆中所有你标记过的“琴”牌。',
|
||||
dcweiwan:'媦婉',
|
||||
dcweiwan_info:'出牌阶段限一次,你可以弃置一张“琴”并随机获得一名其他角色区域内花色与此牌不相同的牌各一张,若你获得了:一张牌,其失去1点体力;两张牌,本回合你对其使用牌无距离和次数限制;三张牌,本回合你不能对其使用牌。',
|
||||
dc_lingcao:'新杀凌操',
|
||||
dc_lingcao_prefix:'新杀',
|
||||
dcdufeng:'独锋',
|
||||
dcdufeng_info:'锁定技。出牌阶段开始时,你失去1点体力或废除一个装备栏,摸X张牌,然后你的攻击范围与使用【杀】的次数上限均为X直到回合结束(X为你已废除的装备栏数与损失的体力值之和,至多为你的体力上限)。',
|
||||
|
||||
sp_baigei:'无双上将',
|
||||
sp_caizijiaren:'才子佳人',
|
||||
|
|
|
@ -8208,6 +8208,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
jsrg_fanjiangzhangda_prefix:'转',
|
||||
jsrgfushan:'负山',
|
||||
jsrgfushan_info:'出牌阶段开始时,所有其他角色可以依次交给你一张牌并令你此阶段使用【杀】的次数上限+1。此阶段结束时,若你使用【杀】的次数未达到上限且此阶段以此法交给你牌的角色均存活,你失去2点体力,否则你将手牌摸至体力上限。',
|
||||
//江山如故·合
|
||||
jsrg_zhugeliang:'梦诸葛亮',
|
||||
jsrg_zhugeliang_prefix:'梦',
|
||||
jsrgwentian:'问天',
|
||||
|
|
|
@ -482,32 +482,34 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
audio:'twjieyu',
|
||||
trigger:{player:'phaseJieshuBegin'},
|
||||
filter:function(event,player){
|
||||
for(var i=0;i<ui.discardPile.childElementCount;i++){
|
||||
if(get.type(ui.discardPile.childNodes[i])=='basic') return true;
|
||||
for(let i=0;i<ui.discardPile.childElementCount;i++){
|
||||
if(get.type(ui.discardPile.childNodes[i],false)=='basic') return true;
|
||||
}
|
||||
return false;
|
||||
},
|
||||
prompt2:function(event,player){
|
||||
const num=lib.skill.jieyu.getNum(player,true);
|
||||
const num=lib.skill.jieyu.getNum(player);
|
||||
return '获得弃牌堆中'+get.cnNumber(num)+'张'+(num>1?'牌名各不相同的':'')+'基本牌';
|
||||
},
|
||||
async content(event,trigger,player){
|
||||
const num=lib.skill.jieyu.getNum(player,false);
|
||||
let gains=[],names=lib.inpile.filter(name=>get.type(name)=='basic').randomGets(num);
|
||||
names.forEach(name=>{
|
||||
let card=get.discardPile(card=>card.name==name);
|
||||
if(name) gains.push(card);
|
||||
});
|
||||
if(gains.length) player.gain(gains,'gain2');
|
||||
const num=lib.skill.jieyu.getNum(player,event);
|
||||
let gains=[],names=[];
|
||||
for(let i=0;i<ui.discardPile.childElementCount;i++){
|
||||
let card=ui.discardPile.childNodes[i];
|
||||
if(get.type(card,false)=='basic'&&!names.includes(card.name)){
|
||||
gains.push(card);
|
||||
names.push(card.name);
|
||||
}
|
||||
}
|
||||
if(gains.length) player.gain(gains.randomGets(Math.min(gains.length,num)),'gain2');
|
||||
},
|
||||
getNum:function(player,goon){
|
||||
let num=3,bool=goon;
|
||||
getNum:function(player,event){
|
||||
let num=3;
|
||||
const history=game.getAllGlobalHistory('everything');
|
||||
for(let i=history.length-1;i>=0;i--){
|
||||
const evt=history[i];
|
||||
if(evt.name=='useSkill'&&evt.player==player&&evt.skill=='jieyu'){
|
||||
if(!bool) bool=true;
|
||||
else break;
|
||||
if(evt.name=='jieyu'&&evt.player==player){
|
||||
if(!event||evt!=event) break;
|
||||
}
|
||||
if(evt.name=='useCard'&&evt.player!=player&&evt.targets&&evt.targets.includes(player)&&get.tag(evt.card,'damage')){
|
||||
num--;
|
||||
|
@ -599,7 +601,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
if(to.hujia>0) return distance+1;
|
||||
},
|
||||
},
|
||||
audio:2,
|
||||
audio:true,
|
||||
trigger:{player:'damageBegin2'},
|
||||
filter:function(event,player){
|
||||
return player.hujia>0&&event.hasNature('fire');
|
||||
|
|
|
@ -129,6 +129,8 @@ window.noname_character_rank={
|
|||
'caoxian',
|
||||
'sb_guanyu',
|
||||
'mb_chengui',
|
||||
'jsrg_guozhao',
|
||||
'sb_caopi',
|
||||
],
|
||||
a:[
|
||||
'diy_zaozhirenjun',
|
||||
|
@ -354,8 +356,11 @@ window.noname_character_rank={
|
|||
'ol_jianyong',
|
||||
'ol_sb_jiangwei',
|
||||
'dc_sb_zhouyu',
|
||||
'dc_lingcao',
|
||||
'jsrg_zhugeliang',
|
||||
],
|
||||
am:[
|
||||
'muludawang',
|
||||
'diy_caiwenji',
|
||||
'diy_liuyan',
|
||||
'diy_zhenji',
|
||||
|
@ -648,8 +653,12 @@ window.noname_character_rank={
|
|||
'zhugeruoxue',
|
||||
'dc_sb_lusu',
|
||||
'mb_huban',
|
||||
'jsrg_simayi',
|
||||
'jsrg_zhaoyun',
|
||||
'jsrg_zhangxuan',
|
||||
],
|
||||
bp:[
|
||||
'xin_huojun',
|
||||
'chess_diaochan',
|
||||
'chess_huangzhong',
|
||||
'chess_sunshangxiang',
|
||||
|
@ -1017,8 +1026,16 @@ window.noname_character_rank={
|
|||
'sunhuan',
|
||||
'yue_caiyong',
|
||||
'sb_huangyueying',
|
||||
'jsrg_jiangwei',
|
||||
'jsrg_luxun',
|
||||
'jsrg_caofang',
|
||||
'jsrg_guoxun',
|
||||
'jsrg_gaoxiang',
|
||||
'jsrg_sunlubansunluyu',
|
||||
'jsrg_weiwenzhugezhi',
|
||||
],
|
||||
b:[
|
||||
'liyi',
|
||||
'diy_feishi',
|
||||
'diy_liufu',
|
||||
'diy_tianyu',
|
||||
|
@ -1332,6 +1349,8 @@ window.noname_character_rank={
|
|||
'lvboshe',
|
||||
'ol_caozhang',
|
||||
'ol_lingtong',
|
||||
'jsrg_liuyong',
|
||||
'jsrg_sunjun',
|
||||
],
|
||||
bm:[
|
||||
'diy_xizhenxihong',
|
||||
|
@ -2089,6 +2108,8 @@ window.noname_character_rank={
|
|||
'dc_sb_zhouyu',
|
||||
],
|
||||
rare:[
|
||||
'xin_huojun',
|
||||
'muludawang',
|
||||
'mb_huban',
|
||||
'sp_jianggan',
|
||||
'ol_caozhang',
|
||||
|
|
|
@ -6363,7 +6363,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
sbfangzhu:'放逐',
|
||||
sbfangzhu_info:'出牌阶段限一次,你可以:1.移去2个“颂”标记,令一名其他角色的非Charlotte技能失效直到其回合结束;2.移去2个“颂”标记,令一名其他角色不能响应除其以为的角色使用的牌直到其回合结束;3.移去2个“颂”标记,令一名其他角色将武将牌翻面;4.移去2个“颂”标记,令一名其他角色只能使用你选择的一种类型的牌直到其回合结束。',
|
||||
sbsongwei:'颂威',
|
||||
sbsongwei_info:'①出牌阶段开始时,你获得Y个“颂”标记(Y为场上其他魏势力角色数)。②每局游戏限一次,出牌阶段,你可以令一名其他魏势力角色失去所有武将牌的技能。',
|
||||
sbsongwei_info:'主公技。①出牌阶段开始时,你获得Y个“颂”标记(Y为场上其他魏势力角色数)。②每局游戏限一次,出牌阶段,你可以令一名其他魏势力角色失去所有武将牌的技能。',
|
||||
|
||||
sb_zhi:'谋攻篇·知',
|
||||
sb_shi:'谋攻篇·识',
|
||||
|
|
215
character/sp.js
215
character/sp.js
|
@ -8,7 +8,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
sp_tianji:["sunhao","liuxie","caoang","hetaihou","sunluyu",'ol_wangrong',"zuofen","ol_bianfuren","qinghegongzhu","tengfanglan","ruiji",'caoxiancaohua'],
|
||||
sp_sibi:["yangxiu","chenlin","chengyu","shixie","fuwan","wangyun","zhugejin","simalang","maliang","buzhi","dongyun","kanze","sunqian","xizhicai","sunshao",'duxi',"jianggan",'ol_dengzhi','ol_yangyi','ol_dongzhao','ol_chendeng','jin_yanghu','wangyan','xiahouxuan','quhuang','zhanghua','wangguan','sunhong','caoxi'],
|
||||
sp_tianzhu:['zhangyan','niujin','hejin','hansui',"wutugu","yanbaihu","shamoke","zhugedan",'huangzu','gaogan',"tadun","fanjiangzhangda","ahuinan","dongtuna",'ol_wenqin'],
|
||||
sp_nvshi:["lingju","guanyinping","zhangxingcai","mayunlu","dongbai","zhaoxiang",'ol_zhangchangpu',"daxiaoqiao","jin_guohuai"],
|
||||
sp_nvshi:['ol_dingshangwan',"lingju","guanyinping","zhangxingcai","mayunlu","dongbai","zhaoxiang",'ol_zhangchangpu',"daxiaoqiao","jin_guohuai"],
|
||||
sp_shaowei:["simahui","zhangbao","zhanglu","zhugeguo","xujing","zhangling",'huangchengyan','zhangzhi','lushi'],
|
||||
sp_huben:['duanjiong','ol_mengda',"caohong","xiahouba","zhugeke","zumao","wenpin","litong","mazhong","heqi","quyi","luzhi","zangba","yuejin","dingfeng","wuyan","ol_zhuling","tianyu","huojun",'zhaoyǎn','dengzhong','ol_furong','macheng','ol_zhangyì','ol_zhujun','maxiumatie','luoxian','ol_huban','haopu','ol_qianzhao'],
|
||||
sp_liesi:['lvboshe','mizhu','weizi','ol_liuba','zhangshiping'],
|
||||
|
@ -18,7 +18,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
sp_zhongdan:["cuiyan","huangfusong"],
|
||||
sp_guozhan2:["sp_dongzhuo","liqueguosi","zhangren"],
|
||||
sp_others:["hanba","caiyang"],
|
||||
sp_waitforsort:['ol_luyusheng','ol_pengyang','ol_tw_zhangji','ol_dingshangwan','ol_liwan','ol_liuyan','caoyu'],
|
||||
sp_waitforsort:['ol_luyusheng','ol_pengyang','ol_tw_zhangji','ol_liwan','ol_liuyan','caoyu','liyi'],
|
||||
},
|
||||
},
|
||||
characterFilter:{
|
||||
|
@ -30,6 +30,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
},
|
||||
},
|
||||
character:{
|
||||
liyi:['male','wu',4,['olchanshuang','olzhanjin']],
|
||||
caoyu:['male','wei',3,['olgongjie','olxiangxv','olxiangzuo']],
|
||||
ol_liwan:['female','wei',3,['ollianju','olsilv']],
|
||||
ol_dingshangwan:['female','wei',3,['olfudao','olfengyan']],
|
||||
|
@ -202,6 +203,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
luzhi:['male','wei',3,['qingzhong','weijing']]
|
||||
},
|
||||
characterIntro:{
|
||||
liyi:'李异(生卒年不详),三国时期东吴将领。建安末,与谢旌率水陆三千,击破刘备军将领詹晏、陈凤。刘备领兵攻孙权时,李异与陆逊等人屯巫、秭归,为蜀将所破。黄武元年(222年),陆逊破刘备于猇亭,李异追踪蜀军,屯驻南山。清代学者赵一清认为此李异与刘璋部将李异为同一人。',
|
||||
caoyu:'曹宇(?-278年),字彭祖,沛国谯县(今安徽亳州)人。三国时期魏国宗室,魏武帝曹操与环夫人之子,邓哀王曹冲同母兄弟。太和六年,封为燕王。魏明帝病危,欲以大将军辅政,不果。其子常道乡公曹奂,是魏国末代皇帝,史称魏元帝。晋朝建立后,降封燕公。咸宁四年(278年),曹宇去世。',
|
||||
zhangyan:'张燕,本姓褚,生卒年不详,常山真定(今河北正定南)人,东汉末年黑山军首领。张燕剽捍,敏捷过人,军中称为“飞燕”。官渡之战时投降曹操,被任命为平北将军,封安国亭侯。死后其子张方袭爵。',
|
||||
lushi:'卢氏,五斗米教主张衡妻,张鲁母,擅长驻颜之术,常年令自己保持少女的容颜。常拜访刘焉,与其交好。',
|
||||
|
@ -705,6 +707,207 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
},
|
||||
},
|
||||
skill:{
|
||||
//李异
|
||||
olchanshuang:{
|
||||
audio:2,
|
||||
enable:'phaseUse',
|
||||
filterTarget:lib.filter.notMe,
|
||||
usable:1,
|
||||
content:function*(event,map){
|
||||
const player=map.player,target=event.target;
|
||||
const choiceList=[
|
||||
'重铸一张牌',
|
||||
'使用一张【杀】',
|
||||
'弃置两张牌',
|
||||
],list=['重铸','出杀','弃牌','无法选择'];
|
||||
let result=[];
|
||||
for(let current of [player,target]){
|
||||
let list1=list.slice(),choiceList1=choiceList.slice();
|
||||
list1=list1.filter(control=>{
|
||||
if(control=='无法选择') return false;
|
||||
if(control=='重铸') return current.countCards('he',card=>current.canRecast(card));
|
||||
if(control=='出杀') return current.countCards('he',card=>card.name=='sha'&¤t.hasUseTarget(card));
|
||||
if(control=='弃牌') return current.countCards('he',card=>lib.filter.cardDiscardable(card,current))>1;
|
||||
});
|
||||
choiceList1=choiceList.filter(control=>{
|
||||
if(choiceList.indexOf(control)==0) return current.countCards('he',card=>current.canRecast(card));
|
||||
if(choiceList.indexOf(control)==1) return current.countCards('he',card=>card.name=='sha'&¤t.hasUseTarget(card));
|
||||
if(choiceList.indexOf(control)==2) return current.countCards('he',card=>lib.filter.cardDiscardable(card,current))>1;
|
||||
});
|
||||
if(list1.length){
|
||||
if(list1.length==1) result.push(list.indexOf(list1[0]));
|
||||
else{
|
||||
let result1=yield current.chooseControl(list1).set('ai',()=>{
|
||||
const current=_status.event.player;
|
||||
const controls=_status.event.controls.slice();
|
||||
if(controls.includes('出杀')&¤t.countCards('hs',card=>card.name=='sha'&¤t.hasValueTarget(card))) return '出杀';
|
||||
if(controls.includes('重铸')) return '重铸';
|
||||
return '弃牌';
|
||||
}).set('choiceList',choiceList1);
|
||||
if(result1.control) result.push(list.indexOf(result1.control));
|
||||
}
|
||||
}
|
||||
else result.push(3);
|
||||
}
|
||||
player.popup(list[result[0]]);
|
||||
target.popup(list[result[1]]);
|
||||
for(let current of [player,target]){
|
||||
switch(list[result[current==player?0:1]]){
|
||||
case '重铸':
|
||||
let result2=yield current.chooseCard('he','请重铸一张牌',(card,player)=>player.canRecast(card),true);
|
||||
if(result2.bool) current.recast(result2.cards);
|
||||
break;
|
||||
case '出杀':
|
||||
current.chooseToUse({
|
||||
prompt:'请使用一张【杀】',
|
||||
filterCard:function(card,player){
|
||||
if(card.name!='sha') return false;
|
||||
return lib.filter.filterCard.apply(this,arguments);
|
||||
},
|
||||
forced:true,
|
||||
ai1:function(card){
|
||||
return _status.event.player.getUseValue(card);
|
||||
},
|
||||
});
|
||||
break;
|
||||
case '弃牌':
|
||||
current.chooseToDiscard('he',2,true);
|
||||
break;
|
||||
}
|
||||
}
|
||||
},
|
||||
ai:{
|
||||
order:function(item,player){
|
||||
return get.order({name:'sha'},player)-0.1;
|
||||
},
|
||||
result:{
|
||||
target:function(player,target){
|
||||
const att=get.attitude(player,target);
|
||||
if(target.countCards('hs',card=>{
|
||||
return card.name=='sha'&&game.hasPlayer(current=>{
|
||||
return target.canUse(card,current)&&get.effect(current,card,target,target)>0&&get.effect(current,card,target,player)>0;
|
||||
});
|
||||
})) return 3;
|
||||
if(att>0) return 2;
|
||||
if(!target.countCards('h')) return get.sgn(att)+(att==0?1:0);
|
||||
return 0;
|
||||
},
|
||||
},
|
||||
},
|
||||
group:'olchanshuang_end',
|
||||
subSkill:{
|
||||
end:{
|
||||
audio:'olchanshuang',
|
||||
trigger:{player:'phaseJieshuBegin'},
|
||||
filter:function(event,player){
|
||||
return player.getHistory('lose',evt=>{
|
||||
if(evt.type=='discard'){
|
||||
var evtx=evt.getl(player);
|
||||
return evtx&&evtx.cards2.length==2;
|
||||
}
|
||||
return evt.getParent(2).name=='recast';
|
||||
}).length||player.getHistory('useCard',evt=>evt.card.name=='sha').length;
|
||||
},
|
||||
forced:true,
|
||||
locked:false,
|
||||
content:function*(event,map){
|
||||
let num=0,player=map.player;
|
||||
if(player.getHistory('lose',evt=>evt.getParent(2).name=='recast').length) num++;
|
||||
if(player.getHistory('useCard',evt=>evt.card.name=='sha').length) num++;
|
||||
if(player.getHistory('lose',evt=>{
|
||||
if(evt.type=='discard'){
|
||||
var evtx=evt.getl(player);
|
||||
return evtx&&evtx.cards2.length==2;
|
||||
}
|
||||
}).length) num++;
|
||||
if(num&&player.countCards('he',card=>player.canRecast(card))){
|
||||
let result=yield player.chooseCard('he','请重铸一张牌',(card,player)=>player.canRecast(card),true);
|
||||
if(result.bool) yield player.recast(result.cards);
|
||||
}
|
||||
if(num>1&&player.countCards('he',card=>card.name=='sha'&&player.hasUseTarget(card))){
|
||||
yield player.chooseToUse({
|
||||
prompt:'请使用一张【杀】',
|
||||
filterCard:function(card,player){
|
||||
if(card.name!='sha') return false;
|
||||
return lib.filter.filterCard.apply(this,arguments);
|
||||
},
|
||||
forced:true,
|
||||
ai1:function(card){
|
||||
return _status.event.player.getUseValue(card);
|
||||
},
|
||||
});
|
||||
}
|
||||
if(num>2&&player.countCards('he',card=>lib.filter.cardDiscardable(card,player))) yield player.chooseToDiscard('he',2,true);
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
olzhanjin:{
|
||||
audio:2,
|
||||
locked:true,
|
||||
group:'olzhanjin_guanshi',
|
||||
subSkill:{
|
||||
guanshi:{
|
||||
audio:'olzhanjin',
|
||||
nobracket:true,
|
||||
equipSkill:true,
|
||||
trigger:{player:['shaMiss','eventNeutralized']},
|
||||
filter:function(event,player){
|
||||
if(!player.hasEmptySlot(1)||!lib.card.guanshi) return false;
|
||||
if(event.type!='card'||event.card.name!='sha'||!event.target.isIn()) return false;
|
||||
return player.countCards('he')>=2;
|
||||
},
|
||||
direct:true,
|
||||
locked:false,
|
||||
content:function(){
|
||||
"step 0"
|
||||
player.chooseToDiscard(get.prompt('olzhanjin_guanshi'),'弃置两张牌,令'+get.translation(trigger.card)+'强制命中',2,'he').set('ai',function(card){
|
||||
var evt=_status.event.getTrigger();
|
||||
if(get.attitude(evt.player,evt.target)<0){
|
||||
if(player.needsToDiscard()) return 15-get.value(card);
|
||||
if(evt.baseDamage+evt.extraDamage>=Math.min(2,evt.target.hp)) return 8-get.value(card);
|
||||
return 5-get.value(card);
|
||||
}
|
||||
return -1;
|
||||
}).set('complexCard',true).logSkill='olzhanjin_guanshi';
|
||||
'step 1'
|
||||
if(result.bool){
|
||||
if(event.triggername=='shaMiss'){
|
||||
trigger.untrigger();
|
||||
trigger.trigger('shaHit');
|
||||
trigger._result.bool=false;
|
||||
trigger._result.result=null;
|
||||
}
|
||||
else trigger.unneutralize();
|
||||
}
|
||||
},
|
||||
mod:{
|
||||
attackRange:function(player,num){
|
||||
if(lib.card.guanshi&&player.hasEmptySlot(1)) return num-lib.card.guanshi.distance.attackFrom;
|
||||
},
|
||||
},
|
||||
ai:{
|
||||
directHit_ai:true,
|
||||
skillTagFilter:function(player,tag,arg){
|
||||
if(player._olzhanjin_guanshi_temp||!player.hasEmptySlot(1)||!lib.card.guanshi) return;
|
||||
player._guanshi_temp=true;
|
||||
var bool=(get.attitude(player,arg.target)<0&&arg.card&&arg.card.name=='sha'&&player.countCards('he',card=>{
|
||||
return card!=arg.card&&(!arg.card.cards||!arg.card.cards.includes(card))&&get.value(card)<5;
|
||||
})>1);
|
||||
delete player._olzhanjin_guanshi_temp;
|
||||
return bool;
|
||||
},
|
||||
effect:{
|
||||
target:function(card,player,target){
|
||||
if(player==target&&get.subtype(card)=='equip1'){
|
||||
if(get.equipValue(card)<=get.equipValue({name:'guanshi'})) return 0;
|
||||
}
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
},
|
||||
//曹宇
|
||||
olgongjie:{
|
||||
audio:2,
|
||||
|
@ -764,9 +967,9 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
}
|
||||
return cards.length-player.countCards('h')>0;
|
||||
},
|
||||
usable:1,
|
||||
logTarget:()=>_status.currentPhase,
|
||||
async content(event,trigger,player){
|
||||
player.tempBanSkill('olxiangxv',null,false);
|
||||
player.when({global:'phaseEnd'}).then(()=>{
|
||||
if(target&&target.isIn()){
|
||||
var num=target.countCards('h')-player.countCards('h');
|
||||
|
@ -26815,6 +27018,12 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
olxiangxv_info:'当你的手牌数变为全场最少时,你可以获得以下效果:本回合结束时,将手牌数调整至与当前回合角色手牌数相同(至多摸至五张)。',
|
||||
olxiangzuo:'襄胙',
|
||||
olxiangzuo_info:'限定技,当你进入濒死状态时,你可以交给当前回合角色任意张牌,若如此做,若你本回合已对其发动过〖恭节〗或〖相胥〗,你回复等量的体力。',
|
||||
liyi:'李异',
|
||||
olchanshuang:'缠双',
|
||||
olchanshuang_info:'①出牌阶段限一次,你可以选择一名其他角色。你与其依次选择〖缠双③〗的一项,然后你与其依次执行各自选择的项。②结束阶段,若X大于0,你执行〖缠双③〗的前X项(X为你本回合以任意形式执行过的〖缠双③〗的选项数)。③选项:1.重铸一张牌;2.使用一张【杀】;3.弃置两张牌。',
|
||||
olzhanjin:'蘸金',
|
||||
olzhanjin_guanshi:'贯石斧(蘸金)',
|
||||
olzhanjin_info:'锁定技,若你有空置的武器栏,则你视为装备【贯石斧】。',
|
||||
|
||||
sp_tianji:'天极·皇室宗亲',
|
||||
sp_sibi:'四弼·辅国文曲',
|
||||
|
|
|
@ -6188,7 +6188,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
player.chooseCard('he',get.prompt('twxingwu'),'将一张牌置于武将牌上作为“星舞”').set('ai',function(card){
|
||||
if(_status.event.goon) return 20-get.value(card);
|
||||
return 7-get.value(card);
|
||||
}).set('goon',player.needsToDiscard()||player.getStorage('twxingwu').length>1);
|
||||
}).set('goon',player.needsToDiscard()||player.getExpansions('twxingwu').length>1);
|
||||
'step 1'
|
||||
if(result.bool){
|
||||
player.logSkill('twxingwu');
|
||||
|
@ -8340,6 +8340,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
effect:{
|
||||
intro:{content:'使用下一张牌时弃置&张牌'},
|
||||
charlotte:true,
|
||||
onremove:true,
|
||||
audio:'twchayi',
|
||||
trigger:{player:'useCard'},
|
||||
forced:true,
|
||||
|
|
|
@ -9182,7 +9182,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
},
|
||||
},
|
||||
huaping:{
|
||||
audio:'huaping',
|
||||
audio:2,
|
||||
trigger:{global:'die'},
|
||||
limited:true,
|
||||
skillAnimation:true,
|
||||
|
@ -13859,7 +13859,7 @@ game.import('character',function(lib,game,ui,get,ai,_status){
|
|||
dcjinjie:'尽节',
|
||||
dcjinjie_info:'当一名角色进入濒死状态时,可以令其摸一张牌。然后若你本轮未进行过回合,你可以弃置X张手牌令其回复1点体力(X为本轮你发动过〖尽节〗的次数)。',
|
||||
dcjue:'举讹',
|
||||
dcjue_info:'准备阶段,你可以视为对一名未受伤的角色使用一张【杀】。',
|
||||
dcjue_info:'准备阶段,你可以视为对一名体力值或手牌数大于你的角色使用一张【杀】。',
|
||||
dc_tengfanglan:'滕芳兰',
|
||||
dcluochong:'落宠',
|
||||
dcluochong_info:'一轮游戏开始时,你可以弃置任意名角色区域里的共计至多[4]张牌,然后若你以此法弃置了一名角色的至少三张牌,则你方括号内的数字-1。',
|
||||
|
|
Binary file not shown.
After Width: | Height: | Size: 60 KiB |
|
@ -7159,9 +7159,9 @@ export class Game extends Uninstantable {
|
|||
}
|
||||
for (let i = 0; i < event.config.num; i++) {
|
||||
let rand2 = rand.randomGet();
|
||||
for (let j = 0; j < rand2.length; j++) {
|
||||
if (rand2[j] == rand2) {
|
||||
rand2.splice(j--, 1);
|
||||
for (let j = 0; j < rand.length; j++) {
|
||||
if (rand[j] == rand2) {
|
||||
rand.splice(j--, 1);
|
||||
}
|
||||
}
|
||||
event.enemylist.push(event.enemy[rand2]);
|
||||
|
|
|
@ -1736,7 +1736,7 @@ export class Get extends Uninstantable {
|
|||
* @returns {string}
|
||||
*/
|
||||
static suit(card, player) {
|
||||
if (!card) return;
|
||||
if (typeof card !== 'object') return;
|
||||
if (Array.isArray(card)) {
|
||||
if (card.length == 1) return get.suit(card[0], player);
|
||||
return 'none';
|
||||
|
@ -1761,7 +1761,7 @@ export class Get extends Uninstantable {
|
|||
* @returns {string}
|
||||
*/
|
||||
static color(card, player) {
|
||||
if (!card) return;
|
||||
if (typeof card !== 'object') return;
|
||||
if (Array.isArray(card)) {
|
||||
if (!card.length) return 'none';
|
||||
const cards = card.slice(), color = get.color(cards.shift(), player);
|
||||
|
@ -1790,7 +1790,7 @@ export class Get extends Uninstantable {
|
|||
* @returns {number}
|
||||
*/
|
||||
static number(card, player) {
|
||||
if (!card) return;
|
||||
if (typeof card !== 'object') return;
|
||||
//狗卡你是真敢出啊
|
||||
var number = null;
|
||||
if ('number' in card) {
|
||||
|
|
|
@ -203,6 +203,22 @@ export class Player extends HTMLDivElement {
|
|||
handcards2: ui.create.div('.handcards'),
|
||||
expansions: ui.create.div('.expansions')
|
||||
};
|
||||
if(lib.config.equip_span){
|
||||
let observer = new MutationObserver(mutationsList=>{
|
||||
for (let mutation of mutationsList) {
|
||||
if (mutation.type === 'childList') {
|
||||
const addedNodes = Array.from(mutation.addedNodes);
|
||||
const removedNodes = Array.from(mutation.removedNodes);
|
||||
if(addedNodes.some(card=>!card.classList.contains('emptyequip')) ||
|
||||
removedNodes.some(card=>!card.classList.contains('emptyequip'))){
|
||||
player.$handleEquipChange();
|
||||
}
|
||||
}
|
||||
}
|
||||
});
|
||||
const config = { childList: true };
|
||||
observer.observe(node.equips, config);
|
||||
}
|
||||
node.expansions.style.display = 'none';
|
||||
const chainLength = game.layout == 'default' ? 64 : 40;
|
||||
for (let repetition = 0; repetition < chainLength; repetition++) {
|
||||
|
@ -2896,14 +2912,14 @@ export class Player extends HTMLDivElement {
|
|||
}
|
||||
else if (arg1[i] == 'e') {
|
||||
for (j = 0; j < this.node.equips.childElementCount; j++) {
|
||||
if (!this.node.equips.childNodes[j].classList.contains('removing') && !this.node.equips.childNodes[j].classList.contains('feichu')) {
|
||||
if (!this.node.equips.childNodes[j].classList.contains('removing') && !this.node.equips.childNodes[j].classList.contains('feichu') && !this.node.equips.childNodes[j].classList.contains('emptyequip')) {
|
||||
cards.push(this.node.equips.childNodes[j]);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (arg1[i] == 'j') {
|
||||
for (j = 0; j < this.node.judges.childElementCount; j++) {
|
||||
if (!this.node.judges.childNodes[j].classList.contains('removing') && !this.node.judges.childNodes[j].classList.contains('feichu')) {
|
||||
if (!this.node.judges.childNodes[j].classList.contains('removing') && !this.node.judges.childNodes[j].classList.contains('feichu') && !this.node.judges.childNodes[j].classList.contains('emptyequip')) {
|
||||
cards.push(this.node.judges.childNodes[j]);
|
||||
if (this.node.judges.childNodes[j].viewAs && arguments.length > 1) {
|
||||
this.node.judges.childNodes[j].tempJudge = this.node.judges.childNodes[j].name;
|
||||
|
@ -3074,7 +3090,7 @@ export class Player extends HTMLDivElement {
|
|||
var es = [];
|
||||
if (arg3 !== false) {
|
||||
for (i = 0; i < this.node.equips.childElementCount; i++) {
|
||||
if (!this.node.equips.childNodes[i].classList.contains('removing') && !this.node.equips.childNodes[i].classList.contains('feichu')) {
|
||||
if (!this.node.equips.childNodes[i].classList.contains('removing') && !this.node.equips.childNodes[i].classList.contains('feichu') && !this.node.equips.childNodes[i].classList.contains('emptyequip')) {
|
||||
var equipskills = get.info(this.node.equips.childNodes[i]).skills;
|
||||
if (equipskills) {
|
||||
es.addArray(equipskills);
|
||||
|
@ -3115,19 +3131,19 @@ export class Player extends HTMLDivElement {
|
|||
for (i = 0; i < arg1.length; i++) {
|
||||
if (arg1[i] == 'h') {
|
||||
for (j = 0; j < this.node.handcards1.childElementCount; j++) {
|
||||
if (!this.node.handcards1.childNodes[j].classList.contains('removing') && !this.node.handcards1.childNodes[j].classList.contains('feichu') && !this.node.handcards1.childNodes[j].classList.contains('glows')) {
|
||||
if (!this.node.handcards1.childNodes[j].classList.contains('removing') && !this.node.handcards1.childNodes[j].classList.contains('feichu') && !this.node.handcards1.childNodes[j].classList.contains('emptyequip') && !this.node.handcards1.childNodes[j].classList.contains('glows')) {
|
||||
cards.push(this.node.handcards1.childNodes[j]);
|
||||
}
|
||||
}
|
||||
for (j = 0; j < this.node.handcards2.childElementCount; j++) {
|
||||
if (!this.node.handcards2.childNodes[j].classList.contains('removing') && !this.node.handcards2.childNodes[j].classList.contains('feichu') && !this.node.handcards2.childNodes[j].classList.contains('glows')) {
|
||||
if (!this.node.handcards2.childNodes[j].classList.contains('removing') && !this.node.handcards2.childNodes[j].classList.contains('feichu') && !this.node.handcards2.childNodes[j].classList.contains('emptyequip') && !this.node.handcards2.childNodes[j].classList.contains('glows')) {
|
||||
cards.push(this.node.handcards2.childNodes[j]);
|
||||
}
|
||||
}
|
||||
}
|
||||
else if (arg1[i] == 'e') {
|
||||
for (j = 0; j < this.node.equips.childElementCount; j++) {
|
||||
if (!this.node.equips.childNodes[j].classList.contains('removing') && !this.node.equips.childNodes[j].classList.contains('feichu')) {
|
||||
if (!this.node.equips.childNodes[j].classList.contains('removing') && !this.node.equips.childNodes[j].classList.contains('feichu') && !this.node.equips.childNodes[j].classList.contains('emptyequip')) {
|
||||
cards.push(this.node.equips.childNodes[j]);
|
||||
}
|
||||
}
|
||||
|
@ -3140,7 +3156,7 @@ export class Player extends HTMLDivElement {
|
|||
}
|
||||
else if (arg1[i] == 'j') {
|
||||
for (j = 0; j < this.node.judges.childElementCount; j++) {
|
||||
if (!this.node.judges.childNodes[j].classList.contains('removing') && !this.node.judges.childNodes[j].classList.contains('feichu')) {
|
||||
if (!this.node.judges.childNodes[j].classList.contains('removing') && !this.node.judges.childNodes[j].classList.contains('feichu') && !this.node.judges.childNodes[j].classList.contains('emptyequip')) {
|
||||
cards.push(this.node.judges.childNodes[j]);
|
||||
if (this.node.judges.childNodes[j].viewAs && arguments.length > 1) {
|
||||
this.node.judges.childNodes[j].tempJudge = this.node.judges.childNodes[j].name;
|
||||
|
@ -9090,6 +9106,66 @@ export class Player extends HTMLDivElement {
|
|||
}
|
||||
}
|
||||
}
|
||||
$handleEquipChange(){
|
||||
let player = this;
|
||||
const cards = Array.from(this.node.equips.childNodes);
|
||||
const cardsResume = cards.slice(0);
|
||||
cards.forEach(card=>{
|
||||
if(card.name.indexOf('empty_equip') == 0){
|
||||
let num = get.equipNum(card);
|
||||
let remove = false;
|
||||
if((num == 4 || num == 3) && get.is.mountCombined()){
|
||||
remove = !this.hasEmptySlot('equip3_4') || this.getEquips('equip3_4').length;
|
||||
}else if(!this.hasEmptySlot(num) || this.getEquips(num).length){
|
||||
remove = true;
|
||||
}
|
||||
if(remove){
|
||||
this.node.equips.removeChild(card);
|
||||
cardsResume.remove(card);
|
||||
}
|
||||
}
|
||||
});
|
||||
for(let i=1;i<=4;i++){
|
||||
let add = false;
|
||||
if((i == 4 || i == 3) && get.is.mountCombined()){
|
||||
add = this.hasEmptySlot('equip3_4') && !this.getEquips('equip3_4').length;
|
||||
}else{
|
||||
add = this.hasEmptySlot(i) && !this.getEquips(i).length;
|
||||
}
|
||||
if(add && !cardsResume.some(card=>{
|
||||
let num = get.equipNum(card);
|
||||
if((i==4|| i==3) && get.is.mountCombined()){
|
||||
return num == 4 || num == 3;
|
||||
}else{
|
||||
return num == i;
|
||||
}
|
||||
})){
|
||||
const card = game.createCard('empty_equip' + i,'', '');
|
||||
card.fix();
|
||||
console.log('add '+card.name);
|
||||
card.style.transform = '';
|
||||
card.classList.remove('drawinghidden');
|
||||
card.classList.add('emptyequip');
|
||||
card.classList.add('hidden');
|
||||
delete card._transform;
|
||||
const equipNum = get.equipNum(card);
|
||||
let equipped = false;
|
||||
for (let j = 0; j < player.node.equips.childNodes.length; j++) {
|
||||
if (get.equipNum(player.node.equips.childNodes[j]) >= equipNum) {
|
||||
player.node.equips.insertBefore(card, player.node.equips.childNodes[j]);
|
||||
equipped = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if (!equipped) {
|
||||
player.node.equips.appendChild(card);
|
||||
if (_status.discarded) {
|
||||
_status.discarded.remove(card);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
$equip(card) {
|
||||
game.broadcast(function (player, card) {
|
||||
player.$equip(card);
|
||||
|
|
|
@ -3056,6 +3056,12 @@ export class Library extends Uninstantable {
|
|||
lib.init.cssstyles();
|
||||
}
|
||||
},
|
||||
equip_span:{
|
||||
name: '装备牌占位',
|
||||
intro:'打开后,没有装备的装备区将在装备栏占据空白位置。',
|
||||
init: false,
|
||||
unfrequent:false,
|
||||
},
|
||||
fold_card: {
|
||||
name: '折叠手牌',
|
||||
init: true,
|
||||
|
@ -9577,6 +9583,30 @@ export class Library extends Uninstantable {
|
|||
type: "equip",
|
||||
subtype: "equip6",
|
||||
},
|
||||
empty_equip1: {
|
||||
type: "equip",
|
||||
subtype: "equip1",
|
||||
},
|
||||
empty_equip2: {
|
||||
type: "equip",
|
||||
subtype: "equip2",
|
||||
},
|
||||
empty_equip3: {
|
||||
type: "equip",
|
||||
subtype: "equip3",
|
||||
},
|
||||
empty_equip4: {
|
||||
type: "equip",
|
||||
subtype: "equip4",
|
||||
},
|
||||
empty_equip5: {
|
||||
type: "equip",
|
||||
subtype: "equip5",
|
||||
},
|
||||
empty_equip6: {
|
||||
type: "equip",
|
||||
subtype: "equip6",
|
||||
},
|
||||
zhengsu_leijin: {},
|
||||
zhengsu_mingzhi: {},
|
||||
zhengsu_bianzhen: {},
|
||||
|
|
Loading…
Reference in New Issue