This commit is contained in:
libccy 2016-03-26 13:32:00 +08:00
parent e9e2c05466
commit b039cbd009
13 changed files with 318 additions and 232 deletions

View File

@ -461,6 +461,7 @@ character.sp={
trigger.player.line(player); trigger.player.line(player);
} }
else{ else{
if(get.itemtype(trigger.card)=='card'){
trigger.player.$gain2(trigger.card); trigger.player.$gain2(trigger.card);
if(!trigger.player.storage.zhenwei2){ if(!trigger.player.storage.zhenwei2){
trigger.player.storage.zhenwei2=[trigger.card]; trigger.player.storage.zhenwei2=[trigger.card];
@ -469,6 +470,7 @@ character.sp={
trigger.player.storage.zhenwei2.push(trigger.card); trigger.player.storage.zhenwei2.push(trigger.card);
} }
ui.special.appendChild(trigger.card); ui.special.appendChild(trigger.card);
}
trigger.untrigger(); trigger.untrigger();
trigger.finish(); trigger.finish();
trigger.player.addSkill('zhenwei2'); trigger.player.addSkill('zhenwei2');

View File

@ -4214,10 +4214,30 @@ character.yijiang={
if(player.num('h','jiu')>0) return 0; if(player.num('h','jiu')>0) return 0;
if(player.num('e','zhuge')&&player.num('h','sha')>1) return 0; if(player.num('e','zhuge')&&player.num('h','sha')>1) return 0;
if(!player.num('h','sha')) return 0; if(!player.num('h','sha')) return 0;
var targets=[];
var target;
for(var i=0;i<game.players.length;i++){ for(var i=0;i<game.players.length;i++){
if(ai.get.attitude(player,game.players[i])<0){ if(ai.get.attitude(player,game.players[i])<0){
var target=game.players[i]; if(player.canUse('sha',game.players[i],true,true)){
if(player.canUse('sha',target)&&ai.get.effect(target,{name:'sha'},player,player)>0){ targets.push(game.players[i]);
}
}
}
if(targets.length){
target=targets[0];
}
else{
return 0;
}
var num=ai.get.effect(target,{name:'sha'},player,player);
for(var i=1;i<targets.length;i++){
var num2=ai.get.effect(targets[i],{name:'sha'},player,player);
if(num2>num){
target=targets[i];
num=num2;
}
}
if(num<=0) return 0;
var e2=target.get('e','2'); var e2=target.get('e','2');
if(e2){ if(e2){
if(e2.name=='tengjia'){ if(e2.name=='tengjia'){
@ -4231,9 +4251,6 @@ character.yijiang={
if(player.num('e','guanshi')&&player.num('he')>2) return 1; if(player.num('e','guanshi')&&player.num('he')>2) return 1;
return target.num('h')>3?0:1; return target.num('h')>3?0:1;
} }
}
}
}
if(player==_status.event.dying||player.isTurnedOver()) return 3; if(player==_status.event.dying||player.isTurnedOver()) return 3;
} }
}, },

View File

@ -15,7 +15,7 @@
bg.style.backgroundSize="cover"; bg.style.backgroundSize="cover";
} }
if(temp.image_background&&temp.image_background!='default'&&temp.image_background!='custom'){ if(temp.image_background&&temp.image_background!='default'&&temp.image_background!='custom'){
bg.style.backgroundImage="url('image/background/"+temp.image_background+".jpg')"; bg.setBackgroundImage('image/background/'+temp.image_background+'.jpg');
switch (temp.image_background_filter){ switch (temp.image_background_filter){
case 'blur': case 'blur':
@ -71,4 +71,15 @@
} }
} }
},5000); },5000);
if(navigator.userAgent.toLowerCase().indexOf('android')!=-1){
var script=document.createElement('script');
script.src='cordova.js';
document.body.appendChild(script);
document.addEventListener('deviceready',function(){
if(window._onDeviceReady){
window._onDeviceReady();
delete window._onDeviceReady;
}
});
}
}()) }())

View File

@ -364,3 +364,4 @@ window.character={};
window.play={}; window.play={};
window.background={}; window.background={};
window.music={}; window.music={};
window.font={};

View File

@ -16,13 +16,15 @@
dieClose:[] dieClose:[]
}; };
var lib={ var lib={
version:'1.7.11', version:'1.7.12',
changeLog:[ changeLog:[
'扩展', '安卓版改进:',
'AI改进', '·程序与素材分离',
'安卓屏幕常亮' '·可导出数据',
'·自动暂停、确认退出等'
], ],
configprefix:'noname_0.9_', configprefix:'noname_0.9_',
assetURL:'',
updates:[], updates:[],
canvasUpdates:[], canvasUpdates:[],
video:[], video:[],
@ -257,6 +259,10 @@
name:'限制结算速度', name:'限制结算速度',
init:true init:true
}, },
enable_vibrate:{
name:'开启震动',
init:true
},
right_click:{ right_click:{
name:'右键功能', name:'右键功能',
init:'pause', init:'pause',
@ -564,7 +570,7 @@
}); });
} }
else{ else{
ui.background.style.backgroundImage="url('image/background/"+lib.config.image_background+".jpg')"; ui.background.setBackgroundImage('image/background/'+lib.config.image_background+'.jpg');
} }
ui.background.style.backgroundSize='cover'; ui.background.style.backgroundSize='cover';
}, },
@ -992,12 +998,7 @@
name:'人名字体', name:'人名字体',
init:'xinwei', init:'xinwei',
unfrequent:true, unfrequent:true,
item:{ item:{},
xinwei:'新魏',
huangcao:'黄草',
xiaozhuan:'小篆',
// default:'默认',
},
onclick:function(font){ onclick:function(font){
game.saveConfig('name_font',font); game.saveConfig('name_font',font);
ui.arena.dataset.name_font=font; ui.arena.dataset.name_font=font;
@ -1007,12 +1008,7 @@
name:'身份字体', name:'身份字体',
init:'huangcao', init:'huangcao',
unfrequent:true, unfrequent:true,
item:{ item:{},
xinwei:'新魏',
huangcao:'黄草',
xiaozhuan:'小篆',
// default:'默认',
},
onclick:function(font){ onclick:function(font){
game.saveConfig('identity_font',font); game.saveConfig('identity_font',font);
ui.arena.dataset.identity_font=font; ui.arena.dataset.identity_font=font;
@ -1022,12 +1018,7 @@
name:'卡牌字体', name:'卡牌字体',
init:'default', init:'default',
unfrequent:true, unfrequent:true,
item:{ item:{},
xinwei:'新魏',
huangcao:'黄草',
xiaozhuan:'小篆',
default:'默认',
},
onclick:function(font){ onclick:function(font){
game.saveConfig('cardtext_font',font); game.saveConfig('cardtext_font',font);
ui.arena.dataset.cardtext_font=font; ui.arena.dataset.cardtext_font=font;
@ -1037,12 +1028,7 @@
name:'界面字体', name:'界面字体',
init:'default', init:'default',
unfrequent:true, unfrequent:true,
item:{ item:{},
xinwei:'新魏',
huangcao:'黄草',
xiaozhuan:'小篆',
default:'默认',
},
onclick:function(font){ onclick:function(font){
game.saveConfig('global_font',font); game.saveConfig('global_font',font);
ui.arena.dataset.global_font=font; ui.arena.dataset.global_font=font;
@ -1567,8 +1553,7 @@
for(var i in localStorage){ for(var i in localStorage){
data[i]=localStorage[i]; data[i]=localStorage[i];
} }
game.export(lib.init.encode(JSON.stringify(data)), game.export(lib.init.encode(JSON.stringify(data)),'无名杀 - 数据 - '+(new Date()).toLocaleString());
'无名杀 - 数据 - '+(new Date()).toLocaleString());
}, },
clear:true clear:true
}, },
@ -2832,6 +2817,30 @@
}, },
init:{ init:{
init:function(){ init:function(){
var scripts=document.head.querySelectorAll('script');
for(var i=0;i<scripts.length;i++){
if(scripts[i].src&&scripts[i].src.indexOf('game/game.js')!=-1){
if(scripts[i].src.indexOf('ios')!=-1){
var ua=navigator.userAgent.toLowerCase();
if(ua.indexOf('ipad')!=-1){
window.isIpad=true;
}
else{
var metas=document.head.querySelectorAll('meta');
for(var i=0;i<metas.length;i++){
if(metas[i].name=='viewport'){
metas[i].content="user-scalable=no, initial-scale=0.6, maximum-scale=0.6, minimum-scale=0.6, width=device-width, height=device-height";
}
}
}
}
if(scripts[i].src.indexOf('asset')!=-1){
lib.assetLoading=[];
}
break;
}
}
lib.config={}; lib.config={};
var config2; var config2;
var config=window.config; var config=window.config;
@ -2931,12 +2940,31 @@
delete lib.configMenu.audio.config.background_music.item.music_custom; delete lib.configMenu.audio.config.background_music.item.music_custom;
} }
} }
ui.fontsheet=document.createElement('style');
document.head.appendChild(ui.fontsheet);
if(font&&font.pack){
for(i in font.pack){
lib.configMenu.appearence.config.name_font.item[i]=font.pack[i];
lib.configMenu.appearence.config.identity_font.item[i]=font.pack[i];
lib.configMenu.appearence.config.cardtext_font.item[i]=font.pack[i];
lib.configMenu.appearence.config.global_font.item[i]=font.pack[i];
if(Array.isArray(lib.assetLoading)){
lib.assetLoading.push(i);
}
else{
ui.fontsheet.sheet.insertRule("@font-face {font-family: '"+i+"';src: url('"+lib.assetURL+"font/"+i+".ttf');}",0);
}
}
lib.configMenu.appearence.config.cardtext_font.item.default='默认';
lib.configMenu.appearence.config.global_font.item.default='默认';
}
delete character.pack; delete character.pack;
delete card.pack; delete card.pack;
delete play.pack; delete play.pack;
delete mode.pack; delete mode.pack;
delete window.background; delete window.background;
delete window.music; delete window.music;
delete window.font;
if(lib.config.all.mode.indexOf('chess')!=-1){ if(lib.config.all.mode.indexOf('chess')!=-1){
for(var i in lib.help2){ for(var i in lib.help2){
@ -3017,6 +3045,7 @@
game.saveConfig('touchscreen',true); game.saveConfig('touchscreen',true);
game.saveConfig('low_performance',true); game.saveConfig('low_performance',true);
game.saveConfig('layout','phone'); game.saveConfig('layout','phone');
game.saveConfig('confirm_exit',true);
game.reload(); game.reload();
} }
} }
@ -3135,23 +3164,63 @@
} }
}); });
var scripts=document.head.querySelectorAll('script'); if(navigator.userAgent.toLowerCase().indexOf('android')!=-1){
for(var i=0;i<scripts.length;i++){ window._onDeviceReady=function(){
if(scripts[i].src&&scripts[i].src.indexOf('game/game.js')!=-1){ document.addEventListener("pause", function(){
if(scripts[i].src.indexOf('ios')!=-1){ if(!_status.paused2&&!_status.event.isMine()){
var ua=navigator.userAgent.toLowerCase(); ui.click.pause();
if(ua.indexOf('ipad')!=-1){ }
window.isIpad=true; if(ui.backgroundMusic){
ui.backgroundMusic.pause();
}
});
document.addEventListener("resume", function(){
if(ui.backgroundMusic){
ui.backgroundMusic.play();
}
});
document.addEventListener("backbutton", function(){
if(ui.arena.classList.contains('menupaused')){
ui.click.configMenu();
}
else if(lib.config.confirm_exit){
navigator.notification.confirm(
'是否退出游戏?',
function(index){
switch(index){
case 2:game.saveConfig('null');game.reload();break;
case 3:navigator.app.exitApp();break;
}
},
'确认退出',
['取消','重新开始','退出']
);
} }
else{ else{
var metas=document.head.querySelectorAll('meta'); navigator.app.exitApp();
for(var i=0;i<metas.length;i++){ }
if(metas[i].name=='viewport'){ });
metas[i].content="user-scalable=no, initial-scale=0.6, maximum-scale=0.6, minimum-scale=0.6, width=device-width, height=device-height"; window.resolveLocalFileSystemURL(cordova.file.externalApplicationStorageDirectory,function(entry){
} var url=entry.toURL();
if(Array.isArray(lib.assetLoading)){
for(var i=0;i<lib.assetLoading.length;i++){
var item=lib.assetLoading[i];
if(typeof item=='string'){
ui.fontsheet.sheet.insertRule("@font-face {font-family: '"+item+"';src: url('"+url+"font/"+item+".ttf');}",0);
}
else if(item._cordovaimg){
item.style.backgroundImage='url("'+url+item._cordovaimg+'")';
delete item._cordovaimg;
}
else if(item._cordovasrc){
item.src=url+item._cordovasrc;
delete item._cordovasrc;
} }
} }
} }
delete lib.assetLoading;
lib.assetURL=url;
});
} }
} }
}, },
@ -3510,6 +3579,10 @@
if(event.isMine()){ if(event.isMine()){
if(!ok||!lib.config.auto_confirm){ if(!ok||!lib.config.auto_confirm){
game.pause(); game.pause();
if(lib.config.enable_vibrate&&player._noVibrate){
delete player._noVibrate;
game.vibrate();
}
} }
if(typeof event.prompt=='string'){ if(typeof event.prompt=='string'){
if(!ok) event.dialog=ui.create.dialog(event.prompt); if(!ok) event.dialog=ui.create.dialog(event.prompt);
@ -4512,41 +4585,7 @@
"step 0" "step 0"
var info=get.info(event.skill); var info=get.info(event.skill);
event._skill=event.skill; event._skill=event.skill;
if(!info.direct&&lib.config.background_speak&& game.trySkillAudio(event.skill,player);
(!lib.skill.global.contains(event.skill)||lib.skill[event.skill].forceaudio)){
var audioname=event.skill;
var audioinfo=info.audio;
if(typeof audioinfo=='string'){
audioname=audioinfo;
if(lib.skill[audioinfo]){
audioinfo=lib.skill[audioinfo].audio;
}
}
else if(Array.isArray(audioinfo)){
audioname=audioinfo[0];
audioinfo=audioinfo[1];
}
if(Array.isArray(info.audioname)){
if(info.audioname.contains(player.name)){
audioname+='_'+player.name;
}
else if(info.audioname.contains(player.name1)){
audioname+='_'+player.name1;
}
else if(info.audioname.contains(player.name2)){
audioname+='_'+player.name2;
}
}
if(typeof audioinfo=='number'){
game.playAudio('skill',audioname+Math.ceil(audioinfo*Math.random()));
}
else if(audioinfo){
game.playAudio('skill',audioname);
}
else if(lib.config.background_ogg&&info.audio!==false){
game.playSkillAudio(audioname);
}
}
if(player.checkShow){ if(player.checkShow){
player.checkShow(event.skill); player.checkShow(event.skill);
} }
@ -7063,43 +7102,7 @@
if(this.checkShow){ if(this.checkShow){
this.checkShow(name); this.checkShow(name);
} }
var info=lib.skill[name]; game.trySkillAudio(name,this,true);
if(info&&lib.config.background_speak){
var audioname=name;
var audioinfo=info.audio;
if(typeof audioinfo=='string'){
audioname=audioinfo;
if(lib.skill[audioinfo]){
audioinfo=lib.skill[audioinfo].audio;
}
}
else if(Array.isArray(audioinfo)){
audioname=audioinfo[0];
audioinfo=audioinfo[1];
}
if(Array.isArray(info.audioname)){
if(info.audioname.contains(this.name)){
audioname+='_'+this.name;
}
else if(info.audioname.contains(this.name1)){
audioname+='_'+this.name1;
}
else if(info.audioname.contains(this.name2)){
audioname+='_'+this.name2;
}
}
if(typeof audioinfo==='number'){
game.playAudio('skill',audioname+Math.ceil(audioinfo*Math.random()));
}
else if(audioinfo){
game.playAudio('skill',audioname);
}
else{
if(lib.config.background_ogg&&info.audio!==false){
game.playSkillAudio(audioname);
}
}
}
if(lib.config.mode=='chess'){ if(lib.config.mode=='chess'){
this.chessFocus(); this.chessFocus();
} }
@ -8649,7 +8652,7 @@
this.node.image.setBackgroundDB(img); this.node.image.setBackgroundDB(img);
} }
else{ else{
this.node.image.style.backgroundImage='url("image/card/'+card[2]+'.png")' this.node.image.setBackgroundImage('image/card/'+card[2]+'.png');
} }
} }
else if(lib.card[card[2]].image=='background'){ else if(lib.card[card[2]].image=='background'){
@ -9445,6 +9448,7 @@
game.log(); game.log();
game.log(player,'的回合开始'); game.log(player,'的回合开始');
game.phaseNumber++; game.phaseNumber++;
player._noVibrate=true;
if(get.config('identity_mode')!='zhong'){ if(get.config('identity_mode')!='zhong'){
var num; var num;
switch(get.config('auto_identity')){ switch(get.config('auto_identity')){
@ -9694,7 +9698,7 @@
var audio=document.createElement('audio'); var audio=document.createElement('audio');
audio.autoplay=true; audio.autoplay=true;
audio.volume=lib.config.volumn_audio/8; audio.volume=lib.config.volumn_audio/8;
audio.src='audio'+str+'.mp3'; audio.src=lib.assetURL+'audio'+str+'.mp3';
audio.addEventListener('ended',function(){ audio.addEventListener('ended',function(){
this.remove(); this.remove();
}); });
@ -9703,12 +9707,51 @@
this.remove(); this.remove();
} }
else{ else{
this.src='audio'+str+'.ogg'; this.src=lib.assetURL+'audio'+str+'.ogg';
this._changed=true; this._changed=true;
} }
}; };
ui.window.appendChild(audio); ui.window.appendChild(audio);
}, },
trySkillAudio:function(skill,player,directaudio){
var info=get.info(skill);
if(!info) return;
if((!info.direct||directaudio)&&lib.config.background_speak&&
(!lib.skill.global.contains(skill)||lib.skill[skill].forceaudio)){
var audioname=skill;
var audioinfo=info.audio;
if(typeof audioinfo=='string'){
audioname=audioinfo;
if(lib.skill[audioinfo]){
audioinfo=lib.skill[audioinfo].audio;
}
}
else if(Array.isArray(audioinfo)){
audioname=audioinfo[0];
audioinfo=audioinfo[1];
}
if(Array.isArray(info.audioname)&&player){
if(info.audioname.contains(player.name)){
audioname+='_'+player.name;
}
else if(info.audioname.contains(player.name1)){
audioname+='_'+player.name1;
}
else if(info.audioname.contains(player.name2)){
audioname+='_'+player.name2;
}
}
if(typeof audioinfo=='number'){
game.playAudio('skill',audioname+Math.ceil(audioinfo*Math.random()));
}
else if(audioinfo){
game.playAudio('skill',audioname);
}
else if(lib.config.background_ogg&&info.audio!==false){
game.playSkillAudio(audioname);
}
}
},
playSkillAudio:function(name){ playSkillAudio:function(name){
if(_status.video&&arguments[1]!='video') return; if(_status.video&&arguments[1]!='video') return;
if(_status.skillaudio.contains(name)) return; if(_status.skillaudio.contains(name)) return;
@ -9724,7 +9767,7 @@
var audio=document.createElement('audio'); var audio=document.createElement('audio');
audio.autoplay=true; audio.autoplay=true;
audio.volume=lib.config.volumn_audio/8; audio.volume=lib.config.volumn_audio/8;
audio.src=str+name+'.mp3'; audio.src=lib.assetURL+str+name+'.mp3';
audio.addEventListener('ended',function(){ audio.addEventListener('ended',function(){
this.remove(); this.remove();
}); });
@ -9732,17 +9775,17 @@
audio.onerror=function(){ audio.onerror=function(){
switch(this._changed){ switch(this._changed){
case 1:{ case 1:{
audio.src=str+name+'.ogg'; audio.src=lib.assetURL+str+name+'.ogg';
this._changed=2; this._changed=2;
break; break;
} }
case 2:{ case 2:{
audio.src=str+name+Math.ceil(Math.random()*2)+'.mp3'; audio.src=lib.assetURL+str+name+Math.ceil(Math.random()*2)+'.mp3';
this._changed=3; this._changed=3;
break; break;
} }
case 3:{ case 3:{
audio.src=str+name+Math.ceil(Math.random()*2)+'.ogg'; audio.src=lib.assetURL+str+name+Math.ceil(Math.random()*2)+'.ogg';
this._changed=4; this._changed=4;
break; break;
} }
@ -9784,7 +9827,13 @@
} }
} }
else{ else{
ui.backgroundMusic.src='audio/background/'+music+'.mp3'; if(lib.assetLoading){
ui.backgroundMusic._cordovasrc='audio/background/'+music+'.mp3';
lib.assetLoading.push(ui.backgroundMusic);
}
else{
ui.backgroundMusic.src=lib.assetURL+'audio/background/'+music+'.mp3';
}
} }
} }
}, },
@ -9888,13 +9937,27 @@
export:function(textToWrite,name){ export:function(textToWrite,name){
var textFileAsBlob = new Blob([textToWrite], {type:'text/plain'}); var textFileAsBlob = new Blob([textToWrite], {type:'text/plain'});
var fileNameToSaveAs = name||'noname'; var fileNameToSaveAs = name||'noname';
fileNameToSaveAs=fileNameToSaveAs.replace(/\\|\/|\:|\?|\"|\*|\<|\>|\|/g,'.');
if(window.resolveLocalFileSystemURL){
window.resolveLocalFileSystemURL(cordova.file.externalDataDirectory,function(entry){
entry.getFile(fileNameToSaveAs,{create:true},function(fileEntry){
fileEntry.createWriter(function(fileWriter){
fileWriter.onwriteend=function(){
alert('文件已导出至'+cordova.file.externalDataDirectory+fileNameToSaveAs);
}
fileWriter.write(textFileAsBlob)
});
});
});
}
else{
var downloadLink = document.createElement("a"); var downloadLink = document.createElement("a");
downloadLink.download = fileNameToSaveAs; downloadLink.download = fileNameToSaveAs;
downloadLink.innerHTML = "Download File"; downloadLink.innerHTML = "Download File";
downloadLink.href = window.URL.createObjectURL(textFileAsBlob); downloadLink.href = window.URL.createObjectURL(textFileAsBlob);
downloadLink.click(); downloadLink.click();
}
}, },
exportCharacters:function(packname,list,callback){ exportCharacters:function(packname,list,callback){
var zipReady=function(){ var zipReady=function(){
@ -9908,13 +9971,27 @@
var load=function(img){ var load=function(img){
var blob = zip.generate({type:"blob"}); var blob = zip.generate({type:"blob"});
var fileNameToSaveAs = packname||'noname'; var fileNameToSaveAs = packname||'noname';
fileNameToSaveAs=fileNameToSaveAs.replace(/\\|\/|\:|\?|\"|\*|\<|\>|\|/g,'.');
if(window.resolveLocalFileSystemURL){
window.resolveLocalFileSystemURL(cordova.file.externalDataDirectory,function(entry){
entry.getFile(fileNameToSaveAs,{create:true},function(fileEntry){
fileEntry.createWriter(function(fileWriter){
fileWriter.onwriteend=function(){
alert('文件已导出至'+cordova.file.externalDataDirectory+fileNameToSaveAs);
}
fileWriter.write(textFileAsBlob)
});
});
});
}
else{
var downloadLink = document.createElement("a"); var downloadLink = document.createElement("a");
downloadLink.download = fileNameToSaveAs; downloadLink.download = fileNameToSaveAs;
downloadLink.innerHTML = "Download File"; downloadLink.innerHTML = "Download File";
downloadLink.href = window.URL.createObjectURL(blob); downloadLink.href = window.URL.createObjectURL(blob);
downloadLink.click(); downloadLink.click();
}
if(typeof callback=='function'){ if(typeof callback=='function'){
callback(character); callback(character);
@ -11198,6 +11275,11 @@
game.update(lib.updateCanvas); game.update(lib.updateCanvas);
} }
}, },
vibrate:function(time){
if(typeof navigator.vibrate=='function'){
navigator.vibrate(time||500);
}
},
animate:{ animate:{
flame:function(x,y,duration,type){ flame:function(x,y,duration,type){
var particles=[]; var particles=[];
@ -11659,25 +11741,27 @@
return next; return next;
}, },
addCharacter:function(name,info){ addCharacter:function(name,info){
var character=[info.sex,info.group,info.hp,info.skills||[],['db:extension-'+_status.extension+':'+name+'.jpg']]; var extname=(_status.extension||info.extension);
var character=[info.sex,info.group,info.hp,info.skills||[],['db:extension-'+extname+':'+name+'.jpg']];
if(info.tags){ if(info.tags){
character[4]=character[4].concat(info.tags); character[4]=character[4].concat(info.tags);
} }
lib.character[name]=character; lib.character[name]=character;
var packname='mode_extension_'+_status.extension; var packname='mode_extension_'+extname;
if(!lib.characterPack[packname]){ if(!lib.characterPack[packname]){
lib.characterPack[packname]={}; lib.characterPack[packname]={};
lib.translate[name]=info.translate;
} }
lib.translate[name]=info.translate;
lib.characterPack[packname][name]=character; lib.characterPack[packname][name]=character;
lib.translate[packname+'_character_config']=_status.extension; lib.translate[packname+'_character_config']=extname;
}, },
addCard:function(name,info,info2){ addCard:function(name,info,info2){
var extname=(_status.extension||info2.extension);
if(info.fullskin){ if(info.fullskin){
info.image='db:extension-'+_status.extension+':'+name+'.png'; info.image='db:extension-'+extname+':'+name+'.png';
} }
else if(info.fullimage){ else if(info.fullimage){
info.image='db:extension-'+_status.extension+':'+name+'.jpg'; info.image='db:extension-'+extname+':'+name+'.jpg';
} }
lib.card[name]=info; lib.card[name]=info;
lib.translate[name]=info2.translate; lib.translate[name]=info2.translate;
@ -11694,10 +11778,10 @@
lib.card.list.push([suits[Math.floor(Math.random()*suits.length)],Math.ceil(Math.random()*13),name]); lib.card.list.push([suits[Math.floor(Math.random()*suits.length)],Math.ceil(Math.random()*13),name]);
} }
} }
var packname='mode_extension_'+_status.extension; var packname='mode_extension_'+extname;
if(!lib.cardPack[packname]){ if(!lib.cardPack[packname]){
lib.cardPack[packname]=[]; lib.cardPack[packname]=[];
lib.translate[packname+'_card_config']=_status.extension; lib.translate[packname+'_card_config']=extname;
} }
lib.cardPack[packname].push(name); lib.cardPack[packname].push(name);
}, },
@ -11707,7 +11791,7 @@
lib.mode[name]={ lib.mode[name]={
name:info2.translate, name:info2.translate,
config:info2.config, config:info2.config,
splash:'extension-'+_status.extension+':'+'sunquanmode.jpg' splash:'extension-'+(_status.extension||info2.extension)+':'+name+'.jpg'
} }
lib.init['setMode_'+name]=function(){ lib.init['setMode_'+name]=function(){
mode[name]=info; mode[name]=info;
@ -19026,7 +19110,7 @@
game.saveConfig('skin',lib.config.skin); game.saveConfig('skin',lib.config.skin);
avatar.setBackground(player.name,'character'); avatar.setBackground(player.name,'character');
} }
img.src='image/skin/'+player.name+'/'+num+'.jpg'; img.src=lib.assetURL+'image/skin/'+player.name+'/'+num+'.jpg';
}, },
avatar2:function(){ avatar2:function(){
if(!lib.config.change_skin) return; if(!lib.config.change_skin) return;
@ -19063,7 +19147,7 @@
game.saveConfig('skin',lib.config.skin); game.saveConfig('skin',lib.config.skin);
avatar.setBackground(player.name2,'character'); avatar.setBackground(player.name2,'character');
} }
img.src='image/skin/'+player.name2+'/'+num+'.jpg'; img.src=lib.assetURL+'image/skin/'+player.name2+'/'+num+'.jpg';
}, },
player:function(){ player:function(){
return ui.click.target.apply(this,arguments); return ui.click.target.apply(this,arguments);
@ -19742,7 +19826,7 @@
}); });
} }
else{ else{
ui.background.style.backgroundImage="url('image/background/"+lib.config.image_background+".jpg')"; ui.background.setBackgroundImage("image/background/"+lib.config.image_background+".jpg");
} }
ui.background.style.backgroundSize='cover'; ui.background.style.backgroundSize='cover';
}, },
@ -21365,10 +21449,10 @@
}); });
button._link=i; button._link=i;
if(i){ if(i){
button.style.backgroundImage='url("image/skin/'+(avatar2?node.name2:node.name)+'/'+i+'.jpg")'; button.setBackgroundImage('image/skin/'+(avatar2?node.name2:node.name)+'/'+i+'.jpg');
} }
else{ else{
button.style.backgroundImage='url("image/character/'+(avatar2?node.name2:node.name)+'.jpg")'; button.setBackgroundImage('image/character/'+(avatar2?node.name2:node.name)+'.jpg');
} }
} }
uiintro.add(buttons); uiintro.add(buttons);
@ -21380,7 +21464,7 @@
} }
} }
} }
img.src='image/skin/'+(avatar2?node.name2:node.name)+'/'+num+'.jpg'; img.src=lib.assetURL+'image/skin/'+(avatar2?node.name2:node.name)+'/'+num+'.jpg';
} }
if(!node.classList.contains('unseen')){ if(!node.classList.contains('unseen')){
loadImage(); loadImage();
@ -22142,7 +22226,7 @@
else{ else{
src='image/'+name+ext; src='image/'+name+ext;
} }
this.style.backgroundImage="url('"+src+"')"; this.setBackgroundImage(src);
this.style.backgroundSize="cover"; this.style.backgroundSize="cover";
return this; return this;
}; };
@ -22153,6 +22237,15 @@
node.style.backgroundSize="cover"; node.style.backgroundSize="cover";
}); });
}; };
HTMLDivElement.prototype.setBackgroundImage=function(img){
if(lib.assetLoading){
this._cordovaimg=img;
lib.assetLoading.push(this);
}
else{
this.style.backgroundImage='url("'+lib.assetURL+img+'")';
}
},
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;
@ -22317,8 +22410,13 @@
game.saveConfig('test_game',!lib.config.test_game); game.saveConfig('test_game',!lib.config.test_game);
game.reload(); game.reload();
}, },
a:function(){ a:function(name){
game.save('test',!lib.storage.test); if(lib.storage.test&&!name){
game.save('test',false);
}
else{
game.save('test',name||true);
}
game.reload(); game.reload();
}, },
u:function(){ u:function(){
@ -22975,11 +23073,11 @@
game.loop(); game.loop();
} }
} }
if(!mode[lib.config.mode]){ if(!mode[lib.config.mode]){
window.inSplash=true; window.inSplash=true;
var clickNode=function(){ var clickNode=function(){
lib.config.mode=this.link; lib.config.mode=this.link;
game.saveConfig('mode',this.link);
splash.delete(); splash.delete();
delete window.inSplash; delete window.inSplash;
var scriptnode=lib.init.js('mode',lib.config.mode); var scriptnode=lib.init.js('mode',lib.config.mode);
@ -22996,7 +23094,7 @@
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])));
if(lib.config.all.stockmode.indexOf(lib.config.all.mode[i])!=-1){ 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")'; ui.create.div(node,'.avatar').setBackgroundImage('image/splash/'+lib.config.all.mode[i]+'.jpg');
} }
else{ else{
ui.create.div(node,'.avatar').setBackgroundDB(lib.mode[lib.config.all.mode[i]].splash); ui.create.div(node,'.avatar').setBackgroundDB(lib.mode[lib.config.all.mode[i]].splash);

View File

@ -55,4 +55,9 @@ music.pack={
music_diaochan:'貂蝉', music_diaochan:'貂蝉',
music_shezhan:'舌战', music_shezhan:'舌战',
music_danji:'单骑', music_danji:'单骑',
};
font.pack={
xiaozhuan:'小篆',
xinwei:'新魏',
huangcao:'黄草',
} }

View File

@ -1578,11 +1578,7 @@ div:hover>.wunature{
@keyframes flip{from{transform:perspective(1000px) rotateY(0);}to{transform:perspective(1000px) rotateY(360deg);}} @keyframes flip{from{transform:perspective(1000px) rotateY(0);}to{transform:perspective(1000px) rotateY(360deg);}}
@-webkit-keyframes flip{from{transform:perspective(1000px) rotateY(0);}to{transform:perspective(1000px) rotateY(360deg);}} @-webkit-keyframes flip{from{transform:perspective(1000px) rotateY(0);}to{transform:perspective(1000px) rotateY(360deg);}}
/*--------其它--------*/ /*--------其它--------*/
@font-face {font-family: 'xiaozhuan';src: url('../../font/xiaozhuan.ttf');}
@font-face {font-family: 'huangcao';src: url('../../font/huangcao.ttf');}
@font-face {font-family: 'xinwei';src: url('../../font/xinwei.ttf');}
::-webkit-scrollbar{display: none;} ::-webkit-scrollbar{display: none;}
@media screen and (min-height: 800px) and (orientation:landscape) { @media screen and (min-height: 800px) and (orientation:landscape) {
#arena{height: 720px;top: calc(50% - 350px);} #arena{height: 720px;top: calc(50% - 350px);}
} }

View File

@ -1,36 +0,0 @@
{
"name": "noname",
"xwalk_version": "1.7.11",
"xwalk_app_version": "1.7.11",
"xwalk_package_id": "com.widget.noname",
"xwalk_android_keep_screen_on":true,
"start_url": "index.html",
"icons": [
{
"src": "image/meta/iconset-android/icon-256.png",
"sizes": "192x192",
"type": "image/png",
"density": "1.3"
},
{
"src": "image/meta/iconset-android/icon-256.png",
"sizes": "144x144",
"type": "image/png",
"density": "1.8"
},
{
"src": "image/meta/iconset-android/icon-256.png",
"sizes": "96x96",
"type": "image/png",
"density": "2.7"
},
{
"src": "image/meta/iconset-android/icon-256.png",
"sizes": "72x72",
"type": "image/png",
"density": "3.6"
}
],
"display": "fullscreen",
"orientation": "landscape"
}

View File

@ -528,7 +528,6 @@ mode.boss={
// dialog.add('0/3'); // dialog.add('0/3');
dialog.add([list.slice(0,20),'character']); dialog.add([list.slice(0,20),'character']);
dialog.noopen=true; dialog.noopen=true;
var next=game.me.chooseButton(dialog,true); var next=game.me.chooseButton(dialog,true);
next._triggered=null; next._triggered=null;
next.custom.replace.target=event.customreplacetarget; next.custom.replace.target=event.customreplacetarget;

View File

@ -177,6 +177,10 @@ mode.identity={
game.zhu.storage.enhance_zhu=skill; game.zhu.storage.enhance_zhu=skill;
} }
if(lib.storage.test){ if(lib.storage.test){
if(typeof lib.storage.test=='string'){
if(Math.random()<0.5) game.me.next.init(lib.storage.test);
else game.me.init(lib.storage.test);
}
var str=''; var str='';
for(var i=0;i<game.players.length;i++){ for(var i=0;i<game.players.length;i++){
str+=get.translation(game.players[i]); str+=get.translation(game.players[i]);

View File

@ -1512,19 +1512,8 @@ mode.versus={
} }
ui.versushighlight=game.me; ui.versushighlight=game.me;
game.me.classList.add('current_action'); game.me.classList.add('current_action');
// game.me.line(ui.fakeme,{opacity:0.5,dashed:true});
ui.fakeme.style.backgroundImage=game.me.node.avatar.style.backgroundImage; ui.fakeme.style.backgroundImage=game.me.node.avatar.style.backgroundImage;
// var info=lib.character[name];
// if(lib.config.layout=='newlayout'&&info[4]&&info[4].contains('fullskin')){
// // ui.fakeme.classList.add('fullskin');
// ui.fakeme.style.backgroundImage='url("image/character/'+name+'.jpg")';
// ui.fakeme.style.backgroundSize='cover';
// }
// else{
// ui.fakeme.classList.remove('fullskin');
// ui.fakemebg.setBackground(name,'character');
// }
} }
}, },
modeSwapPlayer:function(player){ modeSwapPlayer:function(player){

View File

@ -1,5 +1,5 @@
{ {
"name": "无名杀", "name": "无名杀",
"version": "1.7.11", "version": "1.8.0",
"main": "main.js" "main": "main.js"
} }

View File

@ -65,7 +65,7 @@ body[data-background_color_wood='black']{
.control .controlthundertext{ .control .controlthundertext{
color: rgb(62, 41, 30); color: rgb(62, 41, 30);
} }
.player,.card,.button,.dialog>.bar, .player,.card,.dialog>.bar,
#arena.mobile:not(.chess) .player[data-position='0'] .equips,.playerbg{ #arena.mobile:not(.chess) .player[data-position='0'] .equips,.playerbg{
background: url('wood.jpg'); background: url('wood.jpg');
} }