extension

This commit is contained in:
libccy 2016-03-20 01:28:54 +08:00
parent ae804392a9
commit 7d0b30f077
4 changed files with 462 additions and 172 deletions

View File

@ -1349,7 +1349,7 @@ character.yijiang={
}, },
zhanjue2:{ zhanjue2:{
audio:false, audio:false,
trigger:{player:'phaseBegin'}, trigger:{player:'phaseBefore'},
forced:true, forced:true,
popup:false, popup:false,
silent:true, silent:true,

View File

@ -17,7 +17,7 @@ window.config={
forbiddouble:['zhugedan','swd_kangnalishi','dongzhuo','wutugu','jg_simayi','hs_siwangzhiyi','hs_ronghejuren','hs_shanlingjuren'], forbiddouble:['zhugedan','swd_kangnalishi','dongzhuo','wutugu','jg_simayi','hs_siwangzhiyi','hs_ronghejuren','hs_shanlingjuren'],
layoutfixed:['chess'], layoutfixed:['chess'],
all:{ all:{
mode:['identity','guozhan','versus','boss','chess','stone'], stockmode:['identity','guozhan','versus','boss','chess','stone'],
layout:['default','newlayout'], layout:['default','newlayout'],
theme:['woodden','music','simple'], theme:['woodden','music','simple'],
card_font:['xiaozhuan','huangcao','caoshu','xingshu'], card_font:['xiaozhuan','huangcao','caoshu','xingshu'],
@ -209,6 +209,7 @@ window.config={
hiddenModePack:[], hiddenModePack:[],
hiddenCharacterPack:[], hiddenCharacterPack:[],
hiddenCardPack:[], hiddenCardPack:[],
hiddenPlayPack:[],
theme:'woodden', theme:'woodden',
layout:'mobile', layout:'mobile',
@ -261,6 +262,7 @@ window.config={
cards:['standard','ex','extra','refresh'], cards:['standard','ex','extra','refresh'],
characters:['standard','shenhua','refresh','yijiang'], characters:['standard','shenhua','refresh','yijiang'],
plays:[], plays:[],
extensions:[],
banned:[], banned:[],
bannedcards:[], bannedcards:[],
bannedpile:{}, bannedpile:{},

View File

@ -25,7 +25,6 @@
updates:[], updates:[],
canvasUpdates:[], canvasUpdates:[],
video:[], video:[],
arenaReady:[],
_onDB:[], _onDB:[],
customCharacters:[], customCharacters:[],
customCards:[], customCards:[],
@ -35,6 +34,7 @@
onresize:[], onresize:[],
onwash:[], onwash:[],
onover:[], onover:[],
arenaReady:[],
onDB:function(func){ onDB:function(func){
if(lib.db){ if(lib.db){
func(); func();
@ -1234,197 +1234,255 @@
} }
} }
}, },
playpack:{ extension:{
name:'玩法', name:'扩展',
config:{ config:{
character:{ character:{
name:'技能卡牌', name:'技能卡牌',
init:false, init:false,
restart:true, restart:true,
onclick:function(bool){ onclick:function(bool){
if(bool){ if(bool){
lib.config.plays.add('character'); lib.config.plays.add('character');
} }
else{ else{
lib.config.plays.remove('character'); lib.config.plays.remove('character');
} }
game.saveConfig('plays',lib.config.plays); game.saveConfig('plays',lib.config.plays);
} }
}, },
character_num_playpackconfig:{ character_num_playpackconfig:{
name:'卡牌比例', name:'卡牌比例',
init:'0.05', init:'0.05',
item:{ item:{
'0.02':'2%', '0.02':'2%',
'0.05':'5%', '0.05':'5%',
'0.1':'10%', '0.1':'10%',
'0.2':'20%', '0.2':'20%',
}
},
character_hide_playpackconfig:{
name:'隐藏此扩展',
clear:true,
onclick:function(){
lib.config.hiddenPlayPack.add('character');
game.saveConfig('hiddenPlayPack',lib.config.hiddenPlayPack);
} }
}, },
soldier:{ soldier:{
name:'士兵模式', name:'士兵模式',
init:false, init:false,
restart:true, restart:true,
onclick:function(bool){ onclick:function(bool){
if(bool){ if(bool){
lib.config.plays.add('soldier'); lib.config.plays.add('soldier');
} }
else{ else{
lib.config.plays.remove('soldier'); lib.config.plays.remove('soldier');
} }
game.saveConfig('plays',lib.config.plays); game.saveConfig('plays',lib.config.plays);
}
},
soldier_hide_playpackconfig:{
name:'隐藏此扩展',
clear:true,
onclick:function(){
lib.config.hiddenPlayPack.add('soldier');
game.saveConfig('hiddenPlayPack',lib.config.hiddenPlayPack);
} }
}, },
wuxing:{ wuxing:{
name:'五行生克', name:'五行生克',
init:false, init:false,
restart:true, restart:true,
onclick:function(bool){ onclick:function(bool){
if(bool){ if(bool){
lib.config.plays.add('wuxing'); lib.config.plays.add('wuxing');
} }
else{ else{
lib.config.plays.remove('wuxing'); lib.config.plays.remove('wuxing');
} }
game.saveConfig('plays',lib.config.plays); game.saveConfig('plays',lib.config.plays);
} }
}, },
wuxing_num_playpackconfig:{ wuxing_num_playpackconfig:{
name:'带属性卡牌', name:'带属性卡牌',
init:'0.3', init:'0.3',
item:{ item:{
'0.1':'10%', '0.1':'10%',
'0.2':'20%', '0.2':'20%',
'0.3':'30%', '0.3':'30%',
'0.5':'50%', '0.5':'50%',
}
},
wuxing_hide_playpackconfig:{
name:'隐藏此扩展',
clear:true,
onclick:function(){
lib.config.hiddenPlayPack.add('wuxing');
game.saveConfig('hiddenPlayPack',lib.config.hiddenPlayPack);
} }
}, },
weather:{ weather:{
name:'天气变化', name:'天气变化',
init:false, init:false,
restart:true, restart:true,
onclick:function(bool){ onclick:function(bool){
if(bool){ if(bool){
lib.config.plays.add('weather'); lib.config.plays.add('weather');
} }
else{ else{
lib.config.plays.remove('weather'); lib.config.plays.remove('weather');
} }
game.saveConfig('plays',lib.config.plays); game.saveConfig('plays',lib.config.plays);
} }
}, },
// weather_animation_playpackconfig:{ // weather_animation_playpackconfig:{
// name:'天气动画', // name:'天气动画',
// init:true // init:true
// }, // },
weather_noqing_playpackconfig:{ weather_noqing_playpackconfig:{
name:'异常天气出现概率', name:'异常天气出现概率',
init:'0.5', init:'0.5',
item:{ item:{
'0.1':'10%', '0.1':'10%',
'0.3':'30%', '0.3':'30%',
'0.5':'50%', '0.5':'50%',
'0.7':'70%', '0.7':'70%',
'0.9':'90%', '0.9':'90%',
} }
}, },
weather_chance_playpackconfig:{ weather_chance_playpackconfig:{
name:'天气效果触发概率', name:'天气效果触发概率',
init:'0.5', init:'0.5',
item:{ item:{
'0.1':'10%', '0.1':'10%',
'0.2':'20%', '0.2':'20%',
'0.3':'30%', '0.3':'30%',
'0.5':'50%', '0.5':'50%',
'0.8':'80%', '0.8':'80%',
}, },
onclick:function(item){ onclick:function(item){
game.saveConfig('weather_chance_playpackconfig',item); game.saveConfig('weather_chance_playpackconfig',item);
_status.weatherchance=parseFloat(lib.config.weather_chance_playpackconfig)||0; _status.weatherchance=parseFloat(lib.config.weather_chance_playpackconfig)||0;
} }
}, },
weather_duration_playpackconfig:{ weather_duration_playpackconfig:{
name:'异常天气持续时间', name:'异常天气持续时间',
init:'[4,4]', init:'[4,4]',
item:{ item:{
'[2,4]':'1~3回合', '[2,4]':'1~3回合',
'[4,4]':'3~6回合', '[4,4]':'3~6回合',
'[4,7]':'3~9回合', '[4,7]':'3~9回合',
'[7,4]':'6~9回合', '[7,4]':'6~9回合',
'[7,7]':'6~12回合', '[7,7]':'6~12回合',
} }
}, },
weather_qingduration_playpackconfig:{ weather_qingduration_playpackconfig:{
name:'晴朗天气持续时间', name:'晴朗天气持续时间',
init:'[2,4]', init:'[2,4]',
item:{ item:{
'[2,4]':'1~3回合', '[2,4]':'1~3回合',
'[4,4]':'3~6回合', '[4,4]':'3~6回合',
'[4,7]':'3~9回合', '[4,7]':'3~9回合',
'[7,4]':'6~9回合', '[7,4]':'6~9回合',
'[7,7]':'6~12回合', '[7,7]':'6~12回合',
}
},
weather_hide_playpackconfig:{
name:'隐藏此扩展',
clear:true,
onclick:function(){
lib.config.hiddenPlayPack.add('weather');
game.saveConfig('hiddenPlayPack',lib.config.hiddenPlayPack);
} }
}, },
coin:{ coin:{
name:'富甲天下', name:'富甲天下',
init:false, init:false,
restart:true, restart:true,
onclick:function(bool){ onclick:function(bool){
if(bool){ if(bool){
lib.config.plays.add('coin'); lib.config.plays.add('coin');
} }
else{ else{
lib.config.plays.remove('coin'); lib.config.plays.remove('coin');
} }
game.saveConfig('plays',lib.config.plays); game.saveConfig('plays',lib.config.plays);
} }
}, },
coin_display_playpackconfig:{ coin_display_playpackconfig:{
name:'金币显示', name:'金币显示',
init:'text', init:'text',
item:{ item:{
symbol:'符号', symbol:'符号',
text:'文字' text:'文字'
}, },
onclick:function(item){ onclick:function(item){
game.saveConfig('coin_display_playpackconfig',item); game.saveConfig('coin_display_playpackconfig',item);
if(game.changeCoin) game.changeCoin(0); if(game.changeCoin) game.changeCoin(0);
} }
}, },
coin_canvas_playpackconfig:{ coin_canvas_playpackconfig:{
name:'特效置顶', name:'特效置顶',
init:false, init:false,
onclick:function(bool){ onclick:function(bool){
game.saveConfig('coin_canvas_playpackconfig',bool); game.saveConfig('coin_canvas_playpackconfig',bool);
if(bool){ if(bool){
ui.window.classList.add('canvas_top'); ui.window.classList.add('canvas_top');
} }
else{ else{
ui.window.classList.remove('canvas_top'); ui.window.classList.remove('canvas_top');
} }
}
},
coin_hide_playpackconfig:{
name:'隐藏此扩展',
clear:true,
onclick:function(){
lib.config.hiddenPlayPack.add('coin');
game.saveConfig('hiddenPlayPack',lib.config.hiddenPlayPack);
} }
}, },
// coin_free_playpackconfig:{
// name:'仅在空闲时显示特效',
// init:false,
// },
update:function(config,map){ update:function(config,map){
for(var i in map){ for(var i in map){
if(i.indexOf('_playpackconfig')!=-1){ if(i.indexOf('extension_')==0) continue;
map[i].classList.add('indent'); if(i.indexOf('_playpackconfig')!=-1){
if(lib.config.plays.contains(i.slice(0,i.indexOf('_')))){ var packname=i.slice(0,i.indexOf('_'));
map[i].show(); map[i].classList.add('indent');
} if(!lib.config.hiddenPlayPack.contains(packname)&&
else{ lib.config.plays.contains(packname)){
map[i].show();
}
else{
map[i].hide();
}
}
else{
if(lib.config.hiddenPlayPack.contains(i)){
map[i].hide(); map[i].hide();
} }
}
else{
if(lib.config.plays.contains(i)){
map[i].classList.add('on');
}
else{ else{
map[i].classList.remove('on'); if(lib.config.plays.contains(i)){
map[i].classList.add('on');
}
else{
map[i].classList.remove('on');
}
}
}
}
for(var i=0;i<lib.config.extensions.length;i++){
var name='extension_'+lib.config.extensions[i];
for(var j in map){
if(j!=name&&j.indexOf(name)==0){
map[j].classList.add('indent');
if(config[name]){
map[j].show();
}
else{
map[j].hide();
}
} }
} }
} }
@ -1517,6 +1575,7 @@
game.saveConfig('hiddenModePack',[]); game.saveConfig('hiddenModePack',[]);
game.saveConfig('hiddenCharacterPack',[]); game.saveConfig('hiddenCharacterPack',[]);
game.saveConfig('hiddenCardPack',[]); game.saveConfig('hiddenCardPack',[]);
game.saveConfig('hiddenPlayPack',[]);
var that=this; var that=this;
setTimeout(function(){ setTimeout(function(){
that.innerHTML='重置隐藏扩展包'; that.innerHTML='重置隐藏扩展包';
@ -2618,8 +2677,7 @@
'<li>回复体力<br>player.recover(num)<li>摸牌<br>player.draw(num)<li>获得牌<br>player.gain(cards)<li>弃牌<br>player.discard(cards)'+ '<li>回复体力<br>player.recover(num)<li>摸牌<br>player.draw(num)<li>获得牌<br>player.gain(cards)<li>弃牌<br>player.discard(cards)'+
'<li>使用卡牌<br>player.useCard(card,<br>targets)<li>死亡<br>player.die()<li>复活<br>player.revive(hp)</ul>'+ '<li>使用卡牌<br>player.useCard(card,<br>targets)<li>死亡<br>player.die()<li>复活<br>player.revive(hp)</ul>'+
'<div style="margin:10px">游戏操作</div><ul style="margin-top:0"><li>在命令输入框中输出结果<br>game.print(str)<li>游戏结束<br>game.over(bool)'+ '<div style="margin:10px">游戏操作</div><ul style="margin-top:0"><li>在命令输入框中输出结果<br>game.print(str)<li>游戏结束<br>game.over(bool)'+
'<li>角色资料<br>lib.character<li>卡牌资料<br>lib.card</ul>'+ '<li>角色资料<br>lib.character<li>卡牌资料<br>lib.card</ul>',
'<div style="margin:10px">富甲天下</div><ul style="margin-top:0"><li>改变金币数<br>game.changeCoin(num)<li>自动下雪<br>game.haveFun.alwaysSnow()',
'身份模式':'<div style="margin:10px">选项</div><ul style="margin-top:0"><li>加强主公<br>反贼人数多于2时主公会额外增加一个技能每个主公的额外技能固定非常备主公增加天命</ul>'+ '身份模式':'<div style="margin:10px">选项</div><ul style="margin-top:0"><li>加强主公<br>反贼人数多于2时主公会额外增加一个技能每个主公的额外技能固定非常备主公增加天命</ul>'+
'<div style="margin:10px">明忠</div><ul style="margin-top:0"><li>本模式需要8名玩家进行游戏使用的身份牌为1主公、2忠臣、4反贼和1内奸。游戏开始时每名玩家随机获得一个身份由系统随机选择一名忠臣身份的玩家亮出身份将忠臣牌正面朝上放在面前其他身份包括主公的玩家不亮出身份。<li>'+ '<div style="margin:10px">明忠</div><ul style="margin-top:0"><li>本模式需要8名玩家进行游戏使用的身份牌为1主公、2忠臣、4反贼和1内奸。游戏开始时每名玩家随机获得一个身份由系统随机选择一名忠臣身份的玩家亮出身份将忠臣牌正面朝上放在面前其他身份包括主公的玩家不亮出身份。<li>'+
'首先由亮出身份的忠臣玩家随机获得六张武将牌,挑选一名角色,并将选好的武将牌展示给其他玩家。之后其余每名玩家随机获得三张武将牌,各自从其中挑选一张同时亮出<li>'+ '首先由亮出身份的忠臣玩家随机获得六张武将牌,挑选一名角色,并将选好的武将牌展示给其他玩家。之后其余每名玩家随机获得三张武将牌,各自从其中挑选一张同时亮出<li>'+
@ -2863,8 +2921,6 @@
else{ else{
lib.config[i]=config2[i]; lib.config[i]=config2[i];
} }
} }
for(var i in lib.config.translate){ for(var i in lib.config.translate){
lib.translate[i]=lib.config.translate[i]; lib.translate[i]=lib.config.translate[i];
@ -2933,6 +2989,24 @@
} }
delete lib.help2; delete lib.help2;
for(var i=0;i<lib.config.extensions.length;i++){
try{
eval(localStorage.getItem(lib.configprefix+'extension_'+lib.config.extensions[i]));
}
catch(e){}
if(game.importedPack&&lib.config['extension_'+game.importedPack.name]){
var cfg={};
for(var i in lib.config){
if(i.indexOf('extension_'+game.importedPack.name)==0&&
i!='extension_'+game.importedPack.name){
cfg[i.slice(11+game.importedPack.name.length)]=lib.config[i];
}
}
game.importedPack.content(cfg);
delete game.importedPack;
}
}
if(localStorage.getItem(lib.configprefix+'playback')){ if(localStorage.getItem(lib.configprefix+'playback')){
lib.init.js('mode',lib.config.mode); lib.init.js('mode',lib.config.mode);
} }
@ -3120,6 +3194,10 @@
return style; return style;
}, },
js:function(path,file,onload){ js:function(path,file,onload){
if(path=='mode'&&lib.config.all.stockmode.indexOf(file)==-1){
lib.init['setMode_'+file]();
return;
}
if(typeof file=='object'){ if(typeof file=='object'){
for(var i=0;i<file.length;i++){ for(var i=0;i<file.length;i++){
lib.init.js(path,file[i]); lib.init.js(path,file[i]);
@ -8550,23 +8628,45 @@
} }
} }
var bg=card[2]; var bg=card[2];
var img=lib.card[card[2]].image;
if(img&&img.indexOf('db:')==0){
img=img.slice(3);
}
else{
img=null;
}
if(!lib.config.hide_card_image&&lib.card[card[2]].fullskin){ if(!lib.config.hide_card_image&&lib.card[card[2]].fullskin){
this.classList.add('fullskin'); this.classList.add('fullskin');
this.node.image.style.backgroundImage='url("image/card/'+card[2]+'.png")' if(img){
this.node.image.setBackgroundDB(img);
}
else{
this.node.image.style.backgroundImage='url("image/card/'+card[2]+'.png")'
}
} }
else if(lib.card[card[2]].image=='background'){ else if(lib.card[card[2]].image=='background'){
if(card[3]) this.node.background.setBackground(bg+'_'+card[3],'card'); if(card[3]) this.node.background.setBackground(bg+'_'+card[3],'card');
else this.node.background.setBackground(bg,'card'); else this.node.background.setBackground(bg,'card');
} }
else if(lib.card[card[2]].fullimage){ else if(lib.card[card[2]].fullimage){
this.setBackground('card/'+bg); if(img){
this.setBackgroundDB(img);
}
else{
this.setBackground('card/'+bg);
}
} }
else if(lib.card[card[2]].image=='card'){ else if(lib.card[card[2]].image=='card'){
if(card[3]) this.setBackground(bg+'_'+card[3],'card'); if(card[3]) this.setBackground(bg+'_'+card[3],'card');
else this.setBackground(bg,'card'); else this.setBackground(bg,'card');
} }
else if(typeof lib.card[card[2]].image=='string'){ else if(typeof lib.card[card[2]].image=='string'&&!lib.card[card[2]].fullskin){
this.setBackground(lib.card[card[2]].image); if(img){
this.setBackgroundDB(img);
}
else{
this.setBackground(lib.card[card[2]].image);
}
} }
else{ else{
this.node.background.innerHTML=lib.translate[bg+'_bg']||get.translation(bg)[0]; this.node.background.innerHTML=lib.translate[bg+'_bg']||get.translation(bg)[0];
@ -9724,6 +9824,57 @@
lib.config.customCharacterPack[obj.name]=pack; lib.config.customCharacterPack[obj.name]=pack;
game.saveConfig('customCharacterPack',lib.config.customCharacterPack); game.saveConfig('customCharacterPack',lib.config.customCharacterPack);
} }
else if(type=='extension'){
lib.configMenu.extension.config['extension_'+obj.name]={
name:obj.name,
init:true
}
for(var i in obj.config){
lib.configMenu.extension.config['extension_'+obj.name+'_'+i]=obj.config[i];
}
for(var i in obj.help){
lib.help[i]=obj.help[i];
}
lib.configMenu.extension.config['extension_'+obj.name+'_delete']={
name:'删除此扩展',
clear:true,
onclick:function(){
if(this.innerHTML=='确认删除'){
var prefix='extension_'+obj.name;
var page=this.parentNode;
for(var i=0;i<page.childElementCount;i++){
if(page.childNodes[i]._link&&page.childNodes[i]._link.config._name.indexOf(prefix)==0){
page.childNodes[i].remove();
i--;
}
}
for(var i in lib.config){
if(i.indexOf(prefix)==0){
game.saveConfig(i);
}
}
localStorage.removeItem(lib.configprefix+prefix);
lib.config.extensions.remove(obj.name);
game.saveConfig('extensions',lib.config.extensions);
if(obj.image){
for(var i=0;i<obj.image.length;i++){
game.deleteDB('image','extension-'+obj.name+':'+obj.image[i]);
}
}
if(obj.onremove){
obj.onremove();
}
}
else{
this.innerHTML='确认删除';
var that=this;
setTimeout(function(){
that.innerHTML='删除'+obj.name;
},1000);
}
}
}
}
game.importedPack=obj; game.importedPack=obj;
}, },
export:function(textToWrite,name){ export:function(textToWrite,name){
@ -13097,9 +13248,20 @@
else{ else{
lib.config[key]=value; lib.config[key]=value;
} }
config[key]=value; if(value===undefined){
delete config[key];
}
else{
config[key]=value;
}
localStorage.setItem(lib.configprefix+'config',JSON.stringify(config)); localStorage.setItem(lib.configprefix+'config',JSON.stringify(config));
}, },
saveExtensionConfig:function(extension,key,value){
return game.saveConfig('extension_'+extension+'_'+key,value);
},
getExtensionConfig:function(extension,key){
return lib.config['extension_'+extension+'_'+key];
},
addPlayer:function(position,character,character2){ addPlayer:function(position,character,character2){
if(position<0||position>game.players.length+game.dead.length||position==undefined){ if(position<0||position>game.players.length+game.dead.length||position==undefined){
position=Math.ceil(Math.random()*(game.players.length+game.dead.length)); position=Math.ceil(Math.random()*(game.players.length+game.dead.length));
@ -14748,8 +14910,110 @@
var banskillNodes=[]; var banskillNodes=[];
var custombanskillNodes=[]; var custombanskillNodes=[];
var banskill; var banskill;
if(mode=='playpack'){ if(mode=='extension'){
var importextensionexpanded=false;
page.style.textAlign='left';
page.style.paddingBottom='10px'; page.style.paddingBottom='10px';
var importExtension;
var extensionnode=ui.create.div('.config.more','导入扩展 <div>&gt;</div>',page,function(){
if(importextensionexpanded){
this.classList.remove('on');
importExtension.style.display='none';
}
else{
this.classList.add('on');
importExtension.style.display='';
}
importextensionexpanded=!importextensionexpanded;
});
importExtension=ui.create.div('.new_character.export.import',page);
importExtension.style.marginLeft='5px';
importExtension.style.marginTop='5px';
importExtension.style.display='none';
ui.create.div('','<input type="file" accept="application/zip" style="width:153px"><button>确定</button>',importExtension);
importExtension.firstChild.lastChild.onclick=function(){
var fileToLoad=this.previousSibling.files[0];
if(fileToLoad){
var zipReady=function(){
var fileReader = new FileReader();
fileReader.onload = function(fileLoadedEvent)
{
var data = fileLoadedEvent.target.result;
var zip=new JSZip();
zip.load(data);
var str=zip.file('extension.js').asText();
try{
eval(str);
if(!game.importedPack) throw('err');
var extname=game.importedPack.name;
localStorage.setItem(lib.configprefix+'extension_'+extname,str);
lib.config.extensions.add(extname);
game.saveConfig('extensions',lib.config.extensions);
game.saveConfig('extension_'+extname,true);
for(var i in game.importedPack.config){
if(game.importedPack.config[i]&&game.importedPack.config[i].hasOwnProperty('init')){
game.saveConfig('extension_'+extname+'_'+i,game.importedPack.config[i].init);
}
}
if(game.importedPack.image){
for(var i=0;i<game.importedPack.image.length;i++){
var buttons=page.querySelectorAll('.button.character');
for(var j=0;j<buttons.length;j++){
if(buttons[j].link==i){
buttons[j].remove();
break;
}
}
var imgname=game.importedPack.image[i];
var str=zip.file(imgname).asArrayBuffer();
if(str){
var blob=new Blob([str]);
var fileReader=new FileReader();
fileReader.onload = (function(imgname){
return function(fileLoadedEvent)
{
var data = fileLoadedEvent.target.result;
game.putDB('image','extension-'+extname+':'+imgname,data);
};
}(imgname))
fileReader.readAsDataURL(blob, "UTF-8");
}
}
}
delete game.importedPack;
}
catch(e){
console.log(e);
alert('导入失败');
return;
}
extensionnode.innerHTML='导入成功5秒后将重启';
setTimeout(function(){
extensionnode.innerHTML='导入成功4秒后将重启';
setTimeout(function(){
extensionnode.innerHTML='导入成功3秒后将重启';
setTimeout(function(){
extensionnode.innerHTML='导入成功2秒后将重启';
setTimeout(function(){
extensionnode.innerHTML='导入成功1秒后将重启';
setTimeout(game.reload,1000);
},1000);
},1000);
},1000);
},1000);
importExtension.style.display='none';
};
fileReader.readAsArrayBuffer(fileToLoad, "UTF-8");
}
if(!window.JSZip){
lib.init.js('game','jszip',zipReady);
}
else{
zipReady();
}
}
}
} }
else if(mode=='skill'){ else if(mode=='skill'){
var autoskillexpanded=false; var autoskillexpanded=false;
@ -16608,6 +16872,7 @@
} }
} }
for(var i=0;i<lib.config.all.mode.length;i++){ for(var i=0;i<lib.config.all.mode.length;i++){
if(!lib.config.gameRecord[lib.config.all.mode[i]]) continue;
if(lib.config.gameRecord[lib.config.all.mode[i]].str){ if(lib.config.gameRecord[lib.config.all.mode[i]].str){
ui.create.div('.config.indent',lib.translate[lib.config.all.mode[i]],page).style.marginBottom='-5px'; ui.create.div('.config.indent',lib.translate[lib.config.all.mode[i]],page).style.marginBottom='-5px';
var item=ui.create.div('.config.indent',lib.config.gameRecord[lib.config.all.mode[i]].str+'<span>重置</span>',page); var item=ui.create.div('.config.indent',lib.config.gameRecord[lib.config.all.mode[i]].str+'<span>重置</span>',page);
@ -21742,7 +22007,16 @@
ext=ext||'.jpg'; ext=ext||'.jpg';
subfolder=subfolder||'default' subfolder=subfolder||'default'
if(type){ if(type){
if(type=='character'&&lib.customCharacters.contains(name)){ if(type=='character'&&lib.character[name]&&lib.character[name][4]&&
lib.character[name][4].contains('dbimage')){
for(var i=0;i<lib.character[name][4].length;i++){
if(lib.character[name][4][i].indexOf('db:')==0){
this.setBackgroundDB(lib.character[name][4][i].slice(3));
return this;
}
}
}
else if(type=='character'&&lib.customCharacters.contains(name)){
src=""; src="";
var node=this; var node=this;
game.getDB('image','character:'+name,function(src){ game.getDB('image','character:'+name,function(src){
@ -21768,6 +22042,13 @@
this.style.backgroundSize="cover"; this.style.backgroundSize="cover";
return this; return this;
}; };
HTMLDivElement.prototype.setBackgroundDB=function(img){
var node=this;
game.getDB('image',img,function(src){
node.style.backgroundImage="url('"+src+"')";
node.style.backgroundSize="cover";
});
};
HTMLDivElement.prototype.listen=function(func){ HTMLDivElement.prototype.listen=function(func){
this.addEventListener(lib.config.touchscreen?'touchend':'click',function(e){ this.addEventListener(lib.config.touchscreen?'touchend':'click',function(e){
if(_status.dragged) return; if(_status.dragged) return;
@ -22481,6 +22762,7 @@
} }
} }
for(i in play){ for(i in play){
if(lib.config.hiddenPlayPack.contains(i)) continue;
if(play[i].forbid&&play[i].forbid.contains(lib.config.mode)) continue; if(play[i].forbid&&play[i].forbid.contains(lib.config.mode)) continue;
if(play[i].mode&&play[i].mode.contains(lib.config.mode)==false) continue; if(play[i].mode&&play[i].mode.contains(lib.config.mode)==false) continue;
for(j in play[i].element){ for(j in play[i].element){
@ -22512,12 +22794,9 @@
for(j in play[i].get){ for(j in play[i].get){
get[j]=lib.init.eval(play[i].get[j]); get[j]=lib.init.eval(play[i].get[j]);
} }
if(play[i].config){
lib.config.current_mode=lib.config.current_mode.concat(play[i].config);
}
for(j in play[i]){ for(j in play[i]){
if(j=='mode'||j=='forbid'||j=='init'||j=='element'|| if(j=='mode'||j=='forbid'||j=='init'||j=='element'||
j=='game'||j=='get'||j=='config'||j=='ui'||j=='arenaReady') continue; j=='game'||j=='get'||j=='ui'||j=='arenaReady') continue;
for(k in play[i][j]){ for(k in play[i][j]){
if(j=='translate'&&k==i){ if(j=='translate'&&k==i){
lib[j][k+'_play_config']=play[i][j][k]; lib[j][k+'_play_config']=play[i][j][k];
@ -22583,14 +22862,25 @@
lib.config.mode=this.link; lib.config.mode=this.link;
splash.delete(); splash.delete();
delete window.inSplash; delete window.inSplash;
lib.init.js('mode',lib.config.mode).onload=proceed; var scriptnode=lib.init.js('mode',lib.config.mode);
if(scriptnode){
scriptnode.onload=proceed;
}
else{
proceed();
}
} }
var splash=ui.create.div('#splash',document.body); var splash=ui.create.div('#splash',document.body);
for(var i=0;i<lib.config.all.mode.length;i++){ for(var i=0;i<lib.config.all.mode.length;i++){
var node=ui.create.div(splash,'.hidden',clickNode); var node=ui.create.div(splash,'.hidden',clickNode);
node.link=lib.config.all.mode[i]; node.link=lib.config.all.mode[i];
ui.create.div(node,'.splashtext',get.verticalStr(get.translation(lib.config.all.mode[i]))); ui.create.div(node,'.splashtext',get.verticalStr(get.translation(lib.config.all.mode[i])));
ui.create.div(node,'.avatar').style.backgroundImage='url("image/splash/'+lib.config.all.mode[i]+'.jpg")'; if(lib.config.all.stockmode.indexOf(lib.config.all.mode[i])!=-1){
ui.create.div(node,'.avatar').style.backgroundImage='url("image/splash/'+lib.config.all.mode[i]+'.jpg")';
}
else{
ui.create.div(node,'.avatar').setBackgroundDB(lib.mode[lib.config.all.mode[i]].splash);
}
ui.refresh(node); ui.refresh(node);
setTimeout((function(node){ setTimeout((function(node){
return function(){ return function(){

View File

@ -6,8 +6,6 @@ character.pack={
sp:'SP', sp:'SP',
guozhan:'国战', guozhan:'国战',
yijiang:'一将成名', yijiang:'一将成名',
// jiange:'守卫剑阁',
// zhuogui:'捉鬼驱邪',
diy:'DIY', diy:'DIY',
yxs:'英雄杀', yxs:'英雄杀',
hearth:'炉石传说', hearth:'炉石传说',