diff --git a/_server/MotaAction.g4 b/_server/MotaAction.g4
index 441efae..3e38e1b 100644
--- a/_server/MotaAction.g4
+++ b/_server/MotaAction.g4
@@ -39,6 +39,23 @@ var code = '[\n'+action_0+']\n';
return code;
*/;
+//taskEvent 事件编辑器入口之一
+taskEvent_m
+ : '任务描述' EvalString_Multi? BGNL? Newline
+ '需完成的最低子任务数' Int BGNL? Newline
+ tasksList+ Newline
+ '完成奖励' BGNL? Newline action+
+
+
+/* taskEvent_m
+colour : this.tasksColor
+default :["任务描述",1]
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var code = '{"type":"taskEvent"'+EvalString_Multi_0+',"n":'+Int_0+',"info":['+tasksList_0+'\n]'+', "action": [\n' + action_0 + ']}\n'
+return code;
+*/;
+
+
//事件 事件编辑器入口之一
event_m
@@ -867,6 +884,7 @@ action
| battle_s
| battle_1_s
| openDoor_s
+ | specialDoor_s
| closeDoor_s
| changebg_s
| changeFloor_s
@@ -935,6 +953,7 @@ action
| input_s
| input2_s
| choices_s
+ | menu_s
| confirm_s
| callBook_s
| callSave_s
@@ -976,6 +995,15 @@ action
| over_s
| overlist_s
| cgtextList_s
+ | setTask_s
+ | removeTask_s
+ | removeTaskByName_s
+ | successTask_s
+ | successTaskByName_s
+ | clearTask_s
+ | submitTask_s
+ | trymitTask_s
+ | trymitTaskByName_s
| pass_s
;
@@ -1183,7 +1211,7 @@ tooltip : over:这段话将出现在屏幕中心
helpUrl : /_docs/#/instruction
allImages : ['EvalString_1']
allSounds : ['EvalString_2']
-default : ["这段话将在屏幕中心","bg_5043.webp",false,50,30,"","255,255,255,1",'rgba(255,255,255,1)',"0,0,0,1",'rgba(0,0,0,1)','bold 48px Verdana']
+default : ["这段话将在屏幕中心","bg_5043.webp",false,20,10,"","255,255,255,1",'rgba(255,255,255,1)',"0,0,0,1",'rgba(0,0,0,1)','bold 16px Verdana']
var code = '{"type": "over", "text": "'+EvalString_0+'","image":"'+EvalString_1+'","memory":'+Bool_0+',"time":'+Int_0+',"hidetime":'+Int_1+',"sound":"'+EvalString_2+'","textColor": ['+ColorString_0+'], "boldColor": ['+ColorString_1+'], "font": "'+EvalString_3+'"},\n';
return code;
*/;
@@ -1195,7 +1223,7 @@ overlist_s
tooltip : overlist:多行滚动旁白
helpUrl : /_docs/#/instruction
allImages : ['EvalString_0']
-default : ["bg_5043.webp",false,30,[{ "text":"" ,"sound":"","time":50,"textColor":"255,255,255,1","boldColor":"0,0,0,1","font":"bold 48px Verdana","frame":0}]]
+default : ["bg_5043.webp",false,30,[{ "text":"" ,"sound":"","time":20,"textColor":"255,255,255,1","boldColor":"0,0,0,1","font":"bold 48px Verdana","frame":0}]]
var list=',"list": [\n'+overtextList_0.slice(0,-1)+'\n]'
var code = '{"type": "overlist", "image": "'+EvalString_0+'","memory":'+Bool_0+',"hidetime":'+Int_0+''+list+' },\n';
return code;
@@ -1248,7 +1276,7 @@ cgtext_s
tooltip : cgtext:显示一段包含cg的文字(剧情)
helpUrl : /_docs/#/instruction
allImages : ['EvalString_0']
-default : [false,0,"face_050445.webp",-300,0,2000,"","这句话显示在对话框内",[{ "name":"tati_050145a.webp" , "px": 100,"filter":false }]]
+default : [false,0,"face_050445.webp",-100,0,2000,"","这句话显示在对话框内",[{ "name":"tati_050145a.webp" , "px": 33,"filter":false }]]
var head ='{ "name": "'+EvalString_0+'", "px": '+Number_0+' }'
var list=',"bodyList": [\n'+textcgDrawingList_0.slice(0,-1)+'\n]'
var code = '{"type": "cgtext","WindowSkin":'+Bool_0+',"head":'+head+' ,"index":"'+Int_0+'","time":'+Int_1+',"wait":'+Int_2+list+' },\n';
@@ -1259,12 +1287,12 @@ textcgDrawingList
| textcgDrawingEmpty;
textcgDrawing
- : '立绘' EvalString? '绘制坐标' 'x' Number '变暗'Bool? '绘制大小w' IntString? 'h' IntString? '绘制比例(填写后w、h失效,此项默认1.7)' EvalString? Newline
+ : '立绘' EvalString? '绘制坐标' 'x' Number '变暗'Bool? '绘制大小w' IntString? 'h' IntString? '绘制比例(填写后w、h失效,此项默认0.6)' EvalString? Newline
/* textcgDrawing
tooltip : 立绘
helpUrl : /_docs/#/instruction
-default : ["tati_050145a.webp",100,false,"","",""]
+default : ["tati_050145a.webp",200,false,"","",""]
colour : this.subColor
allImages : ['EvalString_0']
if(EvalString_1&&!/^(0|([1-9][0-9]*))(\.[\d]+)?$/.test(EvalString_1))throw new Error("此项仅能填写小数、整数或不填");
@@ -2061,7 +2089,7 @@ changebg_s
/* changebg_s
tooltip : changebg: 剧情转场
helpUrl : /_docs/#/instruction
-default : ["",false,"",false,30,"引入"]
+default : ["",false,"",false,10,"引入"]
colour : this.soundColor
allImages : ['EvalString_0','EvalString_1']
var code = '{"type": "changebg", "img1": "'+EvalString_0+'","memory1":'+Bool_0+',"img2": "'+EvalString_1+'","memory2":'+Bool_1+',"time": '+Int_0+',"style": "'+Changebg_List_0+'"},\n';
@@ -2193,6 +2221,23 @@ var code = '{"type": "openDoor"'+floorstr+IdString_0+Bool_0+Bool_1+'},\n';
return code;
*/;
+
+specialDoor_s
+ : '怪物坐标 x' EvalString? ',y' EvalString? ',' '门坐标x'EvalString? 'y'EvalString? '战后开启机关门' Newline
+
+
+/* specialDoor_s
+tooltip : specialDoor: 战后开启机关门,需在每个机关怪物使用该战后事件,
+helpUrl : /_docs/#/instruction
+default : ["","","",""]
+selectPoint : ["EvalString_2", "EvalString_3"]
+colour : this.mapColor
+var enemy =MotaActionFunctions.processMultiLoc(EvalString_0, EvalString_1)
+var doors=MotaActionFunctions.processMultiDoors(EvalString_2, EvalString_3);
+var code = '{"type": "specialDoor"'+enemy+doors+'},\n';
+return code;
+*/;
+
closeDoor_s
: '关门' 'x' PosString? ',' 'y' PosString? 'ID' IdString '不等待执行完毕' Bool Newline
@@ -2614,7 +2659,7 @@ return code;
animateResize_s
- : '显示动画(60Fps)' EvalString '编号'PosString? '中心像素' 'x' PosString? 'y' PosString?'以勇士为中心' Bool'倒放' Bool'循环'Bool'不等待执行完毕' Bool Newline
+ : '显示动画' EvalString '编号'PosString? '中心像素' 'x' PosString? 'y' PosString?'以勇士为中心' Bool'倒放' Bool'循环'Bool'不等待执行完毕' Bool Newline
/* animateResize_s
@@ -2668,7 +2713,7 @@ return code;
*/;
stopAnimate_s
- : '停止动画编号'PosString?'(不填写编号为继续所有)' '执行动画回调' Bool Newline
+ : '停止动画编号'PosString?'(不填写编号为停止所有)' '执行动画回调' Bool Newline
/* stopAnimate_s
tooltip : stopAnimate:停止动画(不填写编号为继续所有)
@@ -3000,7 +3045,7 @@ return code;
*/;
setWeather_s
- : '更改天气' Weather_List '强度' Int '持续到下个本事件' Bool Newline
+ : '更改天气' Weather_List '强度' Int Newline
/* setWeather_s
@@ -3009,8 +3054,8 @@ helpUrl : /_docs/#/instruction
default : [null,1,true]
colour : this.soundColor
if(Int_0<1 || Int_0>10) throw new Error('天气的强度等级, 在1-10之间');
-Bool_0 = Bool_0 ? ', "keep": true' : ''
-var code = '{"type": "setWeather", "name": "'+Weather_List_0+'", "level": '+Int_0+Bool_0+'},\n';
+
+var code = '{"type": "setWeather", "name": "'+Weather_List_0+'", "level": '+Int_0+'},\n';
if(Weather_List_0===''||Weather_List_0==='null'||Weather_List_0==null)code = '{"type": "setWeather"},\n';
return code;
*/;
@@ -3482,6 +3527,63 @@ var code = ['{"type": "choices"',EvalString_Multi_0,Int_0,IntString_0,
return code;
*/;
+menu_s
+ : 'NPC名字' ':' EvalString_Multi BGNL? Newline choicesList+ BEND Newline
+
+
+/* menu_s
+tooltip : menu: 给NPC提供选项
+helpUrl : /_docs/#/instruction
+previewBlock : true
+colour : this.taskColor
+default : ["流浪者"]
+EvalString_Multi_0 = ', "text": "'+EvalString_Multi_0+'"';
+var code = ['{"type": "menu"',EvalString_Multi_0,
+ block.isCollapsed()?', "_collapsed": true':'',
+ block.isEnabled()?'':', "_disabled": true',
+ ', "choices": [\n',
+ choicesList_0,
+']},\n'].join('');
+return code;
+*/;
+choicesList
+ : chooseContext
+ | taskContext;
+
+chooseContext
+ : '子选项' EvalString '启用条件' EvalString? '出现条件' EvalString? BGNL? Newline action+
+
+
+/* chooseContext
+tooltip : 选项的选择
+helpUrl : /_docs/#/instruction
+default : ["对话","",""]
+colour : this.subColor
+EvalString_1 = EvalString_1 && (', "need": "'+EvalString_1+'"');
+EvalString_2 = EvalString_2 && (', "condition": "'+EvalString_2+'"');
+var collapsed=block.isCollapsed()?', "_collapsed": true':'';
+var disabled=block.isEnabled()?'':', "_disabled": true';
+var code = '{"type":"context","text": "'+EvalString_0+'"'+EvalString_1+EvalString_2+collapsed+disabled+', "action": [\n'+action_0+']},\n';
+return code;
+*/;
+
+taskContext
+ : '可接取任务名'EvalString? Newline
+ '可提交任务名' EvalString? BGNL? Newline action+
+
+
+/* taskContext
+tooltip : 选项的选择
+helpUrl : /_docs/#/instruction
+default : ["新手任务","task1,task2"]
+colour : this.subColor
+var condition = ', "condition": "\''+EvalString_0+'\'.split(\',\').some(v=>core.plugin.可接取任务.includes(v))||\''+EvalString_1+'\'.split(\',\').some(v=>core.taskSystem.tasksInfo.find(a => a.name ===v.name))"';
+var collapsed=block.isCollapsed()?', "_collapsed": true':'';
+var disabled=block.isEnabled()?'':', "_disabled": true';
+var code = '{"type":"taskContext","text":"任务","text1": "'+EvalString_0+'","text2":"'+EvalString_1+'"'+condition+collapsed+disabled+', "action": [\n'+action_0+']},\n';
+return code;
+*/;
+
choicesContext
: '子选项' EvalString '图标' IdString? '颜色' ColorString? Colour '启用条件' EvalString? '出现条件' EvalString? BGNL? Newline action+
@@ -4271,6 +4373,298 @@ var code = ' \n';
return code;
*/;
+setTask_s
+ : '接取任务 任务名' EvalString Newline
+
+/* setTask_s
+tooltip :接取任务
+colour : this.tasksColor
+default :["mission name"]
+
+var code = '{"type":"setTask","name":"'+EvalString_0+'"},\n'
+return code;
+*/;
+
+tasksList
+ : checkItem
+ | checkStatus
+ | checkFlag
+ | checkBlock
+ | kill
+ | killLocs
+ | killSpecial
+ | killAll
+ | specialBlock
+ | gosthFloor
+ | arrival
+ | empty;
+
+checkItem
+ : '道具ID' IdString TaskOperator_List '数量' Int '子任务描述' EvalString_Multi? BGNL? Newline
+/* checkItem
+tooltip : 检查道具数量
+default : ["yellowKey",">=",0,""]
+colour : this.childColor
+allItems : ['IdString_0']
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var code = '{"type":"checkItem","checkItem":"'+IdString_0+'","operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_0+'},';
+return code;
+ */;
+
+checkStatus
+ :'检查' Status_List '属性' TaskOperator_List Int '子任务描述' EvalString_Multi? BGNL? Newline
+/* checkStatus
+tooltip : 检查属性数值
+default : ["atk",">=",10,""]
+colour : this.childColor
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var code = '{"type":"checkStatus","checkStatus":"'+Status_List_0+'","operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_0+'},';
+return code;
+ */;
+
+checkFlag
+ :'检查Flag变量' EvalString TaskOperator_List expression '子任务描述'EvalString_Multi? BGNL? Newline
+/* checkFlag
+tooltip : 检查Flag变量
+default : ["flag1","=","",""]
+colour : this.childColor
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var code = '{"type":"checkFlag","checkFlag":"'+EvalString_0+'","operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":"'+expression_0+'"},';
+return code;
+*/;
+
+checkBlock
+ :'检查地面图块数量' EvalString '楼层' EvalString TaskOperator_List Int '子任务描述' EvalString_Multi? BGNL? Newline
+/* checkBlock
+tooltip : 检查地面图块数量
+default : ["ju87b","MT1,MT2","<=",0,""]
+colour : this.childColor
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var thisFloorId=EvalString_1.split(",")
+thisFloorId=thisFloorId.map(function(v){return '"'+v.trim()+'"'})
+var floorstr=',"floorId":['+thisFloorId.join(",")+']'
+var code = '{"type":"checkBlock","checkBlock":"'+EvalString_0+'"'+floorstr+',"operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_0+'},';
+return code;
+*/;
+
+
+kill
+ :'击杀' IdString? '敌人楼层' EvalString? TaskOperator_List Int'子任务描述' EvalString_Multi? BGNL? Newline
+/* kill
+tooltip : 击杀一定数量的敌人
+default : ["","",">",0,""]
+colour : this.childColor
+allEnemys : ['IdString_0']
+IdString_0=IdString_0?(',"kill": "'+IdString_0+'"'):'';
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+if(EvalString_0){
+var thisFloorId=EvalString_0.split(",")
+thisFloorId=thisFloorId.map(function(v){return '"'+v.trim()+'"'})
+var floorstr=',"floorId":['+thisFloorId.join(",")+']'
+}else {
+var floorstr=""
+}
+var code = '{"type":"kill"'+IdString_0+floorstr+',"operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_0+'},';
+return code;
+*/;
+
+killLocs
+ :'击杀x' EvalString 'y' EvalString '楼层' IdString '位置的敌人' TaskOperator_List Int'子任务描述' EvalString_Multi? BGNL? Newline
+/* killLocs
+tooltip : 击杀某些位置的敌人
+default : ["1","1","MT1",">=",1,""]
+colour : this.childColor
+allFloorIds : ['IdString_0']
+selectPoint : ["EvalString_0","EvalString_1","IdString_0"]
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var floorstr = MotaActionFunctions.processMultiLoc(EvalString_0,EvalString_1);
+var code = '{"type":"killLocs"'+floorstr+',"floorId":"'+IdString_0+'","operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_0+'},';
+return code;
+*/;
+
+killSpecial
+ :'击杀拥有' Int '技能的敌人楼层' EvalString? TaskOperator_List Int '子任务描述' EvalString_Multi? BGNL? Newline
+/* killSpecial
+tooltip : 击杀一定数量的某种敌人
+default : [61,"MT1,MT2",">=",1,""]
+colour : this.childColor
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+if(EvalString_0){
+var thisFloorId=EvalString_0.split(",")
+thisFloorId=thisFloorId.map(function(v){return '"'+v.trim()+'"'})
+var floorstr=',"floorId":['+thisFloorId.join(",")+']'
+}else {
+var floorstr=""
+}
+var code = '{"type":"killSpecial","killSpecial":"'+Int_0+'"'+floorstr+',"operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_1+'},';
+return code;
+*/;
+
+killAll
+ :'击杀楼层' EvalString '所有敌人' '子任务描述' EvalString_Multi? BGNL? Newline
+/* killAll
+tooltip : 击杀某些楼层所有敌人
+default : ["MT1",""]
+colour : this.childColor
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var thisFloorId=EvalString_0.split(",")
+thisFloorId=thisFloorId.map(function(v){return '"'+v.trim()+'"'})
+var floorstr=',"floorId":['+thisFloorId.join(",")+']'
+var code = '{"type":"killAll"'+floorstr+EvalString_Multi_0+'},';
+return code;
+*/;
+
+specialBlock
+ :'在楼层' EvalString? '受到' MapDamage_List '地图伤害次数' TaskOperator_List Int '子任务描述' EvalString_Multi? BGNL? Newline
+/* specialBlock
+tooltip : 在某些楼层受到一定次数的地图伤害
+default : ["MT1","血网伤害","<",1,""]
+colour : this.childColor
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+if(EvalString_0){
+var thisFloorId=EvalString_0.split(",")
+thisFloorId=thisFloorId.map(function(v){return '"'+v.trim()+'"'})
+var floorstr=',"floorId":['+thisFloorId.join(",")+']'
+}else {
+var floorstr=""
+}
+var code = '{"type":"specialBlock"'+floorstr+',"specialBlock":"'+MapDamage_List_0+'"'+',"operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_0+'},'
+return code;
+*/;
+
+gosthFloor
+ :'切换至楼层' EvalString? '次数' TaskOperator_List Int '子任务描述' EvalString_Multi? BGNL? Newline
+/* gosthFloor
+tooltip : 切换/到达某楼层不超过一定次数
+default : ["MT1","<",1,""]
+colour : this.childColor
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+if(EvalString_0){
+var thisFloorId=EvalString_0.split(",")
+thisFloorId=thisFloorId.map(function(v){return '"'+v.trim()+'"'})
+var floorstr=',"floorId":['+thisFloorId.join(",")+']'
+}else {
+var floorstr=""
+}
+var code = '{"type":"gosthFloor"'+floorstr+',"operator":"'+TaskOperator_List_0+'"'+EvalString_Multi_0+',"count":'+Int_0+'},'
+return code;
+*/;
+
+arrival
+ :'抵达' IdString '子任务描述' EvalString_Multi? BGNL? Newline
+/* arrival
+tooltip : 抵达某楼层
+default : ["MT1",""]
+colour : this.childColor
+allFloorIds : ['IdString_0']
+EvalString_Multi_0=EvalString_Multi_0?(',"text": "'+EvalString_Multi_0+'"'): '';
+var code = '{"type":"arrival","floorId":"'+IdString_0+'"'+EvalString_Multi_0+'},'
+return code;
+*/;
+
+empty
+ : Newline
+
+
+/* empty
+var code = ' \n';
+return code;
+*/;
+
+
+
+removeTask_s
+ : '移除第' Int '项任务'
+
+
+/* removeTask_s
+tooltip : 移除第n项任务。
+colour : this.tasksColor
+default :[0]
+var code = '{"type":"removeTask","index":'+Int_0+'},\n';
+return code;
+*/;
+
+removeTaskByName_s
+ : '移除名为' EvalString '的任务'
+
+
+/* removeTaskByName_s
+tooltip : 移除某一任务。
+colour : this.tasksColor
+default :["mission's name"]
+var code = '{"type":"removeTaskByName","name":"'+EvalString_0+'"},\n';
+return code;
+*/;
+
+successTask_s
+ : '完成第' Int '项任务'
+
+
+/* successTask_s
+tooltip : 强制完成第n项任务时。
+colour : this.tasksColor
+default :[0]
+var code = '{"type":"successTask","index":'+Int_0+'},\n';
+return code;
+*/;
+
+successTaskByName_s
+ : '完成名为' EvalString '的任务'
+
+
+/* successTaskByName_s
+tooltip : 强制完成某一任务时。
+colour : this.tasksColor
+default :["mission's name"]
+var code = '{"type":"successTaskByName","name":"'+EvalString_0+'"},\n';
+return code;
+*/;
+
+clearTask_s
+ : '删除所有任务'
+
+
+/* clearTask_s
+tooltip : 删除所有任务。
+colour : this.tasksColor
+var code = '{"type":"clearTask"},\n';
+return code;
+*/;
+
+submitTask_s
+ : '提交并清空任务'
+
+
+/* submitTask_s
+tooltip : 关卡结束时清空任务并提交。
+colour : this.tasksColor
+var code = '{"type":"submitTask"},\n';
+return code;
+*/;
+trymitTask_s
+ : '尝试提交第' Int '项任务'
+
+
+/* trymitTask_s
+tooltip : 尝试提交第n项任务时(未完成时无效果)。
+colour : this.tasksColor
+default :[0]
+var code = '{"type":"trymitTask","index":'+Int_0+'},\n';
+return code;
+*/;
+
+trymitTaskByName_s
+ : '尝试提交名为' EvalString '的任务'
+
+
+/* trymitTaskByName_s
+tooltip : 尝试提交某一任务时(未完成时无效果)。
+colour : this.tasksColor
+default :["mission's name"]
+var code = '{"type":"trymitTaskByName","name":"'+EvalString_0+'"},\n';
+return code;
+*/;
statExprSplit : '=== statement ^ === expression v ===' ;
//===blockly表达式===
@@ -4812,6 +5206,15 @@ EnemyId_List
EnemyPoint_List
: '生命'|'攻击'|'防御'|'金币'|'经验'|'加点'|'名称'
/*EnemyPoint_List ['hp','atk','def','money','exp','point','name']*/;
+TaskOperator_List
+ : '等于'|'小于'|'小于等于'|'大于'|'大于等于'
+ /*TaskOperator_List ['=','<','<=','>','>=']*/;
+Status_List
+ : '生命'|'攻击'|'防御'|'法强'|'速度'|'金币'
+ /*Status_List ['hp','atk','def','spell','speed','money']*/;
+MapDamage_List
+ : '血网伤害'|'领域伤害'|'阻击伤害'|'激光伤害'|'夹击伤害'
+ /*MapDamage_List ['血网伤害','领域伤害','阻击伤害','激光伤害','夹击伤害']*/;
Equip_List
: '生命'|'生命上限'|'攻击'|'防御'|'法强'|'魔攻比例'|'护盾比例'|'法抗百分比'|'魔力'|'魔力上限'|'速度'
@@ -4890,7 +5293,8 @@ LineComment
this.evisitor.valueColor=330;
this.evisitor.statementColor=70;
this.evisitor.entryColor=250;
-
+this.evisitor.tasksColor=210
+this.evisitor.childColor=35
this.evisitor.idstring_eColor=310;
this.evisitor.subColor=250;
this.evisitor.dataColor=130;
diff --git a/_server/MotaActionParser.js b/_server/MotaActionParser.js
index 7b60bd2..2d047b4 100644
--- a/_server/MotaActionParser.js
+++ b/_server/MotaActionParser.js
@@ -3,6 +3,125 @@ MotaActionParser = function () {
ActionParser.prototype.parse = function (obj, type) {
switch (type) {
+ case "taskEvent": // 设置任务
+ if (!obj) obj = {"type":"taskEvent","text": "任务描述","n":1,"info":[
+ {"type":"checkItem","checkItem":"yellowKey","operator":">=","count":0},
+ {"type":"checkStatus","checkStatus":"atk","operator":">=","count":10},
+ {"type":"checkFlag","checkFlag":"flag1","operator":"=","count":"\"value\""},
+ {"type":"checkBlock","checkBlock":"bat","floorId":["MT1","MT2"],"operator":"<=","count":0},
+ {"type":"kill","operator":">=","count":0},
+ {"type":"killLocs", "loc": [[1,1]],"floorId":"MT1","operator":">=","count":1},
+ {"type":"killSpecial","killSpecial":"61","floorId":["61"],"operator":">=","count":1},
+ {"type":"killAll","floorId":["MT1"]},
+ {"type":"specialBlock","floorId":["MT1"],"specialBlock":"血网伤害","operator":"<","count":1},
+ {"type":"gosthFloor","floorId":["MT1"],"operator":"<","count":1},
+ {"type":"arrival","floorId":"MT1"},
+ ], "action": [
+ ]};
+ var that=this
+ var bulidTaskList = function (obj) {
+ var res = null;
+ for (var ii = obj.length - 1, one; (one = obj[ii]); ii--) {
+ if(one.type==="checkItem"){
+ res = MotaActionBlocks["checkItem"].xmlText([
+ one.checkItem,
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="checkStatus"){
+ res = MotaActionBlocks["checkStatus"].xmlText([
+ one.checkStatus,
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="checkFlag"){
+ res = MotaActionBlocks["checkFlag"].xmlText([
+ one.checkFlag,
+ one.operator,
+ that.expandEvalBlock([one.count]),
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="checkBlock"){
+ res = MotaActionBlocks["checkBlock"].xmlText([
+ one.checkBlock,
+ one.floorId.join(","),
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="kill"){
+ res = MotaActionBlocks["kill"].xmlText([
+ one.kill||"",
+ one.floorId?one.floorId.join(","):"",
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="killLocs"){
+ var x_str = [],
+ y_str = [];
+ one.loc.forEach(function(t){
+ x_str.push(t[0]);
+ y_str.push(t[1]);
+ });
+ res = MotaActionBlocks["killLocs"].xmlText([
+ x_str.join(","),
+ y_str.join(","),
+ one.floorId,
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="killSpecial"){
+ res = MotaActionBlocks["killSpecial"].xmlText([
+ one.floorId.join(","),
+ one.killSpecial,
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="killAll"){
+ res = MotaActionBlocks["killAll"].xmlText([
+ one.floorId.join(","),
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="specialBlock"){
+ res = MotaActionBlocks["specialBlock"].xmlText([
+ one.floorId.join(","),
+ one.specialBlock,
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="gosthFloor"){
+ res = MotaActionBlocks["gosthFloor"].xmlText([
+ one.floorId.join(","),
+ one.operator,
+ one.count,
+ one.text||"",
+ res,
+ ]);
+ }else if(one.type==="empty"){
+ res = MotaActionBlocks["empty"].xmlText([
+ res,
+ ]);
+ }
+
+ }
+ return res;
+ };
+ return MotaActionBlocks['taskEvent_m'].xmlText([obj.text||"",obj.n,bulidTaskList(obj.info),this.insertActionList(obj.action)]);
case "event":
if (!obj) obj = {};
if (typeof obj === typeof "") obj = { data: [obj] };
@@ -569,7 +688,7 @@ MotaActionParser = function () {
data.WindowSkin,
data.index,
data.head.name,
- data.head.px || -300,
+ data.head.px || -100,
data.time,
data.wait,
buildcgDrawing(data.bodyList),
@@ -691,14 +810,14 @@ MotaActionParser = function () {
data.text ?? "",
data.image ?? "",
data.memory ?? false,
- data.time ?? 3000,
- data.hidetime ?? 100,
+ data.time ?? 20,
+ data.hidetime ?? 10,
data.sound ?? "",
data.textColor,
"rgba(" + data.textColor + ")",
data.boldColor,
"rgba(" + data.boldColor + ")",
- data.font ?? "bold 48px Verdana",
+ data.font ?? "bold 16px Verdana",
this.next,
]);
break;
@@ -1494,7 +1613,6 @@ MotaActionParser = function () {
this.next = MotaActionBlocks["setWeather_s"].xmlText([
data.name,
data.level || 1,
- data.keep || false,
this.next,
]);
break;
@@ -1509,6 +1627,32 @@ MotaActionParser = function () {
this.next,
]);
break;
+ case "specialDoor": // 机关门
+ data.loc = data.loc || [];
+ data.doors = data.doors || [];
+ if (!(data.loc[0] instanceof Array)) data.loc = [data.loc];
+ if (!(data.doors[0] instanceof Array)) data.doors = [data.doors];
+ var x_str = [],
+ y_str = [],
+ door_x=[],
+ door_y=[];
+ data.loc.forEach(function (t) {
+ x_str.push(t[0]);
+ y_str.push(t[1]);
+ });
+ data.doors.forEach(function (t) {
+ door_x.push(t[0]);
+ door_y.push(t[1]);
+ });
+
+ this.next = MotaActionBlocks["specialDoor_s"].xmlText([
+ x_str.join(","),
+ y_str.join(","),
+ door_x.join(","),
+ door_y.join(","),
+ this.next,
+ ]);
+ break;
case "closeDoor": // 关一个门,需要该点无事件
data.loc = data.loc || ["", ""];
this.next = MotaActionBlocks["closeDoor_s"].xmlText([
@@ -1881,6 +2025,44 @@ MotaActionParser = function () {
/*disabled*/ data._disabled
);
break;
+ case "menu": // 提供NPC菜单
+ var that = this;
+ var bulidmenuList = function(obj) {
+ var res = null;
+ for (var ii = obj.length - 1, one; (one = obj[ii]); ii--) {
+ if(one.type==="context"){
+ res = MotaActionBlocks["chooseContext"].xmlText([
+ one.text||"",
+ one.need || "",
+ one.condition || "",
+ that.insertActionList(one.action),
+ res,
+ ]);
+ }
+ else if(one.type==="taskContext"){
+ res = MotaActionBlocks["taskContext"].xmlText([
+ one.text1||"",
+ one.text2||"",
+ that.insertActionList(one.action),
+ res,
+ ]);
+ }
+ }
+ return res;
+ }
+ this.next = MotaActionFunctions.xmlText(
+ "menu_s",
+ [
+ data.text,
+ bulidmenuList(data.choices),
+ this.next,
+ ],
+ /* isShadow */ false,
+ /*comment*/ null,
+ /*collapsed*/ data._collapsed,
+ /*disabled*/ data._disabled
+ );
+ break;
case "choices": // 提供选项
var text_choices = null;
for (
@@ -2070,7 +2252,7 @@ MotaActionParser = function () {
data.memory1 ?? false,
data.img2 ?? "",
data.memory2 ?? false,
- data.time ?? 30,
+ data.time ?? 10,
data.style,
this.next,
]);
@@ -2547,6 +2729,34 @@ MotaActionParser = function () {
}
case "animateImage": // 兼容 animateImage
break;
+ case "setTask": // 设置任务
+ this.next = MotaActionBlocks['setTask_s'].xmlText([data.name,this.next ]);
+ break;
+
+ case "removeTask": // 移除第n项任务
+ this.next = MotaActionBlocks['removeTask_s'].xmlText([data.index,this.next ]);
+ break;
+ case "removeTaskByName": // 移除某一任务
+ this.next = MotaActionBlocks['removeTaskByName_s'].xmlText([data.name,this.next ]);
+ break;
+ case "successTask": // 强制完成第n项任务
+ this.next = MotaActionBlocks['successTask_s'].xmlText([data.index,this.next ]);
+ break;
+ case "successTaskByName": // 强制完成某一任务
+ this.next = MotaActionBlocks['successTaskByName_s'].xmlText([data.name,this.next ]);
+ break;
+ case "trymitTask": // 尝试提交第n项任务
+ this.next = MotaActionBlocks['trymitTask_s'].xmlText([data.index,this.next ]);
+ break;
+ case "trymitTaskTaskByName": // 尝试提交某一任务
+ this.next = MotaActionBlocks['trymitTaskByName_s'].xmlText([data.name,this.next ]);
+ break;
+ case "clearTask": // 删除所有任务
+ this.next = MotaActionBlocks['clearTask_s'].xmlText([this.next ]);
+ break;
+ case "submitTask": // 清除并提交任务
+ this.next = MotaActionBlocks['submitTask_s'].xmlText([this.next ]);
+ break;
default:
this.next = MotaActionBlocks["unknown_s"].xmlText([
JSON.stringify(data),
@@ -3075,6 +3285,30 @@ MotaActionParser = function () {
return floorstr;
};
+ MotaActionFunctions.processMultiDoors = function (EvalString_0, EvalString_1) {
+ var floorstr = "";
+ if (EvalString_0 && EvalString_1) {
+ var x = EvalString_0,
+ y = EvalString_1;
+ var pattern = /^([+-]?\d+)(, ?[+-]?\d+)*$/;
+ if (
+ pattern.test(x) &&
+ pattern.test(y) &&
+ x.split(",").length == y.split(",").length
+ ) {
+ x = x.split(",");
+ y = y.split(",");
+ for (var ii = 0; ii < x.length; ii++)
+ x[ii] = "[" + x[ii].trim() + "," + y[ii].trim() + "]";
+ floorstr = ', "doors": [' + x.join(",") + "]";
+ }
+ if (floorstr == "") {
+ floorstr = ', "doors": ["' + x + '","' + y + '"]';
+ }
+ }
+ return floorstr;
+ };
+
MotaActionFunctions.StepString_pre = function (StepString) {
//StepString='上右3下2左上左2'
var route = StepString.replace(/上/g, "U")
diff --git a/_server/editor_blocklyconfig.js b/_server/editor_blocklyconfig.js
index b0f038c..b3fd551 100644
--- a/_server/editor_blocklyconfig.js
+++ b/_server/editor_blocklyconfig.js
@@ -692,6 +692,7 @@ editor_blocklyconfig = function () {
"eachArrive",
"commonEvent",
"item",
+ "taskEvent"
];
return commonEntries.indexOf(editor_blockly.entryType) >= 0;
};
diff --git a/_server/editor_file.js b/_server/editor_file.js
index 1b4a200..9a14a4c 100644
--- a/_server/editor_file.js
+++ b/_server/editor_file.js
@@ -941,6 +941,7 @@ editor_file = function (editor, callback) {
}
var saveSetting = function (file, actionList, callback) {
+
var _update = function (name, value) {
if (value[2] === undefined) {
eval("delete " + name + value[1]);
@@ -1089,6 +1090,7 @@ editor_file = function (editor, callback) {
});
return;
}
+
if (file == 'plugins') {
actionList.forEach(function (value) {
if(value[0]==='add'){
diff --git a/_server/editor_mappanel.js b/_server/editor_mappanel.js
index a65a760..12e71dc 100644
--- a/_server/editor_mappanel.js
+++ b/_server/editor_mappanel.js
@@ -653,7 +653,7 @@ editor_mappanel_wrapper = function (editor) {
}
if (bindSpecialDoor.loc == null || bindSpecialDoor.enemys.length != bindSpecialDoor.n) return;
// 添加机关门自动事件
- var doorFlag = "flag:door_" + editor.currentFloorId + "_" + bindSpecialDoor.loc.replace(',', '_');
+ /*var doorFlag = "flag:door_" + editor.currentFloorId + "_" + bindSpecialDoor.loc.replace(',', '_');
editor.currentFloorData.autoEvent[bindSpecialDoor.loc] = {
'0': {
"condition": doorFlag + "==" + bindSpecialDoor.n,
@@ -666,11 +666,14 @@ editor_mappanel_wrapper = function (editor) {
{ "type": "setValue", "name": doorFlag, "operator": "=", "value": "null" },
]
}
- };
- bindSpecialDoor.enemys.forEach(function (loc) {
+ };*/
+ var enemys=bindSpecialDoor.enemys.map(function (loc) {
+ return loc.split(",")
+ })
+ bindSpecialDoor.enemys.forEach(function (loc,_i,arr){
if (!editor.currentFloorData.afterBattle[loc])
editor.currentFloorData.afterBattle[loc] = [];
- editor.currentFloorData.afterBattle[loc].push({ "type": "setValue", "name": doorFlag, "operator": "+=", "value": "1" });
+ editor.currentFloorData.afterBattle[loc].push({"type": "specialDoor", "loc": enemys, "doors": [bindSpecialDoor.loc.split(",")]},);
});
editor.file.saveFloorFile(function (err) {
if (err) {
diff --git a/_server/editor_mode.js b/_server/editor_mode.js
index 151a3b8..afcfa6a 100644
--- a/_server/editor_mode.js
+++ b/_server/editor_mode.js
@@ -79,6 +79,7 @@ editor_mode = function (editor) {
if (callback) callback();
}
switch (mode) {
+
case 'loc':
editor.file.editLoc(editor_mode.pos.x, editor_mode.pos.y, actionList, function (objs_) {
cb(objs_);
@@ -106,9 +107,14 @@ editor_mode = function (editor) {
case 'commonevent':
editor.file.editCommonEvent(actionList, cb);
break;
+ case 'CommonEventTemplate':
+ editor.file.editCommonEventTemplate(actionList, cb)
case 'plugins':
editor.file.editPlugins(actionList, cb);
break;
+ case 'task':
+ editor.file.editTask(actionList, cb);
+ break;
default:
break;
}
diff --git a/_server/editor_uievent.js b/_server/editor_uievent.js
index 6f064fb..741457c 100644
--- a/_server/editor_uievent.js
+++ b/_server/editor_uievent.js
@@ -587,12 +587,12 @@ editor_uievent_wrapper = function (editor) {
var disabled = _isTileset && value.indexOf(one) >= 0 ? 'disabled' : ''
html += ` ${one}`;
// 预览图片
- if (one.endsWith('.png') || one.endsWith('.jpg') || one.endsWith('.jpeg') || one.endsWith('.gif')) {
+ if (one.endsWith('.png') || one.endsWith('.jpg') || one.endsWith('.jpeg') || one.endsWith('.gif')||one.endsWith('.webp')) {
html += "";
html += '
';
}
// 试听音频
- if (one.endsWith('.mp3') || one.endsWith('.ogg') || one.endsWith('.wav') || one.endsWith('.m4a') || one.endsWith('.flac')) {
+ if (one.endsWith('.mp3') || one.endsWith('.ogg') || one.endsWith('.wav') || one.endsWith('.m4a') || one.endsWith('.flac')||one.endsWith('.opus')) {
html += ""
html += " 音调:";
html += `0:00 / 0:00
diff --git a/_server/table/comment.js b/_server/table/comment.js
index 98f7d1a..38208ee 100644
--- a/_server/table/comment.js
+++ b/_server/table/comment.js
@@ -255,41 +255,107 @@ var comment_c456ea59_6018_45ef_8bcc_211a24c627dc = {
"_docs": "特殊属性数值",
"_data": "特殊属性的数值\n如:领域/阻激/激光怪的伤害值;光环怪增加生命的比例"
},
- "zone": {
+ "baoshang": {
"_leaf": true,
"_type": "textarea",
- "_docs": "领域伤害",
- "_data": "领域怪的伤害值"
+ "_docs": "暴击伤害",
+ "_data": "暴击伤害的数值,此项为百分数。如20为20%"
},
- "repulse": {
+ "baoji": {
"_leaf": true,
"_type": "textarea",
- "_docs": "阻击伤害",
- "_data": "阻击怪的伤害值"
+ "_docs": "暴击回合",
+ "_data": "怪物每进行多少回合进行一次暴击"
},
- "laser": {
+ "duck": {
"_leaf": true,
"_type": "textarea",
- "_docs": "激光伤害",
- "_data": "激光怪的伤害值"
+ "_docs": "闪避回合",
+ "_data": "怪物每受到多少次普通攻击进行一次闪避"
+ },
+ "absorb": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "汲取效果",
+ "_data": "怪物对角色护盾造成破坏时,将窃取破坏数值的一定比例作为自身护盾,此项为百分数。如20为20%"
+ },
+ "gravity": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "重力效果",
+ "_data": "怪物操纵角色的重力,每携带一件双手装备速度下降4x%,每携带一件单手装备速度下降2x%,每携带一件其他装备速度下降x%,此项为百分数。如20为20%"
+ },
+ "cold": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "寒霜回合",
+ "_data": "怪物前多少次回合附加寒霜,0为每回合"
+ },
+ "coldValue": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "寒霜效果",
+ "_data": "每层寒霜下降的速度"
+ },
+ "fire": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "灼炎效果",
+ "_data": "每层灼炎熔毁的防御"
+ },
+ "wind": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "风行效果",
+ "_data": "每层风行提高的速度"
+ },
+ "light": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "闪电效果",
+ "_data": "闪电对护盾伤害提升效果百分比,此项为百分数。如20为20%"
+ },
+ "poison": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "毒素效果",
+ "_data": "每层毒素造成的生命流失"
+ },
+ "tear": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "撕裂效果",
+ "_data": "怪物的普通攻击附加角色当前已损失生命值的百分比,此项为百分数。如20为20%"
+ },
+ "immolate": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "献祭伤害",
+ "_data": "每次献祭造成的伤害"
},
"breakArmor": {
"_leaf": true,
"_type": "textarea",
"_docs": "破甲比例",
- "_data": "破甲百分比"
+ "_data": "破甲百分比,此项为百分数。如20为20%"
},
- "counterAttack": {
+ "onceBreakArmor": {
"_leaf": true,
"_type": "textarea",
- "_docs": "反击比例",
- "_data": "反击百分比"
+ "_docs": "首次额外破甲比例",
+ "_data": "额外破甲百分比,此项为百分数。如20为20%,首次伤害与破甲比例加算"
},
"vampire": {
"_leaf": true,
"_type": "textarea",
"_docs": "吸血比例",
- "_data": "吸血怪的吸血百分比"
+ "_data": "吸血怪的吸血百分比,此项为百分数。如20为20%,仅计算破盾后伤害"
+ },
+ "curseValue": {
+ "_leaf": true,
+ "_type": "textarea",
+ "_docs": "诅咒倍率",
+ "_data": "触发诅咒时魔法伤害提升比例,此项为百分数。如20为20%"
},
"hpBuff": {
"_leaf": true,
@@ -297,6 +363,7 @@ var comment_c456ea59_6018_45ef_8bcc_211a24c627dc = {
"_docs": "光环加血",
"_data": "光环怪增加生命的比例"
},
+
"atkBuff": {
"_leaf": true,
"_type": "textarea",
@@ -341,53 +408,14 @@ var comment_c456ea59_6018_45ef_8bcc_211a24c627dc = {
"_docs": "不可炸",
"_data": "该怪物不可被炸"
},
- "n": {
- "_leaf": true,
- "_type": "textarea",
- "_range": "(thiseval==~~thiseval && thiseval>0)||thiseval==null",
- "_docs": "连击数",
- "_data": "多连击的连击数,净化怪的净化倍率"
- },
- "purify": {
- "_leaf": true,
- "_type": "textarea",
- "_range": "(thiseval==~~thiseval && thiseval>0)||thiseval==null",
- "_docs": "净化倍率",
- "_data": "净化百分比"
- },
- "add": {
- "_leaf": true,
- "_type": "checkbox",
- "_docs": "吸血加到自身",
- "_data": "吸血后是否加到自身"
- },
+
"haloAdd": {
"_leaf": true,
"_type": "checkbox",
"_docs": "光环是否叠加",
"_data": "光环是否叠加"
},
- "atkValue": {
- "_leaf": true,
- "_type": "textarea",
- "_range": "thiseval==~~thiseval||thiseval==null",
- "_docs": "退化扣攻",
- "_data": "退化时勇士下降的攻击力点数"
- },
- "defValue": {
- "_leaf": true,
- "_type": "textarea",
- "_range": "thiseval==~~thiseval||thiseval==null",
- "_docs": "退化扣防",
- "_data": "退化时勇士下降的防御力点数"
- },
- "damage": {
- "_leaf": true,
- "_type": "textarea",
- "_range": "thiseval==~~thiseval||thiseval==null",
- "_docs": "固伤",
- "_data": "战前扣血的点数"
- },
+
"beforeBattle": {
"_leaf": true,
"_type": "event",
diff --git a/_server/table/plugins.comment.js b/_server/table/plugins.comment.js
index a9cb7a1..bfcbcfa 100644
--- a/_server/table/plugins.comment.js
+++ b/_server/table/plugins.comment.js
@@ -15,6 +15,7 @@ var plugins_comment_c456ea59_6018_45ef_8bcc_211a24c627dc = {
"_range": "typeof(thiseval)=='string'",
"_data": "初始化"
},
+
"shop": {
"_leaf": true,
"_type": "textarea",
diff --git a/libs/actions.js b/libs/actions.js
index e25afb8..13c3abe 100644
--- a/libs/actions.js
+++ b/libs/actions.js
@@ -1,4 +1,3 @@
-
/*
actions.js:用户交互的事件的处理
键盘、鼠标、触摸屏事件相关
@@ -6,56 +5,122 @@ actions.js:用户交互的事件的处理
"use strict";
-function actions () {
- this._init();
- this._HX_ = core._HALF_WIDTH_;
- this._HY_ = core._HALF_HEIGHT_;
- this._out = function (x) { return x < this._HX_ - 2 || this._HX_ + 2 < x; };
- this.LAST = core._WIDTH_ - 1;
+function actions() {
+ this._init();
+ this._HX_ = core._HALF_WIDTH_;
+ this._HY_ = core._HALF_HEIGHT_;
+ this._out = function (x) {
+ return x < this._HX_ - 2 || this._HX_ + 2 < x;
+ };
+ this.LAST = core._WIDTH_ - 1;
}
actions.prototype._init = function () {
- this.actionsdata = functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a.actions;
- this.actions = {};
- // --- onkeyDown注册
- this.registerAction('onkeyDown', '_sys_checkReplay', this._sys_checkReplay, 100);
- this.registerAction('onkeyDown', '_sys_onkeyDown', this._sys_onkeyDown, 0);
- // --- onkeyUp注册
- this.registerAction('onkeyUp', '_sys_onkeyUp_replay', this._sys_onkeyUp_replay, 100);
- this.registerAction('onkeyUp', '_sys_onkeyUp', this._sys_onkeyUp, 0);
- // --- pressKey注册
- this.registerAction('pressKey', '_sys_checkReplay', this._sys_checkReplay, 100);
- this.registerAction('pressKey', '_sys_pressKey', this._sys_pressKey, 0);
- // --- keyDown注册
- this.registerAction('keyDown', '_sys_checkReplay', this._sys_checkReplay, 100);
- this.registerAction('keyDown', '_sys_keyDown_lockControl', this._sys_keyDown_lockControl, 50);
- this.registerAction('keyDown', '_sys_keyDown', this._sys_keyDown, 0);
- // --- keyUp注册
- this.registerAction('keyUp', '_sys_keyUp_replay', this._sys_keyUp_replay, 100);
- this.registerAction('keyUp', '_sys_keyUp_lockControl', this._sys_keyUp_lockControl, 50);
- this.registerAction('keyUp', '_sys_keyUp', this._sys_keyUp, 0);
- // --- ondown注册
- this.registerAction('ondown', '_sys_checkReplay', this._sys_checkReplay, 100);
- this.registerAction('ondown', '_sys_ondown_lockControl', this._sys_ondown_lockControl, 30);
- this.registerAction('ondown', '_sys_ondown', this._sys_ondown, 0);
- // --- onmove注册
- this.registerAction('onmove', '_sys_checkReplay', this._sys_checkReplay, 100);
- this.registerAction('onmove', '_sys_onmove_choices', this._sys_onmove_choices, 30);
- this.registerAction('onmove', '_sys_onmove', this._sys_onmove, 0);
- // --- onup注册
- this.registerAction('onup', '_sys_checkReplay', this._sys_checkReplay, 100);
- this.registerAction('onup', '_sys_onup', this._sys_onup, 0);
- // --- onclick已废弃,将视为ondown
- // --- onmousewheel注册
- this.registerAction('onmousewheel', '_sys_onmousewheel', this._sys_onmousewheel, 0);
- // --- keyDownCtrl注册
- this.registerAction('keyDownCtrl', '_sys_keyDownCtrl', this._sys_keyDownCtrl, 0);
- // --- longClick注册
- this.registerAction('longClick', '_sys_longClick_lockControl', this._sys_longClick_lockControl, 50);
- // --- onStatusBarClick注册
- this.registerAction('onStatusBarClick', '_sys_onStatusBarClick', this._sys_onStatusBarClick, 0);
-
-}
+ this.actionsdata = functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a.actions;
+ this.actions = {};
+ // --- onkeyDown注册
+ this.registerAction(
+ "onkeyDown",
+ "_sys_checkReplay",
+ this._sys_checkReplay,
+ 100
+ );
+ this.registerAction("onkeyDown", "_sys_onkeyDown", this._sys_onkeyDown, 0);
+ // --- onkeyUp注册
+ this.registerAction(
+ "onkeyUp",
+ "_sys_onkeyUp_replay",
+ this._sys_onkeyUp_replay,
+ 100
+ );
+ this.registerAction("onkeyUp", "_sys_onkeyUp", this._sys_onkeyUp, 0);
+ // --- pressKey注册
+ this.registerAction(
+ "pressKey",
+ "_sys_checkReplay",
+ this._sys_checkReplay,
+ 100
+ );
+ this.registerAction("pressKey", "_sys_pressKey", this._sys_pressKey, 0);
+ // --- keyDown注册
+ this.registerAction(
+ "keyDown",
+ "_sys_checkReplay",
+ this._sys_checkReplay,
+ 100
+ );
+ this.registerAction(
+ "keyDown",
+ "_sys_keyDown_lockControl",
+ this._sys_keyDown_lockControl,
+ 50
+ );
+ this.registerAction("keyDown", "_sys_keyDown", this._sys_keyDown, 0);
+ // --- keyUp注册
+ this.registerAction(
+ "keyUp",
+ "_sys_keyUp_replay",
+ this._sys_keyUp_replay,
+ 100
+ );
+ this.registerAction(
+ "keyUp",
+ "_sys_keyUp_lockControl",
+ this._sys_keyUp_lockControl,
+ 50
+ );
+ this.registerAction("keyUp", "_sys_keyUp", this._sys_keyUp, 0);
+ // --- ondown注册
+ this.registerAction("ondown", "_sys_checkReplay", this._sys_checkReplay, 100);
+ this.registerAction(
+ "ondown",
+ "_sys_ondown_lockControl",
+ this._sys_ondown_lockControl,
+ 30
+ );
+ this.registerAction("ondown", "_sys_ondown", this._sys_ondown, 0);
+ // --- onmove注册
+ this.registerAction("onmove", "_sys_checkReplay", this._sys_checkReplay, 100);
+ this.registerAction(
+ "onmove",
+ "_sys_onmove_choices",
+ this._sys_onmove_choices,
+ 30
+ );
+ this.registerAction("onmove", "_sys_onmove", this._sys_onmove, 0);
+ // --- onup注册
+ this.registerAction("onup", "_sys_checkReplay", this._sys_checkReplay, 100);
+ this.registerAction("onup", "_sys_onup", this._sys_onup, 0);
+ // --- onclick已废弃,将视为ondown
+ // --- onmousewheel注册
+ this.registerAction(
+ "onmousewheel",
+ "_sys_onmousewheel",
+ this._sys_onmousewheel,
+ 0
+ );
+ // --- keyDownCtrl注册
+ this.registerAction(
+ "keyDownCtrl",
+ "_sys_keyDownCtrl",
+ this._sys_keyDownCtrl,
+ 0
+ );
+ // --- longClick注册
+ this.registerAction(
+ "longClick",
+ "_sys_longClick_lockControl",
+ this._sys_longClick_lockControl,
+ 50
+ );
+ // --- onStatusBarClick注册
+ this.registerAction(
+ "onStatusBarClick",
+ "_sys_onStatusBarClick",
+ this._sys_onStatusBarClick,
+ 0
+ );
+};
////// 注册一个用户交互行为 //////
/*
@@ -67,3099 +132,3740 @@ actions.prototype._init = function () {
* 返回:如果func返回true,则不会再继续执行其他的交互函数;否则会继续执行其他的交互函数。
*/
actions.prototype.registerAction = function (action, name, func, priority) {
- if (!name || !func)
- return;
- // 将onclick视为ondown处理
- if (action == 'onclick') action = 'ondown';
- priority = priority || 0;
- if (!this.actions[action]) {
- this.actions[action] = [];
- }
- this.unregisterAction(action, name);
- this.actions[action].push(
- { "action": action, "name": name, "func": func, "priority": priority }
- );
- this.actions[action] = this.actions[action].sort(function (a, b) {
- return b.priority - a.priority;
- });
-}
+ if (!name || !func) return;
+ // 将onclick视为ondown处理
+ if (action == "onclick") action = "ondown";
+ priority = priority || 0;
+ if (!this.actions[action]) {
+ this.actions[action] = [];
+ }
+ this.unregisterAction(action, name);
+ this.actions[action].push({
+ action: action,
+ name: name,
+ func: func,
+ priority: priority,
+ });
+ this.actions[action] = this.actions[action].sort(function (a, b) {
+ return b.priority - a.priority;
+ });
+};
////// 注销一个用户交互行为 //////
actions.prototype.unregisterAction = function (action, name) {
- // 将onclick视为ondown处理
- if (action == 'onclick') action = 'ondown';
- if (!this.actions[action]) return;
- this.actions[action] = this.actions[action].filter(function (x) {
- return x.name != name;
- });
-}
+ // 将onclick视为ondown处理
+ if (action == "onclick") action = "ondown";
+ if (!this.actions[action]) return;
+ this.actions[action] = this.actions[action].filter(function (x) {
+ return x.name != name;
+ });
+};
////// 执行一个用户交互行为 //////
actions.prototype.doRegisteredAction = function (action) {
- var actions = this.actions[action];
- if (!actions) return false;
- for (var i = 0; i < actions.length; ++i) {
- try {
- if (core.doFunc.apply(core, [actions[i].func, this].concat(Array.prototype.slice.call(arguments, 1))))
- return true;
- }
- catch (e) {
- console.error(e);
- console.error("ERROR in actions[" + actions[i].name + "].");
- }
+ var actions = this.actions[action];
+ if (!actions) return false;
+ for (var i = 0; i < actions.length; ++i) {
+ try {
+ if (
+ core.doFunc.apply(
+ core,
+ [actions[i].func, this].concat(
+ Array.prototype.slice.call(arguments, 1)
+ )
+ )
+ )
+ return true;
+ } catch (e) {
+ console.error(e);
+ console.error("ERROR in actions[" + actions[i].name + "].");
}
- return false;
-}
+ }
+ return false;
+};
actions.prototype._checkReplaying = function () {
- if (core.isReplaying() &&
- ['save', 'book', 'book-detail', 'viewMaps', 'toolbox', 'equipbox', 'text'].indexOf(core.status.event.id) < 0)
- return true;
- return false;
-}
+ if (
+ core.isReplaying() &&
+ [
+ "save",
+ "book",
+ "book-detail",
+ "viewMaps",
+ "toolbox",
+ "equipbox",
+ "text",
+ ].indexOf(core.status.event.id) < 0
+ )
+ return true;
+ return false;
+};
////// 检查是否在录像播放中,如果是,则停止交互
actions.prototype._sys_checkReplay = function () {
- if (this._checkReplaying()) return true;
-}
+ if (this._checkReplaying()) return true;
+};
////// 检查左手模式
actions.prototype.__checkLeftHandPrefer = function (e) {
- if (!core.flags.leftHandPrefer) return e;
- var map = {
- 87: 38, // W -> up
- 83: 40, // S -> down
- 65: 37, // A -> left
- 68: 39, // D -> right
- 73: 87, // I -> W
- 74: 65, // J -> A
- 75: 83, // K -> S
- 76: 68, // L -> D
+ if (!core.flags.leftHandPrefer) return e;
+ var map = {
+ 87: 38, // W -> up
+ 83: 40, // S -> down
+ 65: 37, // A -> left
+ 68: 39, // D -> right
+ 73: 87, // I -> W
+ 74: 65, // J -> A
+ 75: 83, // K -> S
+ 76: 68, // L -> D
+ };
+ var newEvent = {};
+ for (var one in e) {
+ if (!(e[one] instanceof Function)) {
+ newEvent[one] = e[one];
}
- var newEvent = {};
- for (var one in e) {
- if (!(e[one] instanceof Function)) {
- newEvent[one] = e[one];
- }
- };
- ["stopPropagation", "stopImmediatePropagation", "preventDefault"].forEach(function (one) {
- newEvent[one] = function () {
- return e[one]();
- }
- });
- newEvent.keyCode = map[e.keyCode] || e.keyCode;
- return newEvent;
-}
+ }
+ ["stopPropagation", "stopImmediatePropagation", "preventDefault"].forEach(
+ function (one) {
+ newEvent[one] = function () {
+ return e[one]();
+ };
+ }
+ );
+ newEvent.keyCode = map[e.keyCode] || e.keyCode;
+ return newEvent;
+};
////// 按下某个键时 //////
actions.prototype.onkeyDown = function (e) {
- this.doRegisteredAction('onkeyDown', this.__checkLeftHandPrefer(e));
-}
+ this.doRegisteredAction("onkeyDown", this.__checkLeftHandPrefer(e));
+};
actions.prototype._sys_onkeyDown = function (e) {
- core.status.holdingKeys = core.status.holdingKeys || []
- var isArrow = { 37: true, 38: true, 39: true, 40: true }[e.keyCode]
- if (isArrow && !core.status.lockControl) {
- for (var ii = 0; ii < core.status.holdingKeys.length; ii++) {
- if (core.status.holdingKeys[ii] === e.keyCode) {
- return;
- }
- }
- if (e.preventDefault) e.preventDefault();
- core.status.holdingKeys.push(e.keyCode);
- this.pressKey(e.keyCode);
- } else {
- if (e.keyCode == 17) core.status.ctrlDown = true;
- this.keyDown(e.keyCode);
+ core.status.holdingKeys = core.status.holdingKeys || [];
+ var isArrow = { 37: true, 38: true, 39: true, 40: true }[e.keyCode];
+ if (isArrow && !core.status.lockControl) {
+ for (var ii = 0; ii < core.status.holdingKeys.length; ii++) {
+ if (core.status.holdingKeys[ii] === e.keyCode) {
+ return;
+ }
}
-}
+ if (e.preventDefault) e.preventDefault();
+ core.status.holdingKeys.push(e.keyCode);
+ this.pressKey(e.keyCode);
+ } else {
+ if (e.keyCode == 17) core.status.ctrlDown = true;
+ this.keyDown(e.keyCode);
+ }
+};
////// 放开某个键时 //////
actions.prototype.onkeyUp = function (e) {
- this.doRegisteredAction('onkeyUp', this.__checkLeftHandPrefer(e));
-}
+ this.doRegisteredAction("onkeyUp", this.__checkLeftHandPrefer(e));
+};
actions.prototype._sys_onkeyUp_replay = function (e) {
- if (this._checkReplaying()) {
- if (e.keyCode == 27) // ESCAPE
- core.stopReplay();
- else if (e.keyCode == 90) // Z
- core.speedDownReplay();
- else if (e.keyCode == 67) // C
- core.speedUpReplay();
- else if (e.keyCode == 32) // SPACE
- core.triggerReplay();
- else if (e.keyCode == 65) // A
- core.rewindReplay();
- else if (e.keyCode == 83) // S
- core.control._replay_SL();
- else if (e.keyCode == 88) // X
- core.control._replay_book();
- else if (e.keyCode == 33 || e.keyCode == 34) // PgUp/PgDn
- core.control._replay_viewMap();
- else if (e.keyCode == 78) // N
- core.stepReplay();
- else if (e.keyCode == 84) // T
- core.control._replay_toolbox();
- else if (e.keyCode == 81) // Q
- core.control._replay_equipbox();
- else if (e.keyCode == 66) // B
- core.ui._drawStatistics();
- else if (e.keyCode >= 49 && e.keyCode <= 51) // 1-3
- core.setReplaySpeed(e.keyCode - 48);
- else if (e.keyCode == 52) // 4
- core.setReplaySpeed(6);
- else if (e.keyCode == 53) // 5
- core.setReplaySpeed(12);
- else if (e.keyCode == 54) // 6
- core.setReplaySpeed(24);
- return true;
- }
-}
+ if (this._checkReplaying()) {
+ if (e.keyCode == 27)
+ // ESCAPE
+ core.stopReplay();
+ else if (e.keyCode == 90)
+ // Z
+ core.speedDownReplay();
+ else if (e.keyCode == 67)
+ // C
+ core.speedUpReplay();
+ else if (e.keyCode == 32)
+ // SPACE
+ core.triggerReplay();
+ else if (e.keyCode == 65)
+ // A
+ core.rewindReplay();
+ else if (e.keyCode == 83)
+ // S
+ core.control._replay_SL();
+ else if (e.keyCode == 88)
+ // X
+ core.control._replay_book();
+ else if (e.keyCode == 33 || e.keyCode == 34)
+ // PgUp/PgDn
+ core.control._replay_viewMap();
+ else if (e.keyCode == 78)
+ // N
+ core.stepReplay();
+ else if (e.keyCode == 84)
+ // T
+ core.control._replay_toolbox();
+ else if (e.keyCode == 81)
+ // Q
+ core.control._replay_equipbox();
+ else if (e.keyCode == 66)
+ // B
+ core.ui._drawStatistics();
+ else if (e.keyCode >= 49 && e.keyCode <= 51)
+ // 1-3
+ core.setReplaySpeed(e.keyCode - 48);
+ else if (e.keyCode == 52)
+ // 4
+ core.setReplaySpeed(6);
+ else if (e.keyCode == 53)
+ // 5
+ core.setReplaySpeed(12);
+ else if (e.keyCode == 54)
+ // 6
+ core.setReplaySpeed(24);
+ return true;
+ }
+};
actions.prototype._sys_onkeyUp = function (e) {
- var isArrow = { 37: true, 38: true, 39: true, 40: true }[e.keyCode]
- if (isArrow && !core.status.lockControl) {
- for (var ii = 0; ii < core.status.holdingKeys.length; ii++) {
- if (core.status.holdingKeys[ii] === e.keyCode) {
- core.status.holdingKeys = core.status.holdingKeys.slice(0, ii).concat(core.status.holdingKeys.slice(ii + 1));
- if (ii === core.status.holdingKeys.length && core.status.holdingKeys.length !== 0) core.pressKey(core.status.holdingKeys.slice(-1)[0]);
- break;
- }
- }
- if (e.preventDefault) e.preventDefault();
- this.keyUp(e.keyCode, e.altKey);
- } else {
- if (e.keyCode == 17) core.status.ctrlDown = false;
- this.keyUp(e.keyCode, e.altKey);
+ var isArrow = { 37: true, 38: true, 39: true, 40: true }[e.keyCode];
+ if (isArrow && !core.status.lockControl) {
+ for (var ii = 0; ii < core.status.holdingKeys.length; ii++) {
+ if (core.status.holdingKeys[ii] === e.keyCode) {
+ core.status.holdingKeys = core.status.holdingKeys
+ .slice(0, ii)
+ .concat(core.status.holdingKeys.slice(ii + 1));
+ if (
+ ii === core.status.holdingKeys.length &&
+ core.status.holdingKeys.length !== 0
+ )
+ core.pressKey(core.status.holdingKeys.slice(-1)[0]);
+ break;
+ }
}
-}
+ if (e.preventDefault) e.preventDefault();
+ this.keyUp(e.keyCode, e.altKey);
+ } else {
+ if (e.keyCode == 17) core.status.ctrlDown = false;
+ this.keyUp(e.keyCode, e.altKey);
+ }
+};
////// 按住某个键时 //////
actions.prototype.pressKey = function (keyCode) {
- this.doRegisteredAction('pressKey', keyCode);
-}
+ this.doRegisteredAction("pressKey", keyCode);
+};
actions.prototype._sys_pressKey = function (keyCode) {
- if (keyCode === core.status.holdingKeys.slice(-1)[0]) {
- this.keyDown(keyCode);
- window.setTimeout(function () {
- core.pressKey(keyCode);
- }, 30);
- }
-}
+ if (keyCode === core.status.holdingKeys.slice(-1)[0]) {
+ this.keyDown(keyCode);
+ window.setTimeout(function () {
+ core.pressKey(keyCode);
+ }, 30);
+ }
+};
////// 根据按下键的code来执行一系列操作 //////
actions.prototype.keyDown = function (keyCode) {
- this.doRegisteredAction('keyDown', keyCode);
-}
+ this.doRegisteredAction("keyDown", keyCode);
+};
actions.prototype._sys_keyDown_lockControl = function (keyCode) {
- if (!core.status.lockControl) return false;
- // Ctrl跳过对话
- if (keyCode == 17) {
- this.keyDownCtrl();
- return true;
- }
- switch (core.status.event.id) {
- case 'action':
- this._keyDownAction(keyCode);
- break;
- case 'book':
- this._keyDownBook(keyCode);
- break;
- case 'fly':
- this._keyDownFly(keyCode);
- break;
- case 'viewMaps':
- this._keyDownViewMaps(keyCode);
- break;
- case 'equipbox':
- this._keyDownEquipbox(keyCode);
- break;
- case 'toolbox':
- this._keyDownToolbox(keyCode);
- break;
- case 'save':
- case 'load':
- case 'replayLoad':
- case 'replayRemain':
- case 'replaySince':
- this._keyDownSL(keyCode);
- break;
- case 'selectShop':
- case 'switchs':
- case 'switchs-sounds':
- case 'switchs-display':
- case 'switchs-action':
- case 'notes':
- case 'settings':
- case 'syncSave':
- case 'syncSelect':
- case 'localSaveSelect':
- case 'storageRemove':
- case 'replay':
- case 'gameInfo':
- this._keyDownChoices(keyCode);
- break;
- case 'cursor':
- this._keyDownCursor(keyCode);
- break;
- }
+ if (!core.status.lockControl) return false;
+ // Ctrl跳过对话
+ if (keyCode == 17) {
+ this.keyDownCtrl();
return true;
-}
+ }
+ switch (core.status.event.id) {
+ case "action":
+ this._keyDownAction(keyCode);
+ break;
+ case "book":
+ this._keyDownBook(keyCode);
+ break;
+ case "fly":
+ this._keyDownFly(keyCode);
+ break;
+ case "viewMaps":
+ this._keyDownViewMaps(keyCode);
+ break;
+ case "equipbox":
+ this._keyDownEquipbox(keyCode);
+ break;
+ case "toolbox":
+ this._keyDownToolbox(keyCode);
+ break;
+ case "save":
+ case "load":
+ case "replayLoad":
+ case "replayRemain":
+ case "replaySince":
+ this._keyDownSL(keyCode);
+ break;
+ case "selectShop":
+ case "switchs":
+ case "switchs-sounds":
+ case "switchs-display":
+ case "switchs-action":
+ case "notes":
+ case "settings":
+ case "syncSave":
+ case "syncSelect":
+ case "localSaveSelect":
+ case "storageRemove":
+ case "replay":
+ case "gameInfo":
+ this._keyDownChoices(keyCode);
+ break;
+ case "cursor":
+ this._keyDownCursor(keyCode);
+ break;
+ }
+ return true;
+};
actions.prototype._sys_keyDown = function (keyCode) {
- if (!core.status.played)
- return true;
- switch (keyCode) {
- case 37:
- core.moveHero('left');
- break;
- case 38:
- core.moveHero('up');
- break;
- case 39:
- core.moveHero('right');
- break;
- case 40:
- core.moveHero('down');
- break;
- }
- return true;
-}
+ if (!core.status.played) return true;
+ switch (keyCode) {
+ case 37:
+ core.moveHero("left");
+ break;
+ case 38:
+ core.moveHero("up");
+ break;
+ case 39:
+ core.moveHero("right");
+ break;
+ case 40:
+ core.moveHero("down");
+ break;
+ }
+ return true;
+};
////// 根据放开键的code来执行一系列操作 //////
actions.prototype.keyUp = function (keyCode, altKey, fromReplay) {
- this.doRegisteredAction('keyUp', keyCode, altKey, fromReplay);
-}
+ this.doRegisteredAction("keyUp", keyCode, altKey, fromReplay);
+};
actions.prototype._sys_keyUp_replay = function (keyCode, altKey, fromReplay) {
- if (!fromReplay && this._checkReplaying()) return true;
-}
+ if (!fromReplay && this._checkReplaying()) return true;
+};
actions.prototype._sys_keyUp_lockControl = function (keyCode, altKey) {
- if (!core.status.lockControl) return false;
+ if (!core.status.lockControl) return false;
- var ok = function () {
- return keyCode == 27 || keyCode == 88 || keyCode == 13 || keyCode == 32 || keyCode == 67;
- }
+ var ok = function () {
+ return (
+ keyCode == 27 ||
+ keyCode == 88 ||
+ keyCode == 13 ||
+ keyCode == 32 ||
+ keyCode == 67
+ );
+ };
- core.status.holdingKeys = [];
- switch (core.status.event.id) {
- case 'text':
- ok() && core.drawText();
- break;
- case 'confirmBox':
- this._keyUpConfirmBox(keyCode);
- break;
- case 'action':
- this._keyUpAction(keyCode);
- break;
- case 'about':
- ok() && core.closePanel();
- break;
- case 'help':
- ok() && core.closePanel();
- break;
- case 'book':
- this._keyUpBook(keyCode);
- break;
- case 'book-detail':
- ok() && this._clickBookDetail();
- break;
- case 'fly':
- this._keyUpFly(keyCode);
- break;
- case 'viewMaps':
- this._keyUpViewMaps(keyCode);
- break;
- case 'selectShop':
- this._keyUpQuickShop(keyCode);
- break;
- case 'toolbox':
- this._keyUpToolbox(keyCode);
- break;
- case 'equipbox':
- this._keyUpEquipbox(keyCode, altKey);
- break;
- case 'save':
- case 'load':
- case 'replayLoad':
- case 'replayRemain':
- case 'replaySince':
- this._keyUpSL(keyCode);
- break;
- case 'keyBoard':
- ok() && core.closePanel();
- break;
- case 'switchs':
- this._keyUpSwitchs(keyCode);
- break;
- case 'switchs-sounds':
- this._keyUpSwitchs_sounds(keyCode);
- break;
- case 'switchs-display':
- this._keyUpSwitchs_display(keyCode);
- break;
- case 'switchs-action':
- this._keyUpSwitchs_action(keyCode);
- break;
- case 'settings':
- this._keyUpSettings(keyCode);
- break;
- case 'notes':
- this._keyUpNotes(keyCode);
- break;
- case 'syncSave':
- this._keyUpSyncSave(keyCode);
- break;
- case 'syncSelect':
- this._keyUpSyncSelect(keyCode);
- break;
- case 'localSaveSelect':
- this._keyUpLocalSaveSelect(keyCode);
- break;
- case 'storageRemove':
- this._keyUpStorageRemove(keyCode);
- break;
- case 'cursor':
- this._keyUpCursor(keyCode);
- break;
- case 'replay':
- this._keyUpReplay(keyCode);
- break;
- case 'gameInfo':
- this._keyUpGameInfo(keyCode);
- break;
- case 'centerFly':
- this._keyUpCenterFly(keyCode);
- break;
- }
- return true;
-}
+ core.status.holdingKeys = [];
+ switch (core.status.event.id) {
+ case "text":
+ ok() && core.drawText();
+ break;
+ case "confirmBox":
+ this._keyUpConfirmBox(keyCode);
+ break;
+ case "action":
+ this._keyUpAction(keyCode);
+ break;
+ case "about":
+ ok() && core.closePanel();
+ break;
+ case "help":
+ ok() && core.closePanel();
+ break;
+ case "book":
+ this._keyUpBook(keyCode);
+ break;
+ case "book-detail":
+ ok() && this._clickBookDetail();
+ break;
+ case "fly":
+ this._keyUpFly(keyCode);
+ break;
+ case "viewMaps":
+ this._keyUpViewMaps(keyCode);
+ break;
+ case "selectShop":
+ this._keyUpQuickShop(keyCode);
+ break;
+ case "toolbox":
+ this._keyUpToolbox(keyCode);
+ break;
+ case "equipbox":
+ this._keyUpEquipbox(keyCode, altKey);
+ break;
+ case "save":
+ case "load":
+ case "replayLoad":
+ case "replayRemain":
+ case "replaySince":
+ this._keyUpSL(keyCode);
+ break;
+ case "keyBoard":
+ ok() && core.closePanel();
+ break;
+ case "switchs":
+ this._keyUpSwitchs(keyCode);
+ break;
+ case "switchs-sounds":
+ this._keyUpSwitchs_sounds(keyCode);
+ break;
+ case "switchs-display":
+ this._keyUpSwitchs_display(keyCode);
+ break;
+ case "switchs-action":
+ this._keyUpSwitchs_action(keyCode);
+ break;
+ case "settings":
+ this._keyUpSettings(keyCode);
+ break;
+ case "notes":
+ this._keyUpNotes(keyCode);
+ break;
+ case "syncSave":
+ this._keyUpSyncSave(keyCode);
+ break;
+ case "syncSelect":
+ this._keyUpSyncSelect(keyCode);
+ break;
+ case "localSaveSelect":
+ this._keyUpLocalSaveSelect(keyCode);
+ break;
+ case "storageRemove":
+ this._keyUpStorageRemove(keyCode);
+ break;
+ case "cursor":
+ this._keyUpCursor(keyCode);
+ break;
+ case "replay":
+ this._keyUpReplay(keyCode);
+ break;
+ case "gameInfo":
+ this._keyUpGameInfo(keyCode);
+ break;
+ case "centerFly":
+ this._keyUpCenterFly(keyCode);
+ break;
+ }
+ return true;
+};
actions.prototype._sys_keyUp = function (keyCode, altKey) {
- if (!core.status.played)
- return true;
- this.actionsdata.onKeyUp(keyCode, altKey);
- if (core.status.automaticRoute && core.status.automaticRoute.autoHeroMove) {
- core.stopAutomaticRoute();
- }
- core.status.heroStop = true;
- return true;
-}
+ if (!core.status.played) return true;
+ this.actionsdata.onKeyUp(keyCode, altKey);
+ if (core.status.automaticRoute && core.status.automaticRoute.autoHeroMove) {
+ core.stopAutomaticRoute();
+ }
+ core.status.heroStop = true;
+ return true;
+};
////// 点击(触摸)事件按下时 //////
actions.prototype.ondown = function (loc) {
- var x = parseInt(loc.x / loc.size), y = parseInt(loc.y / loc.size);
- var px = parseInt(loc.x / core.domStyle.scale), py = parseInt(loc.y / core.domStyle.scale);
- this.doRegisteredAction('ondown', x, y, px, py);
-}
+ var x = parseInt(loc.x / loc.size),
+ y = parseInt(loc.y / loc.size);
+ var px = parseInt(loc.x / core.domStyle.scale),
+ py = parseInt(loc.y / core.domStyle.scale);
+ this.doRegisteredAction("ondown", x, y, px, py);
+};
actions.prototype._sys_ondown_lockControl = function (x, y, px, py) {
- if (core.status.played && !core.status.lockControl) return false;
+ if (core.status.played && !core.status.lockControl) return false;
- switch (core.status.event.id) {
- case 'centerFly':
- this._clickCenterFly(x, y, px, py);
- break;
- case 'book':
- this._clickBook(x, y, px, py);
- break;
- case 'book-detail':
- this._clickBookDetail(x, y, px, py);
- break;
- case 'fly':
- this._clickFly(x, y, px, py);
- break;
- case 'viewMaps':
- this._clickViewMaps(x, y, px, py);
- break;
- case 'switchs':
- this._clickSwitchs(x, y, px, py);
- break;
- case 'switchs-sounds':
- this._clickSwitchs_sounds(x, y, px, py);
- break;
- case 'switchs-display':
- this._clickSwitchs_display(x, y, px, py);
- break;
- case 'switchs-action':
- this._clickSwitchs_action(x, y, px, py);
- break;
- case 'settings':
- this._clickSettings(x, y, px, py);
- break;
- case 'selectShop':
- this._clickQuickShop(x, y, px, py);
- break;
- case 'equipbox':
- this._clickEquipbox(x, y, px, py);
- break;
- case 'toolbox':
- this._clickToolbox(x, y, px, py);
- break;
- case 'save':
- case 'load':
- case 'replayLoad':
- case 'replayRemain':
- case 'replaySince':
- this._clickSL(x, y, px, py);
- break;
- case 'confirmBox':
- this._clickConfirmBox(x, y, px, py);
- break;
- case 'keyBoard':
- this._clickKeyBoard(x, y, px, py);
- break;
- case 'action':
- this._clickAction(x, y, px, py);
- break;
- case 'text':
- core.drawText();
- break;
- case 'notes':
- this._clickNotes(x, y, px, py);
- break;
- case 'syncSave':
- this._clickSyncSave(x, y, px, py);
- break;
- case 'syncSelect':
- this._clickSyncSelect(x, y, px, py);
- break;
- case 'localSaveSelect':
- this._clickLocalSaveSelect(x, y, px, py);
- break;
- case 'storageRemove':
- this._clickStorageRemove(x, y, px, py);
- break;
- case 'cursor':
- this._clickCursor(x, y, px, py);
- break;
- case 'replay':
- this._clickReplay(x, y, px, py);
- break;
- case 'gameInfo':
- this._clickGameInfo(x, y, px, py);
- break;
- case 'about':
- case 'help':
- core.ui.closePanel();
- break;
- }
+ switch (core.status.event.id) {
+ case "centerFly":
+ this._clickCenterFly(x, y, px, py);
+ break;
+ case "book":
+ this._clickBook(x, y, px, py);
+ break;
+ case "book-detail":
+ this._clickBookDetail(x, y, px, py);
+ break;
+ case "fly":
+ this._clickFly(x, y, px, py);
+ break;
+ case "viewMaps":
+ this._clickViewMaps(x, y, px, py);
+ break;
+ case "switchs":
+ this._clickSwitchs(x, y, px, py);
+ break;
+ case "switchs-sounds":
+ this._clickSwitchs_sounds(x, y, px, py);
+ break;
+ case "switchs-display":
+ this._clickSwitchs_display(x, y, px, py);
+ break;
+ case "switchs-action":
+ this._clickSwitchs_action(x, y, px, py);
+ break;
+ case "settings":
+ this._clickSettings(x, y, px, py);
+ break;
+ case "selectShop":
+ this._clickQuickShop(x, y, px, py);
+ break;
+ case "equipbox":
+ this._clickEquipbox(x, y, px, py);
+ break;
+ case "toolbox":
+ this._clickToolbox(x, y, px, py);
+ break;
+ case "save":
+ case "load":
+ case "replayLoad":
+ case "replayRemain":
+ case "replaySince":
+ this._clickSL(x, y, px, py);
+ break;
+ case "confirmBox":
+ this._clickConfirmBox(x, y, px, py);
+ break;
+ case "keyBoard":
+ this._clickKeyBoard(x, y, px, py);
+ break;
+ case "action":
+ this._clickAction(x, y, px, py);
+ break;
+ case "text":
+ core.drawText();
+ break;
+ case "notes":
+ this._clickNotes(x, y, px, py);
+ break;
+ case "syncSave":
+ this._clickSyncSave(x, y, px, py);
+ break;
+ case "syncSelect":
+ this._clickSyncSelect(x, y, px, py);
+ break;
+ case "localSaveSelect":
+ this._clickLocalSaveSelect(x, y, px, py);
+ break;
+ case "storageRemove":
+ this._clickStorageRemove(x, y, px, py);
+ break;
+ case "cursor":
+ this._clickCursor(x, y, px, py);
+ break;
+ case "replay":
+ this._clickReplay(x, y, px, py);
+ break;
+ case "gameInfo":
+ this._clickGameInfo(x, y, px, py);
+ break;
+ case "about":
+ case "help":
+ core.ui.closePanel();
+ break;
+ }
- // --- 长按判定
- if (core.timeout.onDownTimeout == null) {
- core.timeout.onDownTimeout = setTimeout(function () {
- if (core.interval.onDownInterval == null) {
- core.interval.onDownInterval = setInterval(function () {
- if (!core.actions.longClick(x, y, px, py)) {
- clearInterval(core.interval.onDownInterval);
- core.interval.onDownInterval = null;
- }
- }, 40)
- }
- }, 500);
- }
- return true;
-}
+ // --- 长按判定
+ if (core.timeout.onDownTimeout == null) {
+ core.timeout.onDownTimeout = setTimeout(function () {
+ if (core.interval.onDownInterval == null) {
+ core.interval.onDownInterval = setInterval(function () {
+ if (!core.actions.longClick(x, y, px, py)) {
+ clearInterval(core.interval.onDownInterval);
+ core.interval.onDownInterval = null;
+ }
+ }, 40);
+ }
+ }, 500);
+ }
+ return true;
+};
actions.prototype._sys_ondown = function (x, y, px, py) {
- if (core.status.lockControl) return false;
- core.status.downTime = new Date();
- core.deleteCanvas('route');
- var pos = { 'x': parseInt((px + core.bigmap.offsetX) / 32), 'y': parseInt((py + core.bigmap.offsetY) / 32) };
- core.status.stepPostfix = [];
- core.status.stepPostfix.push(pos);
- core.fillRect('ui', pos.x * 32 + 12 - core.bigmap.offsetX, pos.y * 32 + 12 - core.bigmap.offsetY, 8, 8, '#bfbfbf');
+ if (core.status.lockControl) return false;
+ core.status.downTime = new Date();
+ core.deleteCanvas("route");
+ var pos = {
+ x: parseInt((px + core.bigmap.offsetX) / 32),
+ y: parseInt((py + core.bigmap.offsetY) / 32),
+ };
+ core.status.stepPostfix = [];
+ core.status.stepPostfix.push(pos);
+ core.fillRect(
+ "ui",
+ pos.x * 32 + 12 - core.bigmap.offsetX,
+ pos.y * 32 + 12 - core.bigmap.offsetY,
+ 8,
+ 8,
+ "#bfbfbf"
+ );
- clearTimeout(core.timeout.onDownTimeout);
- core.timeout.onDownTimeout = null;
- core.status.preview.prepareDragging = false;
- if (!core.hasFlag('__lockViewport__') && (core.status.thisMap.width > core._WIDTH_ || core.status.thisMap.height > core._HEIGHT_)) {
- core.status.preview.prepareDragging = true;
- core.status.preview.px = px;
- core.status.preview.py = py;
- core.timeout.onDownTimeout = setTimeout(function () {
- core.clearMap('ui');
- core.status.preview.prepareDragging = false;
- core.status.preview.enabled = true;
- core.status.preview.dragging = true;
- core.drawTip('已进入预览模式,可直接拖动大地图');
- core.status.stepPostfix = [];
- }, 500);
- }
-}
+ clearTimeout(core.timeout.onDownTimeout);
+ core.timeout.onDownTimeout = null;
+ core.status.preview.prepareDragging = false;
+ if (
+ !core.hasFlag("__lockViewport__") &&
+ (core.status.thisMap.width > core._WIDTH_ ||
+ core.status.thisMap.height > core._HEIGHT_)
+ ) {
+ core.status.preview.prepareDragging = true;
+ core.status.preview.px = px;
+ core.status.preview.py = py;
+ core.timeout.onDownTimeout = setTimeout(function () {
+ core.clearMap("ui");
+ core.status.preview.prepareDragging = false;
+ core.status.preview.enabled = true;
+ core.status.preview.dragging = true;
+ core.drawTip("已进入预览模式,可直接拖动大地图");
+ core.status.stepPostfix = [];
+ }, 500);
+ }
+};
////// 当在触摸屏上滑动时 //////
actions.prototype.onmove = function (loc) {
- var x = parseInt(loc.x / loc.size), y = parseInt(loc.y / loc.size);
- var px = parseInt(loc.x / core.domStyle.scale), py = parseInt(loc.y / core.domStyle.scale);
- this.doRegisteredAction('onmove', x, y, px, py);
-}
+ var x = parseInt(loc.x / loc.size),
+ y = parseInt(loc.y / loc.size);
+ var px = parseInt(loc.x / core.domStyle.scale),
+ py = parseInt(loc.y / core.domStyle.scale);
+ this.doRegisteredAction("onmove", x, y, px, py);
+};
actions.prototype._sys_onmove_choices = function (x, y, px, py) {
- if (!core.status.lockControl) return false;
+ if (!core.status.lockControl) return false;
- switch (core.status.event.id) {
- case 'action':
- if (core.status.event.data.type == 'choices') {
- this._onMoveChoices(x, y);
- return true;
- }
- if (core.status.event.data.type == 'confirm') {
- this._onMoveConfirmBox(x, y, px, py);
- return true;
- }
- break;
- case 'selectShop':
- case 'switchs':
- case 'switchs-sounds':
- case 'switchs-display':
- case 'switchs-action':
- case 'notes':
- case 'settings':
- case 'syncSave':
- case 'syncSelect':
- case 'localSaveSelect':
- case 'storageRemove':
- case 'replay':
- case 'gameInfo':
- this._onMoveChoices(x, y);
- return true;
- case 'confirmBox':
- this._onMoveConfirmBox(x, y, px, py);
- return true;
- default:
- break;
- }
- return false;
-}
+ switch (core.status.event.id) {
+ case "action":
+ if (core.status.event.data.type == "choices") {
+ this._onMoveChoices(x, y);
+ return true;
+ }
+ if (core.status.event.data.type == "menu") {
+ this._onMoveMenu(px, py);
+ return true;
+ }
+ if (core.status.event.data.type == "confirm") {
+ this._onMoveConfirmBox(x, y, px, py);
+ return true;
+ }
+ break;
+ case "selectShop":
+ case "switchs":
+ case "switchs-sounds":
+ case "switchs-display":
+ case "switchs-action":
+ case "notes":
+ case "settings":
+ case "syncSave":
+ case "syncSelect":
+ case "localSaveSelect":
+ case "storageRemove":
+ case "replay":
+ case "gameInfo":
+ this._onMoveChoices(x, y);
+ return true;
+ case "confirmBox":
+ this._onMoveConfirmBox(x, y, px, py);
+ return true;
+ default:
+ break;
+ }
+ return false;
+};
actions.prototype._sys_onmove = function (x, y, px, py) {
- if (core.status.lockControl) return false;
+ if (core.status.lockControl) return false;
- if (core.status.preview.dragging) {
- core.setViewport(core.bigmap.offsetX - px + core.status.preview.px, core.bigmap.offsetY - py + core.status.preview.py);
- core.status.preview.px = px;
- core.status.preview.py = py;
- return true;
- }
- if (core.status.preview.prepareDragging) {
- if (Math.abs(px - core.status.preview.px) <= 20 && Math.abs(py - core.status.preview.py) <= 20)
- return true;
- else core.status.preview.prepareDragging = false;
- }
-
- clearTimeout(core.timeout.onDownTimeout);
- core.timeout.onDownTimeout = null;
-
- if ((core.status.stepPostfix || []).length > 0) {
- var pos = { 'x': parseInt((px + core.bigmap.offsetX) / 32), 'y': parseInt((py + core.bigmap.offsetY) / 32) };
- var pos0 = core.status.stepPostfix[core.status.stepPostfix.length - 1];
- var directionDistance = [pos.y - pos0.y, pos0.x - pos.x, pos0.y - pos.y, pos.x - pos0.x];
- var max = 0, index = 4;
- for (var ii = 0; ii < 4; ii++) {
- if (directionDistance[ii] > max) {
- index = ii;
- max = directionDistance[ii];
- }
- }
- pos = [{ 'x': 0, 'y': 1 }, { 'x': -1, 'y': 0 }, { 'x': 0, 'y': -1 }, { 'x': 1, 'y': 0 }, false][index]
- if (pos) {
- pos.x += pos0.x;
- pos.y += pos0.y;
- core.status.stepPostfix.push(pos);
- core.fillRect('ui', pos.x * 32 + 12 - core.bigmap.offsetX, pos.y * 32 + 12 - core.bigmap.offsetY, 8, 8, '#bfbfbf');
- }
- }
+ if (core.status.preview.dragging) {
+ core.setViewport(
+ core.bigmap.offsetX - px + core.status.preview.px,
+ core.bigmap.offsetY - py + core.status.preview.py
+ );
+ core.status.preview.px = px;
+ core.status.preview.py = py;
return true;
-}
+ }
+ if (core.status.preview.prepareDragging) {
+ if (
+ Math.abs(px - core.status.preview.px) <= 20 &&
+ Math.abs(py - core.status.preview.py) <= 20
+ )
+ return true;
+ else core.status.preview.prepareDragging = false;
+ }
+
+ clearTimeout(core.timeout.onDownTimeout);
+ core.timeout.onDownTimeout = null;
+
+ if ((core.status.stepPostfix || []).length > 0) {
+ var pos = {
+ x: parseInt((px + core.bigmap.offsetX) / 32),
+ y: parseInt((py + core.bigmap.offsetY) / 32),
+ };
+ var pos0 = core.status.stepPostfix[core.status.stepPostfix.length - 1];
+ var directionDistance = [
+ pos.y - pos0.y,
+ pos0.x - pos.x,
+ pos0.y - pos.y,
+ pos.x - pos0.x,
+ ];
+ var max = 0,
+ index = 4;
+ for (var ii = 0; ii < 4; ii++) {
+ if (directionDistance[ii] > max) {
+ index = ii;
+ max = directionDistance[ii];
+ }
+ }
+ pos = [
+ { x: 0, y: 1 },
+ { x: -1, y: 0 },
+ { x: 0, y: -1 },
+ { x: 1, y: 0 },
+ false,
+ ][index];
+ if (pos) {
+ pos.x += pos0.x;
+ pos.y += pos0.y;
+ core.status.stepPostfix.push(pos);
+ core.fillRect(
+ "ui",
+ pos.x * 32 + 12 - core.bigmap.offsetX,
+ pos.y * 32 + 12 - core.bigmap.offsetY,
+ 8,
+ 8,
+ "#bfbfbf"
+ );
+ }
+ }
+ return true;
+};
////// 当点击(触摸)事件放开时 //////
actions.prototype.onup = function (loc) {
- var x = parseInt(loc.x / loc.size), y = parseInt(loc.y / loc.size);
- var px = parseInt(loc.x / core.domStyle.scale), py = parseInt(loc.y / core.domStyle.scale);
- this.doRegisteredAction('onup', x, y, px, py);
-}
+ var x = parseInt(loc.x / loc.size),
+ y = parseInt(loc.y / loc.size);
+ var px = parseInt(loc.x / core.domStyle.scale),
+ py = parseInt(loc.y / core.domStyle.scale);
+ this.doRegisteredAction("onup", x, y, px, py);
+};
actions.prototype._sys_onup = function (x, y, px, py) {
- clearTimeout(core.timeout.onDownTimeout);
- core.timeout.onDownTimeout = null;
- clearInterval(core.interval.onDownInterval);
- core.interval.onDownInterval = null;
+ clearTimeout(core.timeout.onDownTimeout);
+ core.timeout.onDownTimeout = null;
+ clearInterval(core.interval.onDownInterval);
+ core.interval.onDownInterval = null;
- if (core.isPlaying()) {
- core.status.preview.prepareDragging = false;
- if (core.status.preview.dragging) {
- core.status.preview.dragging = false;
- return true;
- }
+ if (core.isPlaying()) {
+ core.status.preview.prepareDragging = false;
+ if (core.status.preview.dragging) {
+ core.status.preview.dragging = false;
+ return true;
}
+ }
- if ((core.status.stepPostfix || []).length == 0) return false;
+ if ((core.status.stepPostfix || []).length == 0) return false;
- var stepPostfix = [];
- var direction = { '0': { '1': 'down', '-1': 'up' }, '-1': { '0': 'left' }, '1': { '0': 'right' } };
- for (var ii = 1; ii < core.status.stepPostfix.length; ii++) {
- var pos0 = core.status.stepPostfix[ii - 1];
- var pos = core.status.stepPostfix[ii];
- stepPostfix.push({
- 'direction': direction[pos.x - pos0.x][pos.y - pos0.y],
- 'x': pos.x,
- 'y': pos.y
- });
- }
- var posx = core.status.stepPostfix[0].x;
- var posy = core.status.stepPostfix[0].y;
- core.status.stepPostfix = [];
- if (!core.status.lockControl) {
- core.clearMap('ui');
- }
+ var stepPostfix = [];
+ var direction = {
+ 0: { 1: "down", "-1": "up" },
+ "-1": { 0: "left" },
+ 1: { 0: "right" },
+ };
+ for (var ii = 1; ii < core.status.stepPostfix.length; ii++) {
+ var pos0 = core.status.stepPostfix[ii - 1];
+ var pos = core.status.stepPostfix[ii];
+ stepPostfix.push({
+ direction: direction[pos.x - pos0.x][pos.y - pos0.y],
+ x: pos.x,
+ y: pos.y,
+ });
+ }
+ var posx = core.status.stepPostfix[0].x;
+ var posy = core.status.stepPostfix[0].y;
+ core.status.stepPostfix = [];
+ if (!core.status.lockControl) {
+ core.clearMap("ui");
+ }
- // 长按
- if (!core.status.lockControl && stepPostfix.length == 0 && core.status.downTime != null && new Date() - core.status.downTime >= 1000) {
- core.actions.longClick(x, y, px, py);
- }
- else {
- //posx,posy是寻路的目标点,stepPostfix是后续的移动
- core.setAutomaticRoute(posx, posy, stepPostfix);
- }
- core.status.downTime = null;
- return true;
-}
+ // 长按
+ if (
+ !core.status.lockControl &&
+ stepPostfix.length == 0 &&
+ core.status.downTime != null &&
+ new Date() - core.status.downTime >= 1000
+ ) {
+ core.actions.longClick(x, y, px, py);
+ } else {
+ //posx,posy是寻路的目标点,stepPostfix是后续的移动
+ core.setAutomaticRoute(posx, posy, stepPostfix);
+ }
+ core.status.downTime = null;
+ return true;
+};
////// 获得点击事件相对左上角的坐标 //////
actions.prototype._getClickLoc = function (x, y) {
+ var statusBar = { x: 0, y: 0 };
+ var size = 32;
+ size = size * core.domStyle.scale;
- var statusBar = { 'x': 0, 'y': 0 };
- var size = 32;
- size = size * core.domStyle.scale;
-
- if (core.domStyle.isVertical) {
- statusBar.x = 3;
- statusBar.y = core.dom.statusBar.offsetHeight + 3;
- }
- else {
- statusBar.x = core.dom.statusBar.offsetWidth + 3;
- statusBar.y = 3;
- }
-
- var left = core.dom.gameGroup.offsetLeft + statusBar.x;
- var top = core.dom.gameGroup.offsetTop + statusBar.y;
- var loc = { 'x': Math.max(x - left), 'y': Math.max(y - top, 0), 'size': size };
- return loc;
-}
+ if (core.domStyle.isVertical) {
+ statusBar.x = 3;
+ statusBar.y = core.dom.statusBar.offsetHeight + 3;
+ } else {
+ statusBar.x = core.dom.statusBar.offsetWidth + 3;
+ statusBar.y = 3;
+ }
+ var left = core.dom.gameGroup.offsetLeft + statusBar.x;
+ var top = core.dom.gameGroup.offsetTop + statusBar.y;
+ var loc = { x: Math.max(x - left), y: Math.max(y - top, 0), size: size };
+ return loc;
+};
////// 滑动鼠标滚轮时的操作 //////
actions.prototype.onmousewheel = function (direct) {
- this.doRegisteredAction('onmousewheel', direct);
-}
+ this.doRegisteredAction("onmousewheel", direct);
+};
actions.prototype._sys_onmousewheel = function (direct) {
- // 向下滚动是 -1 ,向上是 1
+ // 向下滚动是 -1 ,向上是 1
- if (this._checkReplaying()) {
- // 滚轮控制速度
- if (direct == 1) core.speedUpReplay();
- if (direct == -1) core.speedDownReplay();
- return;
+ if (this._checkReplaying()) {
+ // 滚轮控制速度
+ if (direct == 1) core.speedUpReplay();
+ if (direct == -1) core.speedDownReplay();
+ return;
+ }
+
+ // 楼层飞行器
+ if (core.status.lockControl && core.status.event.id == "fly") {
+ if (direct == 1) core.ui.drawFly(this._getNextFlyFloor(1));
+ if (direct == -1) core.ui.drawFly(this._getNextFlyFloor(-1));
+ return;
+ }
+
+ // 怪物手册
+ if (core.status.lockControl && core.status.event.id == "book") {
+ var pageinfo = core.ui._drawBook_pageinfo();
+ if (direct == 1)
+ core.ui.drawBook(core.status.event.data - pageinfo.per_page);
+ if (direct == -1)
+ core.ui.drawBook(core.status.event.data + pageinfo.per_page);
+ return;
+ }
+
+ // 存读档
+ if (
+ core.status.lockControl &&
+ (core.status.event.id == "save" || core.status.event.id == "load")
+ ) {
+ var index =
+ core.status.event.data.page * 10 + core.status.event.data.offset;
+ if (direct == 1) core.ui._drawSLPanel(index - 10);
+ if (direct == -1) core.ui._drawSLPanel(index + 10);
+ return;
+ }
+
+ // 浏览地图
+ if (core.status.lockControl && core.status.event.id == "viewMaps") {
+ if (direct == 1)
+ this._clickViewMaps(
+ this._HX_,
+ this._HY_ - 3,
+ core._PX_ / 2,
+ (core._PY_ / 5) * 1.5
+ );
+ if (direct == -1)
+ this._clickViewMaps(
+ this._HX_,
+ this._HY_ + 3,
+ core._PX_ / 2,
+ (core._PY_ / 5) * 3.5
+ );
+ return;
+ }
+
+ // wait事件
+ if (
+ core.status.lockControl &&
+ core.status.event.id == "action" &&
+ core.status.event.data.type == "wait"
+ ) {
+ var timeout =
+ Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
+ core.setFlag("type", 0);
+ var keycode = direct == 1 ? 33 : 34;
+ core.setFlag("keycode", keycode);
+ core.setFlag("timeout", timeout);
+ var executed = core.events.__action_wait_afterGet(
+ core.status.event.data.current
+ );
+ if (executed || !core.status.event.data.current.forceChild) {
+ core.status.route.push("input:" + (1e8 * timeout + keycode));
+ clearTimeout(core.status.event.interval);
+ delete core.status.event.timeout;
+ core.doAction();
}
-
- // 楼层飞行器
- if (core.status.lockControl && core.status.event.id == 'fly') {
- if (direct == 1) core.ui.drawFly(this._getNextFlyFloor(1));
- if (direct == -1) core.ui.drawFly(this._getNextFlyFloor(-1));
- return;
- }
-
- // 怪物手册
- if (core.status.lockControl && core.status.event.id == 'book') {
- var pageinfo = core.ui._drawBook_pageinfo();
- if (direct == 1) core.ui.drawBook(core.status.event.data - pageinfo.per_page);
- if (direct == -1) core.ui.drawBook(core.status.event.data + pageinfo.per_page);
- return;
- }
-
- // 存读档
- if (core.status.lockControl && (core.status.event.id == 'save' || core.status.event.id == 'load')) {
- var index = core.status.event.data.page * 10 + core.status.event.data.offset;
- if (direct == 1) core.ui._drawSLPanel(index - 10);
- if (direct == -1) core.ui._drawSLPanel(index + 10);
- return;
- }
-
- // 浏览地图
- if (core.status.lockControl && core.status.event.id == 'viewMaps') {
- if (direct == 1) this._clickViewMaps(this._HX_, this._HY_ - 3, core._PX_ / 2, core._PY_ / 5 * 1.5);
- if (direct == -1) this._clickViewMaps(this._HX_, this._HY_ + 3, core._PX_ / 2, core._PY_ / 5 * 3.5);
- return;
- }
-
- // wait事件
- if (core.status.lockControl && core.status.event.id == 'action' && core.status.event.data.type == 'wait') {
- var timeout = Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- core.setFlag('type', 0);
- var keycode = direct == 1 ? 33 : 34;
- core.setFlag('keycode', keycode);
- core.setFlag('timeout', timeout);
- var executed = core.events.__action_wait_afterGet(core.status.event.data.current);
- if (executed || !core.status.event.data.current.forceChild) {
- core.status.route.push("input:" + (1e8 * timeout + keycode));
- clearTimeout(core.status.event.interval);
- delete core.status.event.timeout;
- core.doAction();
- }
- return;
- }
-
-}
+ return;
+ }
+};
////// 长按Ctrl键时 //////
actions.prototype.keyDownCtrl = function () {
- this.doRegisteredAction('keyDownCtrl');
-}
+ this.doRegisteredAction("keyDownCtrl");
+};
actions.prototype._sys_keyDownCtrl = function () {
- if (core.status.event.id == 'text') {
- core.drawText();
- return true;
+ if (core.status.event.id == "text") {
+ core.drawText();
+ return true;
+ }
+ if (
+ core.status.event.id == "action" &&
+ core.status.event.data.type == "text"
+ ) {
+ core.doAction();
+ return true;
+ }
+ if (
+ core.status.event.id == "action" &&
+ core.status.event.data.type == "sleep" &&
+ !core.status.event.data.current.noSkip
+ ) {
+ if (core.timeout.sleepTimeout && !core.hasAsync()) {
+ clearTimeout(core.timeout.sleepTimeout);
+ core.timeout.sleepTimeout = null;
+ core.doAction();
}
- if (core.status.event.id == 'action' && core.status.event.data.type == 'text') {
- core.doAction();
- return true;
- }
- if (core.status.event.id == 'action' && core.status.event.data.type == 'sleep'
- && !core.status.event.data.current.noSkip) {
- if (core.timeout.sleepTimeout && !core.hasAsync()) {
- clearTimeout(core.timeout.sleepTimeout);
- core.timeout.sleepTimeout = null;
- core.doAction();
- }
- return true;
- }
-}
+ return true;
+ }
+};
////// 长按 //////
actions.prototype.longClick = function (x, y, px, py) {
- if (!core.isPlaying()) return false;
- return this.doRegisteredAction('longClick', x, y, px, py);
-}
+ if (!core.isPlaying()) return false;
+ return this.doRegisteredAction("longClick", x, y, px, py);
+};
actions.prototype._sys_longClick_lockControl = function (x, y, px, py) {
- if (!core.status.lockControl) return false;
- if (core.status.event.id == 'text') {
- core.drawText();
- return true;
+ if (!core.status.lockControl) return false;
+ if (core.status.event.id == "text") {
+ core.drawText();
+ return true;
+ }
+ if (
+ core.status.event.id == "action" &&
+ core.status.event.data.type == "text"
+ ) {
+ core.doAction();
+ return true;
+ }
+ // 长按楼传器的箭头可以快速翻页
+ if (core.status.event.id == "fly") {
+ if (
+ (x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) &&
+ (y == this._HY_ - 1 || y == this._HY_ + 3)
+ ) {
+ this._clickFly(x, y);
+ return true;
}
- if (core.status.event.id == 'action' && core.status.event.data.type == 'text') {
- core.doAction();
- return true;
+ }
+ // 长按SL上下页快速翻页
+ if (
+ ["save", "load", "replayLoad", "replayRemain", "replaySince"].indexOf(
+ core.status.event.id
+ ) >= 0
+ ) {
+ if (
+ [this._HX_ - 2, this._HX_ - 3, this._HX_ + 2, this._HX_ + 3].indexOf(x) >=
+ 0 &&
+ y === core._HEIGHT_ - 1
+ ) {
+ this._clickSL(x, y);
+ return true;
}
- // 长按楼传器的箭头可以快速翻页
- if (core.status.event.id == 'fly') {
- if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && (y == this._HY_ - 1 || y == this._HY_ + 3)) {
- this._clickFly(x, y);
- return true;
- }
+ }
+ // 长按可以跳过等待事件
+ if (
+ core.status.event.id == "action" &&
+ core.status.event.data.type == "sleep" &&
+ !core.status.event.data.current.noSkip
+ ) {
+ if (core.timeout.sleepTimeout && !core.hasAsync()) {
+ clearTimeout(core.timeout.sleepTimeout);
+ core.timeout.sleepTimeout = null;
+ core.doAction();
+ return true;
}
- // 长按SL上下页快速翻页
- if (["save", "load", "replayLoad", "replayRemain", "replaySince"].indexOf(core.status.event.id) >= 0) {
- if ([this._HX_ - 2, this._HX_ - 3, this._HX_ + 2, this._HX_ + 3].indexOf(x) >= 0 && y===core._HEIGHT_-1) {
- this._clickSL(x, y);
- return true;
- }
- }
- // 长按可以跳过等待事件
- if (core.status.event.id == 'action' && core.status.event.data.type == 'sleep'
- && !core.status.event.data.current.noSkip) {
- if (core.timeout.sleepTimeout && !core.hasAsync()) {
- clearTimeout(core.timeout.sleepTimeout);
- core.timeout.sleepTimeout = null;
- core.doAction();
- return true;
- }
- }
- return false;
-}
+ }
+ return false;
+};
actions.prototype.onStatusBarClick = function (e) {
- if (!core.isPlaying()) return false;
- var left = core.dom.gameGroup.offsetLeft + 3;
- var top = core.dom.gameGroup.offsetTop + 3;
- var px = parseInt((e.clientX - left) / core.domStyle.scale), py = parseInt((e.clientY - top) / core.domStyle.scale);
- return this.doRegisteredAction('onStatusBarClick', Math.max(px, 0), Math.max(py, 0));
-}
+ if (!core.isPlaying()) return false;
+ var left = core.dom.gameGroup.offsetLeft + 3;
+ var top = core.dom.gameGroup.offsetTop + 3;
+ var px = parseInt((e.clientX - left) / core.domStyle.scale),
+ py = parseInt((e.clientY - top) / core.domStyle.scale);
+ return this.doRegisteredAction(
+ "onStatusBarClick",
+ Math.max(px, 0),
+ Math.max(py, 0)
+ );
+};
actions.prototype._sys_onStatusBarClick = function (px, py, vertical) {
- if (this.actionsdata.onStatusBarClick)
- return this.actionsdata.onStatusBarClick(px, py, vertical);
-}
+ if (this.actionsdata.onStatusBarClick)
+ return this.actionsdata.onStatusBarClick(px, py, vertical);
+};
/////////////////// 在某个界面时的按键点击效果 ///////////////////
actions.prototype._getChoicesTopIndex = function (length) {
- return this._HY_ - parseInt((length - 1) / 2) + (core.status.event.ui.offset || 0);
-}
+ return (
+ this._HY_ - parseInt((length - 1) / 2) + (core.status.event.ui.offset || 0)
+ );
+};
// 数字键快速选择选项
actions.prototype._selectChoices = function (length, keycode, callback) {
- var topIndex = this._getChoicesTopIndex(length);
- if (keycode == 13 || keycode == 32 || keycode == 67) {
- callback.apply(this, [this._HX_, topIndex + core.status.event.selection]);
- }
+ var topIndex = this._getChoicesTopIndex(length);
+ if (keycode == 13 || keycode == 32 || keycode == 67) {
+ callback.apply(this, [this._HX_, topIndex + core.status.event.selection]);
+ }
- if (keycode >= 49 && keycode <= 57) {
- var index = keycode - 49;
- if (index < length) {
- callback.apply(this, [this._HX_, topIndex + index]);
- }
+ if (keycode >= 49 && keycode <= 57) {
+ var index = keycode - 49;
+ if (index < length) {
+ callback.apply(this, [this._HX_, topIndex + index]);
}
-}
+ }
+};
+// 数字键快速选择选项
+actions.prototype._selectMenu = function (length, keycode, callback) {
+ if (keycode == 13 || keycode == 32 || keycode == 67) {
+ callback.apply(this, [,,core.menu.x+2,core.menu.y+34+core.menu.selection*32]);
+ }
+callback.apply(this, [,,core.menu.x-2,0]);
+};
// 上下键调整选项
actions.prototype._keyDownChoices = function (keycode) {
- if (keycode == 38) {
- core.status.event.selection--;
- core.playSound('光标移动');
- core.ui.drawChoices(core.status.event.ui.text, core.status.event.ui.choices, core.status.event.ui.width);
- }
- if (keycode == 40) {
- core.status.event.selection++;
- core.playSound('光标移动');
- core.ui.drawChoices(core.status.event.ui.text, core.status.event.ui.choices, core.status.event.ui.width);
- }
-}
+ if (keycode == 38) {
+ core.status.event.selection--;
+ core.playSound("光标移动");
+ core.ui.drawChoices(
+ core.status.event.ui.text,
+ core.status.event.ui.choices,
+ core.status.event.ui.width
+ );
+ }
+ if (keycode == 40) {
+ core.status.event.selection++;
+ core.playSound("光标移动");
+ core.ui.drawChoices(
+ core.status.event.ui.text,
+ core.status.event.ui.choices,
+ core.status.event.ui.width
+ );
+ }
+};
+actions.prototype._keyDownMenu = function (keycode) {
+ if (keycode == 38) {
+ core.menu.selection--;
+ if(core.menu.selection<0)core.menu.selection=0
+ core.playSound("光标移动");
+ core.menu.update()
+ }
+ if (keycode == 40) {
+ core.menu.selection++;
+ if(core.menu.select>core.menu.list.length-2)core.menu.selection=core.menu.list.length-2
+ core.playSound("光标移动");
+ core.menu.update()
+ }
+};
// 移动光标
actions.prototype._onMoveChoices = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- if (selection == core.status.event.selection) return;
- core.status.event.selection = selection;
- core.playSound('光标移动');
- core.ui.drawChoices(core.status.event.ui.text, core.status.event.ui.choices, core.status.event.ui.width);
- }
-}
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ if (selection == core.status.event.selection) return;
+ core.status.event.selection = selection;
+ core.playSound("光标移动");
+ core.ui.drawChoices(
+ core.status.event.ui.text,
+ core.status.event.ui.choices,
+ core.status.event.ui.width
+ );
+ }
+};
+actions.prototype._onMoveMenu = function (px, py) {
+ if (
+ px < core.menu.x ||
+ px > core.menu.w + core.menu.x ||
+ py < core.menu.y ||
+ py > core.menu.y + core.menu.h
+ ) return;
+ if(py - core.menu.y<=34)return
+ let selection = Math.floor((py - 34 - core.menu.y) / 32);
+if(core.menu.selection===selection)return
+
+ core.menu.selection = selection;
+ core.playSound("光标移动");
+ core.menu.update()
+ }
////// 点击中心对称飞行器时
actions.prototype._clickCenterFly = function (x, y) {
- var posX = core.status.event.data.posX, posY = core.status.event.data.posY;
- core.ui.closePanel();
- if (x == posX && y == posY) {
- if (core.canUseItem('centerFly')) {
- core.useItem('centerFly');
- }
- else {
- core.playSound('操作失败');
- core.drawTip('当前不能使用' + core.material.items['centerFly'].name, 'centerFly');
- }
+ var posX = core.status.event.data.posX,
+ posY = core.status.event.data.posY;
+ core.ui.closePanel();
+ if (x == posX && y == posY) {
+ if (core.canUseItem("centerFly")) {
+ core.useItem("centerFly");
+ } else {
+ core.playSound("操作失败");
+ core.drawTip(
+ "当前不能使用" + core.material.items["centerFly"].name,
+ "centerFly"
+ );
}
-}
+ }
+};
actions.prototype._keyUpCenterFly = function (keycode) {
- core.ui.closePanel();
- if (keycode == 51 || keycode == 13 || keycode == 32 || keycode == 67) {
- if (core.canUseItem('centerFly')) {
- core.useItem('centerFly');
- }
- else {
- core.playSound('操作失败');
- core.drawTip('当前不能使用' + core.material.items['centerFly'].name, 'centerFly');
- }
+ core.ui.closePanel();
+ if (keycode == 51 || keycode == 13 || keycode == 32 || keycode == 67) {
+ if (core.canUseItem("centerFly")) {
+ core.useItem("centerFly");
+ } else {
+ core.playSound("操作失败");
+ core.drawTip(
+ "当前不能使用" + core.material.items["centerFly"].name,
+ "centerFly"
+ );
}
-}
+ }
+};
////// 点击确认框时 //////
actions.prototype._clickConfirmBox = function (x, y, px, py) {
- if (px >= core._PX_ / 2 - 70 && px <= core._PX_ / 2 - 10
- && py >= core._PY_ / 2 && py <= core._PY_ / 2 + 64 && core.status.event.data.yes)
- core.status.event.data.yes();
- if (px >= core._PX_ / 2 + 10 && px <= core._PX_ / 2 + 70
- && py >= core._PY_ / 2 && py <= core._PY_ / 2 + 64 && core.status.event.data.no)
- core.status.event.data.no();
-}
+ if (
+ px >= core._PX_ / 2 - 70 &&
+ px <= core._PX_ / 2 - 10 &&
+ py >= core._PY_ / 2 &&
+ py <= core._PY_ / 2 + 64 &&
+ core.status.event.data.yes
+ )
+ core.status.event.data.yes();
+ if (
+ px >= core._PX_ / 2 + 10 &&
+ px <= core._PX_ / 2 + 70 &&
+ py >= core._PY_ / 2 &&
+ py <= core._PY_ / 2 + 64 &&
+ core.status.event.data.no
+ )
+ core.status.event.data.no();
+};
////// 键盘操作确认框时 //////
actions.prototype._keyUpConfirmBox = function (keycode) {
- if (keycode == 37 || keycode == 39) {
- core.status.event.selection = 1 - core.status.event.selection;
- core.playSound('光标移动');
- core.ui.drawConfirmBox(core.status.event.ui, core.status.event.data.yes, core.status.event.data.no);
- return;
+ if (keycode == 37 || keycode == 39) {
+ core.status.event.selection = 1 - core.status.event.selection;
+ core.playSound("光标移动");
+ core.ui.drawConfirmBox(
+ core.status.event.ui,
+ core.status.event.data.yes,
+ core.status.event.data.no
+ );
+ return;
+ }
+ if (keycode == 13 || keycode == 32 || keycode == 67) {
+ if (core.status.event.selection == 0 && core.status.event.data.yes) {
+ // core.playSound('确定');
+ core.status.event.selection = null;
+ core.status.event.data.yes();
+ return;
}
- if (keycode == 13 || keycode == 32 || keycode == 67) {
- if (core.status.event.selection == 0 && core.status.event.data.yes) {
- // core.playSound('确定');
- core.status.event.selection = null;
- core.status.event.data.yes();
- return;
- }
- if (core.status.event.selection == 1 && core.status.event.data.no) {
- // core.playSound('确定');
- core.status.event.selection = null;
- core.status.event.data.no();
- return;
- }
+ if (core.status.event.selection == 1 && core.status.event.data.no) {
+ // core.playSound('确定');
+ core.status.event.selection = null;
+ core.status.event.data.no();
+ return;
}
-}
+ }
+};
////// 鼠标在确认框上移动时 //////
actions.prototype._onMoveConfirmBox = function (x, y, px, py) {
- if (py >= core._PY_ / 2 && py <= core._PY_ / 2 + 64) {
- if (px >= core._PX_ / 2 - 70 && px <= core._PX_ / 2 - 10) {
- if (core.status.event.selection != 0) {
- core.status.event.selection = 0;
- core.playSound('光标移动');
- if (core.status.event.id == 'action') {
- core.ui.drawConfirmBox(core.status.event.ui.text);
- } else {
- core.ui.drawConfirmBox(core.status.event.ui, core.status.event.data.yes, core.status.event.data.no);
- }
- }
- return;
- }
- if (px >= core._PX_ / 2 + 10 && px <= core._PX_ / 2 + 70) {
- if (core.status.event.selection != 1) {
- core.status.event.selection = 1;
- core.playSound('光标移动');
- if (core.status.event.id == 'action') {
- core.ui.drawConfirmBox(core.status.event.ui.text);
- } else {
- core.ui.drawConfirmBox(core.status.event.ui, core.status.event.data.yes, core.status.event.data.no);
- }
- }
- return;
+ if (py >= core._PY_ / 2 && py <= core._PY_ / 2 + 64) {
+ if (px >= core._PX_ / 2 - 70 && px <= core._PX_ / 2 - 10) {
+ if (core.status.event.selection != 0) {
+ core.status.event.selection = 0;
+ core.playSound("光标移动");
+ if (core.status.event.id == "action") {
+ core.ui.drawConfirmBox(core.status.event.ui.text);
+ } else {
+ core.ui.drawConfirmBox(
+ core.status.event.ui,
+ core.status.event.data.yes,
+ core.status.event.data.no
+ );
}
+ }
+ return;
}
-}
+ if (px >= core._PX_ / 2 + 10 && px <= core._PX_ / 2 + 70) {
+ if (core.status.event.selection != 1) {
+ core.status.event.selection = 1;
+ core.playSound("光标移动");
+ if (core.status.event.id == "action") {
+ core.ui.drawConfirmBox(core.status.event.ui.text);
+ } else {
+ core.ui.drawConfirmBox(
+ core.status.event.ui,
+ core.status.event.data.yes,
+ core.status.event.data.no
+ );
+ }
+ }
+ return;
+ }
+ }
+};
actions.prototype._clickAction_text = function () {
- // 正在淡入淡出的话不执行
- if (core.status.event.animateUI) return;
+ // 正在淡入淡出的话不执行
+ if (core.status.event.animateUI) return;
- var data = core.clone(core.status.event.data.current);
- if (typeof data == 'string') data = { "type": "text", "text": data };
+ var data = core.clone(core.status.event.data.current);
+ if (typeof data == "string") data = { type: "text", text: data };
- // 打字机效果显示全部文字
- if (core.status.event.interval != null) {
- data.showAll = true;
- core.insertAction(data);
- core.doAction();
- return;
- }
+ // 打字机效果显示全部文字
+ if (core.status.event.interval != null) {
+ data.showAll = true;
+ core.insertAction(data);
+ core.doAction();
+ return;
+ }
- if (!data.code) {
- core.ui._animateUI('hide', null, core.doAction);
- } else {
- // 不清除对话框
- core.doAction();
- }
-}
+ if (!data.code) {
+ core.ui._animateUI("hide", null, core.doAction);
+ } else {
+ // 不清除对话框
+ core.doAction();
+ }
+};
////// 自定义事件时的点击操作 //////
actions.prototype._clickAction = function (x, y, px, py) {
- if (core.status.event.data.type == 'text') {
- return this._clickAction_text();
+ if (core.status.event.data.type == "text") {
+ return this._clickAction_text();
+ }
+
+ if (core.status.event.data.type == "wait") {
+ var timeout =
+ Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
+ core.setFlag("type", 1);
+ core.setFlag("x", x);
+ core.setFlag("y", y);
+ core.setFlag("px", px);
+ core.setFlag("py", py);
+ core.setFlag("timeout", timeout);
+ var executed = core.events.__action_wait_afterGet(
+ core.status.event.data.current
+ );
+ if (executed || !core.status.event.data.current.forceChild) {
+ core.status.route.push(
+ "input:" + (1e8 * timeout + 1000000 + 1000 * px + py)
+ );
+ clearTimeout(core.status.event.interval);
+ delete core.status.event.timeout;
+ core.doAction();
+ }
+ return;
+ }
+ if (core.status.event.data.type == "menu") {
+ // 选项
+ var data = core.status.event.data.current;
+ var choices = data.choices;
+ if (choices.length == 0) return;
+ if (
+ px < core.menu.x ||
+ px > core.menu.w + core.menu.x ||
+ py < core.menu.y ||
+ py > core.menu.y + core.menu.h
+ ) {
+ core.status.route.push("menu:none");
+ core.clearMap(core.menu.canvas);
+ } else if(py - core.menu.y<=34){return}
+ else {
+ core.menu.selection = Math.floor((py - 34 - core.menu.y) / 32);
+ var choice = choices[core.menu.selection];
+ if (
+ choice.need != null &&
+ choice.need != "" &&
+ !core.calValue(choice.need)
+ ) {
+ core.playSound("操作失败");
+ core.drawTip("无法选择此项");
+ return;
+ }
+ core.clearMap(core.menu.canvas);
+ core.status.route.push("menu:" + core.menu.selection);
+ core.insertAction(choice.action);
}
- if (core.status.event.data.type == 'wait') {
- var timeout = Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- core.setFlag('type', 1);
- core.setFlag('x', x);
- core.setFlag('y', y);
- core.setFlag('px', px);
- core.setFlag('py', py);
- core.setFlag('timeout', timeout);
- var executed = core.events.__action_wait_afterGet(core.status.event.data.current);
- if (executed || !core.status.event.data.current.forceChild) {
- core.status.route.push("input:" + (1e8 * timeout + 1000000 + 1000 * px + py));
- clearTimeout(core.status.event.interval);
- delete core.status.event.timeout;
- core.doAction();
- }
- return;
- }
+ core.doAction();
- if (core.status.event.data.type == 'choices') {
- // 选项
- var data = core.status.event.data.current;
- var choices = data.choices;
- if (choices.length == 0) return;
- if (this._out(x)) return;
- var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var choice = choices[y - topIndex];
- if (choice.need != null && choice.need != '' && !core.calValue(choice.need)) {
- core.playSound('操作失败');
- core.drawTip("无法选择此项");
- return;
- }
- clearTimeout(core.status.event.interval);
- var timeout = Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- delete core.status.event.timeout;
- core.setFlag('timeout', timeout);
- // 对全局商店特殊处理
- var index = y - topIndex;
- if (index == choices.length - 1 && core.hasFlag('@temp@shop')) {
- index = -1;
- }
- core.status.route.push("choices:" + (100 * timeout + index));
- core.insertAction(choice.action);
- core.doAction();
- }
+ return;
+ }
+ if (core.status.event.data.type == "choices") {
+ // 选项
+ var data = core.status.event.data.current;
+ var choices = data.choices;
+ if (choices.length == 0) return;
+ if (this._out(x)) return;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var choice = choices[y - topIndex];
+ if (
+ choice.need != null &&
+ choice.need != "" &&
+ !core.calValue(choice.need)
+ ) {
+ core.playSound("操作失败");
+ core.drawTip("无法选择此项");
return;
+ }
+ clearTimeout(core.status.event.interval);
+ var timeout =
+ Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
+ delete core.status.event.timeout;
+ core.setFlag("timeout", timeout);
+ // 对全局商店特殊处理
+ var index = y - topIndex;
+ if (index == choices.length - 1 && core.hasFlag("@temp@shop")) {
+ index = -1;
+ }
+ core.status.route.push("choices:" + (100 * timeout + index));
+ core.insertAction(choice.action);
+ core.doAction();
}
+ return;
+ }
- if (core.status.event.data.type == 'confirm') {
- if ((x == this._HX_ - 2 || x == this._HX_ - 1) && y == this._HY_ + 1) {
- clearTimeout(core.status.event.interval);
- var timeout = Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- delete core.status.event.timeout;
- core.setFlag('timeout', timeout);
- core.status.route.push("choices:" + 100 * timeout);
- core.insertAction(core.status.event.ui.yes);
- core.doAction();
- }
- else if ((x == this._HX_ + 2 || x == this._HX_ + 1) && y == this._HY_ + 1) {
- clearTimeout(core.status.event.interval);
- var timeout = Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- delete core.status.event.timeout;
- core.setFlag('timeout', timeout);
- core.status.route.push("choices:" + (100 * timeout + 1));
- core.insertAction(core.status.event.ui.no);
- core.doAction();
- }
- return;
+ if (core.status.event.data.type == "confirm") {
+ if ((x == this._HX_ - 2 || x == this._HX_ - 1) && y == this._HY_ + 1) {
+ clearTimeout(core.status.event.interval);
+ var timeout =
+ Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
+ delete core.status.event.timeout;
+ core.setFlag("timeout", timeout);
+ core.status.route.push("choices:" + 100 * timeout);
+ core.insertAction(core.status.event.ui.yes);
+ core.doAction();
+ } else if (
+ (x == this._HX_ + 2 || x == this._HX_ + 1) &&
+ y == this._HY_ + 1
+ ) {
+ clearTimeout(core.status.event.interval);
+ var timeout =
+ Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
+ delete core.status.event.timeout;
+ core.setFlag("timeout", timeout);
+ core.status.route.push("choices:" + (100 * timeout + 1));
+ core.insertAction(core.status.event.ui.no);
+ core.doAction();
}
-}
+ return;
+ }
+};
////// 自定义事件时,按下某个键的操作 //////
actions.prototype._keyDownAction = function (keycode) {
- if (core.status.event.data.type == 'choices') {
- this._keyDownChoices(keycode);
- return;
- }
- if (core.status.event.data.type == 'confirm' && (keycode == 37 || keycode == 39)) {
- core.status.event.selection = 1 - core.status.event.selection;
- core.playSound('光标移动');
- core.drawConfirmBox(core.status.event.ui.text);
- return;
- }
-}
+ if (core.status.event.data.type == "choices") {
+ this._keyDownChoices(keycode);
+ return;
+ }
+ if (core.status.event.data.type == "choices") {
+ this._keyDownMenu(keycode);
+ return;
+ }
+ if (
+ core.status.event.data.type == "confirm" &&
+ (keycode == 37 || keycode == 39)
+ ) {
+ core.status.event.selection = 1 - core.status.event.selection;
+ core.playSound("光标移动");
+ core.drawConfirmBox(core.status.event.ui.text);
+ return;
+ }
+};
////// 自定义事件时,放开某个键的操作 //////
actions.prototype._keyUpAction = function (keycode) {
- if (core.status.event.data.type == 'text' && (keycode == 13 || keycode == 32 || keycode == 67)) {
- return this._clickAction_text();
+ if (
+ core.status.event.data.type == "text" &&
+ (keycode == 13 || keycode == 32 || keycode == 67)
+ ) {
+ return this._clickAction_text();
+ }
+ if (core.status.event.data.type == "wait") {
+ var timeout =
+ Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
+ core.setFlag("type", 0);
+ core.setFlag("keycode", keycode);
+ core.setFlag("timeout", timeout);
+ var executed = core.events.__action_wait_afterGet(
+ core.status.event.data.current
+ );
+ if (executed || !core.status.event.data.current.forceChild) {
+ core.status.route.push("input:" + (1e8 * timeout + keycode));
+ clearTimeout(core.status.event.interval);
+ delete core.status.event.timeout;
+ core.doAction();
}
- if (core.status.event.data.type == 'wait') {
- var timeout = Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- core.setFlag('type', 0);
- core.setFlag('keycode', keycode);
- core.setFlag('timeout', timeout);
- var executed = core.events.__action_wait_afterGet(core.status.event.data.current);
- if (executed || !core.status.event.data.current.forceChild) {
- core.status.route.push("input:" + (1e8 * timeout + keycode));
- clearTimeout(core.status.event.interval);
- delete core.status.event.timeout;
- core.doAction();
- }
- return;
+ return;
+ }
+ if (core.status.event.data.type == "menu") {
+ var data = core.status.event.data.current;
+ var choices = data.choices;
+ if (choices.length > 0) {
+ this._selectMenu(choices.length, keycode, this._clickAction);
}
- if (core.status.event.data.type == 'choices') {
- var data = core.status.event.data.current;
- var choices = data.choices;
- if (choices.length > 0) {
- this._selectChoices(choices.length, keycode, this._clickAction);
- }
- return;
+ return;
+ }
+ if (core.status.event.data.type == "choices") {
+ var data = core.status.event.data.current;
+ var choices = data.choices;
+ if (choices.length > 0) {
+ this._selectChoices(choices.length, keycode, this._clickAction);
}
- if (core.status.event.data.type == 'confirm' && (keycode == 13 || keycode == 32 || keycode == 67)) {
- var timeout = Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- delete core.status.event.timeout;
- core.setFlag('timeout', timeout);
- core.status.route.push("choices:" + (100 * timeout + core.status.event.selection));
- if (core.status.event.selection == 0)
- core.insertAction(core.status.event.ui.yes);
- else core.insertAction(core.status.event.ui.no);
- core.doAction();
- return;
- }
-}
+ return;
+ }
+ if (
+ core.status.event.data.type == "confirm" &&
+ (keycode == 13 || keycode == 32 || keycode == 67)
+ ) {
+ var timeout =
+ Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
+ delete core.status.event.timeout;
+ core.setFlag("timeout", timeout);
+ core.status.route.push(
+ "choices:" + (100 * timeout + core.status.event.selection)
+ );
+ if (core.status.event.selection == 0)
+ core.insertAction(core.status.event.ui.yes);
+ else core.insertAction(core.status.event.ui.no);
+ core.doAction();
+ return;
+ }
+};
////// 怪物手册界面的点击操作 //////
actions.prototype._clickBook = function (x, y) {
- var pageinfo = core.ui._drawBook_pageinfo();
- // 上一页
- if ((x == this._HX_ - 2 || x == this._HX_ - 3) && y===core._HEIGHT_-1) {
- core.playSound('光标移动');
- core.ui.drawBook(core.status.event.data - pageinfo.per_page);
- return;
- }
- // 下一页
- if ((x == this._HX_ + 2 || x == this._HX_ + 3) && y===core._HEIGHT_-1) {
- core.playSound('光标移动');
- core.ui.drawBook(core.status.event.data + pageinfo.per_page);
- return;
- }
- // 返回
- if (x >= this.LAST - 2 && y===core._HEIGHT_-1) {
- core.playSound('取消');
- if (core.events.recoverEvents(core.status.event.interval)) {
- return;
- }
- else if (core.status.event.ui != null) {
- core.status.boxAnimateObjs = [];
- core.ui._drawViewMaps(core.status.event.ui);
- }
- else core.ui.closePanel();
- return;
- }
- // 怪物信息
- var data = core.status.event.data;
- if (data != null && y < core._HEIGHT_-1) {
- var per_page = pageinfo.per_page, page = parseInt(data / per_page);
- var u = (core._HEIGHT_ - 1) / per_page;
- for (var i = 0; i < per_page; ++i) {
- if (y >= u * i && y < u * (i + 1)) {
- var index = per_page * page + i;
- core.ui.drawBook(index);
- core.ui._drawBookDetail(index);
- break;
- }
- }
- return;
+ var pageinfo = core.ui._drawBook_pageinfo();
+ // 上一页
+ if ((x == this._HX_ - 2 || x == this._HX_ - 3) && y === core._HEIGHT_ - 1) {
+ core.playSound("光标移动");
+ core.ui.drawBook(core.status.event.data - pageinfo.per_page);
+ return;
+ }
+ // 下一页
+ if ((x == this._HX_ + 2 || x == this._HX_ + 3) && y === core._HEIGHT_ - 1) {
+ core.playSound("光标移动");
+ core.ui.drawBook(core.status.event.data + pageinfo.per_page);
+ return;
+ }
+ // 返回
+ if (x >= this.LAST - 2 && y === core._HEIGHT_ - 1) {
+ core.playSound("取消");
+ if (core.events.recoverEvents(core.status.event.interval)) {
+ return;
+ } else if (core.status.event.ui != null) {
+ core.status.boxAnimateObjs = [];
+ core.ui._drawViewMaps(core.status.event.ui);
+ } else core.ui.closePanel();
+ return;
+ }
+ // 怪物信息
+ var data = core.status.event.data;
+ if (data != null && y < core._HEIGHT_ - 1) {
+ var per_page = pageinfo.per_page,
+ page = parseInt(data / per_page);
+ var u = (core._HEIGHT_ - 1) / per_page;
+ for (var i = 0; i < per_page; ++i) {
+ if (y >= u * i && y < u * (i + 1)) {
+ var index = per_page * page + i;
+ core.ui.drawBook(index);
+ core.ui._drawBookDetail(index);
+ break;
+ }
}
return;
-}
+ }
+ return;
+};
////// 怪物手册界面时,按下某个键的操作 //////
actions.prototype._keyDownBook = function (keycode) {
- var pageinfo = core.ui._drawBook_pageinfo();
- if (keycode == 37) { core.playSound('光标移动'); core.ui.drawBook(core.status.event.data - pageinfo.per_page); }
- if (keycode == 38) { core.playSound('光标移动'); core.ui.drawBook(core.status.event.data - 1); }
- if (keycode == 39) { core.playSound('光标移动'); core.ui.drawBook(core.status.event.data + pageinfo.per_page); }
- if (keycode == 40) { core.playSound('光标移动'); core.ui.drawBook(core.status.event.data + 1); }
- if (keycode == 33) { core.playSound('光标移动'); core.ui.drawBook(core.status.event.data - pageinfo.per_page); }
- if (keycode == 34) { core.playSound('光标移动'); core.ui.drawBook(core.status.event.data + pageinfo.per_page); }
- return;
-}
+ if (core.book.isAnimate) return;
+ if (keycode == 37) {
+ core.book.turnleft();
+ }
+ if (keycode == 38) {
+ core.book.turnleft();
+ }
+ if (keycode == 39) {
+ core.book.turnright();
+ }
+ if (keycode == 40) {
+ core.book.turnright();
+ }
+ if (keycode == 33) {
+ core.book.turnleft();
+ }
+ if (keycode == 34) {
+ core.book.turnright();
+ }
+ return;
+};
////// 怪物手册界面时,放开某个键的操作 //////
actions.prototype._keyUpBook = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.playSound('取消');
- if (core.events.recoverEvents(core.status.event.interval)) {
- return;
- }
- else if (core.status.event.ui != null) {
- core.status.boxAnimateObjs = [];
- core.ui._drawViewMaps(core.status.event.ui);
- }
- else core.ui.closePanel();
- return;
- }
- if (keycode == 13 || keycode == 32 || keycode == 67) {
+ if (core.book.isAnimate) return;
+ if (keycode == 27 || keycode == 88) {
+ core.playSound("取消");
+ core.book.close();
+ if (core.events.recoverEvents(core.status.event.interval)) {
+ return;
+ } else if (core.status.event.ui != null) {
+ core.status.boxAnimateObjs = [];
+ core.ui._drawViewMaps(core.status.event.ui);
+ } else core.ui.closePanel();
+ return;
+ }
+ /*if (keycode == 13 || keycode == 32 || keycode == 67) {
var data = core.status.event.data;
if (data != null) {
core.ui._drawBookDetail(data);
}
return;
- }
-}
+ }*/
+};
////// 怪物手册属性显示界面时的点击操作 //////
actions.prototype._clickBookDetail = function () {
- core.clearMap('data');
- core.playSound('取消');
- core.status.event.id = 'book';
-}
+ core.clearMap("data");
+ core.playSound("取消");
+ core.status.event.id = "book";
+};
////// 楼层传送器界面时的点击操作 //////
actions.prototype._clickFly = function (x, y) {
- if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ + 3) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(-1)); }
- if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ - 1) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(1)); }
- if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ + 4) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(-10)); }
- if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ - 2) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(10)); }
- if (x >= this._HX_ - 1 && x <= this._HX_ + 1 && y===core._HEIGHT_-1) { core.playSound('取消'); core.ui.closePanel(); }
- if (x >= 0 && x <= this._HX_ + 3 && y >= 3 && y <= core._HEIGHT_-1 - 1)
- core.flyTo(core.floorIds[core.status.event.data]);
- return;
-}
+ if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ + 3) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(-1));
+ }
+ if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ - 1) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(1));
+ }
+ if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ + 4) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(-10));
+ }
+ if ((x == core._WIDTH_ - 2 || x == core._WIDTH_ - 3) && y == this._HY_ - 2) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(10));
+ }
+ if (x >= this._HX_ - 1 && x <= this._HX_ + 1 && y === core._HEIGHT_ - 1) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ }
+ if (x >= 0 && x <= this._HX_ + 3 && y >= 3 && y <= core._HEIGHT_ - 1 - 1)
+ core.flyTo(core.floorIds[core.status.event.data]);
+ return;
+};
////// 楼层传送器界面时,按下某个键的操作 //////
actions.prototype._keyDownFly = function (keycode) {
- if (keycode == 37) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(-10)); }
- else if (keycode == 38) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(1)); }
- else if (keycode == 39) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(10)); }
- else if (keycode == 40) { core.playSound('光标移动'); core.ui.drawFly(this._getNextFlyFloor(-1)); }
- return;
-}
+ if (keycode == 37) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(-10));
+ } else if (keycode == 38) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(1));
+ } else if (keycode == 39) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(10));
+ } else if (keycode == 40) {
+ core.playSound("光标移动");
+ core.ui.drawFly(this._getNextFlyFloor(-1));
+ }
+ return;
+};
actions.prototype._getNextFlyFloor = function (delta, index) {
- if (index == null) index = core.status.event.data;
- if (delta == 0) return index;
- var sign = Math.sign(delta);
- delta = Math.abs(delta);
- var ans = index;
- while (true) {
- index += sign;
- if (index < 0 || index >= core.floorIds.length) break;
- var floorId = core.floorIds[index];
- if (core.status.maps[floorId].canFlyTo && core.hasVisitedFloor(floorId)) {
- delta--;
- ans = index;
- }
- if (delta == 0) break;
+ if (index == null) index = core.status.event.data;
+ if (delta == 0) return index;
+ var sign = Math.sign(delta);
+ delta = Math.abs(delta);
+ var ans = index;
+ while (true) {
+ index += sign;
+ if (index < 0 || index >= core.floorIds.length) break;
+ var floorId = core.floorIds[index];
+ if (core.status.maps[floorId].canFlyTo && core.hasVisitedFloor(floorId)) {
+ delta--;
+ ans = index;
}
- return ans;
-}
+ if (delta == 0) break;
+ }
+ return ans;
+};
////// 楼层传送器界面时,放开某个键的操作 //////
actions.prototype._keyUpFly = function (keycode) {
- if (keycode == 71 || keycode == 27 || keycode == 88) {
- core.playSound('取消');
- core.ui.closePanel();
- }
- if (keycode == 13 || keycode == 32 || keycode == 67)
- this._clickFly(this._HX_ - 1, this._HY_ - 1);
- return;
-}
+ if (keycode == 71 || keycode == 27 || keycode == 88) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ }
+ if (keycode == 13 || keycode == 32 || keycode == 67)
+ this._clickFly(this._HX_ - 1, this._HY_ - 1);
+ return;
+};
////// 查看地图界面时的点击操作 //////
actions.prototype._clickViewMaps = function (x, y, px, py) {
- if (core.status.event.data == null) {
- core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));
- return;
- }
- var now = core.floorIds.indexOf(core.status.floorId);
- var index = core.status.event.data.index;
- var cx = core.status.event.data.x, cy = core.status.event.data.y;
- var floorId = core.floorIds[index], mh = core.floors[floorId].height;
- var perpx = core._PX_ / 5, cornerpx = perpx * 3 / 4, perpy = core._PY_ / 5, cornerpy = perpy * 3 / 4;
+ if (core.status.event.data == null) {
+ core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));
+ return;
+ }
+ var now = core.floorIds.indexOf(core.status.floorId);
+ var index = core.status.event.data.index;
+ var cx = core.status.event.data.x,
+ cy = core.status.event.data.y;
+ var floorId = core.floorIds[index],
+ mh = core.floors[floorId].height;
+ var perpx = core._PX_ / 5,
+ cornerpx = (perpx * 3) / 4,
+ perpy = core._PY_ / 5,
+ cornerpy = (perpy * 3) / 4;
- if (px <= cornerpx && py <= cornerpy) {
- core.status.event.data.damage = !core.status.event.data.damage;
- core.playSound('光标移动');
- core.ui._drawViewMaps(index, cx, cy);
- return;
- }
- if (px <= cornerpx && py >= core._PY_ - cornerpy) {
- if (core.markedFloorIds[floorId]) delete core.markedFloorIds[floorId];
- else core.markedFloorIds[floorId] = true;
- core.playSound('光标移动');
- core.ui._drawViewMaps(index, cx, cy);
- return;
- }
- if (px >= core._PX_ - cornerpx && py <= cornerpy) {
- core.status.event.data.all = !core.status.event.data.all;
- core.playSound('光标移动');
- core.ui._drawViewMaps(index, cx, cy);
- return;
- }
+ if (px <= cornerpx && py <= cornerpy) {
+ core.status.event.data.damage = !core.status.event.data.damage;
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(index, cx, cy);
+ return;
+ }
+ if (px <= cornerpx && py >= core._PY_ - cornerpy) {
+ if (core.markedFloorIds[floorId]) delete core.markedFloorIds[floorId];
+ else core.markedFloorIds[floorId] = true;
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(index, cx, cy);
+ return;
+ }
+ if (px >= core._PX_ - cornerpx && py <= cornerpy) {
+ core.status.event.data.all = !core.status.event.data.all;
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(index, cx, cy);
+ return;
+ }
- if (px >= perpx && px <= core._PX_ - perpx && py <= perpy && (!core.status.event.data.all && mh > core._HEIGHT_)) {
- core.playSound('光标移动');
- core.ui._drawViewMaps(index, cx, cy - 1);
- return;
- }
- if (px >= perpx && px <= core._PX_ - perpx && py >= core._PY_ - perpy && (!core.status.event.data.all && mh > core._HEIGHT_)) {
- core.playSound('光标移动');
- core.ui._drawViewMaps(index, cx, cy + 1);
- return;
- }
- if (px <= perpx && py >= perpy && py <= core._PY_ - perpy) {
- core.playSound('光标移动');
- core.ui._drawViewMaps(index, cx - 1, cy);
- return;
- }
- if (px >= core._PX_ - perpx && py >= perpy && py <= core._PY_ - perpy) {
- core.playSound('光标移动');
- core.ui._drawViewMaps(index, cx + 1, cy);
- return;
- }
+ if (
+ px >= perpx &&
+ px <= core._PX_ - perpx &&
+ py <= perpy &&
+ !core.status.event.data.all &&
+ mh > core._HEIGHT_
+ ) {
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(index, cx, cy - 1);
+ return;
+ }
+ if (
+ px >= perpx &&
+ px <= core._PX_ - perpx &&
+ py >= core._PY_ - perpy &&
+ !core.status.event.data.all &&
+ mh > core._HEIGHT_
+ ) {
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(index, cx, cy + 1);
+ return;
+ }
+ if (px <= perpx && py >= perpy && py <= core._PY_ - perpy) {
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(index, cx - 1, cy);
+ return;
+ }
+ if (px >= core._PX_ - perpx && py >= perpy && py <= core._PY_ - perpy) {
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(index, cx + 1, cy);
+ return;
+ }
- if (py <= 2 * perpy && (mh == core._HEIGHT_ || (px >= perpx && px <= core._PX_ - perpx))) {
- core.playSound('光标移动');
- index++;
- while (index < core.floorIds.length && index != now && core.status.maps[core.floorIds[index]].cannotViewMap)
- index++;
- if (index < core.floorIds.length)
- core.ui._drawViewMaps(index);
- return;
- }
- if (py >= 3 * perpy && (mh == core._HEIGHT_ || (px >= perpx && px <= core._PX_ - perpx))) {
- core.playSound('光标移动');
- index--;
- while (index >= 0 && index != now && core.status.maps[core.floorIds[index]].cannotViewMap)
- index--;
- if (index >= 0)
- core.ui._drawViewMaps(index);
- return;
- }
- if (px >= perpx && px <= core._PX_ - perpx && py >= perpy * 2 && py <= perpy * 3) {
- core.clearMap('data');
- core.playSound('取消');
- core.ui.closePanel();
- return;
- }
-}
+ if (
+ py <= 2 * perpy &&
+ (mh == core._HEIGHT_ || (px >= perpx && px <= core._PX_ - perpx))
+ ) {
+ core.playSound("光标移动");
+ index++;
+ while (
+ index < core.floorIds.length &&
+ index != now &&
+ core.status.maps[core.floorIds[index]].cannotViewMap
+ )
+ index++;
+ if (index < core.floorIds.length) core.ui._drawViewMaps(index);
+ return;
+ }
+ if (
+ py >= 3 * perpy &&
+ (mh == core._HEIGHT_ || (px >= perpx && px <= core._PX_ - perpx))
+ ) {
+ core.playSound("光标移动");
+ index--;
+ while (
+ index >= 0 &&
+ index != now &&
+ core.status.maps[core.floorIds[index]].cannotViewMap
+ )
+ index--;
+ if (index >= 0) core.ui._drawViewMaps(index);
+ return;
+ }
+ if (
+ px >= perpx &&
+ px <= core._PX_ - perpx &&
+ py >= perpy * 2 &&
+ py <= perpy * 3
+ ) {
+ core.clearMap("data");
+ core.playSound("取消");
+ core.ui.closePanel();
+ return;
+ }
+};
////// 查看地图界面时,按下某个键的操作 //////
actions.prototype._keyDownViewMaps = function (keycode) {
- if (core.status.event.data == null) return;
+ if (core.status.event.data == null) return;
- var floorId = core.floorIds[core.status.event.data.index], mh = core.floors[floorId].height;
+ var floorId = core.floorIds[core.status.event.data.index],
+ mh = core.floors[floorId].height;
- if (keycode == 38 || keycode == 33) this._clickViewMaps(this._HX_ , this._HY_ - 3 , core._PX_ / 2, core._PY_ / 5 * 1.5);
- if (keycode == 40 || keycode == 34) this._clickViewMaps(this._HX_ , this._HY_ + 3 , core._PX_ / 2, core._PY_ / 5 * 3.5);
- if (keycode == 87 && mh > core._HEIGHT_) this._clickViewMaps(this._HX_ , 0 , core._PX_ / 2, 1 );
- if (keycode == 65) this._clickViewMaps(0 , this._HY_ , 1 , core._PY_ / 2 );
- if (keycode == 83 && mh > core._HEIGHT_) this._clickViewMaps(this._HX_ , core._HEIGHT_ - 1, core._PX_ / 2, core._PY_ - 1 );
- if (keycode == 68) this._clickViewMaps(core._WIDTH_ - 1, this._HY_ , core._PX_ , core._PY_ / 2 - 1 );
- return;
-}
+ if (keycode == 38 || keycode == 33)
+ this._clickViewMaps(
+ this._HX_,
+ this._HY_ - 3,
+ core._PX_ / 2,
+ (core._PY_ / 5) * 1.5
+ );
+ if (keycode == 40 || keycode == 34)
+ this._clickViewMaps(
+ this._HX_,
+ this._HY_ + 3,
+ core._PX_ / 2,
+ (core._PY_ / 5) * 3.5
+ );
+ if (keycode == 87 && mh > core._HEIGHT_)
+ this._clickViewMaps(this._HX_, 0, core._PX_ / 2, 1);
+ if (keycode == 65) this._clickViewMaps(0, this._HY_, 1, core._PY_ / 2);
+ if (keycode == 83 && mh > core._HEIGHT_)
+ this._clickViewMaps(
+ this._HX_,
+ core._HEIGHT_ - 1,
+ core._PX_ / 2,
+ core._PY_ - 1
+ );
+ if (keycode == 68)
+ this._clickViewMaps(
+ core._WIDTH_ - 1,
+ this._HY_,
+ core._PX_,
+ core._PY_ / 2 - 1
+ );
+ return;
+};
////// 查看地图界面时,放开某个键的操作 //////
actions.prototype._keyUpViewMaps = function (keycode) {
- if (core.status.event.data == null) {
- core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));
- return;
- }
- var floorId = core.floorIds[core.status.event.data.index];
+ if (core.status.event.data == null) {
+ core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));
+ return;
+ }
+ var floorId = core.floorIds[core.status.event.data.index];
- if (keycode == 27 || keycode == 13 || keycode == 32 || (!core.isReplaying() && keycode == 67)) {
- core.clearMap('data');
- core.playSound('取消');
- core.ui.closePanel();
- return;
- }
- if (keycode == 86) {
- core.status.event.data.damage = !core.status.event.data.damage;
- core.playSound('光标移动');
- core.ui._drawViewMaps(core.status.event.data);
- return;
- }
- if (keycode == 90) {
- core.status.event.data.all = !core.status.event.data.all;
- core.playSound('光标移动');
- core.ui._drawViewMaps(core.status.event.data);
- return;
- }
- if (keycode == 66) {
- if (core.markedFloorIds[floorId]) delete core.markedFloorIds[floorId];
- else core.markedFloorIds[floorId] = true;
- core.playSound('光标移动');
- core.ui._drawViewMaps(core.status.event.data);
- return;
- }
- if (keycode == 88 || (core.isReplaying() && keycode == 67)) {
- if (core.isReplaying()) {
- core.control._replay_book();
- } else {
- core.openBook(false);
- }
- return;
- }
- if (keycode == 71 && !core.isReplaying()) {
- core.useFly(false);
- return;
+ if (
+ keycode == 27 ||
+ keycode == 13 ||
+ keycode == 32 ||
+ (!core.isReplaying() && keycode == 67)
+ ) {
+ core.clearMap("data");
+ core.playSound("取消");
+ core.ui.closePanel();
+ return;
+ }
+ if (keycode == 86) {
+ core.status.event.data.damage = !core.status.event.data.damage;
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(core.status.event.data);
+ return;
+ }
+ if (keycode == 90) {
+ core.status.event.data.all = !core.status.event.data.all;
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(core.status.event.data);
+ return;
+ }
+ if (keycode == 66) {
+ if (core.markedFloorIds[floorId]) delete core.markedFloorIds[floorId];
+ else core.markedFloorIds[floorId] = true;
+ core.playSound("光标移动");
+ core.ui._drawViewMaps(core.status.event.data);
+ return;
+ }
+ if (keycode == 88 || (core.isReplaying() && keycode == 67)) {
+ if (core.isReplaying()) {
+ core.control._replay_book();
+ } else {
+ core.openBook(false);
}
return;
-}
+ }
+ if (keycode == 71 && !core.isReplaying()) {
+ core.useFly(false);
+ return;
+ }
+ return;
+};
////// 快捷商店界面时的点击操作 //////
actions.prototype._clickQuickShop = function (x, y) {
- var shopIds = core.listShopIds();
- if (this._out(x)) return;
- var topIndex = this._HY_ - parseInt(shopIds.length / 2) + (core.status.event.ui.offset || 0);
- if (y >= topIndex && y < topIndex + shopIds.length) {
- var shopId = shopIds[y - topIndex];
- if (!core.canOpenShop(shopId)) {
- core.playSound('操作失败');
- core.drawTip('当前项尚未开启');
- return;
- }
- var message = core.canUseQuickShop(shopId);
- if (message == null) {
- // core.ui.closePanel();
- core.openShop(shopIds[y - topIndex], false);
- } else {
- core.playSound('操作失败');
- core.drawTip(message);
- }
- }
- // 离开
- else if (y == topIndex + shopIds.length) {
- core.playSound('取消');
- core.ui.closePanel();
- }
-}
+ var shopIds = core.listShopIds();
+ if (this._out(x)) return;
+ var topIndex =
+ this._HY_ -
+ parseInt(shopIds.length / 2) +
+ (core.status.event.ui.offset || 0);
+ if (y >= topIndex && y < topIndex + shopIds.length) {
+ var shopId = shopIds[y - topIndex];
+ if (!core.canOpenShop(shopId)) {
+ core.playSound("操作失败");
+ core.drawTip("当前项尚未开启");
+ return;
+ }
+ var message = core.canUseQuickShop(shopId);
+ if (message == null) {
+ // core.ui.closePanel();
+ core.openShop(shopIds[y - topIndex], false);
+ } else {
+ core.playSound("操作失败");
+ core.drawTip(message);
+ }
+ }
+ // 离开
+ else if (y == topIndex + shopIds.length) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ }
+};
////// 快捷商店界面时,放开某个键的操作 //////
actions.prototype._keyUpQuickShop = function (keycode) {
- if (keycode == 27 || keycode == 75 || keycode == 88 || keycode == 86) {
- core.playSound('取消');
- core.ui.closePanel();
- return;
- }
- this._selectChoices(core.listShopIds().length + 1, keycode, this._clickQuickShop);
+ if (keycode == 27 || keycode == 75 || keycode == 88 || keycode == 86) {
+ core.playSound("取消");
+ core.ui.closePanel();
return;
-}
+ }
+ this._selectChoices(
+ core.listShopIds().length + 1,
+ keycode,
+ this._clickQuickShop
+ );
+ return;
+};
////// 工具栏界面时的点击操作 //////
actions.prototype._clickToolbox = function (x, y) {
- var tools = core.getToolboxItems('tools'),
- constants = core.getToolboxItems('constants');
+ var tools = core.getToolboxItems("tools"),
+ constants = core.getToolboxItems("constants");
- // 装备栏
- if (x >= this.LAST - 2 && y == 0) {
- core.ui.closePanel();
- if (core.isReplaying())
- core.control._replay_equipbox();
- else
- core.openEquipbox();
- return;
- }
- if (x >= this.LAST - 2 && y===core._HEIGHT_-1) {
- core.playSound('取消');
- core.ui.closePanel();
- var last = core.status.route[core.status.route.length - 1] || '';
- if (last.startsWith('equip:') || last.startsWith('unEquip:')) {
- core.status.route.push('no');
- }
- core.checkAutoEvents();
- return;
+ // 装备栏
+ if (x >= this.LAST - 2 && y == 0) {
+ core.ui.closePanel();
+ if (core.isReplaying()) core.control._replay_equipbox();
+ else core.openEquipbox();
+ return;
+ }
+ if (x >= this.LAST - 2 && y === core._HEIGHT_ - 1) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ var last = core.status.route[core.status.route.length - 1] || "";
+ if (last.startsWith("equip:") || last.startsWith("unEquip:")) {
+ core.status.route.push("no");
}
+ core.checkAutoEvents();
+ return;
+ }
- var toolsPage = core.status.event.data.toolsPage;
- var constantsPage = core.status.event.data.constantsPage;
- // 上一页
- if (x == this._HX_ - 2 || x == this._HX_ - 3) {
- if (y===core._HEIGHT_-1 - 5 && toolsPage > 1) {
- core.status.event.data.toolsPage--;
- core.playSound('光标移动');
- core.ui._drawToolbox(core.status.event.selection);
- }
- if (y===core._HEIGHT_-1 && constantsPage > 1) {
- core.status.event.data.constantsPage--;
- core.playSound('光标移动');
- core.ui._drawToolbox(core.status.event.selection);
- }
+ var toolsPage = core.status.event.data.toolsPage;
+ var constantsPage = core.status.event.data.constantsPage;
+ // 上一页
+ if (x == this._HX_ - 2 || x == this._HX_ - 3) {
+ if (y === core._HEIGHT_ - 1 - 5 && toolsPage > 1) {
+ core.status.event.data.toolsPage--;
+ core.playSound("光标移动");
+ core.ui._drawToolbox(core.status.event.selection);
}
- // 下一页
- if (x == this._HX_ + 2 || x == this._HX_ + 3) {
- if (y===core._HEIGHT_-1 - 5 && toolsPage < Math.ceil(tools.length / this.LAST)) {
- core.status.event.data.toolsPage++;
- core.playSound('光标移动');
- core.ui._drawToolbox(core.status.event.selection);
- }
- if (y===core._HEIGHT_-1 && constantsPage < Math.ceil(constants.length / this.LAST)) {
- core.status.event.data.constantsPage++;
- core.playSound('光标移动');
- core.ui._drawToolbox(core.status.event.selection);
- }
+ if (y === core._HEIGHT_ - 1 && constantsPage > 1) {
+ core.status.event.data.constantsPage--;
+ core.playSound("光标移动");
+ core.ui._drawToolbox(core.status.event.selection);
}
+ }
+ // 下一页
+ if (x == this._HX_ + 2 || x == this._HX_ + 3) {
+ if (
+ y === core._HEIGHT_ - 1 - 5 &&
+ toolsPage < Math.ceil(tools.length / this.LAST)
+ ) {
+ core.status.event.data.toolsPage++;
+ core.playSound("光标移动");
+ core.ui._drawToolbox(core.status.event.selection);
+ }
+ if (
+ y === core._HEIGHT_ - 1 &&
+ constantsPage < Math.ceil(constants.length / this.LAST)
+ ) {
+ core.status.event.data.constantsPage++;
+ core.playSound("光标移动");
+ core.ui._drawToolbox(core.status.event.selection);
+ }
+ }
- var index = parseInt(x / 2);
- if (y===core._HEIGHT_-1 - 8) index += 0;
- else if (y===core._HEIGHT_-1 - 6) index += this._HX_;
- else if (y===core._HEIGHT_-1 - 3) index += this.LAST;
- else if (y===core._HEIGHT_-1 - 1) index += this.LAST + this._HX_;
- else index = -1;
- if (index >= 0)
- this._clickToolboxIndex(index);
-}
+ var index = parseInt(x / 2);
+ if (y === core._HEIGHT_ - 1 - 8) index += 0;
+ else if (y === core._HEIGHT_ - 1 - 6) index += this._HX_;
+ else if (y === core._HEIGHT_ - 1 - 3) index += this.LAST;
+ else if (y === core._HEIGHT_ - 1 - 1) index += this.LAST + this._HX_;
+ else index = -1;
+ if (index >= 0) this._clickToolboxIndex(index);
+};
////// 选择工具栏界面中某个Index后的操作 //////
actions.prototype._clickToolboxIndex = function (index) {
- var tools = core.getToolboxItems('tools'),
- constants = core.getToolboxItems('constants');
+ var tools = core.getToolboxItems("tools"),
+ constants = core.getToolboxItems("constants");
- var items = null;
- var select;
- if (index < this.LAST) {
- select = index + this.LAST * (core.status.event.data.toolsPage - 1);
- items = tools;
- }
- else {
- select = index % this.LAST + this.LAST * (core.status.event.data.constantsPage - 1);
- items = constants;
- }
- if (items == null) return;
- if (select >= items.length) return;
- var itemId = items[select];
- if (itemId == core.status.event.data.selectId) {
- if (core.isReplaying()) return;
- core.events.tryUseItem(itemId);
- }
- else {
- core.playSound('光标移动');
- core.ui._drawToolbox(index);
- }
-}
+ var items = null;
+ var select;
+ if (index < this.LAST) {
+ select = index + this.LAST * (core.status.event.data.toolsPage - 1);
+ items = tools;
+ } else {
+ select =
+ (index % this.LAST) +
+ this.LAST * (core.status.event.data.constantsPage - 1);
+ items = constants;
+ }
+ if (items == null) return;
+ if (select >= items.length) return;
+ var itemId = items[select];
+ if (itemId == core.status.event.data.selectId) {
+ if (core.isReplaying()) return;
+ core.events.tryUseItem(itemId);
+ } else {
+ core.playSound("光标移动");
+ core.ui._drawToolbox(index);
+ }
+};
////// 工具栏界面时,按下某个键的操作 //////
actions.prototype._keyDownToolbox = function (keycode) {
- if (core.status.event.data == null) return;
+ if (core.status.event.data == null) return;
- var last_index = this.LAST - 1;
+ var last_index = this.LAST - 1;
- var tools = core.getToolboxItems('tools'),
- constants = core.getToolboxItems('constants');
- var index = core.status.event.selection;
- var toolsPage = core.status.event.data.toolsPage;
- var constantsPage = core.status.event.data.constantsPage;
- var toolsTotalPage = Math.ceil(tools.length / this.LAST);
- var constantsTotalPage = Math.ceil(constants.length / this.LAST);
- var toolsLastIndex = toolsPage < toolsTotalPage ? last_index : (tools.length + last_index) % this.LAST;
- var constantsLastIndex = this.LAST + (constantsPage < constantsTotalPage ? last_index : (constants.length + last_index) % this.LAST);
+ var tools = core.getToolboxItems("tools"),
+ constants = core.getToolboxItems("constants");
+ var index = core.status.event.selection;
+ var toolsPage = core.status.event.data.toolsPage;
+ var constantsPage = core.status.event.data.constantsPage;
+ var toolsTotalPage = Math.ceil(tools.length / this.LAST);
+ var constantsTotalPage = Math.ceil(constants.length / this.LAST);
+ var toolsLastIndex =
+ toolsPage < toolsTotalPage
+ ? last_index
+ : (tools.length + last_index) % this.LAST;
+ var constantsLastIndex =
+ this.LAST +
+ (constantsPage < constantsTotalPage
+ ? last_index
+ : (constants.length + last_index) % this.LAST);
- if (keycode == 37) { // left
- if (index == 0) { // 处理向前翻页
- if (toolsPage > 1) {
- core.status.event.data.toolsPage--;
- index = last_index;
- }
- else return; // 第一页不向前翻
- }
- else if (index == this.LAST) {
- if (constantsPage == 1) {
- if (toolsTotalPage == 0) return;
- core.status.event.data.toolsPage = toolsTotalPage;
- index = (tools.length + last_index) % this.LAST;
- }
- else {
- core.status.event.data.constantsPage--;
- index = 2 * this.LAST - 1;
- }
- }
- else index -= 1;
- this._clickToolboxIndex(index);
- return;
+ if (keycode == 37) {
+ // left
+ if (index == 0) {
+ // 处理向前翻页
+ if (toolsPage > 1) {
+ core.status.event.data.toolsPage--;
+ index = last_index;
+ } else return; // 第一页不向前翻
+ } else if (index == this.LAST) {
+ if (constantsPage == 1) {
+ if (toolsTotalPage == 0) return;
+ core.status.event.data.toolsPage = toolsTotalPage;
+ index = (tools.length + last_index) % this.LAST;
+ } else {
+ core.status.event.data.constantsPage--;
+ index = 2 * this.LAST - 1;
+ }
+ } else index -= 1;
+ this._clickToolboxIndex(index);
+ return;
+ }
+ if (keycode == 38) {
+ // up
+ if (index >= this.LAST && index < this.LAST + this._HX_) {
+ // 进入tools
+ if (toolsTotalPage == 0) return;
+ if (toolsLastIndex >= this._HX_)
+ index = Math.min(toolsLastIndex, index - this._HX_);
+ else index = Math.min(toolsLastIndex, index - this.LAST);
+ } else if (index < this._HX_) return; // 第一行没有向上
+ else index -= this._HX_;
+ this._clickToolboxIndex(index);
+ return;
+ }
+ if (keycode == 39) {
+ // right
+ if (toolsPage < toolsTotalPage && index == last_index) {
+ core.status.event.data.toolsPage++;
+ index = 0;
+ } else if (
+ constantsPage < constantsTotalPage &&
+ index == 2 * this.LAST - 1
+ ) {
+ core.status.event.data.constantsPage++;
+ index = this.LAST;
+ } else if (index == toolsLastIndex) {
+ if (constantsTotalPage == 0) return;
+ core.status.event.data.constantsPage = 1;
+ index = this.LAST;
+ } else if (index == constantsLastIndex)
+ // 一个物品无操作
+ return;
+ else index++;
+ this._clickToolboxIndex(index);
+ return;
+ }
+ if (keycode == 40) {
+ // down
+ var nextIndex = null;
+ if (index < this._HX_) {
+ if (toolsLastIndex >= this._HX_)
+ nextIndex = Math.min(toolsLastIndex, index + this._HX_);
+ else index += this._HX_;
}
- if (keycode == 38) { // up
- if (index >= this.LAST && index < this.LAST + this._HX_) { // 进入tools
- if (toolsTotalPage == 0) return;
- if (toolsLastIndex >= this._HX_) index = Math.min(toolsLastIndex, index - this._HX_);
- else index = Math.min(toolsLastIndex, index - this.LAST);
- }
- else if (index < this._HX_) return; // 第一行没有向上
- else index -= this._HX_;
- this._clickToolboxIndex(index);
- return;
+ if (nextIndex == null && index < this.LAST) {
+ if (constantsTotalPage == 0) return;
+ nextIndex = Math.min(index + this._HX_, constantsLastIndex);
}
- if (keycode == 39) { // right
- if (toolsPage < toolsTotalPage && index == last_index) {
- core.status.event.data.toolsPage++;
- index = 0;
- }
- else if (constantsPage < constantsTotalPage && index == 2 * this.LAST - 1) {
- core.status.event.data.constantsPage++;
- index = this.LAST;
- }
- else if (index == toolsLastIndex) {
- if (constantsTotalPage == 0) return;
- core.status.event.data.constantsPage = 1;
- index = this.LAST;
- }
- else if (index == constantsLastIndex) // 一个物品无操作
- return;
- else index++;
- this._clickToolboxIndex(index);
- return;
+ if (nextIndex == null && index < this.LAST + this._HX_) {
+ if (constantsLastIndex >= this.LAST + this._HX_)
+ nextIndex = Math.min(constantsLastIndex, index + this._HX_);
}
- if (keycode == 40) { // down
- var nextIndex = null;
- if (index < this._HX_) {
- if (toolsLastIndex >= this._HX_) nextIndex = Math.min(toolsLastIndex, index + this._HX_);
- else index += this._HX_;
- }
- if (nextIndex == null && index < this.LAST) {
- if (constantsTotalPage == 0) return;
- nextIndex = Math.min(index + this._HX_, constantsLastIndex);
- }
- if (nextIndex == null && index < this.LAST + this._HX_) {
- if (constantsLastIndex >= this.LAST + this._HX_)
- nextIndex = Math.min(constantsLastIndex, index + this._HX_);
- }
- if (nextIndex != null) {
- this._clickToolboxIndex(nextIndex);
- }
- return;
+ if (nextIndex != null) {
+ this._clickToolboxIndex(nextIndex);
}
-}
+ return;
+ }
+};
////// 工具栏界面时,放开某个键的操作 //////
actions.prototype._keyUpToolbox = function (keycode) {
- if (keycode == 81) {
- core.playSound('确定');
- core.ui.closePanel();
- if (core.isReplaying())
- core.control._replay_equipbox();
- else
- core.openEquipbox();
- return;
+ if (keycode == 81) {
+ core.playSound("确定");
+ core.ui.closePanel();
+ if (core.isReplaying()) core.control._replay_equipbox();
+ else core.openEquipbox();
+ return;
+ }
+ if (keycode == 84 || keycode == 27 || keycode == 88) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ var last = core.status.route[core.status.route.length - 1] || "";
+ if (last.startsWith("equip:") || last.startsWith("unEquip:")) {
+ core.status.route.push("no");
}
- if (keycode == 84 || keycode == 27 || keycode == 88) {
- core.playSound('取消');
- core.ui.closePanel();
- var last = core.status.route[core.status.route.length - 1] || '';
- if (last.startsWith('equip:') || last.startsWith('unEquip:')) {
- core.status.route.push('no');
- }
- core.checkAutoEvents();
- return;
- }
- if (core.status.event.data == null) return;
+ core.checkAutoEvents();
+ return;
+ }
+ if (core.status.event.data == null) return;
- if (keycode == 13 || keycode == 32 || keycode == 67) {
- this._clickToolboxIndex(core.status.event.selection);
- return;
- }
-}
+ if (keycode == 13 || keycode == 32 || keycode == 67) {
+ this._clickToolboxIndex(core.status.event.selection);
+ return;
+ }
+};
////// 装备栏界面时的点击操作 //////
actions.prototype._clickEquipbox = function (x, y, px, py) {
- if (x >= this.LAST - 2 && y == 0) {
- core.playSound('确定');
- core.ui.closePanel();
- if (core.isReplaying())
- core.control._replay_toolbox();
- else
- core.openToolbox();
- return;
+ if (x >= this.LAST - 2 && y == 0) {
+ core.playSound("确定");
+ core.ui.closePanel();
+ if (core.isReplaying()) core.control._replay_toolbox();
+ else core.openToolbox();
+ return;
+ }
+ if (x >= this.LAST - 2 && y === core._HEIGHT_ - 1) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ var last = core.status.route[core.status.route.length - 1] || "";
+ if (last.startsWith("equip:") || last.startsWith("unEquip:")) {
+ core.status.route.push("no");
}
- if (x >= this.LAST - 2 && y===core._HEIGHT_-1) {
- core.playSound('取消');
- core.ui.closePanel();
- var last = core.status.route[core.status.route.length - 1] || '';
- if (last.startsWith('equip:') || last.startsWith('unEquip:')) {
- core.status.route.push('no');
- }
- core.checkAutoEvents();
- return;
+ core.checkAutoEvents();
+ return;
+ }
+ if ((x == this._HX_ - 2 || x == this._HX_ - 3) && y === core._HEIGHT_ - 1) {
+ if (core.status.event.data.page > 1) {
+ core.status.event.data.page--;
+ core.playSound("光标移动");
+ core.ui._drawEquipbox(core.status.event.selection);
}
- if ((x == this._HX_ - 2 || x == this._HX_ - 3) && y===core._HEIGHT_-1) {
- if (core.status.event.data.page > 1) {
- core.status.event.data.page--;
- core.playSound('光标移动');
- core.ui._drawEquipbox(core.status.event.selection);
- }
- return;
+ return;
+ }
+ if ((x == this._HX_ + 2 || x == this._HX_ + 3) && y === core._HEIGHT_ - 1) {
+ var lastPage = Math.ceil(core.getToolboxItems("equips").length / this.LAST);
+ if (core.status.event.data.page < lastPage) {
+ core.status.event.data.page++;
+ core.playSound("光标移动");
+ core.ui._drawEquipbox(core.status.event.selection);
}
- if ((x == this._HX_ + 2 || x == this._HX_ + 3) && y===core._HEIGHT_-1) {
- var lastPage = Math.ceil(core.getToolboxItems('equips').length / this.LAST);
- if (core.status.event.data.page < lastPage) {
- core.status.event.data.page++;
- core.playSound('光标移动');
- core.ui._drawEquipbox(core.status.event.selection);
- }
- return;
- }
- var per_page = this._HX_ - 3, v = core._WIDTH_ / per_page;
- if (y === core._HEIGHT_ - 9) {
- for (var i = 0; i < per_page; ++i) if (x >= i * v && x <= (i + 1) * v) return this._clickEquipboxIndex(i);
- } else if (y === core._HEIGHT_ - 7) {
- for (var i = 0; i < per_page; ++i) if (x >= i * v && x <= (i + 1) * v) return this._clickEquipboxIndex(per_page + i);
- } else if (Math.abs(core._HEIGHT_ - 5 - py / 32) < 0.5) {
- for (var i = 0; i < per_page; ++i) if (x >= i * v && x <= (i + 1) * v) return this._clickEquipboxIndex(2 * per_page + i);
- } else if (y === core._HEIGHT_ - 4) this._clickEquipboxIndex(this.LAST + parseInt(x / 2))
- else if (y === core._HEIGHT_ - 2) this._clickEquipboxIndex(this.LAST + this._HX_ + parseInt(x / 2));
-}
+ return;
+ }
+ var per_page = this._HX_ - 3,
+ v = core._WIDTH_ / per_page;
+ if (y === core._HEIGHT_ - 9) {
+ for (var i = 0; i < per_page; ++i)
+ if (x >= i * v && x <= (i + 1) * v) return this._clickEquipboxIndex(i);
+ } else if (y === core._HEIGHT_ - 7) {
+ for (var i = 0; i < per_page; ++i)
+ if (x >= i * v && x <= (i + 1) * v)
+ return this._clickEquipboxIndex(per_page + i);
+ } else if (Math.abs(core._HEIGHT_ - 5 - py / 32) < 0.5) {
+ for (var i = 0; i < per_page; ++i)
+ if (x >= i * v && x <= (i + 1) * v)
+ return this._clickEquipboxIndex(2 * per_page + i);
+ } else if (y === core._HEIGHT_ - 4)
+ this._clickEquipboxIndex(this.LAST + parseInt(x / 2));
+ else if (y === core._HEIGHT_ - 2)
+ this._clickEquipboxIndex(this.LAST + this._HX_ + parseInt(x / 2));
+};
////// 选择装备栏界面中某个Index后的操作 //////
actions.prototype._clickEquipboxIndex = function (index) {
- if (index < this.LAST) {
- if (index >= core.status.globalAttribute.equipName.length) return;
- if (index == core.status.event.selection && core.status.hero.equipment[index]) {
- if (core.isReplaying()) return;
- core.unloadEquip(index);
- core.status.route.push("unEquip:" + index);
- } else core.playSound('光标移动');
- }
- else {
- var equips = core.getToolboxItems('equips');
- if (index == core.status.event.selection) {
- if (core.isReplaying()) return;
- var equipId = equips[index - this.LAST + (core.status.event.data.page - 1) * this.LAST];
- core.loadEquip(equipId);
- core.status.route.push("equip:" + equipId);
- } else core.playSound('光标移动');
- }
- core.ui._drawEquipbox(index);
-}
+ if (index < this.LAST) {
+ if (index >= core.status.globalAttribute.equipName.length) return;
+ if (
+ index == core.status.event.selection &&
+ core.status.hero.equipment[index]
+ ) {
+ if (core.isReplaying()) return;
+ core.unloadEquip(index);
+ core.status.route.push("unEquip:" + index);
+ } else core.playSound("光标移动");
+ } else {
+ var equips = core.getToolboxItems("equips");
+ if (index == core.status.event.selection) {
+ if (core.isReplaying()) return;
+ var equipId =
+ equips[
+ index - this.LAST + (core.status.event.data.page - 1) * this.LAST
+ ];
+ core.loadEquip(equipId);
+ core.status.route.push("equip:" + equipId);
+ } else core.playSound("光标移动");
+ }
+ core.ui._drawEquipbox(index);
+};
////// 装备栏界面时,按下某个键的操作 //////
actions.prototype._keyDownEquipbox = function (keycode) {
- if (core.status.event.data == null) return;
+ if (core.status.event.data == null) return;
- var last_index = this.LAST - 1;
- var per_line = this._HX_ - 3;
- var equipCapacity = core.status.globalAttribute.equipName.length;
- var ownEquipment = core.getToolboxItems('equips');
- var index = core.status.event.selection;
- var page = core.status.event.data.page;
- var totalPage = Math.ceil(ownEquipment.length / this.LAST);
- var totalLastIndex = this.LAST + (page < totalPage ? last_index : (ownEquipment.length + last_index) % this.LAST);
+ var last_index = this.LAST - 1;
+ var per_line = this._HX_ - 3;
+ var equipCapacity = core.status.globalAttribute.equipName.length;
+ var ownEquipment = core.getToolboxItems("equips");
+ var index = core.status.event.selection;
+ var page = core.status.event.data.page;
+ var totalPage = Math.ceil(ownEquipment.length / this.LAST);
+ var totalLastIndex =
+ this.LAST +
+ (page < totalPage
+ ? last_index
+ : (ownEquipment.length + last_index) % this.LAST);
- if (keycode == 37) { // left
- if (index == 0) return;
- if (index == this.LAST) {
- if (page > 1) {
- core.status.event.data.page--;
- core.playSound('光标移动');
- index = this.LAST + last_index;
- }
- else if (page == 1)
- index = equipCapacity - 1;
- else return;
- }
- else index -= 1;
- this._clickEquipboxIndex(index);
- return;
- }
- if (keycode == 38) { // up
- if (index < per_line) return;
- else if (index < 2 * per_line) index -= per_line;
- else if (index < this.LAST + this._HX_) {
- index = parseInt((index - this.LAST) / 2);
- if (equipCapacity > per_line) index = Math.min(equipCapacity - 1, index + per_line);
- else index = Math.min(equipCapacity - 1, index);
- }
- else index -= this._HX_;
- this._clickEquipboxIndex(index);
- return;
- }
- if (keycode == 39) { // right
- if (page < totalPage && index == this.LAST + last_index) {
- core.status.event.data.page++;
- core.playSound('光标移动');
- index = this.LAST;
- }
- else if (index == equipCapacity - 1) {
- if (totalPage == 0) return;
- index = this.LAST;
- }
- else if (index == totalLastIndex)
- return;
- else index++;
- this._clickEquipboxIndex(index);
- return;
- }
- if (keycode == 40) { // down
- if (index < per_line) {
- if (equipCapacity > per_line) index = Math.min(index + per_line, equipCapacity - 1);
- else {
- if (totalPage == 0) return;
- index = Math.min(2 * index + 1 + this.LAST, totalLastIndex);
- }
- }
- else if (index < 2 * per_line) {
- if (totalPage == 0) return;
- index = Math.min(2 * (index - per_line) + 1 + this.LAST, totalLastIndex);
- }
- else if (index < this.LAST + this._HX_)
- index = Math.min(index + this._HX_, totalLastIndex);
- else return;
- this._clickEquipboxIndex(index);
- return;
- }
-}
+ if (keycode == 37) {
+ // left
+ if (index == 0) return;
+ if (index == this.LAST) {
+ if (page > 1) {
+ core.status.event.data.page--;
+ core.playSound("光标移动");
+ index = this.LAST + last_index;
+ } else if (page == 1) index = equipCapacity - 1;
+ else return;
+ } else index -= 1;
+ this._clickEquipboxIndex(index);
+ return;
+ }
+ if (keycode == 38) {
+ // up
+ if (index < per_line) return;
+ else if (index < 2 * per_line) index -= per_line;
+ else if (index < this.LAST + this._HX_) {
+ index = parseInt((index - this.LAST) / 2);
+ if (equipCapacity > per_line)
+ index = Math.min(equipCapacity - 1, index + per_line);
+ else index = Math.min(equipCapacity - 1, index);
+ } else index -= this._HX_;
+ this._clickEquipboxIndex(index);
+ return;
+ }
+ if (keycode == 39) {
+ // right
+ if (page < totalPage && index == this.LAST + last_index) {
+ core.status.event.data.page++;
+ core.playSound("光标移动");
+ index = this.LAST;
+ } else if (index == equipCapacity - 1) {
+ if (totalPage == 0) return;
+ index = this.LAST;
+ } else if (index == totalLastIndex) return;
+ else index++;
+ this._clickEquipboxIndex(index);
+ return;
+ }
+ if (keycode == 40) {
+ // down
+ if (index < per_line) {
+ if (equipCapacity > per_line)
+ index = Math.min(index + per_line, equipCapacity - 1);
+ else {
+ if (totalPage == 0) return;
+ index = Math.min(2 * index + 1 + this.LAST, totalLastIndex);
+ }
+ } else if (index < 2 * per_line) {
+ if (totalPage == 0) return;
+ index = Math.min(2 * (index - per_line) + 1 + this.LAST, totalLastIndex);
+ } else if (index < this.LAST + this._HX_)
+ index = Math.min(index + this._HX_, totalLastIndex);
+ else return;
+ this._clickEquipboxIndex(index);
+ return;
+ }
+};
////// 装备栏界面时,放开某个键的操作 //////
actions.prototype._keyUpEquipbox = function (keycode, altKey) {
- if (altKey && keycode >= 48 && keycode <= 57) {
- core.items.quickSaveEquip(keycode - 48);
- return;
+ if (altKey && keycode >= 48 && keycode <= 57) {
+ core.items.quickSaveEquip(keycode - 48);
+ return;
+ }
+ if (keycode == 84) {
+ core.playSound("确定");
+ core.ui.closePanel();
+ if (core.isReplaying()) core.control._replay_toolbox();
+ else core.openToolbox();
+ return;
+ }
+ if (keycode == 81 || keycode == 27 || keycode == 88) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ var last = core.status.route[core.status.route.length - 1] || "";
+ if (last.startsWith("equip:") || last.startsWith("unEquip:")) {
+ core.status.route.push("no");
}
- if (keycode == 84) {
- core.playSound('确定');
- core.ui.closePanel();
- if (core.isReplaying())
- core.control._replay_toolbox();
- else
- core.openToolbox();
- return;
- }
- if (keycode == 81 || keycode == 27 || keycode == 88) {
- core.playSound('取消');
- core.ui.closePanel();
- var last = core.status.route[core.status.route.length - 1] || '';
- if (last.startsWith('equip:') || last.startsWith('unEquip:')) {
- core.status.route.push('no');
- }
- core.checkAutoEvents();
- return;
- }
- if (!core.status.event.data.selectId) return;
+ core.checkAutoEvents();
+ return;
+ }
+ if (!core.status.event.data.selectId) return;
- if (keycode == 13 || keycode == 32 || keycode == 67) {
- this._clickEquipboxIndex(core.status.event.selection);
- return;
- }
-}
+ if (keycode == 13 || keycode == 32 || keycode == 67) {
+ this._clickEquipboxIndex(core.status.event.selection);
+ return;
+ }
+};
////// 存读档界面时的点击操作 //////
actions.prototype._clickSL = function (x, y) {
- var page = core.status.event.data.page, offset = core.status.event.data.offset;
- var index = page * 10 + offset;
+ var page = core.status.event.data.page,
+ offset = core.status.event.data.offset;
+ var index = page * 10 + offset;
- // 上一页
- if ((x == this._HX_ - 2 || x == this._HX_ - 3) && y===core._HEIGHT_-1) {
- core.playSound('光标移动');
- core.ui._drawSLPanel(10 * (page - 1) + offset);
- return;
- }
- // 下一页
- if ((x == this._HX_ + 2 || x == this._HX_ + 3) && y===core._HEIGHT_-1) {
- core.playSound('光标移动');
- core.ui._drawSLPanel(10 * (page + 1) + offset);
- return;
- }
- // 返回
- if (x >= this.LAST - 2 && y===core._HEIGHT_-1) {
- core.playSound('取消');
- if (core.events.recoverEvents(core.status.event.interval))
- return;
- core.ui.closePanel();
- delete core.status.tempRoute;
- if (!core.isPlaying())
- core.showStartAnimate(true);
- return;
- }
- // 删除
- if (x >= 0 && x <= 2 && y===core._HEIGHT_-1) {
- if (core.status.event.id == 'save') {
- core.status.event.selection = !core.status.event.selection;
- core.ui._drawSLPanel(index);
- }
- else { // 显示收藏
- core.status.event.data.mode = core.status.event.data.mode == 'all' ? 'fav' : 'all';
- if (core.status.event.data.mode == 'fav')
- core.ui._drawSLPanel(1, true);
- else {
- page = parseInt((core.saves.saveIndex - 1) / 5);
- offset = core.saves.saveIndex - 5 * page;
- core.ui._drawSLPanel(10 * page + offset, true);
- }
- }
- return;
- }
- // 点存档名
- var xLeft = parseInt(core._WIDTH_ / 3), xRight = parseInt(core._WIDTH_ * 2 / 3);
- var topY1 = 0, topY2 = this._HY_;
- if (y >= topY1 && y <= topY1 + 1) {
- if (x >= xLeft && x < xRight) return this._clickSL_favorite(page, 1);
- if (x >= xRight) return this._clickSL_favorite(page, 2);
- }
- if (y >= topY2 && y <= topY2 + 1) {
- if (x < xLeft) return this._clickSL_favorite(page, 3);
- if (x >= xLeft && x < xRight) return this._clickSL_favorite(page, 4);
- if (x >= xRight) return this._clickSL_favorite(page, 5);
+ // 上一页
+ if ((x == this._HX_ - 2 || x == this._HX_ - 3) && y === core._HEIGHT_ - 1) {
+ core.playSound("光标移动");
+ core.ui._drawSLPanel(10 * (page - 1) + offset);
+ return;
+ }
+ // 下一页
+ if ((x == this._HX_ + 2 || x == this._HX_ + 3) && y === core._HEIGHT_ - 1) {
+ core.playSound("光标移动");
+ core.ui._drawSLPanel(10 * (page + 1) + offset);
+ return;
+ }
+ // 返回
+ if (x >= this.LAST - 2 && y === core._HEIGHT_ - 1) {
+ core.playSound("取消");
+ if (core.events.recoverEvents(core.status.event.interval)) return;
+ core.ui.closePanel();
+ delete core.status.tempRoute;
+ if (!core.isPlaying()) core.showStartAnimate(true);
+ return;
+ }
+ // 删除
+ if (x >= 0 && x <= 2 && y === core._HEIGHT_ - 1) {
+ if (core.status.event.id == "save") {
+ core.status.event.selection = !core.status.event.selection;
+ core.ui._drawSLPanel(index);
+ } else {
+ // 显示收藏
+ core.status.event.data.mode =
+ core.status.event.data.mode == "all" ? "fav" : "all";
+ if (core.status.event.data.mode == "fav") core.ui._drawSLPanel(1, true);
+ else {
+ page = parseInt((core.saves.saveIndex - 1) / 5);
+ offset = core.saves.saveIndex - 5 * page;
+ core.ui._drawSLPanel(10 * page + offset, true);
+ }
}
+ return;
+ }
+ // 点存档名
+ var xLeft = parseInt(core._WIDTH_ / 3),
+ xRight = parseInt((core._WIDTH_ * 2) / 3);
+ var topY1 = 0,
+ topY2 = this._HY_;
+ if (y >= topY1 && y <= topY1 + 1) {
+ if (x >= xLeft && x < xRight) return this._clickSL_favorite(page, 1);
+ if (x >= xRight) return this._clickSL_favorite(page, 2);
+ }
+ if (y >= topY2 && y <= topY2 + 1) {
+ if (x < xLeft) return this._clickSL_favorite(page, 3);
+ if (x >= xLeft && x < xRight) return this._clickSL_favorite(page, 4);
+ if (x >= xRight) return this._clickSL_favorite(page, 5);
+ }
- var id = null;
- if (y >= topY1 + 2 && y < this._HY_ - 1) {
- if (x < xLeft) id = "autoSave";
- if (x >= xLeft && x < xRight) id = 5 * page + 1;
- if (x >= xRight) id = 5 * page + 2;
+ var id = null;
+ if (y >= topY1 + 2 && y < this._HY_ - 1) {
+ if (x < xLeft) id = "autoSave";
+ if (x >= xLeft && x < xRight) id = 5 * page + 1;
+ if (x >= xRight) id = 5 * page + 2;
+ }
+ if (y >= topY2 + 2 && y < core._HEIGHT_ - 1) {
+ if (x < xLeft) id = 5 * page + 3;
+ if (x >= xLeft && x < xRight) id = 5 * page + 4;
+ if (x >= xRight) id = 5 * page + 5;
+ }
+ if (id != null) {
+ if (core.status.event.selection) {
+ if (id == "autoSave") {
+ core.playSound("操作失败");
+ core.drawTip("无法删除自动存档!");
+ } else {
+ core.removeSave(id, function () {
+ core.ui._drawSLPanel(index, true);
+ });
+ }
+ } else {
+ if (core.status.event.data.mode == "fav" && id != "autoSave")
+ id = core.saves.favorite[id - 1];
+ core.doSL(id, core.status.event.id);
}
- if (y >= topY2 + 2 && y < core._HEIGHT_ - 1) {
- if (x < xLeft) id = 5 * page + 3;
- if (x >= xLeft && x < xRight) id = 5 * page + 4;
- if (x >= xRight) id = 5 * page + 5;
- }
- if (id != null) {
- if (core.status.event.selection) {
- if (id == 'autoSave') {
- core.playSound('操作失败');
- core.drawTip("无法删除自动存档!");
- } else {
- core.removeSave(id, function () {
- core.ui._drawSLPanel(index, true);
- });
- }
- }
- else {
- if (core.status.event.data.mode == 'fav' && id != 'autoSave')
- id = core.saves.favorite[id - 1];
- core.doSL(id, core.status.event.id);
- }
- }
-}
+ }
+};
actions.prototype._clickSL_favorite = function (page, offset) {
- if (offset == 0) return;
- var index = 5 * page + offset;
- if (core.status.event.data.mode == 'fav') { // 收藏模式下点击的下标直接对应favorite
- index = core.saves.favorite[index - 1];
- core.myprompt("请输入想要显示的存档名(长度不超过5字符)", null, function (value) {
- if (value && value.length <= 5) {
- core.saves.favoriteName[index] = value;
- core.control._updateFavoriteSaves();
- core.ui._drawSLPanel(10 * page + offset);
- } else if (value) {
- alert("无效的输入!");
- }
- });
- } else {
- var v = core.saves.favorite.indexOf(index);
- core.playSound('确定');
- if (v >= 0) { // 已经处于收藏状态:取消收藏
- core.saves.favorite.splice(v, 1);
- delete core.saves.favoriteName[index];
+ if (offset == 0) return;
+ var index = 5 * page + offset;
+ if (core.status.event.data.mode == "fav") {
+ // 收藏模式下点击的下标直接对应favorite
+ index = core.saves.favorite[index - 1];
+ core.myprompt(
+ "请输入想要显示的存档名(长度不超过5字符)",
+ null,
+ function (value) {
+ if (value && value.length <= 5) {
+ core.saves.favoriteName[index] = value;
+ core.control._updateFavoriteSaves();
+ core.ui._drawSLPanel(10 * page + offset);
+ } else if (value) {
+ alert("无效的输入!");
}
- else if (core.hasSave(index)) { // 存在存档则进行收藏
- core.saves.favorite.push(index);
- core.saves.favorite = core.saves.favorite.sort(function (a, b) { return a - b; }); // 保证有序
- core.drawTip("收藏成功!");
- }
- core.control._updateFavoriteSaves();
- core.ui._drawSLPanel(10 * page + offset);
+ }
+ );
+ } else {
+ var v = core.saves.favorite.indexOf(index);
+ core.playSound("确定");
+ if (v >= 0) {
+ // 已经处于收藏状态:取消收藏
+ core.saves.favorite.splice(v, 1);
+ delete core.saves.favoriteName[index];
+ } else if (core.hasSave(index)) {
+ // 存在存档则进行收藏
+ core.saves.favorite.push(index);
+ core.saves.favorite = core.saves.favorite.sort(function (a, b) {
+ return a - b;
+ }); // 保证有序
+ core.drawTip("收藏成功!");
}
-}
+ core.control._updateFavoriteSaves();
+ core.ui._drawSLPanel(10 * page + offset);
+ }
+};
////// 存读档界面时,按下某个键的操作 //////
actions.prototype._keyDownSL = function (keycode) {
+ var page = core.status.event.data.page,
+ offset = core.status.event.data.offset;
+ var index = page * 10 + offset;
- var page = core.status.event.data.page, offset = core.status.event.data.offset;
- var index = page * 10 + offset;
-
- if (keycode == 37) { // left
- core.playSound('光标移动');
- if (offset == 0) {
- core.ui._drawSLPanel(10 * (page - 1) + 5);
- }
- else {
- core.ui._drawSLPanel(index - 1);
- }
- return;
+ if (keycode == 37) {
+ // left
+ core.playSound("光标移动");
+ if (offset == 0) {
+ core.ui._drawSLPanel(10 * (page - 1) + 5);
+ } else {
+ core.ui._drawSLPanel(index - 1);
}
- if (keycode == 38) { // up
- core.playSound('光标移动');
- if (offset < 3) {
- core.ui._drawSLPanel(10 * (page - 1) + offset + 3);
- }
- else {
- core.ui._drawSLPanel(index - 3);
- }
- return;
+ return;
+ }
+ if (keycode == 38) {
+ // up
+ core.playSound("光标移动");
+ if (offset < 3) {
+ core.ui._drawSLPanel(10 * (page - 1) + offset + 3);
+ } else {
+ core.ui._drawSLPanel(index - 3);
}
- if (keycode == 39) { // right
- core.playSound('光标移动');
- if (offset == 5) {
- core.ui._drawSLPanel(10 * (page + 1) + 1);
- }
- else {
- core.ui._drawSLPanel(index + 1);
- }
- return;
+ return;
+ }
+ if (keycode == 39) {
+ // right
+ core.playSound("光标移动");
+ if (offset == 5) {
+ core.ui._drawSLPanel(10 * (page + 1) + 1);
+ } else {
+ core.ui._drawSLPanel(index + 1);
}
- if (keycode == 40) { // down
- core.playSound('光标移动');
- if (offset >= 3) {
- core.ui._drawSLPanel(10 * (page + 1) + offset - 3);
- }
- else {
- core.ui._drawSLPanel(index + 3);
- }
- return;
+ return;
+ }
+ if (keycode == 40) {
+ // down
+ core.playSound("光标移动");
+ if (offset >= 3) {
+ core.ui._drawSLPanel(10 * (page + 1) + offset - 3);
+ } else {
+ core.ui._drawSLPanel(index + 3);
}
- if (keycode == 33) { // PAGEUP
- core.playSound('光标移动');
- core.ui._drawSLPanel(10 * (page - 1) + offset);
- return;
- }
- if (keycode == 34) { // PAGEDOWN
- core.playSound('光标移动');
- core.ui._drawSLPanel(10 * (page + 1) + offset);
- return;
- }
-}
+ return;
+ }
+ if (keycode == 33) {
+ // PAGEUP
+ core.playSound("光标移动");
+ core.ui._drawSLPanel(10 * (page - 1) + offset);
+ return;
+ }
+ if (keycode == 34) {
+ // PAGEDOWN
+ core.playSound("光标移动");
+ core.ui._drawSLPanel(10 * (page + 1) + offset);
+ return;
+ }
+};
////// 存读档界面时,放开某个键的操作 //////
actions.prototype._keyUpSL = function (keycode) {
- var page = core.status.event.data.page, offset = core.status.event.data.offset;
- var index = page * 10 + offset;
+ var page = core.status.event.data.page,
+ offset = core.status.event.data.offset;
+ var index = page * 10 + offset;
- if (keycode == 27 || keycode == 88 || (core.status.event.id == 'save' && keycode == 83)
- || (core.status.event.id == 'load' && keycode == 68)) {
- this._clickSL(core._WIDTH_ - 1, core._HEIGHT_ - 1);
- return;
+ if (
+ keycode == 27 ||
+ keycode == 88 ||
+ (core.status.event.id == "save" && keycode == 83) ||
+ (core.status.event.id == "load" && keycode == 68)
+ ) {
+ this._clickSL(core._WIDTH_ - 1, core._HEIGHT_ - 1);
+ return;
+ }
+ if (keycode >= 48 && keycode <= 57) {
+ if (keycode == 48) keycode = 58;
+ core.ui._drawSLPanel((keycode - 49) * 1000 + 1);
+ return;
+ }
+ if (keycode == 13 || keycode == 32 || keycode == 67) {
+ if (offset == 0) core.doSL("autoSave", core.status.event.id);
+ else {
+ var id = 5 * page + offset;
+ if (core.status.event.data.mode == "fav")
+ id = core.saves.favorite[id - 1];
+ core.doSL(id, core.status.event.id);
}
- if (keycode >= 48 && keycode <= 57) {
- if (keycode == 48) keycode = 58;
- core.ui._drawSLPanel((keycode - 49) * 1000 + 1);
- return;
+ return;
+ }
+ if (keycode == 69 && core.status.event.id != "save") {
+ // E 收藏切换
+ this._clickSL(0, core._HEIGHT_ - 1);
+ return;
+ }
+ if (keycode == 46) {
+ if (offset == 0) {
+ core.playSound("操作失败");
+ core.drawTip("无法删除自动存档!");
+ } else {
+ var id = 5 * page + offset;
+ if (core.status.event.data.mode == "fav")
+ id = core.saves.favorite[id - 1];
+ core.removeSave(id, function () {
+ core.ui._drawSLPanel(index, true);
+ });
}
- if (keycode == 13 || keycode == 32 || keycode == 67) {
- if (offset == 0)
- core.doSL("autoSave", core.status.event.id);
- else {
- var id = 5 * page + offset;
- if (core.status.event.data.mode == 'fav') id = core.saves.favorite[id - 1];
- core.doSL(id, core.status.event.id);
- }
- return;
- }
- if (keycode == 69 && core.status.event.id != 'save') { // E 收藏切换
- this._clickSL(0, core._HEIGHT_ - 1);
- return;
- }
- if (keycode == 46) {
- if (offset == 0) {
- core.playSound('操作失败');
- core.drawTip("无法删除自动存档!");
- }
- else {
- var id = 5 * page + offset;
- if (core.status.event.data.mode == 'fav') id = core.saves.favorite[id - 1];
- core.removeSave(id, function () {
- core.ui._drawSLPanel(index, true);
- });
- }
- }
- if (keycode == 70 && core.status.event.data.mode == 'all') { // F
- this._clickSL_favorite(page, offset);
- }
-}
-
+ }
+ if (keycode == 70 && core.status.event.data.mode == "all") {
+ // F
+ this._clickSL_favorite(page, offset);
+ }
+};
////// 系统设置界面时的点击操作 //////
actions.prototype._clickSwitchs = function (x, y) {
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- var selection = y - topIndex;
- if (this._out(x)) return;
- if (selection >= 0 && selection < choices.length) {
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- core.status.event.selection = 0;
- core.playSound('确定');
- return core.ui._drawSwitchs_sounds();
- case 1:
- core.status.event.selection = 0;
- core.playSound('确定');
- return core.ui._drawSwitchs_display();
- case 2:
- core.status.event.selection = 0;
- core.playSound('确定');
- return core.ui._drawSwitchs_action();
- case 3:
- core.status.event.selection = 0;
- core.playSound('取消');
- return core.ui._drawSettings();
- }
+ var choices = core.status.event.ui.choices;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ var selection = y - topIndex;
+ if (this._out(x)) return;
+ if (selection >= 0 && selection < choices.length) {
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ return core.ui._drawSwitchs_sounds();
+ case 1:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ return core.ui._drawSwitchs_display();
+ case 2:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ return core.ui._drawSwitchs_action();
+ case 3:
+ core.status.event.selection = 0;
+ core.playSound("取消");
+ return core.ui._drawSettings();
}
-}
+ }
+};
////// 系统设置界面时,放开某个键的操作 //////
actions.prototype._keyUpSwitchs = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 0;
- core.playSound('取消');
- core.ui._drawSettings();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickSwitchs);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 0;
+ core.playSound("取消");
+ core.ui._drawSettings();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickSwitchs
+ );
+};
actions.prototype._clickSwitchs_sounds = function (x, y) {
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- var selection = y - topIndex;
- if (this._out(x)) {
- if (selection != 2) return;
+ var choices = core.status.event.ui.choices;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ var selection = y - topIndex;
+ if (this._out(x)) {
+ if (selection != 2) return;
+ }
+ if (selection >= 0 && selection < choices.length) {
+ var width = choices[selection].width;
+ var leftPos = (core._PX_ - width) / 2,
+ rightPos = (core._PX_ + width) / 2;
+ var leftGrid = parseInt(leftPos / 32),
+ rightGrid = parseInt(rightPos / 32) - 1;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ return this._clickSwitchs_sounds_bgm();
+ case 1:
+ return this._clickSwitchs_sounds_se();
+ case 2:
+ if (x == leftGrid || x == leftGrid + 1)
+ return this._clickSwitchs_sounds_userVolume(-1);
+ if (x == rightGrid || x == rightGrid + 1)
+ return this._clickSwitchs_sounds_userVolume(1);
+ return;
+ case 3:
+ core.status.event.selection = 0;
+ core.playSound("取消");
+ core.ui._drawSwitchs();
+ return;
}
- if (selection >= 0 && selection < choices.length) {
- var width = choices[selection].width;
- var leftPos = (core._PX_ - width) / 2, rightPos = (core._PX_ + width) / 2;
- var leftGrid = parseInt(leftPos / 32), rightGrid = parseInt(rightPos / 32) - 1;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- return this._clickSwitchs_sounds_bgm();
- case 1:
- return this._clickSwitchs_sounds_se();
- case 2:
- if (x == leftGrid || x == leftGrid + 1) return this._clickSwitchs_sounds_userVolume(-1);
- if (x == rightGrid || x == rightGrid + 1) return this._clickSwitchs_sounds_userVolume(1);
- return;
- case 3:
- core.status.event.selection = 0;
- core.playSound('取消');
- core.ui._drawSwitchs();
- return;
- }
- }
-}
+ }
+};
actions.prototype._clickSwitchs_sounds_bgm = function () {
- core.triggerBgm();
- core.playSound('确定');
- core.ui._drawSwitchs_sounds();
-}
+ core.triggerBgm();
+ core.playSound("确定");
+ core.ui._drawSwitchs_sounds();
+};
actions.prototype._clickSwitchs_sounds_se = function () {
- core.musicStatus.soundStatus = !core.musicStatus.soundStatus;
- core.setLocalStorage('soundStatus', core.musicStatus.soundStatus);
- core.playSound('确定');
- core.ui._drawSwitchs_sounds();
-}
+ core.musicStatus.soundStatus = !core.musicStatus.soundStatus;
+ core.setLocalStorage("soundStatus", core.musicStatus.soundStatus);
+ core.playSound("确定");
+ core.ui._drawSwitchs_sounds();
+};
actions.prototype._clickSwitchs_sounds_userVolume = function (delta) {
- var value = Math.round(Math.sqrt(100 * core.musicStatus.userVolume));
- if (value == 0 && delta < 0) return;
- core.musicStatus.userVolume = core.clamp(Math.pow(value + delta, 2) / 100, 0, 1);
- //audioContext 音效 不受designVolume 影响
- if (core.musicStatus.gainNode != null) core.musicStatus.gainNode.gain.value = core.musicStatus.userVolume;
- if (core.musicStatus.playingBgm) core.material.bgms[core.musicStatus.playingBgm].volume = core.musicStatus.userVolume * core.musicStatus.designVolume;
- core.setLocalStorage('userVolume', core.musicStatus.userVolume);
- core.playSound('确定');
- core.ui._drawSwitchs_sounds();
-}
+ var value = Math.round(Math.sqrt(100 * core.musicStatus.userVolume));
+ if (value == 0 && delta < 0) return;
+ core.musicStatus.userVolume = core.clamp(
+ Math.pow(value + delta, 2) / 100,
+ 0,
+ 1
+ );
+ //audioContext 音效 不受designVolume 影响
+ if (core.musicStatus.gainNode != null)
+ core.musicStatus.gainNode.gain.value = core.musicStatus.userVolume;
+ if (core.musicStatus.playingBgm)
+ core.material.bgms[core.musicStatus.playingBgm].volume =
+ core.musicStatus.userVolume * core.musicStatus.designVolume;
+ core.setLocalStorage("userVolume", core.musicStatus.userVolume);
+ core.playSound("确定");
+ core.ui._drawSwitchs_sounds();
+};
actions.prototype._keyUpSwitchs_sounds = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 0;
- core.playSound('取消');
- core.ui._drawSwitchs();
- return;
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 0;
+ core.playSound("取消");
+ core.ui._drawSwitchs();
+ return;
+ }
+ if (keycode == 37) {
+ switch (core.status.event.selection) {
+ case 2:
+ core.playSound("确定");
+ return this._clickSwitchs_sounds_userVolume(-1);
}
- if (keycode == 37) {
- switch (core.status.event.selection) {
- case 2: core.playSound('确定'); return this._clickSwitchs_sounds_userVolume(-1);
- }
- } else if (keycode == 39) {
- switch (core.status.event.selection) {
- case 2: core.playSound('确定'); return this._clickSwitchs_sounds_userVolume(1);
- }
+ } else if (keycode == 39) {
+ switch (core.status.event.selection) {
+ case 2:
+ core.playSound("确定");
+ return this._clickSwitchs_sounds_userVolume(1);
}
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickSwitchs_sounds);
-}
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickSwitchs_sounds
+ );
+};
actions.prototype._clickSwitchs_display = function (x, y) {
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- var selection = y - topIndex;
- if (this._out(x)) {
- if (selection != 0) return;
+ var choices = core.status.event.ui.choices;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ var selection = y - topIndex;
+ if (this._out(x)) {
+ if (selection != 0) return;
+ }
+ if (selection >= 0 && selection < choices.length) {
+ var width = choices[selection].width;
+ var leftPos = (core._PX_ - width) / 2,
+ rightPos = (core._PX_ + width) / 2;
+ var leftGrid = parseInt(leftPos / 32),
+ rightGrid = parseInt(rightPos / 32) - 1;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ if (x == leftGrid || x == leftGrid + 1)
+ return this._clickSwitchs_display_setSize(-1);
+ if (x == rightGrid || x == rightGrid + 1)
+ return this._clickSwitchs_display_setSize(1);
+ return;
+ case 1:
+ core.playSound("确定");
+ return this._clickSwitchs_display_enableHDCanvas();
+ case 2:
+ core.playSound("确定");
+ return this._clickSwitchs_display_enableEnemyPoint();
+ case 3:
+ core.playSound("确定");
+ return this._clickSwitchs_display_enemyDamage();
+ case 4:
+ core.playSound("确定");
+ return this._clickSwitchs_display_critical();
+ case 5:
+ core.playSound("确定");
+ return this._clickSwitchs_display_extraDamage();
+ case 6:
+ core.playSound("确定");
+ return this._clickSwitchs_display_extraDamageType();
+ case 7:
+ core.playSound("确定");
+ core.setLocalStorage(
+ "autoScale",
+ core.getLocalStorage("autoScale") ? false : true
+ );
+ core.ui._drawSwitchs_display();
+ break;
+ case 8:
+ core.status.event.selection = 1;
+ core.playSound("取消");
+ core.ui._drawSwitchs();
+ return;
}
- if (selection >= 0 && selection < choices.length) {
- var width = choices[selection].width;
- var leftPos = (core._PX_ - width) / 2, rightPos = (core._PX_ + width) / 2;
- var leftGrid = parseInt(leftPos / 32), rightGrid = parseInt(rightPos / 32) - 1;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- if (x == leftGrid || x == leftGrid + 1) return this._clickSwitchs_display_setSize(-1);
- if (x == rightGrid || x == rightGrid + 1) return this._clickSwitchs_display_setSize(1);
- return;
- case 1:
- core.playSound('确定');
- return this._clickSwitchs_display_enableHDCanvas();
- case 2:
- core.playSound('确定');
- return this._clickSwitchs_display_enableEnemyPoint();
- case 3:
- core.playSound('确定');
- return this._clickSwitchs_display_enemyDamage();
- case 4:
- core.playSound('确定');
- return this._clickSwitchs_display_critical();
- case 5:
- core.playSound('确定');
- return this._clickSwitchs_display_extraDamage();
- case 6:
- core.playSound('确定');
- return this._clickSwitchs_display_extraDamageType();
- case 7:
- core.playSound('确定');
- core.setLocalStorage('autoScale', core.getLocalStorage('autoScale') ? false : true);
- core.ui._drawSwitchs_display();
- break;
- case 8:
- core.status.event.selection = 1;
- core.playSound('取消');
- core.ui._drawSwitchs();
- return;
- }
- }
-}
+ }
+};
actions.prototype._clickSwitchs_display_setSize = function (delta) {
- core.setDisplayScale(delta);
- var currentRatio = Math.max(window.devicePixelRatio || 1, core.domStyle.scale);
- if (currentRatio > core.domStyle.ratio) {
- core.drawTip("需刷新页面以调整UI清晰度");
- }
- core.ui._drawSwitchs_display();
-}
+ core.setDisplayScale(delta);
+ var currentRatio = Math.max(
+ window.devicePixelRatio || 1,
+ core.domStyle.scale
+ );
+ if (currentRatio > core.domStyle.ratio) {
+ core.drawTip("需刷新页面以调整UI清晰度");
+ }
+ core.ui._drawSwitchs_display();
+};
actions.prototype._clickSwitchs_display_enableHDCanvas = function () {
- core.flags.enableHDCanvas = !core.flags.enableHDCanvas;
- core.setLocalStorage('enableHDCanvas', core.flags.enableHDCanvas);
- core.drawTip("开关高清UI,需刷新页面方可生效");
- core.ui._drawSwitchs_display();
-}
+ core.flags.enableHDCanvas = !core.flags.enableHDCanvas;
+ core.setLocalStorage("enableHDCanvas", core.flags.enableHDCanvas);
+ core.drawTip("开关高清UI,需刷新页面方可生效");
+ core.ui._drawSwitchs_display();
+};
actions.prototype._clickSwitchs_display_enableEnemyPoint = function () {
- core.flags.enableEnemyPoint = !core.flags.enableEnemyPoint;
- core.setLocalStorage('enableEnemyPoint', core.flags.enableEnemyPoint);
- core.ui._drawSwitchs_display();
-}
+ core.flags.enableEnemyPoint = !core.flags.enableEnemyPoint;
+ core.setLocalStorage("enableEnemyPoint", core.flags.enableEnemyPoint);
+ core.ui._drawSwitchs_display();
+};
actions.prototype._clickSwitchs_display_enemyDamage = function () {
- core.flags.displayEnemyDamage = !core.flags.displayEnemyDamage;
- core.updateDamage();
- core.setLocalStorage('enemyDamage', core.flags.displayEnemyDamage);
- core.ui._drawSwitchs_display();
-}
+ core.flags.displayEnemyDamage = !core.flags.displayEnemyDamage;
+ core.updateDamage();
+ core.setLocalStorage("enemyDamage", core.flags.displayEnemyDamage);
+ core.ui._drawSwitchs_display();
+};
actions.prototype._clickSwitchs_display_critical = function () {
- core.flags.displayCritical = !core.flags.displayCritical;
- core.updateDamage();
- core.setLocalStorage('critical', core.flags.displayCritical);
- core.ui._drawSwitchs_display();
-}
+ core.flags.displayCritical = !core.flags.displayCritical;
+ core.updateDamage();
+ core.setLocalStorage("critical", core.flags.displayCritical);
+ core.ui._drawSwitchs_display();
+};
actions.prototype._clickSwitchs_display_extraDamage = function () {
- core.flags.displayExtraDamage = !core.flags.displayExtraDamage;
- core.updateDamage();
- core.setLocalStorage('extraDamage', core.flags.displayExtraDamage);
- core.ui._drawSwitchs_display();
-}
+ core.flags.displayExtraDamage = !core.flags.displayExtraDamage;
+ core.updateDamage();
+ core.setLocalStorage("extraDamage", core.flags.displayExtraDamage);
+ core.ui._drawSwitchs_display();
+};
actions.prototype._clickSwitchs_display_extraDamageType = function () {
- core.flags.extraDamageType = (core.flags.extraDamageType + 1) % 3;
- core.updateDamage();
- core.setLocalStorage('extraDamageType', core.flags.extraDamageType);
- core.ui._drawSwitchs_display();
-}
+ core.flags.extraDamageType = (core.flags.extraDamageType + 1) % 3;
+ core.updateDamage();
+ core.setLocalStorage("extraDamageType", core.flags.extraDamageType);
+ core.ui._drawSwitchs_display();
+};
actions.prototype._keyUpSwitchs_display = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 1;
- core.playSound('取消');
- core.ui._drawSwitchs();
- return;
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 1;
+ core.playSound("取消");
+ core.ui._drawSwitchs();
+ return;
+ }
+ if (keycode == 37) {
+ switch (core.status.event.selection) {
+ case 0:
+ core.playSound("确定");
+ return this._clickSwitchs_display_setSize(-1);
}
- if (keycode == 37) {
- switch (core.status.event.selection) {
- case 0: core.playSound('确定'); return this._clickSwitchs_display_setSize(-1);
- }
- } else if (keycode == 39) {
- switch (core.status.event.selection) {
- case 0: core.playSound('确定'); return this._clickSwitchs_display_setSize(1);
- }
+ } else if (keycode == 39) {
+ switch (core.status.event.selection) {
+ case 0:
+ core.playSound("确定");
+ return this._clickSwitchs_display_setSize(1);
}
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickSwitchs_display);
-}
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickSwitchs_display
+ );
+};
actions.prototype._clickSwitchs_action = function (x, y) {
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- var selection = y - topIndex;
- if (this._out(x)) {
- if (selection != 0 && selection != 1) return;
- }
- if (selection >= 0 && selection < choices.length) {
- var width = choices[selection].width;
- var leftPos = (core._PX_ - width) / 2, rightPos = (core._PX_ + width) / 2;
- var leftGrid = parseInt(leftPos / 32), rightGrid = parseInt(rightPos / 32) - 1;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- if (x == leftGrid || x == leftGrid + 1) { core.playSound('确定'); return this._clickSwitchs_action_moveSpeed(-10); }
- if (x == rightGrid || x == rightGrid + 1) { core.playSound('确定'); return this._clickSwitchs_action_moveSpeed(10); }
- return;
- case 1:
- if (x == leftGrid || x == leftGrid + 1) { core.playSound('确定'); return this._clickSwitchs_action_floorChangeTime(-100); }
- if (x == rightGrid || x == rightGrid + 1) { core.playSound('确定'); return this._clickSwitchs_action_floorChangeTime(100); }
- case 2:
- core.playSound('确定');
- return this._clickSwitchs_action_potionNoRouting();
- case 3:
- core.playSound('确定');
- return this._clickSwitchs_action_clickMove();
- case 4:
- core.playSound('确定');
- return this._clickSwitchs_action_leftHandPrefer();
- case 5:
- core.status.event.selection = 2;
- core.playSound('取消');
- core.ui._drawSwitchs();
- return;
+ var choices = core.status.event.ui.choices;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ var selection = y - topIndex;
+ if (this._out(x)) {
+ if (selection != 0 && selection != 1) return;
+ }
+ if (selection >= 0 && selection < choices.length) {
+ var width = choices[selection].width;
+ var leftPos = (core._PX_ - width) / 2,
+ rightPos = (core._PX_ + width) / 2;
+ var leftGrid = parseInt(leftPos / 32),
+ rightGrid = parseInt(rightPos / 32) - 1;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ if (x == leftGrid || x == leftGrid + 1) {
+ core.playSound("确定");
+ return this._clickSwitchs_action_moveSpeed(-10);
}
- }
-}
-
-actions.prototype._clickSwitchs_action_moveSpeed = function (delta) {
- core.values.moveSpeed = core.clamp(core.values.moveSpeed + delta, 50, 200);
- core.setLocalStorage("moveSpeed", core.values.moveSpeed);
- core.ui._drawSwitchs_action();
-}
-
-actions.prototype._clickSwitchs_action_floorChangeTime = function (delta) {
- core.values.floorChangeTime = core.clamp(core.values.floorChangeTime + delta, 0, 2000);
- core.setLocalStorage("floorChangeTime", core.values.floorChangeTime);
- core.ui._drawSwitchs_action();
-}
-
-actions.prototype._clickSwitchs_action_potionNoRouting = function () {
- if (core.hasFlag('__potionNoRouting__')) core.removeFlag('__potionNoRouting__');
- else core.setFlag('__potionNoRouting__', true);
- core.ui._drawSwitchs_action();
-}
-
-actions.prototype._clickSwitchs_action_clickMove = function () {
- if (core.hasFlag('__noClickMove__')) core.removeFlag('__noClickMove__');
- else core.setFlag('__noClickMove__', true);
- core.ui._drawSwitchs_action();
-}
-
-actions.prototype._clickSwitchs_action_leftHandPrefer = function () {
- core.flags.leftHandPrefer = !core.flags.leftHandPrefer;
- core.setLocalStorage('leftHandPrefer', core.flags.leftHandPrefer);
- if (core.flags.leftHandPrefer) {
- core.myconfirm("左手模式已开启!\n此模式下WASD将用于移动勇士,IJKL对应于原始的WASD进行存读档等操作。")
- }
- core.ui._drawSwitchs_action();
-}
-
-actions.prototype._keyUpSwitchs_action = function (keycode) {
- if (keycode == 27 || keycode == 88) {
+ if (x == rightGrid || x == rightGrid + 1) {
+ core.playSound("确定");
+ return this._clickSwitchs_action_moveSpeed(10);
+ }
+ return;
+ case 1:
+ if (x == leftGrid || x == leftGrid + 1) {
+ core.playSound("确定");
+ return this._clickSwitchs_action_floorChangeTime(-100);
+ }
+ if (x == rightGrid || x == rightGrid + 1) {
+ core.playSound("确定");
+ return this._clickSwitchs_action_floorChangeTime(100);
+ }
+ case 2:
+ core.playSound("确定");
+ return this._clickSwitchs_action_potionNoRouting();
+ case 3:
+ core.playSound("确定");
+ return this._clickSwitchs_action_clickMove();
+ case 4:
+ core.playSound("确定");
+ return this._clickSwitchs_action_leftHandPrefer();
+ case 5:
core.status.event.selection = 2;
- core.playSound('取消');
+ core.playSound("取消");
core.ui._drawSwitchs();
return;
}
- if (keycode == 37) {
- switch (core.status.event.selection) {
- case 0: core.playSound('确定'); return this._clickSwitchs_action_moveSpeed(-10);
- case 1: core.playSound('确定'); return this._clickSwitchs_action_floorChangeTime(-100);
- }
- } else if (keycode == 39) {
- switch (core.status.event.selection) {
- case 0: core.playSound('确定'); return this._clickSwitchs_action_moveSpeed(10);
- case 1: core.playSound('确定'); return this._clickSwitchs_action_floorChangeTime(100);
- }
+ }
+};
+
+actions.prototype._clickSwitchs_action_moveSpeed = function (delta) {
+ core.values.moveSpeed = core.clamp(core.values.moveSpeed + delta, 50, 200);
+ core.setLocalStorage("moveSpeed", core.values.moveSpeed);
+ core.ui._drawSwitchs_action();
+};
+
+actions.prototype._clickSwitchs_action_floorChangeTime = function (delta) {
+ core.values.floorChangeTime = core.clamp(
+ core.values.floorChangeTime + delta,
+ 0,
+ 2000
+ );
+ core.setLocalStorage("floorChangeTime", core.values.floorChangeTime);
+ core.ui._drawSwitchs_action();
+};
+
+actions.prototype._clickSwitchs_action_potionNoRouting = function () {
+ if (core.hasFlag("__potionNoRouting__"))
+ core.removeFlag("__potionNoRouting__");
+ else core.setFlag("__potionNoRouting__", true);
+ core.ui._drawSwitchs_action();
+};
+
+actions.prototype._clickSwitchs_action_clickMove = function () {
+ if (core.hasFlag("__noClickMove__")) core.removeFlag("__noClickMove__");
+ else core.setFlag("__noClickMove__", true);
+ core.ui._drawSwitchs_action();
+};
+
+actions.prototype._clickSwitchs_action_leftHandPrefer = function () {
+ core.flags.leftHandPrefer = !core.flags.leftHandPrefer;
+ core.setLocalStorage("leftHandPrefer", core.flags.leftHandPrefer);
+ if (core.flags.leftHandPrefer) {
+ core.myconfirm(
+ "左手模式已开启!\n此模式下WASD将用于移动勇士,IJKL对应于原始的WASD进行存读档等操作。"
+ );
+ }
+ core.ui._drawSwitchs_action();
+};
+
+actions.prototype._keyUpSwitchs_action = function (keycode) {
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 2;
+ core.playSound("取消");
+ core.ui._drawSwitchs();
+ return;
+ }
+ if (keycode == 37) {
+ switch (core.status.event.selection) {
+ case 0:
+ core.playSound("确定");
+ return this._clickSwitchs_action_moveSpeed(-10);
+ case 1:
+ core.playSound("确定");
+ return this._clickSwitchs_action_floorChangeTime(-100);
}
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickSwitchs_action);
-}
+ } else if (keycode == 39) {
+ switch (core.status.event.selection) {
+ case 0:
+ core.playSound("确定");
+ return this._clickSwitchs_action_moveSpeed(10);
+ case 1:
+ core.playSound("确定");
+ return this._clickSwitchs_action_floorChangeTime(100);
+ }
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickSwitchs_action
+ );
+};
////// 系统菜单栏界面时的点击操作 //////
actions.prototype._clickSettings = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- core.status.event.selection = 0;
- core.playSound('确定');
- core.ui._drawSwitchs();
- break;
- case 1:
- // core.playSound('确定');
- core.ui._drawKeyBoard();
- break;
- case 2:
- // core.playSound('确定');
- core.clearUI();
- core.ui._drawViewMaps();
- break;
- case 3:
- core.status.event.selection = 0;
- core.playSound('确定');
- core.ui._drawNotes();
- break;
- case 4:
- core.status.event.selection = 0;
- core.playSound('确定');
- core.ui._drawSyncSave();
- break;
- case 5:
- core.status.event.selection = 0;
- core.playSound('确定');
- core.ui._drawGameInfo();
- break;
- case 6:
- return core.confirmRestart();
- case 7:
- core.playSound('取消');
- core.ui.closePanel();
- break;
- }
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ core.ui._drawSwitchs();
+ break;
+ case 1:
+ // core.playSound('确定');
+ core.ui._drawKeyBoard();
+ break;
+ case 2:
+ // core.playSound('确定');
+ core.clearUI();
+ core.ui._drawViewMaps();
+ break;
+ case 3:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ core.ui._drawNotes();
+ break;
+ case 4:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ core.ui._drawSyncSave();
+ break;
+ case 5:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ core.ui._drawGameInfo();
+ break;
+ case 6:
+ return core.confirmRestart();
+ case 7:
+ core.playSound("取消");
+ core.ui.closePanel();
+ break;
}
- return;
-}
+ }
+ return;
+};
////// 系统菜单栏界面时,放开某个键的操作 //////
actions.prototype._keyUpSettings = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.playSound('取消');
- core.ui.closePanel();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickSettings);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickSettings
+ );
+};
////// 存档笔记页面时的点击操作 //////
actions.prototype._clickNotes = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- core.playSound('确定');
- this._clickNotes_new();
- break;
- case 1:
- // core.playSound('确定');
- this._clickNotes_show();
- break;
- case 2:
- core.playSound('确定');
- this._clickNotes_edit();
- break;
- case 3:
- core.playSound('确定');
- this._clickNotes_delete();
- break;
- case 4:
- core.status.event.selection = 3;
- core.playSound('取消');
- core.ui._drawSettings();
- break;
- }
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ core.playSound("确定");
+ this._clickNotes_new();
+ break;
+ case 1:
+ // core.playSound('确定');
+ this._clickNotes_show();
+ break;
+ case 2:
+ core.playSound("确定");
+ this._clickNotes_edit();
+ break;
+ case 3:
+ core.playSound("确定");
+ this._clickNotes_delete();
+ break;
+ case 4:
+ core.status.event.selection = 3;
+ core.playSound("取消");
+ core.ui._drawSettings();
+ break;
}
-}
+ }
+};
actions.prototype.__clickNotes_replaceText = function (data) {
- data = (data || "").replace(/[\${}]/g, "_")
- .replace(/(\t|\\t)\[.*?\]/g, "")
- .replace("\b", "\\b")
- .replace(/\\b\[.*?\]/g, "")
- .replace(/\n|\\n/g, " ");
- if (data.length > 45) data = data.substring(0, 43) + "...";
- return data;
-}
+ data = (data || "")
+ .replace(/[\${}]/g, "_")
+ .replace(/(\t|\\t)\[.*?\]/g, "")
+ .replace("\b", "\\b")
+ .replace(/\\b\[.*?\]/g, "")
+ .replace(/\n|\\n/g, " ");
+ if (data.length > 45) data = data.substring(0, 43) + "...";
+ return data;
+};
actions.prototype._clickNotes_new = function () {
- core.status.hero.notes = core.status.hero.notes || [];
- core.myprompt("请输入一段笔记,不超过45字", null, function (data) {
- data = core.actions.__clickNotes_replaceText(data);
- if (data) {
- core.status.hero.notes.push(data);
- core.drawText("存档笔记新增成功!");
- } else {
- core.ui.closePanel();
- }
- });
-}
+ core.status.hero.notes = core.status.hero.notes || [];
+ core.myprompt("请输入一段笔记,不超过45字", null, function (data) {
+ data = core.actions.__clickNotes_replaceText(data);
+ if (data) {
+ core.status.hero.notes.push(data);
+ core.drawText("存档笔记新增成功!");
+ } else {
+ core.ui.closePanel();
+ }
+ });
+};
actions.prototype._clickNotes_show = function () {
- core.playSound('确定');
- core.status.hero.notes = core.status.hero.notes || [];
- var result = [];
- for (var i = 0; i < core.status.hero.notes.length; i += 5) {
- var v = [];
- for (var j = i; j < i + 5 && j < core.status.hero.notes.length; ++j) {
- v.push(j + 1 + ". " + this.__clickNotes_replaceText(core.status.hero.notes[j]));
- }
- result.push("\t[存档笔记]" + v.join("\n"));
+ core.playSound("确定");
+ core.status.hero.notes = core.status.hero.notes || [];
+ var result = [];
+ for (var i = 0; i < core.status.hero.notes.length; i += 5) {
+ var v = [];
+ for (var j = i; j < i + 5 && j < core.status.hero.notes.length; ++j) {
+ v.push(
+ j + 1 + ". " + this.__clickNotes_replaceText(core.status.hero.notes[j])
+ );
}
- if (result.length == 0) result.push("当前没有存档笔记,试着新增一个吧!\n(菜单栏 -> 存档笔记 -> 新增存档笔记)");
- core.drawText(result);
-}
+ result.push("\t[存档笔记]" + v.join("\n"));
+ }
+ if (result.length == 0)
+ result.push(
+ "当前没有存档笔记,试着新增一个吧!\n(菜单栏 -> 存档笔记 -> 新增存档笔记)"
+ );
+ core.drawText(result);
+};
actions.prototype._clickNotes_edit = function () {
- core.status.hero.notes = core.status.hero.notes || [];
- if (core.status.hero.notes.length == 0) {
- core.drawText("当前没有存档笔记,试着新增一个吧!");
- } else {
- core.myprompt("请输入要编辑的存档笔记编号(1 - " + core.status.hero.notes.length + ")", "1", function (data) {
- if (!data) core.ui.closePanel();
- var value = parseInt(data) || 0;
- if (!value || value <= 0 || value > core.status.hero.notes.length) {
- core.drawText("不合法的输入!");
- } else {
- core.myprompt("请输入新内容,不超过45字", core.status.hero.notes[value - 1], function (data) {
- data = core.actions.__clickNotes_replaceText(data);
- if (data) {
- core.status.hero.notes[value - 1] = data;
- core.drawText("存档笔记编辑成功!");
- } else {
- core.ui.closePanel();
- }
- });
+ core.status.hero.notes = core.status.hero.notes || [];
+ if (core.status.hero.notes.length == 0) {
+ core.drawText("当前没有存档笔记,试着新增一个吧!");
+ } else {
+ core.myprompt(
+ "请输入要编辑的存档笔记编号(1 - " + core.status.hero.notes.length + ")",
+ "1",
+ function (data) {
+ if (!data) core.ui.closePanel();
+ var value = parseInt(data) || 0;
+ if (!value || value <= 0 || value > core.status.hero.notes.length) {
+ core.drawText("不合法的输入!");
+ } else {
+ core.myprompt(
+ "请输入新内容,不超过45字",
+ core.status.hero.notes[value - 1],
+ function (data) {
+ data = core.actions.__clickNotes_replaceText(data);
+ if (data) {
+ core.status.hero.notes[value - 1] = data;
+ core.drawText("存档笔记编辑成功!");
+ } else {
+ core.ui.closePanel();
+ }
}
- })
- }
-}
+ );
+ }
+ }
+ );
+ }
+};
actions.prototype._clickNotes_delete = function () {
- core.status.hero.notes = core.status.hero.notes || [];
- if (core.status.hero.notes.length == 0) {
- core.stopSound();
- core.playSound('操作失败');
- core.drawText("当前没有存档笔记,无法删除!");
- } else {
- core.myprompt("请输入要删除的所有存档笔记编号,以逗号分隔。不填则代表删除全部笔记。", null, function (data) {
- if (data == null) {
- core.ui.closePanel();
- return;
- }
- else if (!data) {
- core.status.hero.notes = [];
- core.drawText("所有存档笔记删除成功!");
- } else {
- data = data.split(",").map(function (one) { return parseInt(one); })
- .filter(function (one) { return one && one > 0 && one <= core.status.hero.notes.length });
- if (data.length == 0) {
- core.drawText("没有要删除的笔记!");
- } else {
- data.sort(function (a, b) { return b - a; })
- .forEach(function (index) {
- core.status.hero.notes.splice(index - 1, 1);
- });
- core.drawText("已删除 " + data.sort().join(",") + " 号笔记");
- }
- }
- })
- }
-}
+ core.status.hero.notes = core.status.hero.notes || [];
+ if (core.status.hero.notes.length == 0) {
+ core.stopSound();
+ core.playSound("操作失败");
+ core.drawText("当前没有存档笔记,无法删除!");
+ } else {
+ core.myprompt(
+ "请输入要删除的所有存档笔记编号,以逗号分隔。不填则代表删除全部笔记。",
+ null,
+ function (data) {
+ if (data == null) {
+ core.ui.closePanel();
+ return;
+ } else if (!data) {
+ core.status.hero.notes = [];
+ core.drawText("所有存档笔记删除成功!");
+ } else {
+ data = data
+ .split(",")
+ .map(function (one) {
+ return parseInt(one);
+ })
+ .filter(function (one) {
+ return one && one > 0 && one <= core.status.hero.notes.length;
+ });
+ if (data.length == 0) {
+ core.drawText("没有要删除的笔记!");
+ } else {
+ data
+ .sort(function (a, b) {
+ return b - a;
+ })
+ .forEach(function (index) {
+ core.status.hero.notes.splice(index - 1, 1);
+ });
+ core.drawText("已删除 " + data.sort().join(",") + " 号笔记");
+ }
+ }
+ }
+ );
+ }
+};
////// 存档笔记页面时,放开某个键的操作 //////
actions.prototype._keyUpNotes = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 3;
- core.playSound('取消');
- core.ui._drawSettings();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickNotes);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 3;
+ core.playSound("取消");
+ core.ui._drawSettings();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickNotes
+ );
+};
////// 同步存档界面时的点击操作 //////
actions.prototype._clickSyncSave = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- core.status.event.selection = 0;
- core.playSound('确定');
- core.ui._drawSyncSelect();
- break;
- case 1:
- core.playSound('确定');
- core.syncLoad();
- break;
- case 2:
- core.playSound('确定');
- core.status.event.selection = 0;
- core.ui._drawLocalSaveSelect();
- break;
- case 3:
- core.playSound('确定');
- return this._clickSyncSave_readFile();
- case 4:
- // core.playSound('确定');
- return this._clickSyncSave_replay();
- case 5:
- core.status.event.selection = 0;
- core.playSound('确定');
- core.ui._drawStorageRemove();
- break;
- case 6:
- core.status.event.selection = 4;
- core.playSound('取消');
- core.ui._drawSettings();
- break;
-
- }
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ core.ui._drawSyncSelect();
+ break;
+ case 1:
+ core.playSound("确定");
+ core.syncLoad();
+ break;
+ case 2:
+ core.playSound("确定");
+ core.status.event.selection = 0;
+ core.ui._drawLocalSaveSelect();
+ break;
+ case 3:
+ core.playSound("确定");
+ return this._clickSyncSave_readFile();
+ case 4:
+ // core.playSound('确定');
+ return this._clickSyncSave_replay();
+ case 5:
+ core.status.event.selection = 0;
+ core.playSound("确定");
+ core.ui._drawStorageRemove();
+ break;
+ case 6:
+ core.status.event.selection = 4;
+ core.playSound("取消");
+ core.ui._drawSettings();
+ break;
}
- return;
-}
+ }
+ return;
+};
actions.prototype._clickSyncSave_readFile = function () {
- core.readFile(function (obj) {
- if (obj.name != core.firstData.name) return alert("存档和游戏不一致!");
- if (obj.version != core.firstData.version) return alert("游戏版本不一致!");
- if (!obj.data) return alert("无效的存档!");
- core.control._syncLoad_write(obj.data);
- }, null, ".h5save");
-}
+ core.readFile(
+ function (obj) {
+ if (obj.name != core.firstData.name) return alert("存档和游戏不一致!");
+ if (obj.version != core.firstData.version)
+ return alert("游戏版本不一致!");
+ if (!obj.data) return alert("无效的存档!");
+ core.control._syncLoad_write(obj.data);
+ },
+ null,
+ ".h5save"
+ );
+};
actions.prototype._clickSyncSave_replay = function () {
- core.ui._drawReplay();
-}
+ core.ui._drawReplay();
+};
////// 同步存档界面时,放开某个键的操作 //////
actions.prototype._keyUpSyncSave = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 4;
- core.playSound('取消');
- core.ui._drawSettings();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickSyncSave);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 4;
+ core.playSound("取消");
+ core.ui._drawSettings();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickSyncSave
+ );
+};
////// 同步存档选择界面时的点击操作 //////
actions.prototype._clickSyncSelect = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- core.playSound('确定');
- core.myconfirm('你确定要同步全部存档么?\n这可能在存档较多的时候比较慢。', function () {
- core.syncSave('all');
- });
- break;
- case 1:
- core.playSound('确定');
- core.syncSave();
- break;
- case 2:
- core.status.event.selection = 0;
- core.playSound('取消');
- core.ui._drawSyncSave();
- break;
- }
+ var topIndex = this._getChoicesTopIndex(choices.length);
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ core.playSound("确定");
+ core.myconfirm(
+ "你确定要同步全部存档么?\n这可能在存档较多的时候比较慢。",
+ function () {
+ core.syncSave("all");
+ }
+ );
+ break;
+ case 1:
+ core.playSound("确定");
+ core.syncSave();
+ break;
+ case 2:
+ core.status.event.selection = 0;
+ core.playSound("取消");
+ core.ui._drawSyncSave();
+ break;
}
-}
+ }
+};
////// 同步存档选择界面时,放开某个键的操作 //////
actions.prototype._keyUpSyncSelect = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 0;
- core.playSound('取消');
- core.ui._drawSyncSave();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickSyncSelect);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 0;
+ core.playSound("取消");
+ core.ui._drawSyncSave();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickSyncSelect
+ );
+};
////// 存档下载界面时的点击操作 //////
actions.prototype._clickLocalSaveSelect = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
+ var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- if (selection < 2) {
- var callback = function (saves) {
- if (saves) {
- var content = {
- "name": core.firstData.name,
- "version": core.firstData.version,
- "data": saves
- }
- core.download(core.firstData.name + "_" + core.formatDate2(new Date()) + ".h5save",
- LZString.compressToBase64(JSON.stringify(content)));
- }
- };
- if (selection == 0) core.getAllSaves(callback);
- else core.getSave(core.saves.saveIndex, callback);
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ if (selection < 2) {
+ var callback = function (saves) {
+ if (saves) {
+ var content = {
+ name: core.firstData.name,
+ version: core.firstData.version,
+ data: saves,
+ };
+ core.download(
+ core.firstData.name +
+ "_" +
+ core.formatDate2(new Date()) +
+ ".h5save",
+ LZString.compressToBase64(JSON.stringify(content))
+ );
}
-
- core.status.event.selection = 2;
- core.playSound('取消');
- core.ui._drawSyncSave();
+ };
+ if (selection == 0) core.getAllSaves(callback);
+ else core.getSave(core.saves.saveIndex, callback);
}
-}
+
+ core.status.event.selection = 2;
+ core.playSound("取消");
+ core.ui._drawSyncSave();
+ }
+};
////// 存档下载界面时,放开某个键的操作 //////
actions.prototype._keyUpLocalSaveSelect = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 2;
- core.playSound('取消');
- core.ui._drawSyncSave();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickLocalSaveSelect);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 2;
+ core.playSound("取消");
+ core.ui._drawSyncSave();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickLocalSaveSelect
+ );
+};
////// 存档删除界面时的点击操作 //////
actions.prototype._clickStorageRemove = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
+ var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- return this._clickStorageRemove_all();
- case 1:
- return this._clickStorageRemove_current();
- case 2:
- core.status.event.selection = 5;
- core.playSound('取消');
- core.ui._drawSyncSave();
- break;
- }
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ return this._clickStorageRemove_all();
+ case 1:
+ return this._clickStorageRemove_current();
+ case 2:
+ core.status.event.selection = 5;
+ core.playSound("取消");
+ core.ui._drawSyncSave();
+ break;
}
-}
+ }
+};
actions.prototype._clickStorageRemove_all = function () {
- core.myconfirm("你确定要清除【全部游戏】的所有本地存档?\n此行为不可逆!!!", function () {
- core.ui.drawWaiting("正在清空,请稍候...");
- core.clearLocalForage(function () {
- core.saves.ids = {};
- core.saves.autosave.data = null;
- core.saves.autosave.updated = false;
- core.saves.autosave.now = 0;
- core.saves.cache = {};
- core.ui.closePanel();
- core.saves.saveIndex = 1;
- core.saves.favorite = [];
- core.saves.favoriteName = {};
- core.control._updateFavoriteSaves();
- core.removeLocalStorage('saveIndex');
- core.drawText("\t[操作成功]你的所有存档已被清空。");
- });
- });
-}
+ core.myconfirm(
+ "你确定要清除【全部游戏】的所有本地存档?\n此行为不可逆!!!",
+ function () {
+ core.ui.drawWaiting("正在清空,请稍候...");
+ core.clearLocalForage(function () {
+ core.saves.ids = {};
+ core.saves.autosave.data = null;
+ core.saves.autosave.updated = false;
+ core.saves.autosave.now = 0;
+ core.saves.cache = {};
+ core.ui.closePanel();
+ core.saves.saveIndex = 1;
+ core.saves.favorite = [];
+ core.saves.favoriteName = {};
+ core.control._updateFavoriteSaves();
+ core.removeLocalStorage("saveIndex");
+ core.drawText("\t[操作成功]你的所有存档已被清空。");
+ });
+ }
+ );
+};
actions.prototype._clickStorageRemove_current = function () {
- core.myconfirm("你确定要清除本游戏的所有本地存档?\n此行为不可逆!!!", function () {
- var done = function () {
- core.saves.ids = {};
- core.saves.autosave.data = null;
- core.saves.autosave.updated = false;
- core.saves.autosave.now = 0;
- core.ui.closePanel();
- core.saves.saveIndex = 1;
- core.saves.favorite = [];
- core.saves.favoriteName = {};
- core.control._updateFavoriteSaves();
- core.removeLocalStorage('saveIndex');
- core.drawText("\t[操作成功]当前塔的存档已被清空。");
- }
- core.ui.drawWaiting("正在清空,请稍候...");
- Object.keys(core.saves.ids).forEach(function (v) {
- core.removeLocalForage("save" + v);
- });
- core.removeLocalForage("autoSave", done);
- });
-}
+ core.myconfirm(
+ "你确定要清除本游戏的所有本地存档?\n此行为不可逆!!!",
+ function () {
+ var done = function () {
+ core.saves.ids = {};
+ core.saves.autosave.data = null;
+ core.saves.autosave.updated = false;
+ core.saves.autosave.now = 0;
+ core.ui.closePanel();
+ core.saves.saveIndex = 1;
+ core.saves.favorite = [];
+ core.saves.favoriteName = {};
+ core.control._updateFavoriteSaves();
+ core.removeLocalStorage("saveIndex");
+ core.drawText("\t[操作成功]当前塔的存档已被清空。");
+ };
+ core.ui.drawWaiting("正在清空,请稍候...");
+ Object.keys(core.saves.ids).forEach(function (v) {
+ core.removeLocalForage("save" + v);
+ });
+ core.removeLocalForage("autoSave", done);
+ }
+ );
+};
////// 存档删除界面时,放开某个键的操作 //////
actions.prototype._keyUpStorageRemove = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 5;
- core.playSound('取消');
- core.ui._drawSyncSave();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickStorageRemove);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 5;
+ core.playSound("取消");
+ core.ui._drawSyncSave();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickStorageRemove
+ );
+};
////// 回放选择界面时的点击操作 //////
actions.prototype._clickReplay = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
+ var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0: core.playSound('确定'); return this._clickReplay_fromBeginning();
- case 1: core.playSound('确定'); return this._clickReplay_fromLoad();
- case 2: core.playSound('确定'); return this._clickReplay_replayRemain();
- case 3: core.playSound('确定'); return this._clickReplay_replaySince();
- case 4: core.playSound('确定'); return core.chooseReplayFile();
- case 5: core.playSound('确定'); return this._clickReplay_download();
- case 6: core.playSound('取消'); return core.ui.closePanel();
- }
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ core.playSound("确定");
+ return this._clickReplay_fromBeginning();
+ case 1:
+ core.playSound("确定");
+ return this._clickReplay_fromLoad();
+ case 2:
+ core.playSound("确定");
+ return this._clickReplay_replayRemain();
+ case 3:
+ core.playSound("确定");
+ return this._clickReplay_replaySince();
+ case 4:
+ core.playSound("确定");
+ return core.chooseReplayFile();
+ case 5:
+ core.playSound("确定");
+ return this._clickReplay_download();
+ case 6:
+ core.playSound("取消");
+ return core.ui.closePanel();
}
-}
+ }
+};
actions.prototype._clickReplay_fromBeginning = function () {
- core.ui.closePanel();
- core.startGame(core.status.hard, core.getFlag('__seed__'), core.cloneArray(core.status.route));
-}
+ core.ui.closePanel();
+ core.startGame(
+ core.status.hard,
+ core.getFlag("__seed__"),
+ core.cloneArray(core.status.route)
+ );
+};
actions.prototype._clickReplay_fromLoad = function () {
- core.status.event.id = 'replayLoad';
- core.status.event.selection = null;
- core.clearUI();
- var saveIndex = core.saves.saveIndex;
- var page = parseInt((saveIndex - 1) / 5), offset = saveIndex - 5 * page;
- core.ui._drawSLPanel(10 * page + offset);
-}
+ core.status.event.id = "replayLoad";
+ core.status.event.selection = null;
+ core.clearUI();
+ var saveIndex = core.saves.saveIndex;
+ var page = parseInt((saveIndex - 1) / 5),
+ offset = saveIndex - 5 * page;
+ core.ui._drawSLPanel(10 * page + offset);
+};
actions.prototype._clickReplay_replayRemain = function () {
- core.closePanel();
- core.drawText([
- "\t[接续播放录像]该功能允许你播放\r[yellow]两个存档之间的录像\r,常常用于\r[yellow]区域优化\r。\n" +
+ core.closePanel();
+ core.drawText(
+ [
+ "\t[接续播放录像]该功能允许你播放\r[yellow]两个存档之间的录像\r,常常用于\r[yellow]区域优化\r。\n" +
"例如,有若干个区,已经全部通关;之后重打一区并进行了优化,则可以对剩余区域直接播放录像而无需全部重打。\n\n" +
"详细使用方法参见露珠录制的视频教程:\n\r[yellow]https://bilibili.com/video/BV1az4y1C78x",
- "\t[步骤1]请选择一个存档。\n\r[yellow]该存档的坐标必须和当前勇士坐标完全相同。\r\n将尝试从此处开始回放。",
- ], function () {
- core.status.event.id = 'replayRemain';
- core.lockControl();
- var saveIndex = core.saves.saveIndex;
- var page = parseInt((saveIndex - 1) / 5), offset = saveIndex - 5 * page;
- core.ui._drawSLPanel(10 * page + offset);
- });
-}
+ "\t[步骤1]请选择一个存档。\n\r[yellow]该存档的坐标必须和当前勇士坐标完全相同。\r\n将尝试从此处开始回放。",
+ ],
+ function () {
+ core.status.event.id = "replayRemain";
+ core.lockControl();
+ var saveIndex = core.saves.saveIndex;
+ var page = parseInt((saveIndex - 1) / 5),
+ offset = saveIndex - 5 * page;
+ core.ui._drawSLPanel(10 * page + offset);
+ }
+ );
+};
actions.prototype._clickReplay_replaySince = function () {
- core.closePanel();
- core.drawText([
- "\t[播放存档剩余录像]该功能为【接续播放录像】的简化版本,允许你播放\r[yellow]一个存档中剩余的录像\r,常常用于\r[yellow]录像局部优化\r。\n" +
+ core.closePanel();
+ core.drawText(
+ [
+ "\t[播放存档剩余录像]该功能为【接续播放录像】的简化版本,允许你播放\r[yellow]一个存档中剩余的录像\r,常常用于\r[yellow]录像局部优化\r。\n" +
"在录像正常播放中,你随时可以暂停并按S键进行存档;此时\r[yellow]剩余录像\r也会被记在存档中(在读档界面用\r[yellow][R]\r标识。)\n" +
"之后,你可以选择在路线优化后直接播放该存档的\r[yellow]剩余录像\r,而无需再像接续播放一样选择录像起点和终点。\n\n" +
"详细使用方法参见露珠录制的视频教程:\n\r[yellow]https://bilibili.com/video/BV1az4y1C78x",
- "请选择一个存档。\n\n\r[yellow]该存档需为录像播放中存的,且坐标必须和当前勇士坐标完全相同。\r\n将尝试播放此存档的剩余录像。",
- ], function () {
- core.status.event.id = 'replaySince';
- core.lockControl();
- var saveIndex = core.saves.saveIndex;
- var page = parseInt((saveIndex - 1) / 5), offset = saveIndex - 5 * page;
- core.ui._drawSLPanel(10 * page + offset);
- });
-}
+ "请选择一个存档。\n\n\r[yellow]该存档需为录像播放中存的,且坐标必须和当前勇士坐标完全相同。\r\n将尝试播放此存档的剩余录像。",
+ ],
+ function () {
+ core.status.event.id = "replaySince";
+ core.lockControl();
+ var saveIndex = core.saves.saveIndex;
+ var page = parseInt((saveIndex - 1) / 5),
+ offset = saveIndex - 5 * page;
+ core.ui._drawSLPanel(10 * page + offset);
+ }
+ );
+};
actions.prototype._clickReplay_download = function () {
- // if (core.hasFlag('debug')) return core.drawText("\t[系统提示]调试模式下无法下载录像");
- core.download(core.firstData.name + "_" + core.formatDate2() + ".h5route",
- LZString.compressToBase64(JSON.stringify({
- 'name': core.firstData.name,
- 'hard': core.status.hard,
- 'seed': core.getFlag('__seed__'),
- 'route': core.encodeRoute(core.status.route)
- })));
-
-}
+ // if (core.hasFlag('debug')) return core.drawText("\t[系统提示]调试模式下无法下载录像");
+ core.download(
+ core.firstData.name + "_" + core.formatDate2() + ".h5route",
+ LZString.compressToBase64(
+ JSON.stringify({
+ name: core.firstData.name,
+ hard: core.status.hard,
+ seed: core.getFlag("__seed__"),
+ route: core.encodeRoute(core.status.route),
+ })
+ )
+ );
+};
////// 回放选择界面时,放开某个键的操作 //////
actions.prototype._keyUpReplay = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.playSound('取消');
- core.ui.closePanel();
- return;
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickReplay);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ return;
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickReplay
+ );
+};
////// 游戏信息界面时的点击操作 //////
actions.prototype._clickGameInfo = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
+ if (this._out(x)) return;
+ var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
+ var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0: return core.ui._drawStatistics();
- case 1: return this._clickGameInfo_openProject();
- case 2: return this._clickGameInfo_openComments();
- case 3: return core.ui._drawHelp();
- case 4: return core.ui._drawAbout();
- case 5: return this._clickGameInfo_download();
- case 6:
- core.status.event.selection = 5;
- core.playSound('取消');
- core.ui._drawSettings();
- break;
- }
+ if (y >= topIndex && y < topIndex + choices.length) {
+ var selection = y - topIndex;
+ core.status.event.selection = selection;
+ switch (selection) {
+ case 0:
+ return core.ui._drawStatistics();
+ case 1:
+ return this._clickGameInfo_openProject();
+ case 2:
+ return this._clickGameInfo_openComments();
+ case 3:
+ return core.ui._drawHelp();
+ case 4:
+ return core.ui._drawAbout();
+ case 5:
+ return this._clickGameInfo_download();
+ case 6:
+ core.status.event.selection = 5;
+ core.playSound("取消");
+ core.ui._drawSettings();
+ break;
}
-}
+ }
+};
actions.prototype._clickGameInfo_openProject = function () {
- if (core.platform.isPC)
- window.open("editor.html", "_blank");
- else {
- core.myconfirm("即将离开本游戏,跳转至工程页面,确认?", function () {
- window.location.href = "editor-mobile.html";
- });
- }
-}
+ if (core.platform.isPC) window.open("editor.html", "_blank");
+ else {
+ core.myconfirm("即将离开本游戏,跳转至工程页面,确认?", function () {
+ window.location.href = "editor-mobile.html";
+ });
+ }
+};
actions.prototype._clickGameInfo_openComments = function () {
- if (core.platform.isPC) {
- window.open("/score.php?name=" + core.firstData.name, "_blank");
- }
- else {
- core.myconfirm("即将离开本游戏,跳转至评论页面,确认?", function () {
- window.location.href = "/score.php?name=" + core.firstData.name;
- });
- }
-}
+ if (core.platform.isPC) {
+ window.open("/score.php?name=" + core.firstData.name, "_blank");
+ } else {
+ core.myconfirm("即将离开本游戏,跳转至评论页面,确认?", function () {
+ window.location.href = "/score.php?name=" + core.firstData.name;
+ });
+ }
+};
actions.prototype._clickGameInfo_download = function () {
- if (core.platform.isPC)
- window.open(core.firstData.name + ".zip");
- else
- window.location.href = core.firstData.name + ".zip";
-}
+ if (core.platform.isPC) window.open(core.firstData.name + ".zip");
+ else window.location.href = core.firstData.name + ".zip";
+};
////// 游戏信息界面时,放开某个键的操作 //////
actions.prototype._keyUpGameInfo = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.status.event.selection = 5;
- core.playSound('取消');
- return core.ui._drawSettings();
- }
- this._selectChoices(core.status.event.ui.choices.length, keycode, this._clickGameInfo);
-}
+ if (keycode == 27 || keycode == 88) {
+ core.status.event.selection = 5;
+ core.playSound("取消");
+ return core.ui._drawSettings();
+ }
+ this._selectChoices(
+ core.status.event.ui.choices.length,
+ keycode,
+ this._clickGameInfo
+ );
+};
////// “虚拟键盘”界面时的点击操作 //////
actions.prototype._clickKeyBoard = function (x, y) {
- var m = this._HX_;
- if (y == this._HY_ - 3 && x >= m - 5 && x <= m + 5) {
- core.ui.closePanel();
- core.keyUp(112 + x + 5 - m);
- }
- if (y == this._HY_ - 2 && x >= m - 5 && x <= m + 4) {
- core.ui.closePanel();
- core.keyUp(x == m + 4 ? 48 : 49 + x + 5 - m); // 1-9: 49-57; 0: 48
- }
- // 字母
- var lines = [
- ["Q", "W", "E", "R", "T", "Y", "U", "I", "O", "P"],
- ["A", "S", "D", "F", "G", "H", "J", "K", "L"],
- ["Z", "X", "C", "V", "B", "N", "M"],
- ];
- if (y == this._HY_ - 1 && x >= m - 5 && x <= m + 4) {
- core.ui.closePanel();
- core.keyUp(lines[0][x + 5 - m].charCodeAt(0));
- }
- if (y == this._HY_ && x >= m - 5 && x <= m + 3) {
- core.ui.closePanel();
- core.keyUp(lines[1][x + 5 - m].charCodeAt(0));
- }
- if (y == this._HY_ + 1 && x >= m - 5 && x <= m + 1) {
- core.ui.closePanel();
- core.keyUp(lines[2][x + 5 - m].charCodeAt(0));
- }
- if (y == this._HY_ + 2 && x >= m - 5 && x <= m + 5) {
- core.ui.closePanel();
- if (x == m - 5) core.keyUp(189); // -
- if (x == m - 4) core.keyUp(187); // =
- if (x == m - 3) core.keyUp(219); // [
- if (x == m - 2) core.keyUp(221); // ]
- if (x == m - 1) core.keyUp(220); // \
- if (x == m) core.keyUp(186); // ;
- if (x == m + 1) core.keyUp(222); // '
- if (x == m + 2) core.keyUp(188); // ,
- if (x == m + 3) core.keyUp(190); // .
- if (x == m + 4) core.keyUp(191); // /
- if (x == m + 5) core.keyUp(192); // `
- }
- if (y == this._HY_ + 3 && x >= m - 5 && x <= m + 4) {
- core.ui.closePanel();
- if (x == m - 5) core.keyUp(27); // ESC
- if (x == m - 4) core.keyUp(9); // TAB
- if (x == m - 3) core.keyUp(20); // CAPS
- if (x == m - 2) core.keyUp(16); // SHIFT
- if (x == m - 1) core.keyUp(17); // CTRL
- if (x == m) core.keyUp(18); // ALT
- if (x == m + 1) core.keyUp(32); // SPACE
- if (x == m + 2) core.keyUp(8); // BACKSPACE
- if (x == m + 3) core.keyUp(13); // ENTER
- if (x == m + 4) core.keyUp(46); // DEL
- }
- if (y == this._HY_ + 4 && x >= m + 3 && x <= m + 5) {
- core.playSound('取消');
- core.ui.closePanel();
- }
-}
+ var m = this._HX_;
+ if (y == this._HY_ - 3 && x >= m - 5 && x <= m + 5) {
+ core.ui.closePanel();
+ core.keyUp(112 + x + 5 - m);
+ }
+ if (y == this._HY_ - 2 && x >= m - 5 && x <= m + 4) {
+ core.ui.closePanel();
+ core.keyUp(x == m + 4 ? 48 : 49 + x + 5 - m); // 1-9: 49-57; 0: 48
+ }
+ // 字母
+ var lines = [
+ ["Q", "W", "E", "R", "T", "Y", "U", "I", "O", "P"],
+ ["A", "S", "D", "F", "G", "H", "J", "K", "L"],
+ ["Z", "X", "C", "V", "B", "N", "M"],
+ ];
+ if (y == this._HY_ - 1 && x >= m - 5 && x <= m + 4) {
+ core.ui.closePanel();
+ core.keyUp(lines[0][x + 5 - m].charCodeAt(0));
+ }
+ if (y == this._HY_ && x >= m - 5 && x <= m + 3) {
+ core.ui.closePanel();
+ core.keyUp(lines[1][x + 5 - m].charCodeAt(0));
+ }
+ if (y == this._HY_ + 1 && x >= m - 5 && x <= m + 1) {
+ core.ui.closePanel();
+ core.keyUp(lines[2][x + 5 - m].charCodeAt(0));
+ }
+ if (y == this._HY_ + 2 && x >= m - 5 && x <= m + 5) {
+ core.ui.closePanel();
+ if (x == m - 5) core.keyUp(189); // -
+ if (x == m - 4) core.keyUp(187); // =
+ if (x == m - 3) core.keyUp(219); // [
+ if (x == m - 2) core.keyUp(221); // ]
+ if (x == m - 1) core.keyUp(220); // \
+ if (x == m) core.keyUp(186); // ;
+ if (x == m + 1) core.keyUp(222); // '
+ if (x == m + 2) core.keyUp(188); // ,
+ if (x == m + 3) core.keyUp(190); // .
+ if (x == m + 4) core.keyUp(191); // /
+ if (x == m + 5) core.keyUp(192); // `
+ }
+ if (y == this._HY_ + 3 && x >= m - 5 && x <= m + 4) {
+ core.ui.closePanel();
+ if (x == m - 5) core.keyUp(27); // ESC
+ if (x == m - 4) core.keyUp(9); // TAB
+ if (x == m - 3) core.keyUp(20); // CAPS
+ if (x == m - 2) core.keyUp(16); // SHIFT
+ if (x == m - 1) core.keyUp(17); // CTRL
+ if (x == m) core.keyUp(18); // ALT
+ if (x == m + 1) core.keyUp(32); // SPACE
+ if (x == m + 2) core.keyUp(8); // BACKSPACE
+ if (x == m + 3) core.keyUp(13); // ENTER
+ if (x == m + 4) core.keyUp(46); // DEL
+ }
+ if (y == this._HY_ + 4 && x >= m + 3 && x <= m + 5) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ }
+};
////// 光标界面时的点击操作 //////
actions.prototype._clickCursor = function (x, y, px, py) {
- if (x == core.status.automaticRoute.cursorX && y == core.status.automaticRoute.cursorY) {
- core.ui.closePanel();
- // 视为按下再放起
- this.doRegisteredAction('ondown', x, y, px, py);
- this.doRegisteredAction('onup', x, y, px, py);
- return;
- }
- core.status.automaticRoute.cursorX = x;
- core.status.automaticRoute.cursorY = y;
- core.ui._drawCursor();
-}
+ if (
+ x == core.status.automaticRoute.cursorX &&
+ y == core.status.automaticRoute.cursorY
+ ) {
+ core.ui.closePanel();
+ // 视为按下再放起
+ this.doRegisteredAction("ondown", x, y, px, py);
+ this.doRegisteredAction("onup", x, y, px, py);
+ return;
+ }
+ core.status.automaticRoute.cursorX = x;
+ core.status.automaticRoute.cursorY = y;
+ core.ui._drawCursor();
+};
////// 光标界面时,按下某个键的操作 //////
actions.prototype._keyDownCursor = function (keycode) {
- if (keycode == 37) { // left
- core.status.automaticRoute.cursorX--;
- core.playSound('光标移动');
- core.ui._drawCursor();
- return;
- }
- if (keycode == 38) { // up
- core.status.automaticRoute.cursorY--;
- core.playSound('光标移动');
- core.ui._drawCursor();
- return;
- }
- if (keycode == 39) { // right
- core.status.automaticRoute.cursorX++;
- core.playSound('光标移动');
- core.ui._drawCursor();
- return;
- }
- if (keycode == 40) { // down
- core.status.automaticRoute.cursorY++;
- core.playSound('光标移动');
- core.ui._drawCursor();
- return;
- }
-}
+ if (keycode == 37) {
+ // left
+ core.status.automaticRoute.cursorX--;
+ core.playSound("光标移动");
+ core.ui._drawCursor();
+ return;
+ }
+ if (keycode == 38) {
+ // up
+ core.status.automaticRoute.cursorY--;
+ core.playSound("光标移动");
+ core.ui._drawCursor();
+ return;
+ }
+ if (keycode == 39) {
+ // right
+ core.status.automaticRoute.cursorX++;
+ core.playSound("光标移动");
+ core.ui._drawCursor();
+ return;
+ }
+ if (keycode == 40) {
+ // down
+ core.status.automaticRoute.cursorY++;
+ core.playSound("光标移动");
+ core.ui._drawCursor();
+ return;
+ }
+};
////// 光标界面时,放开某个键的操作 //////
actions.prototype._keyUpCursor = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.playSound('取消');
- core.ui.closePanel();
- return;
- }
- if (keycode == 13 || keycode == 32 || keycode == 67 || keycode == 69) {
- core.playSound('确定');
- core.ui.closePanel();
- var x = core.status.automaticRoute.cursorX;
- var y = core.status.automaticRoute.cursorY;
- // 视为按下再放起
- this.doRegisteredAction('ondown', x, y, 32 * x + 16, 32 * y + 16);
- this.doRegisteredAction('onup', x, y, 32 * x + 16, 32 * y + 16);
- return;
- }
-}
+ if (keycode == 27 || keycode == 88) {
+ core.playSound("取消");
+ core.ui.closePanel();
+ return;
+ }
+ if (keycode == 13 || keycode == 32 || keycode == 67 || keycode == 69) {
+ core.playSound("确定");
+ core.ui.closePanel();
+ var x = core.status.automaticRoute.cursorX;
+ var y = core.status.automaticRoute.cursorY;
+ // 视为按下再放起
+ this.doRegisteredAction("ondown", x, y, 32 * x + 16, 32 * y + 16);
+ this.doRegisteredAction("onup", x, y, 32 * x + 16, 32 * y + 16);
+ return;
+ }
+};
diff --git a/libs/control.js b/libs/control.js
index 93b4a0a..8998ca2 100644
--- a/libs/control.js
+++ b/libs/control.js
@@ -194,7 +194,7 @@ control.prototype._animationFrame_globalAnimate = function (timestamp) {
if (timestamp - core.animateFrame.globalTime <= core.values.animateSpeed)
return;
core.status.globalAnimateStatus++;
- if (core.status.floorId) {
+ if (core.status.floorId) {
// Global Animate
core.status.globalAnimateObjs.forEach(function (block) {
core.drawBlock(block, core.status.globalAnimateStatus);
@@ -233,6 +233,7 @@ control.prototype._animationFrame_globalAnimate = function (timestamp) {
}
// Box animate
core.drawBoxAnimate();
+ if(core.status.event.id==="book"&&!core.book.isAnimate)core.book.update()
core.animateFrame.globalTime = timestamp;
};
@@ -1438,6 +1439,9 @@ control.prototype.checkBlock = function () {
var damage = core.status.checkBlock.damage[loc];
if (damage) {
core.status.hero.hp -= damage;
+ core.taskSystem.tasksInfo.forEach(v => v.tasks.forEach(a => {
+ if (a.type==="specialBlock"&&(!a.floorId||a.floorId.includes(core.status.floorId)) &&(core.status.checkBlock.type[loc]|| {})[a.specialType])a.has++
+ }))
var text =
Object.keys(core.status.checkBlock.type[loc] || {}).join(",") || "伤害";
core.drawTip("受到" + text + damage + "点");
@@ -2310,7 +2314,7 @@ control.prototype._replayAction_fly = function (action) {
var toIndex = core.floorIds.indexOf(floorId);
if (
!core.canUseItem("fly") ||
- (core.flags.flyNearStair && !core.nearStair() && !flags.canMoveFloor)
+ (core.flags.flyNearStair && !core.nearStair())
)
return false;
core.ui.drawFly(toIndex);
@@ -2424,7 +2428,8 @@ control.prototype._replayAction_ignoreInput = function (action) {
action.indexOf("input:") == 0 ||
action.indexOf("input2:") == 0 ||
action.indexOf("choices:") == 0 ||
- action.indexOf("random:") == 0
+ action.indexOf("random:") == 0||
+ action.indexOf("menu:")
) {
console.warn("警告!录像播放中出现了未知的 " + action + "!");
core.replay();
@@ -2489,6 +2494,7 @@ control.prototype.checkAutosave = function () {
////// 实际进行存读档事件 //////
control.prototype.doSL = function (id, type) {
+
switch (type) {
case "save":
this._doSL_save(id);
diff --git a/libs/core.js b/libs/core.js
index a6da0df..1f28d12 100644
--- a/libs/core.js
+++ b/libs/core.js
@@ -289,6 +289,7 @@ core.prototype.init = function (coreData, callback) {
core.canvas[name].canvas.width = (b ? core.__PIXELS__ : core._PX_);
core.canvas[name].canvas.height = (b ? core.__PIXELS__ : core._PY_);
}
+ core.canvas[name].imageSmoothingEnabled = false
}
core.loader._load(function () {
diff --git a/libs/enemys.js b/libs/enemys.js
index 122657a..f9373c2 100644
--- a/libs/enemys.js
+++ b/libs/enemys.js
@@ -204,12 +204,12 @@ enemys.prototype.getDamageString = function (enemy, x, y, floorId) {
else color = '#FF2222';
damage = core.formatBigNumber(damage, true);
- if (core.enemys.hasSpecial(enemy, 19))
+ /* if (core.enemys.hasSpecial(enemy, 19))
damage += "+";
if (core.enemys.hasSpecial(enemy, 21))
damage += "-";
if (core.enemys.hasSpecial(enemy, 11))
- damage += "^";
+ damage += "^";*/
}
return {
@@ -219,13 +219,13 @@ enemys.prototype.getDamageString = function (enemy, x, y, floorId) {
}
////// 接下来N个临界值和临界减伤计算 //////
-enemys.prototype.nextCriticals = function (enemy, number, x, y, floorId) {
+enemys.prototype.nextCriticals = function (enemy, number, x, y, floorId,config={}) {
if (typeof enemy == 'string') enemy = core.material.enemys[enemy];
number = number || 1;
var specialCriticals = this._nextCriticals_special(enemy, number, x, y, floorId);
if (specialCriticals != null) return specialCriticals;
- var info = this.getDamageInfo(enemy, null, x, y, floorId);
+ var info = this.getDamageInfo(enemy, config, x, y, floorId);
if (info == null) { // 如果未破防...
var overAtk = this._nextCriticals_overAtk(enemy, x, y, floorId);
if (overAtk == null) return [];
@@ -245,7 +245,7 @@ enemys.prototype.nextCriticals = function (enemy, number, x, y, floorId) {
return this._nextCriticals_useLoop(enemy, info, number, x, y, floorId);
}
else {
- return this._nextCriticals_useBinarySearch(enemy, info, number, x, y, floorId);
+ return this._nextCriticals_useBinarySearch(enemy, info, number, x, y, floorId,config);
}
}
else {
@@ -274,7 +274,7 @@ enemys.prototype._nextCriticals_overAtk = function (enemy, x, y, floorId) {
}
enemys.prototype._nextCriticals_special = function (enemy, number, x, y, floorId) {
- if (this.hasSpecial(enemy.special, 10) || this.hasSpecial(enemy.special, 3))
+ if (this.hasSpecial(enemy.special, 3))
return []; // 模仿or坚固临界
return null;
}
diff --git a/libs/events.js b/libs/events.js
index 3aabd20..3ed63fe 100644
--- a/libs/events.js
+++ b/libs/events.js
@@ -8,6 +8,7 @@ function events() {
events.prototype._init = function () {
this.eventdata = functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a.events;
this.commonEvent = events_c12a15a8_c380_4b28_8144_256cba95f760.commonEvent;
+ this.task = events_c12a15a8_c380_4b28_8144_256cba95f760.task;
this.systemEvents = {};
this.actions = {};
};
diff --git a/libs/maps.js b/libs/maps.js
index 35e6b8d..9fef466 100644
--- a/libs/maps.js
+++ b/libs/maps.js
@@ -35,6 +35,7 @@ maps.prototype._resetFloorImages = function () {
}
maps.prototype._setHDCanvasSize = function (ctx, width, height) {
+ if(main.replyChecking)return
ctx.setTransform(1, 0, 0, 1, 0, 0);
var ratio = core.domStyle.scale;
ratio *= devicePixelRatio;
@@ -1756,7 +1757,11 @@ maps.prototype._drawThumbnail_drawTempCanvas = function (floorId, blocks, option
} else core.maps._setHDCanvasSize(tempCanvas, width * 32, height * 32);
}
options.ctx = tempCanvas;
-
+ if(options.noEnabled){
+ tempCanvas.imageSmoothingEnabled= false
+ }else{
+ tempCanvas.imageSmoothingEnabled= true
+ }
// 地图过大的缩略图不绘制显伤
if (width * height > core.bigmap.threshold)
options.damage = false;
@@ -1803,6 +1808,12 @@ maps.prototype._drawThumbnail_realDrawTempCanvas = function (floorId, blocks, op
maps.prototype._drawThumbnail_drawToTarget = function (floorId, options) {
var ctx = core.getContextByName(options.ctx);
+ let imageSmoothingEnabled=ctx.imageSmoothingEnabled
+ if(options.noEnabled){
+ ctx.imageSmoothingEnabled= false
+ }else{
+ ctx.imageSmoothingEnabled= true
+ }
if (ctx == null) return;
var x = options.x || 0, y = options.y || 0, size = options.size || 1;
// size的含义改为(0,1]范围的系数以适配长方形,默认为1,楼传为3/4,SL界面为0.3
@@ -1860,6 +1871,7 @@ maps.prototype._drawThumbnail_drawToTarget = function (floorId, options) {
}
}
}
+ ctx.imageSmoothingEnabled= imageSmoothingEnabled
}
// -------- 获得某个点的图块信息 -------- //
@@ -2969,11 +2981,10 @@ maps.prototype.removeGlobalAnimate = function (x, y, name) {
maps.prototype.drawBoxAnimate = function () {
if (core.status.boxAnimateObjs.length == 0) return;
// check ui2
- if (main.mode == 'play' && core.status.boxAnimateObjs.filter(function (one) { return one.bigImage }).length > 0 && !core.dymCanvas.ui2) {
+ if (main.mode == 'play' && core.status.boxAnimateObjs.filter(function (one) { return one.bigImage }).length > 0 && !core.dymCanvas.ui2) {
core.createCanvas('ui2', 0, 0, core._PX_, core._PY_, 142);
}
core.clearMap('ui2');
-
core.status.boxAnimateObjs.forEach(function (obj) {
if (obj.bigImage) {
var ctx = obj.ctx || 'ui2';
@@ -2982,14 +2993,18 @@ maps.prototype.drawBoxAnimate = function () {
var actual_width = Math.min(per_width, obj.max_width || per_width), actual_height = per_height * actual_width / per_width;
var x = obj.centerX - actual_width / 2, y = obj.centerY - actual_height / 2;
core.clearMap(ctx, x, y, actual_width, actual_height);
+ if(!obj.nobackground){
core.fillRect(ctx, x, y, actual_width, actual_height, core.material.groundPattern);
- core.strokeRect(ctx, x, y, actual_width, actual_height, 'gold', 2);
+ core.strokeRect(ctx, x, y, actual_width, actual_height, 'gold', 2)
+ };
core.drawImage(ctx, obj.bigImage, sx, sy, per_width, per_height,
obj.centerX - actual_width / 2, obj.centerY - actual_height / 2, actual_width, actual_height);
} else {
var ctx = obj.ctx || 'ui';
- core.clearMap(ctx, obj.bgx, obj.bgy, obj.bgWidth, obj.bgHeight);
- core.fillRect(ctx, obj.bgx, obj.bgy, obj.bgWidth, obj.bgHeight, core.material.groundPattern);
+ core.clearMap(ctx, obj.bgx, obj.bgy, obj.bgWidth, obj.bgHeight);
+ if(!obj.nobackground){
+ core.fillRect(ctx, obj.bgx, obj.bgy, obj.bgWidth, obj.bgHeight,core.material.groundPattern);
+ }
core.drawImage(ctx, obj.image, core.status.globalAnimateStatus % obj.animate * 32, obj.pos,
32, obj.height, obj.x, obj.y, obj.dw || 32, obj.dh || obj.height);
}
diff --git a/libs/ui.js b/libs/ui.js
index bcead0e..08cd1d8 100644
--- a/libs/ui.js
+++ b/libs/ui.js
@@ -1241,6 +1241,7 @@ ui.prototype._drawTextContent_drawChar = function (tempCtx, content, config, ch)
// 检查是不是自动换行
var charwidth = core.calWidth(tempCtx, ch) + config.letterSpacing;
if (config.maxWidth != null) {
+
if (config.offsetX + charwidth > config.maxWidth) {
// --- 当前应当换行,然而还是检查一下是否是forbidStart
if (!config.forceChangeLine && forbidStart.indexOf(ch) >= 0) {
@@ -1269,7 +1270,9 @@ ui.prototype._drawTextContent_drawChar = function (tempCtx, content, config, ch)
// 输出
var left = config.offsetX, top = config.offsetY + config.topMargin;
- core.fillText(tempCtx, ch, left, top);
+ tempCtx.lineWidth = 2;
+
+ tempCtx.fillText( ch, left, top);
config.blocks.push({
left: config.offsetX, top: config.offsetY,
width: charwidth, height: config.currfont + config.lineMargin,
@@ -2355,7 +2358,7 @@ ui.prototype._drawBookDetail = function (index) {
if (!enemy) return;
var content = info[1].join("\n");
core.status.event.id = 'book-detail';
- core.animateFrame.tip = null;
+ core.animateFrame.tip = [];
core.clearMap('data');
var left = 10, width = core._PX_ - 2 * left, right = left + width;
@@ -2553,7 +2556,7 @@ ui.prototype.drawFly = function (page) {
}
var size = 0.75;
core.strokeRect('ui', 16, 64, size * core._PX_, size * core._PY_, '#FFFFFF', 2);
- core.drawThumbnail(floorId, null, { ctx: 'ui', x: 16, y: 64, size: size, damage: true, all: true });
+ core.drawThumbnail(floorId, null, { ctx: 'ui', x: 16, y: 64, size: size, damage: true, all: true , noEnabled: true });
}
////// 绘制中心对称飞行器
@@ -2565,7 +2568,7 @@ ui.prototype._drawCenterFly = function () {
var toX = core.bigmap.width - 1 - core.getHeroLoc('x'), toY = core.bigmap.height - 1 - core.getHeroLoc('y');
this.clearUI();
core.fillRect('ui', 0, 0, core._PX_, core._PY_, '#000000');
- core.drawThumbnail(null, null, { heroLoc: core.status.hero.loc, heroIcon: core.status.hero.image, ctx: 'ui', centerX: toX, centerY: toY });
+ core.drawThumbnail(null, null, { heroLoc: core.status.hero.loc, heroIcon: core.status.hero.image, ctx: 'ui', centerX: toX, centerY: toY, noEnabled: true });
var offsetX = core.clamp(toX - core._HALF_WIDTH_, 0, core.bigmap.width - core._WIDTH_),
offsetY = core.clamp(toY - core._HALF_HEIGHT_, 0, core.bigmap.height - core._HEIGHT_);
core.fillRect('ui', (toX - offsetX) * 32, (toY - offsetY) * 32, 32, 32, fillstyle);
@@ -2581,11 +2584,11 @@ ui.prototype._drawViewMaps = function (index, x, y) {
core.status.event.id = 'viewMaps';
this.clearUI();
if (index == null) return this._drawViewMaps_drawHint();
- core.animateFrame.tip = null;
+ core.animateFrame.tip = [];
core.status.checkBlock.cache = {};
var data = this._drawViewMaps_buildData(index, x, y);
core.fillRect('ui', 0, 0, core._PX_, core._PY_, '#000000');
- core.drawThumbnail(data.floorId, null, { damage: data.damage, ctx: 'ui', centerX: data.x, centerY: data.y, all: data.all });
+ core.drawThumbnail(data.floorId, null, { damage: data.damage, ctx: 'ui', centerX: data.x, centerY: data.y, all: data.all , noEnabled: true });
core.clearMap('data');
core.setTextAlign('data', 'left');
core.setFont('data', '16px Arial');
diff --git a/project/animates/hand.animate b/project/animates/hand.animate
index 936d7d4..5a87b0b 100644
--- a/project/animates/hand.animate
+++ b/project/animates/hand.animate
@@ -1 +1 @@
-{"ratio": 2.0, "bitmaps": ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", ""], "frame_max": 16, "frames": [[[0, 0, 0, 30, 120, 0, 0]], [[0, 0, 0, 35, 153, 0, 0]], [[0, 0, 0, 40, 187, 0, 0]], [[0, 0, 0, 45, 221, 0, 0]], [[0, 0, 0, 50, 255, 0, 0]], [[0, 0, 0, 55, 255, 0, 0]], [[0, 0, 0, 60, 255, 0, 0]], [[0, 0, 0, 65, 255, 0, 0]], [[0, 0, 0, 70, 255, 0, 0]], [[0, 0, 0, 72, 255, 0, 0]], [[0, 0, 0, 75, 255, 0, 0]], [[0, 0, 0, 77, 255, 0, 0]], [[1, 0, 0, 90, 255, 0, 0]], [[1, 0, 0, 90, 255, 0, 0]], [[1, 0, 0, 90, 170, 0, 0]], [[1, 0, 0, 90, 120, 0, 0]]], "se": {"1": "attack.opus"}, "pitch": {"1": 100}}
\ No newline at end of file
+{"ratio":2,"se":{"1":"attack.mp3"},"bitmaps":["","","","","","","","","",""],"frame_max":8,"frames":[[[0,0,0,30,120]],[[0,0,0,50,255]],[[0,0,0,70,255]],[[1,0,0,80,255]],[[1,0,0,90,255]],[[2,0,0,90,120]],[],[]],"pitch":{"1":100}}
\ No newline at end of file
diff --git a/project/animates/jianji.animate b/project/animates/jianji.animate
index fb9fe34..2720aaf 100644
--- a/project/animates/jianji.animate
+++ b/project/animates/jianji.animate
@@ -1 +1 @@
-{"ratio": 2.0, "bitmaps": ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", ""], "frame_max": 17, "frames": [[[0, 0, 0, 60, 255, 1, 60]], [[1, 0, 0, 60, 255, 1, 60]], [[2, 0, 0, 60, 255, 1, 60]], [[3, 0, 0, 60, 255, 1, 60]], [[4, 0, 0, 60, 255, 1, 60]], [[5, 0, 0, 60, 255, 1, 60]], [[6, 0, 0, 60, 255, 1, 60]], [[7, 0, 0, 60, 255, 1, 60]], [[8, 0, 0, 60, 255, 1, 60]], [[9, 0, 0, 60, 255, 1, 60]], [[10, 0, 0, 60, 255, 1, 60]], [[11, 0, 0, 60, 255, 1, 60]], [[12, 0, 0, 60, 255, 1, 60]], [[13, 0, 0, 60, 241, 1, 60]], [[14, 0, 0, 60, 227, 1, 60]], [[15, 0, 0, 60, 213, 1, 60]], [[16, 0, 0, 60, 200, 1, 60]]]}
\ No newline at end of file
+{"ratio":2,"bitmaps":["","","","","","","","","","","","","","","","","","","",""],"frame_max":20,"frames":[[[5,0,0,50,255,0,120]],[[6,0,0,50,255,0,120]],[[7,0,0,50,255,0,120]],[[8,0,0,50,255,0,120]],[[5,0,0,60,255,1,60]],[[5,0,0,60,255,1,60]],[[5,0,0,60,255,1,60]],[[6,0,0,60,255,1,60]],[[7,0,0,60,255,1,60]],[[8,0,0,60,200,1,60]],[[5,-8,-8,60,255,0,60]],[[6,0,-8,60,200,0,60]],[[6,0,-8,60,255,0,60]],[[6,0,-8,60,255,0,60]],[[7,0,-8,60,255,0,60]],[[8,0,-8,60,255,0,60]],[[8,0,-8,60,255,0,60]],[[9,0,-8,60,255,0,60]],[[9,0,-8,60,200,0,60]],[[9,0,-8,60,50,0,60]]]}
\ No newline at end of file
diff --git a/project/animates/jianji2.animate b/project/animates/jianji2.animate
index 4991c6f..a3fd83b 100644
--- a/project/animates/jianji2.animate
+++ b/project/animates/jianji2.animate
@@ -1 +1 @@
-{"ratio": 1.0, "bitmaps": ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", ""], "frame_max": 21, "frames": [[[0, 0, 0, 100, 255, 0, 0]], [[1, 0, 0, 100, 255, 0, 0]], [[2, 0, 0, 100, 255, 0, 0]], [[3, 0, 0, 100, 255, 0, 0]], [[4, 0, 0, 100, 255, 0, 0]], [[5, 0, 0, 100, 255, 0, 0]], [[6, 0, 0, 100, 255, 0, 0]], [[7, 0, 0, 100, 255, 0, 0]], [[8, 0, 0, 100, 255, 0, 0]], [[9, 0, 0, 100, 255, 0, 0]], [[10, 0, 0, 100, 255, 0, 0]], [[11, 0, 0, 100, 255, 0, 0]], [[12, 0, 0, 100, 255, 0, 0]], [[13, 0, 0, 100, 255, 0, 0]], [[14, 0, 0, 100, 255, 0, 0]], [[15, 0, 0, 100, 255, 0, 0]], [[16, 0, 0, 100, 255, 0, 0]], [[17, 0, 0, 100, 255, 0, 0]], [[18, 0, 0, 100, 255, 0, 0]], [[19, 0, 0, 100, 255, 0, 0]], [[20, 0, 0, 100, 255, 0, 0]]]}
\ No newline at end of file
+{"ratio": 1.0, "bitmaps": ["", "", "", "", "", "", ""], "frame_max": 7, "frames": [[[0, 0, 0, 100, 255, 0, 0]], [[1, 0, 0, 100, 255, 0, 0]], [[2, 0, 0, 100, 255, 0, 0]], [[3, 0, 0, 100, 255, 0, 0]], [[4, 0, 0, 100, 255, 0, 0]], [[5, 0, 0, 100, 255, 0, 0]], [[6, 0, 0, 100, 255, 0, 0]]]}
\ No newline at end of file
diff --git a/project/animates/sword.animate b/project/animates/sword.animate
index 26a8fc2..21cc63a 100644
--- a/project/animates/sword.animate
+++ b/project/animates/sword.animate
@@ -1 +1 @@
-{"ratio":2,"bitmaps":["","","","","","","","","","","","","","","","","","","",""],"frame_max":5,"frames":[[[0,8,32,30,100]],[[0,-16,32,50,130]],[[0,-24,40,80,150]],[[0,-48,24,90,180],[1,-8,40,100,255]],[[0,-56,24,100,200],[1,-8,24,100,255]]],"se":{},"pitch":{}}
\ No newline at end of file
+{"ratio":2,"bitmaps":["","","","","","","","","","","","","","","","","","","",""],"frame_max":5,"frames":[[[0,8,32,30,100]],[[0,-16,32,50,130]],[[0,-24,40,80,150]],[[0,-48,24,90,180],[1,-8,40,100,255]],[[0,-56,24,100,200],[1,-8,24,100,255]]]}
\ No newline at end of file
diff --git a/project/animates/thunder.animate b/project/animates/thunder.animate
index 9383a1b..f5447fe 100644
--- a/project/animates/thunder.animate
+++ b/project/animates/thunder.animate
@@ -1 +1 @@
-{"ratio":1,"bitmaps":["","","","","","","","","","","",""],"frame_max":12,"frames":[[[0,0,-56,50,150,0,0]],[[1,0,-56,50,150,0,0]],[[2,0,-56,50,150,0,0]],[[3,0,-40,70,200,0,0]],[[4,0,-40,70,200,0,0]],[[5,0,-40,70,200,0,0]],[[6,0,-8,100,255,0,0]],[[7,0,-8,100,255,0,0]],[[8,0,-8,100,255,0,0]],[[9,0,-8,100,150,0,0]],[[10,0,-8,100,150,0,0]],[[11,0,-8,100,150,0,0]]],"se":{},"pitch":{}}
\ No newline at end of file
+{"ratio":1,"se":"124-Thunder02.ogg","bitmaps":["","","","","","","","","",""],"frame_max":16,"frames":[[[2,0,-56,50,150,0,0]],[[2,0,-40,70,200,0,0]],[[2,0,-8,100,255,0,0]],[[3,0,-8,100,150,0,0]],[[3,0,-8,100,255,0,0]],[[2,0,-8,100,255,0,0]],[[2,0,-8,100,160,0,0]],[[2,0,-8,100,255,0,0]],[[3,0,-8,100,255,0,0]],[[3,0,-8,100,200,0,0]],[[0,0,-8,100,255,0,0]],[[0,0,-8,100,150,0,0]],[[1,0,-8,100,200,0,0]],[[1,0,-8,100,150,0,0]],[[0,0,-8,100,100,0,0]],[]]}
\ No newline at end of file
diff --git a/project/animates/yongchang.animate b/project/animates/yongchang.animate
index 2173c5d..c4365f4 100644
--- a/project/animates/yongchang.animate
+++ b/project/animates/yongchang.animate
@@ -1 +1 @@
-{"ratio": 2.0, "bitmaps": ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", ""], "frame_max": 16, "frames": [[[2, 0, -24, 50, 120, 0, 0]], [[3, 0, -24, 50, 120, 0, 0]], [[2, 0, -24, 50, 255]], [[3, 0, -24, 50, 255], [5, -56, 40, 50, 255], [5, 0, 64, 30, 255], [5, 56, 32, 40, 255]], [[4, 0, -24, 50, 255], [5, 56, 8, 40, 255], [5, -32, 32, 30, 255], [5, -56, 8, 50, 255], [5, 0, 40, 30, 255]], [[3, 0, -24, 50, 255], [5, -56, -16, 50, 255], [5, 56, -16, 40, 255], [5, 0, 24, 30, 255], [5, -32, 0, 30, 255]], [[4, 0, -24, 50, 255, 0, 0], [5, -56, -32, 50, 255, 0, 0], [5, 56, -32, 40, 255, 0, 0], [5, 0, 8, 30, 255, 0, 0], [5, -32, -16, 30, 255, 0, 0]], [[3, 0, -24, 50, 255, 0, 0], [5, -56, -48, 50, 255, 0, 0], [5, 56, -48, 40, 255, 0, 0], [5, 0, 8, 30, 255, 0, 0], [5, -32, -24, 30, 255, 0, 0]], [[2, 0, -24, 50, 255, 0, 0], [5, -56, -64, 50, 150, 0, 0], [5, 56, -56, 40, 150, 0, 0], [5, 0, -16, 30, 150, 0, 0], [5, -32, -32, 30, 150, 0, 0]], [[3, 0, -24, 50, 255, 0, 0], [5, -56, -80, 50, 150, 0, 0], [5, 56, -72, 40, 150, 0, 0], [5, 0, -32, 30, 150, 0, 0], [5, -32, -48, 30, 150, 0, 0]], [[4, 0, -24, 50, 120, 0, 0], [5, -56, -96, 50, 80, 0, 0], [5, 56, -96, 40, 100, 0, 0], [5, -32, -64, 30, 100, 0, 0], [5, 0, -48, 30, 100, 0, 0]], [[4, 0, -24, 50, 255, 0, 0], [5, -56, -112, 50, 80, 0, 0], [5, 56, -112, 40, 100, 0, 0], [5, -32, -80, 30, 100, 0, 0], [5, 0, -72, 30, 100, 0, 0]], [[3, 0, -24, 50, 255, 0, 0]], [[2, 0, -24, 50, 255, 0, 0]], [[2, 0, -24, 50, 80, 0, 0]], [[2, 0, -24, 50, 80, 0, 0]]]}
\ No newline at end of file
+{"ratio":2,"bitmaps":["","","","","","","","","",""],"frame_max":16,"frames":[[[2,0,-24,50,120]],[[3,0,-24,50,120]],[[2,0,-24,50,255]],[[3,0,-24,50,255],[5,-56,40,50,255],[5,0,64,30,255],[5,56,32,40,255]],[[4,0,-24,50,255],[5,56,8,40,255],[5,-32,32,30,255],[5,-56,8,50,255],[5,0,40,30,255]],[[3,0,-24,50,255],[5,-56,-16,50,255],[5,56,-16,40,255],[5,0,24,30,255],[5,-32,0,30,255]],[[4,0,-24,50,255],[5,-56,-32,50,255],[5,56,-32,40,255],[5,0,8,30,255],[5,-32,-16,30,255]],[[3,0,-24,50,255],[5,-56,-48,50,255],[5,56,-48,40,255],[5,0,8,30,255],[5,-32,-24,30,255]],[[2,0,-24,50,255],[5,-56,-64,50,150],[5,56,-56,40,150],[5,0,-16,30,150],[5,-32,-32,30,150]],[[3,0,-24,50,255],[5,-56,-80,50,150],[5,56,-72,40,150],[5,0,-32,30,150],[5,-32,-48,30,150]],[[4,0,-24,50,120],[5,-56,-96,50,80],[5,56,-96,40,100],[5,-32,-64,30,100],[5,0,-48,30,100]],[[4,0,-24,50,255],[5,-56,-112,50,80],[5,56,-112,40,100],[5,-32,-80,30,100],[5,0,-72,30,100]],[[3,0,-24,50,255]],[[2,0,-24,50,255]],[[2,0,-24,50,80]],[[2,0,-24,50,80]]]}
\ No newline at end of file
diff --git a/project/animates/zone.animate b/project/animates/zone.animate
index fa88a37..8c2b604 100644
--- a/project/animates/zone.animate
+++ b/project/animates/zone.animate
@@ -1 +1 @@
-{"ratio": 2.0, "bitmaps": ["", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", "", ""], "frame_max": 18, "frames": [[[0, 0, 32, 30, 100]], [[0, 0, 32, 30, 100]], [[0, 0, 32, 30, 100]], [[0, 0, 16, 50, 130]], [[0, 0, 16, 50, 130]], [[0, 0, 16, 50, 130]], [[0, 0, 0, 80, 150, 0, 0]], [[0, 0, 0, 80, 150, 0, 0]], [[0, 0, 0, 80, 150, 0, 0]], [[0, 0, -8, 90, 180, 0, 0], [1, 24, 24, 100, 255, 0, 0]], [[0, 0, -8, 90, 180, 0, 0], [1, 24, 24, 100, 255, 0, 0]], [[0, 0, -8, 90, 180, 0, 0], [1, 24, 24, 100, 255, 0, 0]], [[0, 0, -8, 100, 200, 0, 0], [1, 24, 8, 100, 255, 0, 0]], [[0, 0, -8, 100, 200, 0, 0], [1, 24, 8, 100, 255, 0, 0]], [[0, 0, -8, 100, 200, 0, 0], [1, 24, 8, 100, 255, 0, 0]], [[0, 0, -8, 100, 255, 0, 0]], [[0, 0, -8, 100, 255, 0, 0]], [[0, 0, -8, 100, 255, 0, 0]]], "se": {"1": "zone.opus"}, "pitch": {"1": 100}}
\ No newline at end of file
+{"ratio":2,"se":"zone.mp3","bitmaps":["","","","","","","","","",""],"frame_max":6,"frames":[[[0,0,32,30,100]],[[0,0,16,50,130]],[[0,0,0,80,150]],[[0,0,-8,90,180],[1,24,24,100,255]],[[0,0,-8,100,200],[1,24,8,100,255]],[[0,0,-8,100,255]]]}
\ No newline at end of file
diff --git a/project/data.js b/project/data.js
index 33e8fbd..2dd0db7 100644
--- a/project/data.js
+++ b/project/data.js
@@ -28,6 +28,9 @@ var data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d =
"yiqu8",
"yiqu9",
"yiqu10",
+ "yiqu11",
+ "yiqu12",
+ "yiqu13",
"changguan1",
"yushou",
"zhujuejia",
@@ -907,7 +910,8 @@ var data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d =
"7.webp",
"10.webp",
"C5.webp",
- "c6.png"
+ "c6.png",
+ "2233.png"
],
"animates": [
"hand",
@@ -1453,8 +1457,7 @@ var data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d =
"HATTEN",
"Verdana",
"number",
- "pala",
- "simhei"
+ "pala"
],
"nameMap": {
"确定": "confirm.opus",
@@ -1555,7 +1558,6 @@ var data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d =
},
"flags": {
"itemDetail": true,
- "useBetweenLight": true,
"__mdef_buff__": 0,
"popmove": true
},
@@ -2126,7 +2128,7 @@ var data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d =
"animateSpeed": 300,
"moveSpeed": 100,
"statusCanvasRowsOnMobile": 3,
- "floorChangeTime": 0,
+ "floorChangeTime": 500,
"yellowGem": 2
},
"flags": {
@@ -2161,7 +2163,7 @@ var data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d =
"ignoreChangeFloor": true,
"canGoDeadZone": false,
"enableMoveDirectly": true,
- "enableRouteFolding": true,
+ "enableRouteFolding": false,
"disableShopOnDamage": false,
"blurFg": true,
"hideLeftStatusBar": false
diff --git a/project/enemys.js b/project/enemys.js
index 5e8a014..707f3f2 100644
--- a/project/enemys.js
+++ b/project/enemys.js
@@ -1,21 +1,21 @@
var enemys_fcae963b_31c9_42b4_b48c_bb48d09f3f80 =
{
- "greenSlime": {"name":"绿头怪","hp":64,"atk":32,"def":2,"money":0,"exp":1,"point":0,"special":[],"mdef":0,"spell":0,"speed":17},
+ "greenSlime": {"name":"绿头怪","hp":64,"atk":32,"def":2,"money":0,"exp":1,"point":0,"special":[],"mdef":0,"spell":0,"speed":18},
"redSlime": {"name":"红头怪","hp":84,"atk":27,"def":6,"money":0,"exp":1,"point":0,"special":[],"value":null,"mdef":0,"spell":0,"speed":19},
- "blackSlime": {"name":"青头怪","hp":222,"atk":46,"def":10,"money":0,"exp":0,"point":0,"special":[],"mdef":0,"spell":0,"speed":15,"damage":null},
- "slimelord": {"name":"怪王","hp":790,"atk":48,"def":8,"money":0,"exp":0,"point":0,"special":[],"mdef":0,"spell":0,"speed":20},
- "bat": {"name":"小蝙蝠","hp":46,"atk":49,"def":0,"money":0,"exp":1,"point":0,"special":[1],"mdef":0,"speed":29,"spell":0},
- "bigBat": {"name":"大蝙蝠","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
+ "blackSlime": {"name":"青头怪","hp":222,"atk":46,"def":10,"money":0,"exp":2,"point":0,"special":[],"mdef":0,"spell":0,"speed":16,"damage":null},
+ "slimelord": {"name":"怪王","hp":810,"atk":48,"def":8,"money":0,"exp":4,"point":0,"special":[],"mdef":0,"spell":0,"speed":20},
+ "bat": {"name":"小蝙蝠","hp":46,"atk":49,"def":0,"money":0,"exp":1,"point":0,"special":[1],"mdef":0,"speed":34,"spell":0},
+ "bigBat": {"name":"大蝙蝠","hp":88,"atk":94,"def":12,"money":0,"exp":2,"point":0,"special":[1],"mdef":0,"speed":52,"spell":0,"displayIdInBook":null},
"redBat": {"name":"红蝙蝠","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[],"mdef":0,"spell":0,"speed":1},
"vampire": {"name":"冥灵魔王","hp":888,"atk":888,"def":888,"money":888,"exp":888,"point":0,"special":[6],"n":8,"mdef":0,"spell":0,"speed":1},
- "skeleton": {"name":"骷髅人","hp":77,"atk":77,"def":7,"money":0,"exp":2,"point":0,"special":0,"mdef":0,"spell":0,"speed":17},
+ "skeleton": {"name":"骷髅人","hp":77,"atk":77,"def":7,"money":0,"exp":2,"point":0,"special":0,"mdef":0,"spell":0,"speed":20},
"skeletonCaptain": {"name":"骷髅队长","hp":226,"atk":66,"def":1,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":18},
"zombie": {"name":"兽人","hp":444,"atk":43,"def":9,"money":0,"exp":3,"point":0,"special":[],"mdef":0,"spell":0,"speed":27},
"zombieKnight": {"name":"兽人武士","hp":10000,"atk":100,"def":100,"money":0,"exp":0,"point":0,"special":[22],"speed":10,"mdef":0,"damage2":20,"spell":0},
"rock": {"name":"石头人","hp":50,"atk":50,"def":0,"money":3,"exp":0,"point":0,"special":3,"damage2":15,"mdef":0,"spell":0,"speed":1},
- "bluePriest": {"name":"初级法师","hp":108,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[],"mdef":0,"spell":270,"speed":12},
- "redPriest": {"name":"高级法师","hp":162,"atk":0,"def":1,"money":0,"exp":0,"point":0,"special":[1],"mdef":0,"spell":308,"speed":14},
- "brownWizard": {"name":"初级巫师","hp":162,"atk":120,"def":1,"money":16,"exp":0,"point":0,"special":[],"value":null,"range":2,"mdef":0,"spell":66,"speed":14},
+ "bluePriest": {"name":"初级法师教程","hp":108,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[],"mdef":0,"spell":270,"speed":12},
+ "redPriest": {"name":"高级法师","hp":162,"atk":0,"def":1,"money":0,"exp":0,"point":0,"special":[1],"mdef":0,"spell":308,"speed":16},
+ "brownWizard": {"name":"初级巫师","hp":162,"atk":120,"def":1,"money":16,"exp":0,"point":0,"special":[],"value":null,"range":2,"mdef":0,"spell":66,"speed":16},
"redWizard": {"name":"高级巫师","hp":1000,"atk":1200,"def":0,"money":160,"exp":0,"point":0,"special":15,"value":200,"zoneSquare":true,"mdef":0,"spell":0,"speed":1},
"swordsman": {"name":"双手剑士","hp":100,"atk":120,"def":0,"money":6,"exp":3,"point":0,"special":4,"mdef":0,"spell":0,"speed":1},
"soldier": {"name":"冥战士","hp":120,"atk":50,"def":8,"money":10,"exp":7,"point":0,"special":0,"mdef":0,"spell":0,"speed":8},
@@ -43,19 +43,19 @@ var enemys_fcae963b_31c9_42b4_b48c_bb48d09f3f80 =
"evilBat": {"name":"邪恶蝙蝠","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"silverSlimelord": {"name":"银怪王","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"goldSlimelord": {"name":"金怪王","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
- "skeletonWarrior": {"name":"骷髅士兵","hp":226,"atk":66,"def":1,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":18,"displayIdInBook":null},
+ "skeletonWarrior": {"name":"骷髅士兵","hp":107,"atk":97,"def":21,"money":0,"exp":4,"point":0,"special":0,"mdef":0,"spell":0,"speed":20,"displayIdInBook":null},
"whiteSlimeman": {"name":"水银战士","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
- "slimeman": {"name":"影子战士","hp":243,"atk":28,"def":5,"money":0,"exp":0,"point":0,"special":[],"atkValue":2,"defValue":3,"mdef":0,"spell":0,"speed":69},
- "yellowGateKeeper": {"name":"初级卫兵","hp":80,"atk":25,"def":5,"money":3,"exp":1,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
+ "slimeman": {"name":"影子战士","hp":243,"atk":28,"def":5,"money":0,"exp":2,"point":0,"special":[],"atkValue":2,"defValue":3,"mdef":0,"spell":0,"speed":73},
+ "yellowGateKeeper": {"name":"初级卫兵","hp":192,"atk":49,"def":33,"money":0,"exp":4,"point":0,"special":0,"mdef":0,"spell":0,"speed":19},
"blueGateKeeper": {"name":"中级卫兵","hp":80,"atk":25,"def":5,"money":3,"exp":1,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"redGateKeeper": {"name":"高级卫兵","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"magicMaster": {"name":"黑暗大法师","hp":100,"atk":120,"def":0,"money":12,"exp":0,"point":0,"special":11,"value":0.3333333333333333,"add":true,"notBomb":true,"mdef":0,"spell":0,"speed":1},
"devilWarrior": {"name":"魔神武士","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"fairyEnemy": {"name":"仙子","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"dragon": {"name":"魔龙","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"bigImage":null,"mdef":0,"spell":0,"speed":1},
- "skeletonKnight": {"name":"骷髅武士","hp":330,"atk":113,"def":2,"money":0,"exp":4,"point":0,"special":0,"mdef":0,"spell":0,"speed":20},
+ "skeletonKnight": {"name":"猩红骷髅","hp":330,"atk":113,"def":2,"money":0,"exp":4,"point":0,"special":0,"mdef":0,"spell":0,"speed":22},
"skeletonPresbyter": {"name":"骷髅巫师","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
- "ironRock": {"name":"铁面人","hp":111,"atk":97,"def":37,"money":0,"exp":0,"point":0,"special":[3],"mdef":0,"spell":0,"speed":14},
+ "ironRock": {"name":"铁面人","hp":110,"atk":97,"def":37,"money":0,"exp":0,"point":0,"special":[3],"mdef":0,"spell":0,"speed":15},
"grayRock": {"name":"灰色石头人","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"yellowPriest": {"name":"中级法师","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":1},
"evilPrincess": {"name":"痛苦魔女","hp":1000,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[10],"mdef":0,"spell":0,"speed":1},
@@ -81,8 +81,17 @@ var enemys_fcae963b_31c9_42b4_b48c_bb48d09f3f80 =
"bearLeft": {"name":"熊出没","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[],"faceIds":{"down":"bearDown","left":"bearLeft","right":"bearRight","up":"bearUp"},"mdef":0,"spell":0,"speed":1},
"bearRight": {"name":"熊出没","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[],"faceIds":{"down":"bearDown","left":"bearLeft","right":"bearRight","up":"bearUp"},"mdef":0,"spell":0,"speed":1},
"bearUp": {"name":"熊出没","hp":0,"atk":0,"def":0,"money":0,"exp":0,"point":0,"special":[],"faceIds":{"down":"bearDown","left":"bearLeft","right":"bearRight","up":"bearUp"},"mdef":0,"spell":0,"speed":1},
- "E421": {"name":"蓝头怪","hp":104,"atk":33,"def":8,"money":0,"exp":1,"point":0,"special":[],"value":null,"mdef":0,"spell":0,"speed":19,"displayIdInBook":null},
+ "E421": {"name":"蓝头怪","hp":104,"atk":33,"def":8,"money":0,"exp":1,"point":0,"special":[],"value":null,"mdef":0,"spell":0,"speed":20,"displayIdInBook":null},
"E422": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
- "E425": {"name":"黄骷髅","hp":226,"atk":66,"def":1,"money":0,"exp":0,"point":0,"special":0,"mdef":0,"spell":0,"speed":18,"displayIdInBook":null},
- "E426": {"name":"小偷","hp":377,"atk":53,"def":17,"mdef":0,"speed":34,"money":50,"exp":10,"point":0,"special":[],"spell":0}
+ "E425": {"name":"黄骷髅","hp":226,"atk":66,"def":1,"money":0,"exp":3,"point":0,"special":0,"mdef":0,"spell":0,"speed":20,"displayIdInBook":null},
+ "E426": {"name":"小偷","hp":377,"atk":53,"def":17,"mdef":0,"speed":34,"money":50,"exp":10,"point":0,"special":[],"spell":0},
+ "E428": {"name":"初级法师","hp":216,"atk":0,"def":21,"money":0,"exp":4,"point":0,"special":[],"mdef":0,"spell":55,"speed":14,"displayIdInBook":null},
+ "E429": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
+ "E430": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
+ "E431": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
+ "E432": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
+ "E433": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
+ "E434": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
+ "E435": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]},
+ "E436": {"name":"新敌人","hp":0,"atk":0,"def":0,"mdef":0,"speed":1,"money":0,"exp":0,"point":0,"special":[]}
}
\ No newline at end of file
diff --git a/project/events.js b/project/events.js
index 7fbf65a..5f74cad 100644
--- a/project/events.js
+++ b/project/events.js
@@ -164,7 +164,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_0000.png",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -172,8 +172,8 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"text": "人生不如意事,十常居七八。",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -187,15 +187,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "世间的万物皆被装缀着不公的色彩。",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -209,15 +209,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "没错,就像——",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -231,15 +231,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "十几年前的那一天,",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -253,15 +253,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "在都市的角落,同许多的生命共同消逝一般。",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -275,15 +275,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "没错,就像——",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -297,15 +297,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "十几年前的那天起以来,",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -319,15 +319,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "无数的生命被那无法逃脱的污泥囚禁一样。",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -341,15 +341,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "人生不如意事,十常居七八。",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -363,15 +363,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "世间的万物皆被装缀着不公的色彩。",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -385,15 +385,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "没错,就像——",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -407,15 +407,15 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "over",
"text": "如今,这一天。",
"image": "",
"memory": false,
- "time": 50,
- "hidetime": 30,
+ "time": 20,
+ "hidetime": 10,
"sound": "",
"textColor": [
255,
@@ -429,7 +429,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
0,
1
],
- "font": "bold 48px Verdana"
+ "font": "bold 16px Verdana"
},
{
"type": "changebg",
@@ -437,7 +437,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
]
@@ -453,7 +453,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "other_0001.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -470,7 +470,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 30,
@@ -488,7 +488,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 30,
@@ -506,7 +506,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 30,
@@ -525,7 +525,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3563.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -533,7 +533,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 30,
@@ -551,7 +551,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "4",
"time": 30,
@@ -569,7 +569,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "5",
"time": 30,
@@ -587,7 +587,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "6",
"time": 30,
@@ -605,7 +605,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "7",
"time": 30,
@@ -623,7 +623,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "8",
"time": 30,
@@ -641,7 +641,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "9",
"time": 30,
@@ -659,7 +659,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "10",
"time": 30,
@@ -678,7 +678,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "other_0002.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -686,7 +686,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "11",
"time": 30,
@@ -704,7 +704,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "12",
"time": 30,
@@ -722,7 +722,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "13",
"time": 30,
@@ -740,7 +740,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "14",
"time": 30,
@@ -758,7 +758,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "15",
"time": 30,
@@ -776,7 +776,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "16",
"time": 30,
@@ -794,7 +794,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "17",
"time": 30,
@@ -812,7 +812,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "18",
"time": 30,
@@ -831,7 +831,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "other_0001.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -839,7 +839,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "19",
"time": 30,
@@ -858,7 +858,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "other_0003.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -866,7 +866,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 30,
@@ -884,7 +884,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 30,
@@ -903,7 +903,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_0000.png",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -911,7 +911,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 30,
@@ -930,7 +930,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "other_0003.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -938,7 +938,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 30,
@@ -956,7 +956,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 50,
@@ -975,7 +975,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_0000.png",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -983,7 +983,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 30,
@@ -1001,7 +1001,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 30,
@@ -1019,7 +1019,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 30,
@@ -1037,7 +1037,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "28",
"time": 30,
@@ -1055,7 +1055,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 30,
@@ -1073,7 +1073,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 30,
@@ -1091,7 +1091,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 30,
@@ -1110,7 +1110,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
]
@@ -1128,7 +1128,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3601.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -1140,7 +1140,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020106.webp",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 30,
@@ -1162,7 +1162,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020141.webp",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 30,
@@ -1170,7 +1170,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020141.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1180,7 +1180,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020157.webp",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 30,
@@ -1188,7 +1188,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1198,7 +1198,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 30,
@@ -1206,7 +1206,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1216,7 +1216,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020107.webp",
- "px": -300
+ "px": -100
},
"index": "4",
"time": 30,
@@ -1224,7 +1224,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1234,7 +1234,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "5",
"time": 30,
@@ -1242,7 +1242,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1252,7 +1252,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "6",
"time": 30,
@@ -1260,7 +1260,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1270,7 +1270,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "7",
"time": 30,
@@ -1278,7 +1278,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1288,7 +1288,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "8",
"time": 30,
@@ -1296,7 +1296,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1306,7 +1306,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020157.webp",
- "px": -300
+ "px": -100
},
"index": "9",
"time": 30,
@@ -1314,7 +1314,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1324,7 +1324,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020157.webp",
- "px": -300
+ "px": -100
},
"index": "10",
"time": 30,
@@ -1332,7 +1332,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1342,7 +1342,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "11",
"time": 30,
@@ -1350,7 +1350,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1360,7 +1360,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020111.webp",
- "px": -300
+ "px": -100
},
"index": "12",
"time": 30,
@@ -1368,7 +1368,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1378,7 +1378,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "13",
"time": 30,
@@ -1386,7 +1386,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1396,7 +1396,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020101.webp",
- "px": -300
+ "px": -100
},
"index": "14",
"time": 30,
@@ -1404,7 +1404,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1414,7 +1414,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "15",
"time": 30,
@@ -1422,7 +1422,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1432,7 +1432,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020107.webp",
- "px": -300
+ "px": -100
},
"index": "16",
"time": 30,
@@ -1440,7 +1440,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1450,7 +1450,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "17",
"time": 30,
@@ -1458,7 +1458,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1468,7 +1468,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020157.webp",
- "px": -300
+ "px": -100
},
"index": "18",
"time": 30,
@@ -1476,7 +1476,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1486,7 +1486,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "19",
"time": 30,
@@ -1494,7 +1494,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1504,7 +1504,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 30,
@@ -1512,7 +1512,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020157.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1522,7 +1522,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020125.webp",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 30,
@@ -1530,7 +1530,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020125.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1540,7 +1540,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 30,
@@ -1548,7 +1548,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020125.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1558,7 +1558,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020121.webp",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 30,
@@ -1566,7 +1566,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020121.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1576,7 +1576,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 30,
@@ -1584,7 +1584,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020121.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1594,7 +1594,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 30,
@@ -1602,7 +1602,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020121.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1612,7 +1612,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020105.webp",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 30,
@@ -1620,7 +1620,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1630,7 +1630,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020103.webp",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 30,
@@ -1638,7 +1638,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020103.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1656,7 +1656,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020141.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1666,7 +1666,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 30,
@@ -1674,7 +1674,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020141.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1684,7 +1684,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020105.webp",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 30,
@@ -1692,7 +1692,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1702,7 +1702,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 30,
@@ -1710,7 +1710,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1720,7 +1720,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020105.webp",
- "px": -300
+ "px": -100
},
"index": "32",
"time": 30,
@@ -1728,7 +1728,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1738,7 +1738,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020107.webp",
- "px": -300
+ "px": -100
},
"index": "33",
"time": 30,
@@ -1746,7 +1746,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1756,7 +1756,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "34",
"time": 30,
@@ -1764,7 +1764,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1774,7 +1774,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_020141.webp",
- "px": -300
+ "px": -100
},
"index": "35",
"time": 30,
@@ -1782,7 +1782,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020145.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1792,7 +1792,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "36",
"time": 30,
@@ -1800,7 +1800,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020145.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1810,7 +1810,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "37",
"time": 30,
@@ -1818,7 +1818,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_020145.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -1829,7 +1829,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
],
@@ -1840,7 +1840,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3561.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -1852,7 +1852,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 30,
@@ -1870,7 +1870,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 30,
@@ -1888,7 +1888,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 30,
@@ -1906,7 +1906,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 30,
@@ -1924,7 +1924,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "4",
"time": 30,
@@ -1942,7 +1942,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "5",
"time": 30,
@@ -1960,7 +1960,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "6",
"time": 30,
@@ -1978,7 +1978,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "7",
"time": 30,
@@ -1996,7 +1996,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "8",
"time": 30,
@@ -2014,7 +2014,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "9",
"time": 30,
@@ -2033,7 +2033,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3021.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2041,7 +2041,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "10",
"time": 30,
@@ -2059,7 +2059,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "11",
"time": 30,
@@ -2077,7 +2077,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "12",
"time": 30,
@@ -2095,7 +2095,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "13",
"time": 30,
@@ -2113,7 +2113,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "14",
"time": 30,
@@ -2131,7 +2131,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "15",
"time": 30,
@@ -2149,7 +2149,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "16",
"time": 30,
@@ -2168,7 +2168,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_0000.png",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2176,7 +2176,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "17",
"time": 30,
@@ -2194,7 +2194,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "18",
"time": 30,
@@ -2212,7 +2212,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "19",
"time": 30,
@@ -2231,7 +2231,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3021.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2277,7 +2277,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 30,
@@ -2285,7 +2285,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -2295,14 +2295,14 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 30,
"wait": 1000,
"bodyList": [
{
- "name": "",
+ "name": "tati_440101.webp",
"px": 600,
"filter": false
}
@@ -2313,14 +2313,14 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 30,
"wait": 1000,
"bodyList": [
{
- "name": "",
+ "name": "tati_440101.webp",
"px": 600,
"filter": false
}
@@ -2331,7 +2331,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 30,
@@ -2392,7 +2392,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440101.webp",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 30,
@@ -2410,7 +2410,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440105.webp",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 30,
@@ -2428,7 +2428,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440101.webp",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 30,
@@ -2446,7 +2446,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440110.webp",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 30,
@@ -2464,7 +2464,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440101.webp",
- "px": -300
+ "px": -100
},
"index": "28",
"time": 30,
@@ -2482,7 +2482,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440102.webp",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 30,
@@ -2505,7 +2505,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3026.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2518,7 +2518,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "eve_030101.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2526,7 +2526,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030102.webp",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 30,
@@ -2544,7 +2544,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030101.webp",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 30,
@@ -2566,7 +2566,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "32",
"time": 30,
@@ -2584,7 +2584,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "33",
"time": 30,
@@ -2602,7 +2602,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "34",
"time": 30,
@@ -2620,7 +2620,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "35",
"time": 30,
@@ -2638,7 +2638,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "36",
"time": 30,
@@ -2656,7 +2656,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "37",
"time": 30,
@@ -2674,7 +2674,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "38",
"time": 30,
@@ -2692,7 +2692,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "39",
"time": 30,
@@ -2710,7 +2710,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "40",
"time": 30,
@@ -2728,7 +2728,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "41",
"time": 30,
@@ -2750,7 +2750,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "42",
"time": 30,
@@ -2769,7 +2769,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3021.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2777,7 +2777,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "43",
"time": 30,
@@ -2795,7 +2795,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "44",
"time": 30,
@@ -2813,7 +2813,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "45",
"time": 30,
@@ -2831,7 +2831,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "46",
"time": 30,
@@ -2849,7 +2849,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "47",
"time": 30,
@@ -2868,7 +2868,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3026.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2876,7 +2876,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030107.webp",
- "px": -300
+ "px": -100
},
"index": "48",
"time": 30,
@@ -2894,7 +2894,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_130104.webp",
- "px": -300
+ "px": -100
},
"index": "49",
"time": 30,
@@ -2912,7 +2912,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440103.webp",
- "px": -300
+ "px": -100
},
"index": "50",
"time": 30,
@@ -2930,7 +2930,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030145.webp",
- "px": -300
+ "px": -100
},
"index": "51",
"time": 30,
@@ -2948,7 +2948,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440107.webp",
- "px": -300
+ "px": -100
},
"index": "52",
"time": 30,
@@ -2966,7 +2966,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030145.webp",
- "px": -300
+ "px": -100
},
"index": "53",
"time": 30,
@@ -2984,7 +2984,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "54",
"time": 30,
@@ -3002,7 +3002,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320105.webp",
- "px": -300
+ "px": -100
},
"index": "55",
"time": 30,
@@ -3020,7 +3020,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "56",
"time": 30,
@@ -3038,7 +3038,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "57",
"time": 30,
@@ -3056,7 +3056,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030124.webp",
- "px": -300
+ "px": -100
},
"index": "58",
"time": 30,
@@ -3074,7 +3074,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320107.webp",
- "px": -300
+ "px": -100
},
"index": "59",
"time": 30,
@@ -3092,7 +3092,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030125.webp",
- "px": -300
+ "px": -100
},
"index": "60",
"time": 30,
@@ -3110,7 +3110,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030141.webp",
- "px": -300
+ "px": -100
},
"index": "61",
"time": 30,
@@ -3128,7 +3128,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "62",
"time": 30,
@@ -3146,7 +3146,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440102.webp",
- "px": -300
+ "px": -100
},
"index": "63",
"time": 30,
@@ -3164,7 +3164,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440109.webp",
- "px": -300
+ "px": -100
},
"index": "64",
"time": 30,
@@ -3182,7 +3182,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "65",
"time": 30,
@@ -3200,7 +3200,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320108.webp",
- "px": -300
+ "px": -100
},
"index": "66",
"time": 30,
@@ -3218,7 +3218,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030145.webp",
- "px": -300
+ "px": -100
},
"index": "67",
"time": 30,
@@ -3236,7 +3236,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "68",
"time": 30,
@@ -3254,7 +3254,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "69",
"time": 30,
@@ -3272,7 +3272,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030101.webp",
- "px": -300
+ "px": -100
},
"index": "70",
"time": 30,
@@ -3290,7 +3290,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "71",
"time": 30,
@@ -3308,7 +3308,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030105.webp",
- "px": -300
+ "px": -100
},
"index": "72",
"time": 30,
@@ -3326,7 +3326,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440106.webp",
- "px": -300
+ "px": -100
},
"index": "73",
"time": 30,
@@ -3344,7 +3344,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "74",
"time": 30,
@@ -3362,7 +3362,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440102.webp",
- "px": -300
+ "px": -100
},
"index": "75",
"time": 30,
@@ -3380,7 +3380,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030125.webp",
- "px": -300
+ "px": -100
},
"index": "76",
"time": 30,
@@ -3398,7 +3398,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_130124.webp",
- "px": -300
+ "px": -100
},
"index": "77",
"time": 30,
@@ -3416,7 +3416,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "78",
"time": 30,
@@ -3434,7 +3434,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "79",
"time": 30,
@@ -3453,7 +3453,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
],
@@ -3464,7 +3464,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3801.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -3476,7 +3476,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 30,
@@ -3494,7 +3494,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 30,
@@ -3512,7 +3512,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 30,
@@ -3530,7 +3530,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 30,
@@ -3548,7 +3548,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "4",
"time": 30,
@@ -3566,7 +3566,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "5",
"time": 30,
@@ -3584,7 +3584,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "6",
"time": 30,
@@ -3602,7 +3602,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "7",
"time": 30,
@@ -3620,7 +3620,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "8",
"time": 30,
@@ -3638,7 +3638,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "9",
"time": 30,
@@ -3656,7 +3656,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "10",
"time": 30,
@@ -3674,7 +3674,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "11",
"time": 30,
@@ -3692,7 +3692,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "12",
"time": 30,
@@ -3710,7 +3710,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "13",
"time": 30,
@@ -3732,7 +3732,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "14",
"time": 30,
@@ -3750,7 +3750,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "15",
"time": 30,
@@ -3768,7 +3768,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "16",
"time": 30,
@@ -3786,7 +3786,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "17",
"time": 30,
@@ -3804,7 +3804,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "18",
"time": 30,
@@ -3830,7 +3830,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "19",
"time": 30,
@@ -3848,7 +3848,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 30,
@@ -3866,7 +3866,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 30,
@@ -3884,7 +3884,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 30,
@@ -3902,7 +3902,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 30,
@@ -3920,7 +3920,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 30,
@@ -3938,7 +3938,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 30,
@@ -3956,7 +3956,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 30,
@@ -3974,7 +3974,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 30,
@@ -3992,7 +3992,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "28",
"time": 30,
@@ -4010,7 +4010,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 30,
@@ -4028,7 +4028,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 30,
@@ -4046,7 +4046,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 30,
@@ -4064,7 +4064,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "32",
"time": 30,
@@ -4082,7 +4082,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "33",
"time": 30,
@@ -4100,7 +4100,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "34",
"time": 30,
@@ -4118,7 +4118,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "35",
"time": 30,
@@ -4136,7 +4136,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "36",
"time": 30,
@@ -4154,7 +4154,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "37",
"time": 30,
@@ -4172,7 +4172,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "38",
"time": 30,
@@ -4190,7 +4190,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "39",
"time": 30,
@@ -4208,7 +4208,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "40",
"time": 30,
@@ -4226,7 +4226,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "41",
"time": 30,
@@ -4244,7 +4244,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "42",
"time": 30,
@@ -4262,7 +4262,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "43",
"time": 30,
@@ -4280,7 +4280,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "44",
"time": 30,
@@ -4298,7 +4298,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "45",
"time": 30,
@@ -4316,7 +4316,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "46",
"time": 30,
@@ -4334,7 +4334,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "47",
"time": 30,
@@ -4352,7 +4352,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "48",
"time": 30,
@@ -4374,7 +4374,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "49",
"time": 30,
@@ -4392,7 +4392,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "50",
"time": 30,
@@ -4410,7 +4410,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "51",
"time": 30,
@@ -4428,7 +4428,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "52",
"time": 30,
@@ -4446,7 +4446,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "53",
"time": 30,
@@ -4464,7 +4464,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "54",
"time": 30,
@@ -4494,7 +4494,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430103.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4512,7 +4512,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4530,7 +4530,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4541,7 +4541,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_0000.png",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -4550,7 +4550,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3801.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -4584,7 +4584,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4602,7 +4602,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4620,7 +4620,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4638,7 +4638,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4656,7 +4656,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4674,7 +4674,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4692,7 +4692,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4710,7 +4710,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4728,7 +4728,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4746,7 +4746,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4764,7 +4764,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4782,7 +4782,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4800,7 +4800,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4818,7 +4818,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4836,7 +4836,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4854,7 +4854,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4872,7 +4872,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4890,7 +4890,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4908,7 +4908,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4926,7 +4926,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430108.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4944,7 +4944,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430108.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4962,7 +4962,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430108.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4980,7 +4980,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -4998,7 +4998,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5016,7 +5016,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5034,7 +5034,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5052,7 +5052,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5070,7 +5070,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5088,7 +5088,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5106,7 +5106,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5124,7 +5124,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5142,7 +5142,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5160,7 +5160,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5178,7 +5178,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5196,7 +5196,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5214,7 +5214,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5232,7 +5232,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5250,7 +5250,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5268,7 +5268,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430108.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5286,7 +5286,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430108.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5304,7 +5304,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5322,7 +5322,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5340,7 +5340,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5358,7 +5358,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5376,7 +5376,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5394,7 +5394,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5412,7 +5412,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5430,7 +5430,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5448,7 +5448,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5466,7 +5466,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5484,7 +5484,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5502,7 +5502,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5520,7 +5520,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5538,7 +5538,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5556,7 +5556,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5574,7 +5574,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_430105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5628,7 +5628,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5646,7 +5646,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5664,7 +5664,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5682,7 +5682,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5930,7 +5930,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5948,7 +5948,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5966,7 +5966,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050126.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -5984,7 +5984,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050126.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6002,7 +6002,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6020,7 +6020,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6038,7 +6038,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6056,7 +6056,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050105.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6074,7 +6074,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050143.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6092,7 +6092,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050143.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6110,7 +6110,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_050143.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6121,7 +6121,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
],
@@ -6132,7 +6132,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3512.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -6141,7 +6141,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3522.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -6150,7 +6150,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3602.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -6159,7 +6159,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3551.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -6171,7 +6171,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120122.webp",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 0,
@@ -6189,7 +6189,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120101.webp",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 0,
@@ -6197,7 +6197,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6207,7 +6207,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 0,
@@ -6215,7 +6215,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6225,7 +6225,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 0,
@@ -6233,7 +6233,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6243,7 +6243,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "4",
"time": 0,
@@ -6251,7 +6251,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6261,7 +6261,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120102.webp",
- "px": -300
+ "px": -100
},
"index": "5",
"time": 0,
@@ -6269,7 +6269,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6279,7 +6279,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "6",
"time": 0,
@@ -6287,7 +6287,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6297,7 +6297,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "7",
"time": 0,
@@ -6305,7 +6305,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6315,7 +6315,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120111.webp",
- "px": -300
+ "px": -100
},
"index": "8",
"time": 0,
@@ -6323,7 +6323,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6333,7 +6333,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "9",
"time": 0,
@@ -6341,7 +6341,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6351,7 +6351,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120127.webp",
- "px": -300
+ "px": -100
},
"index": "10",
"time": 0,
@@ -6359,7 +6359,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120127.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6369,7 +6369,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "11",
"time": 0,
@@ -6377,7 +6377,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120127.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6387,7 +6387,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "12",
"time": 0,
@@ -6395,7 +6395,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6405,7 +6405,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "13",
"time": 0,
@@ -6413,7 +6413,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6423,7 +6423,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "14",
"time": 0,
@@ -6431,7 +6431,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6441,7 +6441,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "15",
"time": 0,
@@ -6449,7 +6449,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6459,7 +6459,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "16",
"time": 0,
@@ -6467,7 +6467,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6477,7 +6477,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "17",
"time": 0,
@@ -6485,7 +6485,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6495,7 +6495,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "18",
"time": 0,
@@ -6503,7 +6503,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6513,7 +6513,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120121.webp",
- "px": -300
+ "px": -100
},
"index": "19",
"time": 0,
@@ -6521,7 +6521,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120121.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6531,7 +6531,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120102.webp",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 0,
@@ -6539,7 +6539,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6549,7 +6549,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120111.webp",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 0,
@@ -6557,7 +6557,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6567,7 +6567,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 0,
@@ -6575,7 +6575,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6585,7 +6585,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 0,
@@ -6593,7 +6593,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6603,7 +6603,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120106.webp",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 0,
@@ -6611,7 +6611,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120106.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6621,7 +6621,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 0,
@@ -6629,7 +6629,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120106.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6639,7 +6639,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 0,
@@ -6647,7 +6647,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6661,7 +6661,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120122.webp",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 0,
@@ -6669,7 +6669,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120122.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6679,7 +6679,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "28",
"time": 0,
@@ -6687,7 +6687,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6697,7 +6697,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 0,
@@ -6705,7 +6705,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6715,7 +6715,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 0,
@@ -6723,7 +6723,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6733,7 +6733,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 0,
@@ -6741,7 +6741,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6751,7 +6751,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "32",
"time": 0,
@@ -6759,7 +6759,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6769,7 +6769,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "33",
"time": 0,
@@ -6777,7 +6777,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6787,7 +6787,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "34",
"time": 0,
@@ -6795,7 +6795,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6805,7 +6805,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "35",
"time": 0,
@@ -6813,7 +6813,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6823,7 +6823,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "36",
"time": 0,
@@ -6831,7 +6831,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6841,7 +6841,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340102.webp",
- "px": -300
+ "px": -100
},
"index": "37",
"time": 0,
@@ -6849,7 +6849,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6859,7 +6859,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "38",
"time": 0,
@@ -6867,7 +6867,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6877,7 +6877,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340101.webp",
- "px": -300
+ "px": -100
},
"index": "39",
"time": 0,
@@ -6885,7 +6885,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6895,7 +6895,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "40",
"time": 0,
@@ -6903,7 +6903,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6913,7 +6913,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "41",
"time": 0,
@@ -6921,7 +6921,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6931,7 +6931,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "42",
"time": 0,
@@ -6939,7 +6939,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6949,7 +6949,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340104.webp",
- "px": -300
+ "px": -100
},
"index": "43",
"time": 0,
@@ -6957,7 +6957,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340104.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6967,7 +6967,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "44",
"time": 0,
@@ -6975,7 +6975,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6985,7 +6985,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "45",
"time": 0,
@@ -6993,7 +6993,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7003,7 +7003,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340108.webp",
- "px": -300
+ "px": -100
},
"index": "46",
"time": 0,
@@ -7011,7 +7011,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340108.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7021,7 +7021,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340114.webp",
- "px": -300
+ "px": -100
},
"index": "47",
"time": 0,
@@ -7029,7 +7029,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340114.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7039,7 +7039,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "48",
"time": 0,
@@ -7047,7 +7047,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340114.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7057,7 +7057,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340102.webp",
- "px": -300
+ "px": -100
},
"index": "49",
"time": 0,
@@ -7065,7 +7065,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": 67,
"filter": false
}
]
@@ -7075,7 +7075,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "50",
"time": 0,
@@ -7083,7 +7083,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7093,7 +7093,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340104.webp",
- "px": -300
+ "px": -100
},
"index": "51",
"time": 0,
@@ -7101,7 +7101,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340104.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7111,7 +7111,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "52",
"time": 0,
@@ -7119,7 +7119,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7129,7 +7129,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120132.webp",
- "px": -300
+ "px": -100
},
"index": "53",
"time": 0,
@@ -7137,12 +7137,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340104.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120132.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7152,7 +7152,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120101.webp",
- "px": -300
+ "px": -100
},
"index": "54",
"time": 0,
@@ -7160,12 +7160,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120101.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7175,7 +7175,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120121.webp",
- "px": -300
+ "px": -100
},
"index": "55",
"time": 0,
@@ -7183,12 +7183,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120121.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7198,7 +7198,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "56",
"time": 0,
@@ -7206,7 +7206,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7216,7 +7216,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "57",
"time": 0,
@@ -7224,7 +7224,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7234,7 +7234,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340101.webp",
- "px": -300
+ "px": -100
},
"index": "58",
"time": 0,
@@ -7242,7 +7242,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7252,7 +7252,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "59",
"time": 0,
@@ -7260,7 +7260,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7270,7 +7270,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120102.webp",
- "px": -300
+ "px": -100
},
"index": "60",
"time": 0,
@@ -7278,12 +7278,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120102.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7293,7 +7293,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "61",
"time": 0,
@@ -7301,12 +7301,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120102.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7316,7 +7316,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340102.webp",
- "px": -300
+ "px": -100
},
"index": "62",
"time": 0,
@@ -7324,12 +7324,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120102.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7339,7 +7339,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340110.webp",
- "px": -300
+ "px": -100
},
"index": "63",
"time": 0,
@@ -7347,12 +7347,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340110.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120102.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7362,7 +7362,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "64",
"time": 0,
@@ -7370,12 +7370,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340110.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120113.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7385,7 +7385,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120101.webp",
- "px": -300
+ "px": -100
},
"index": "65",
"time": 0,
@@ -7393,12 +7393,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120101.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7408,7 +7408,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "66",
"time": 0,
@@ -7416,12 +7416,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120101.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7431,7 +7431,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120121.webp",
- "px": -300
+ "px": -100
},
"index": "67",
"time": 0,
@@ -7439,12 +7439,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120121.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7454,7 +7454,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120132.webp",
- "px": -300
+ "px": -100
},
"index": "68",
"time": 0,
@@ -7462,12 +7462,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120132.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7477,7 +7477,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340106.webp",
- "px": -300
+ "px": -100
},
"index": "69",
"time": 0,
@@ -7485,12 +7485,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340106.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120132.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7500,7 +7500,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340112.webp",
- "px": -300
+ "px": -100
},
"index": "70",
"time": 0,
@@ -7508,12 +7508,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340106.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120112.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7523,7 +7523,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "71",
"time": 0,
@@ -7531,12 +7531,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340106.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120112.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7546,7 +7546,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340108.webp",
- "px": -300
+ "px": -100
},
"index": "72",
"time": 0,
@@ -7554,12 +7554,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340108.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120112.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7569,7 +7569,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340105.webp",
- "px": -300
+ "px": -100
},
"index": "73",
"time": 0,
@@ -7577,12 +7577,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340105.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120112.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7592,7 +7592,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "74",
"time": 0,
@@ -7600,12 +7600,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340105.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120107.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7615,7 +7615,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "75",
"time": 0,
@@ -7623,12 +7623,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120107.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7638,7 +7638,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "76",
"time": 0,
@@ -7646,12 +7646,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120107.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7661,7 +7661,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340103.webp",
- "px": -300
+ "px": -100
},
"index": "77",
"time": 0,
@@ -7669,12 +7669,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340103.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120107.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7684,7 +7684,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340101.webp",
- "px": -300
+ "px": -100
},
"index": "78",
"time": 0,
@@ -7692,12 +7692,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120107.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7707,7 +7707,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "79",
"time": 0,
@@ -7715,12 +7715,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340105.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120113.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7730,7 +7730,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "80",
"time": 0,
@@ -7738,12 +7738,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340105.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120112.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7753,7 +7753,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "81",
"time": 0,
@@ -7761,12 +7761,12 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
},
{
"name": "tati_120112.webp",
- "px": 1200,
+ "px": 400,
"filter": false
}
]
@@ -7777,7 +7777,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
],
@@ -7823,7 +7823,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -7832,12 +7832,10 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
},
{
"type": "cgtext",
- "bg": "",
- "memory": false,
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 30,
@@ -7852,12 +7850,10 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
},
{
"type": "cgtext",
- "bg": "",
- "memory": false,
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 30,
@@ -7872,12 +7868,10 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
},
{
"type": "cgtext",
- "bg": "",
- "memory": false,
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 30,
@@ -7892,12 +7886,10 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
},
{
"type": "cgtext",
- "bg": "",
- "memory": false,
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 30,
@@ -7927,12 +7919,10 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
},
{
"type": "cgtext",
- "bg": "bg_3531.webp",
- "memory": false,
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 0,
@@ -7945,6 +7935,3560 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
}
]
}
+ ],
+ "序章零一": [
+ {
+ "type": "changebg",
+ "img1": "",
+ "memory1": false,
+ "img2": "bg_3531.webp",
+ "memory2": false,
+ "time": 30,
+ "style": "引入"
+ },
+ {
+ "type": "cgtextList",
+ "textList": "chapter002"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "0",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "1",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "2",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "3",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "4",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "5",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "6",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "7",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "8",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "9",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "10",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "11",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "12",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "13",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "14",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "15",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "16",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "17",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "18",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "19",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "20",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "21",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "22",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "23",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "24",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "25",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "26",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "27",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "28",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "29",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "30",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "31",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "32",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "33",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "34",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "35",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "36",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "37",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "38",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "39",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "40",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "41",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "42",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "43",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "44",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "45",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "46",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "47",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "48",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "49",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "50",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "51",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "52",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "53",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "54",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "55",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "56",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "57",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "58",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "59",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "60",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "61",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "62",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "63",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "64",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "65",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "66",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "67",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "68",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "69",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "70",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "71",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "72",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "73",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "74",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "75",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "76",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "77",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 0,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "changebg",
+ "img1": "bg_3531.webp",
+ "memory1": false,
+ "img2": "",
+ "memory2": false,
+ "time": 30,
+ "style": "引出"
+ },
+ {
+ "type": "setHeroOpacity",
+ "opacity": 1
+ },
+ {
+ "type": "setCurtain",
+ "time": 1000
+ },
+ {
+ "type": "moveHero",
+ "time": 350,
+ "steps": [
+ "left:7",
+ "down:4"
+ ]
+ },
+ {
+ "type": "changeFloor",
+ "floorId": "changguan2",
+ "loc": [
+ 0,
+ 7
+ ],
+ "direction": "down"
+ }
+ ],
+ "序章零二": [
+ {
+ "type": "moveHero",
+ "time": 350,
+ "steps": [
+ "right:6"
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "79",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "moveHero",
+ "steps": [
+ "up:0"
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "80",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "81",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "82",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "83",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "84",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "85",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "86",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "87",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "88",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "setBlock",
+ "number": "fairy",
+ "loc": [
+ [
+ 6,
+ 0
+ ]
+ ],
+ "time": 250
+ },
+ {
+ "type": "move",
+ "loc": [
+ 6,
+ 0
+ ],
+ "time": 350,
+ "keep": true,
+ "async": true,
+ "steps": [
+ "down:5"
+ ]
+ },
+ {
+ "type": "setBlock",
+ "number": "upPortal",
+ "loc": [
+ [
+ 6,
+ 0
+ ]
+ ],
+ "time": 0,
+ "async": true
+ },
+ {
+ "type": "waitAsync"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "89",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "90",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtextList",
+ "textList": "chapter01"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020106.webp",
+ "px": -100
+ },
+ "index": "0",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020106.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020141.webp",
+ "px": -100
+ },
+ "index": "1",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020141.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020157.webp",
+ "px": -100
+ },
+ "index": "2",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020157.webp",
+ "px": -100
+ },
+ "index": "3",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020107.webp",
+ "px": -100
+ },
+ "index": "4",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "5",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "6",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "7",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "8",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020157.webp",
+ "px": -100
+ },
+ "index": "9",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020157.webp",
+ "px": -100
+ },
+ "index": "10",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "11",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020111.webp",
+ "px": -100
+ },
+ "index": "12",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020111.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "13",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020111.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020101.webp",
+ "px": -100
+ },
+ "index": "14",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020101.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "15",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020101.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020107.webp",
+ "px": -100
+ },
+ "index": "16",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "17",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020157.webp",
+ "px": -100
+ },
+ "index": "18",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "19",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "20",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020157.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020125.webp",
+ "px": -100
+ },
+ "index": "21",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020125.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020125.webp",
+ "px": -100
+ },
+ "index": "22",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020125.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020121.webp",
+ "px": -100
+ },
+ "index": "23",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020121.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "24",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020121.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020121.webp",
+ "px": -100
+ },
+ "index": "25",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020121.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "26",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020105.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020103.webp",
+ "px": -100
+ },
+ "index": "27",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020103.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020141.webp",
+ "px": -100
+ },
+ "index": "28",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020141.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "29",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020141.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020105.webp",
+ "px": -100
+ },
+ "index": "30",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020105.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "31",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020105.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020105.webp",
+ "px": -100
+ },
+ "index": "32",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020105.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020107.webp",
+ "px": -100
+ },
+ "index": "33",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "34",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020107.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_020145.webp",
+ "px": -100
+ },
+ "index": "35",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020145.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "36",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020145.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "37",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "tati_020145.webp",
+ "px": 200,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "setValue",
+ "name": "flag:剧情进度",
+ "value": "2"
+ }
+ ],
+ "序章零三": [
+ {
+ "type": "moveHero",
+ "time": 300,
+ "steps": [
+ "up:4"
+ ]
+ },
+ {
+ "type": "cgtextList",
+ "textList": "chapter02"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "0",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "setBlock",
+ "number": "youngMan",
+ "loc": [
+ [
+ 5,
+ 0
+ ]
+ ],
+ "floorId": "guangchang5",
+ "time": 150
+ },
+ {
+ "type": "move",
+ "loc": [
+ 5,
+ 0
+ ],
+ "time": 200,
+ "keep": true,
+ "steps": [
+ "rightdown:1",
+ "down:4"
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "1",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "2",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "3",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "4",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "5",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "6",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "7",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "8",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "moveHero",
+ "time": 300,
+ "async": true,
+ "steps": [
+ "up:5"
+ ]
+ },
+ {
+ "type": "move",
+ "loc": [
+ 6,
+ 5
+ ],
+ "time": 350,
+ "keep": true,
+ "async": true,
+ "steps": [
+ "leftdown:1",
+ "down:8"
+ ]
+ },
+ {
+ "type": "waitAsync"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "9",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "10",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "11",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "12",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "13",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "14",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "15",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "16",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "moveHero",
+ "time": 250,
+ "steps": [
+ "up:1",
+ "left:1"
+ ]
+ },
+ {
+ "type": "jumpHero",
+ "loc": [
+ 2,
+ 1
+ ],
+ "time": 350
+ },
+ {
+ "type": "moveHero",
+ "time": 250,
+ "steps": [
+ "up:0"
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "17",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "18",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "changebg",
+ "img1": "",
+ "memory1": false,
+ "img2": "bg_3021.webp",
+ "memory2": false,
+ "time": 30,
+ "style": "引入"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "19",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "20",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "21",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "22",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "23",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440101.webp",
+ "px": -100
+ },
+ "index": "24",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "comment",
+ "text": "这要加神官那个沙雕特效,先cy"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440105.webp",
+ "px": -100
+ },
+ "index": "25",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440101.webp",
+ "px": -100
+ },
+ "index": "26",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440101.webp",
+ "px": -100
+ },
+ "index": "27",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440110.webp",
+ "px": -100
+ },
+ "index": "28",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440105.webp",
+ "px": -100
+ },
+ "index": "29",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "comment",
+ "text": "吹笛子"
+ },
+ {
+ "type": "changebg",
+ "img1": "bg_3021.webp",
+ "memory1": false,
+ "img2": "bg_3026.webp",
+ "memory2": false,
+ "time": 30,
+ "style": "场景切换"
+ },
+ {
+ "type": "changebg",
+ "img1": "bg_3026.webp",
+ "memory1": false,
+ "img2": "eve_030101.webp",
+ "memory2": false,
+ "time": 30,
+ "style": "场景切换"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_030105.webp",
+ "px": -100
+ },
+ "index": "30",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_030101.webp",
+ "px": -100
+ },
+ "index": "31",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "32",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "33",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "34",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "35",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "36",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "37",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "changebg",
+ "img1": "eve_030101.webp",
+ "memory1": false,
+ "img2": "bg_3021.webp",
+ "memory2": false,
+ "time": 30,
+ "style": "场景切换"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "38",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "39",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "40",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "41",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "42",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "43",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "44",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "45",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "46",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "",
+ "px": -100
+ },
+ "index": "47",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "changebg",
+ "img1": "bg_3021.webp",
+ "memory1": false,
+ "img2": "bg_3026.webp",
+ "memory2": false,
+ "time": 30,
+ "style": "场景切换"
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_030107.webp",
+ "px": -100
+ },
+ "index": "48",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_130104.webp",
+ "px": -100
+ },
+ "index": "49",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440105.webp",
+ "px": -100
+ },
+ "index": "50",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_030145.webp",
+ "px": -100
+ },
+ "index": "51",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_440107.webp",
+ "px": -100
+ },
+ "index": "52",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "cgtext",
+ "WindowSkin": false,
+ "head": {
+ "name": "face_030145.webp",
+ "px": -100
+ },
+ "index": "53",
+ "time": 30,
+ "wait": 2000,
+ "bodyList": [
+ {
+ "name": "",
+ "px": 100,
+ "filter": false
+ }
+ ]
+ },
+ {
+ "type": "comment",
+ "text": "总觉得这里可以砍...掉吗?"
+ },
+ {
+ "type": "comment",
+ "text": "总之可以去一区打怪了..."
+ },
+ {
+ "type": "changebg",
+ "img1": "bg_3026.webp",
+ "memory1": false,
+ "img2": "",
+ "memory2": false,
+ "time": 30,
+ "style": "引出"
+ },
+ {
+ "type": "changeFloor",
+ "floorId": "yiqu1",
+ "loc": [
+ 0,
+ 7
+ ],
+ "direction": "right",
+ "time": 0
+ }
]
},
"CommonEventTemplate": {
@@ -8214,5 +11758,177 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"speed": 1
}
]
+ },
+ "task": {
+ "新手任务": {
+ "type": "taskEvent",
+ "text": "任务描述",
+ "n": 1,
+ "info": [
+ {
+ "type": "checkItem",
+ "checkItem": "yellowKey",
+ "operator": ">=",
+ "count": 0
+ },
+ {
+ "type": "checkStatus",
+ "checkStatus": "atk",
+ "operator": ">=",
+ "count": 10
+ },
+ {
+ "type": "checkFlag",
+ "checkFlag": "flag1",
+ "operator": "=",
+ "count": "\"value\""
+ },
+ {
+ "type": "checkBlock",
+ "checkBlock": "bat",
+ "floorId": [
+ "MT1",
+ "MT2"
+ ],
+ "operator": "<=",
+ "count": 0
+ },
+ {
+ "type": "kill",
+ "operator": ">=",
+ "count": 0
+ },
+ {
+ "type": "killLocs",
+ "loc": [
+ [
+ 1,
+ 1
+ ]
+ ],
+ "floorId": "MT1",
+ "operator": ">=",
+ "count": 1
+ },
+ {
+ "type": "killSpecial",
+ "killSpecial": "61",
+ "floorId": [
+ "61"
+ ],
+ "operator": ">=",
+ "count": 1
+ },
+ {
+ "type": "killAll",
+ "floorId": [
+ "MT1"
+ ]
+ },
+ {
+ "type": "specialBlock",
+ "floorId": [
+ "MT1"
+ ],
+ "specialBlock": "血网伤害",
+ "operator": "<",
+ "count": 1
+ },
+ {
+ "type": "gosthFloor",
+ "floorId": [
+ "MT1"
+ ],
+ "operator": "<",
+ "count": 1
+ }
+ ],
+ "action": []
+ },
+ "task1": {
+ "type": "taskEvent",
+ "text": "任务描述",
+ "n": 1,
+ "info": [
+ {
+ "type": "checkItem",
+ "checkItem": "yellowKey",
+ "operator": ">=",
+ "count": 0
+ },
+ {
+ "type": "checkStatus",
+ "checkStatus": "atk",
+ "operator": ">=",
+ "count": 10
+ },
+ {
+ "type": "checkFlag",
+ "checkFlag": "flag1",
+ "operator": "=",
+ "count": "\"value\""
+ },
+ {
+ "type": "checkBlock",
+ "checkBlock": "bat",
+ "floorId": [
+ "MT1",
+ "MT2"
+ ],
+ "operator": "<=",
+ "count": 0
+ },
+ {
+ "type": "kill",
+ "operator": ">=",
+ "count": 0
+ },
+ {
+ "type": "killLocs",
+ "loc": [
+ [
+ 1,
+ 1
+ ]
+ ],
+ "floorId": "MT1",
+ "operator": ">=",
+ "count": 1
+ },
+ {
+ "type": "killSpecial",
+ "killSpecial": "61",
+ "floorId": [
+ "61"
+ ],
+ "operator": ">=",
+ "count": 1
+ },
+ {
+ "type": "killAll",
+ "floorId": [
+ "MT1"
+ ]
+ },
+ {
+ "type": "specialBlock",
+ "floorId": [
+ "MT1"
+ ],
+ "specialBlock": "血网伤害",
+ "operator": "<",
+ "count": 1
+ },
+ {
+ "type": "gosthFloor",
+ "floorId": [
+ "MT1"
+ ],
+ "operator": "<",
+ "count": 1
+ }
+ ],
+ "action": []
+ }
}
}
\ No newline at end of file
diff --git a/project/floors/KTV.js b/project/floors/KTV.js
index 5fd3f57..32c14ea 100644
--- a/project/floors/KTV.js
+++ b/project/floors/KTV.js
@@ -13,178 +13,13 @@ main.floors.KTV=
"defaultGround": "grass",
"firstArrive": [
{
- "type": "changebg",
- "img1": "",
- "memory1": false,
- "img2": "bg_3531.webp",
- "memory2": false,
- "time": 30,
- "style": "引入"
+ "type": "insert",
+ "name": "序章零一"
},
{
- "type": "cgtextList",
- "textList": "chapter002"
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "0",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "1",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "2",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "3",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "4",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "5",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "6",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "cgtext",
- "WindowSkin": false,
- "head": {
- "name": "",
- "px": -300
- },
- "index": "7",
- "time": 0,
- "wait": 2000,
- "bodyList": [
- {
- "name": "",
- "px": 0,
- "filter": false
- }
- ]
- },
- {
- "type": "changebg",
- "img1": "bg_3531.webp",
- "memory1": false,
- "img2": "",
- "memory2": false,
- "time": 30,
- "style": "引出"
- },
- {
- "type": "setHeroOpacity",
- "opacity": 1
- },
- {
- "type": "setCurtain",
- "time": 1000
+ "type": "setValue",
+ "name": "flag:剧情进度",
+ "value": "1"
}
],
"eachArrive": [],
@@ -194,8 +29,8 @@ main.floors.KTV=
"12,10": {
"floorId": "changguan2",
"loc": [
- 2,
- 1
+ 4,
+ 2
]
},
"10,1": {
@@ -204,6 +39,13 @@ main.floors.KTV=
10,
4
]
+ },
+ "3,12": {
+ "floorId": "changguan2",
+ "loc": [
+ 0,
+ 7
+ ]
}
},
"beforeBattle": {},
diff --git a/project/floors/changguan1.js b/project/floors/changguan1.js
index 5c6b7b7..259206f 100644
--- a/project/floors/changguan1.js
+++ b/project/floors/changguan1.js
@@ -19,7 +19,7 @@ main.floors.changguan1=
{
"type": "autoText",
"text": "通称——",
- "time": 2000
+ "time": 1500
},
{
"type": "setCurtain",
@@ -52,13 +52,6 @@ main.floors.changguan1=
12
]
},
- "5,12": {
- "floorId": "changguan2",
- "loc": [
- 5,
- 0
- ]
- },
"6,12": {
"floorId": "changguan2",
"loc": [
@@ -67,7 +60,7 @@ main.floors.changguan1=
]
},
"12,7": {
- "floorId": "yiqu1",
+ "floorId": "street01",
"loc": [
0,
7
@@ -92,9 +85,9 @@ main.floors.changguan1=
[110289,110290,110291,110292, 0, 0, 0, 0, 0, 0, 0, 0, 94],
[110297,110298,110299,110300, 0, 0, 0, 0, 0,110116, 0, 0, 0],
[110305,110306,110307,110308, 0, 0, 0, 0, 0,110261,110262,110262,110263],
- [110313,110314,110315,110316,110122,110122, 0,110122,110122,110269,110270,110270,110271],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0,110277,110278,110278,110279],
- [140,140186,120002,120003, 0, 93, 93, 0, 0,110285,110286,110286,110286]
+ [140099,110314,110315,110316,110122,110122, 0,110122,110122,110269,110270,110270,110271],
+ [140107,140108, 0, 0, 0, 0, 0, 0, 0,110277,110278,110278,110279],
+ [110258,110259,110260, 0, 0, 0, 93, 0, 0,110285,110286,110286,110286]
],
"bgmap": [
[90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078],
@@ -122,9 +115,9 @@ main.floors.changguan1=
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0,110246,110246,110246,110246],
[140091,140092,140093, 0,110114,110114, 0,110114,110114, 0, 0, 0, 0],
- [140099,140100,140101, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [140107,140108,140109, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+ [110242,140100,140101, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [110250,110251,140109, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [110258, 0, 0,120002,120003, 0, 0, 0,110114, 0, 0, 0, 0]
],
"bg2map": [
[ 0, 0, 0, 0,130046,130046,130046,130046,130046,210178, 0, 0,210178],
@@ -137,7 +130,7 @@ main.floors.changguan1=
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [110313, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
diff --git a/project/floors/changguan2.js b/project/floors/changguan2.js
index c0e530d..c0b3065 100644
--- a/project/floors/changguan2.js
+++ b/project/floors/changguan2.js
@@ -12,6 +12,10 @@ main.floors.changguan2=
"ratio": 1,
"defaultGround": "X20003",
"firstArrive": [
+ {
+ "type": "comment",
+ "text": "太慢了调一下速度,提醒我到时候改回去"
+ },
{
"type": "setCurtain",
"time": 1000
@@ -19,7 +23,7 @@ main.floors.changguan2=
{
"type": "autoText",
"text": "《牢狱》",
- "time": 2000
+ "time": 1000
},
{
"type": "setCurtain",
@@ -38,20 +42,30 @@ main.floors.changguan2=
"loc": [
10,
8
+ ],
+ "direction": "down"
+ }
+ ],
+ "eachArrive": [
+ {
+ "type": "if",
+ "condition": "(flag:剧情进度===1)",
+ "true": [
+ {
+ "type": "insert",
+ "name": "序章零二"
+ },
+ {
+ "type": "setValue",
+ "name": "flag:剧情进度",
+ "value": "2"
+ }
]
}
],
- "eachArrive": [],
"parallelDo": "",
"events": {},
"changeFloor": {
- "5,0": {
- "floorId": "changguan1",
- "loc": [
- 5,
- 12
- ]
- },
"6,0": {
"floorId": "changguan1",
"loc": [
@@ -59,19 +73,33 @@ main.floors.changguan2=
12
]
},
- "12,8": {
- "floorId": "street01",
+ "12,9": {
+ "floorId": "zhujuejia",
"loc": [
0,
- 8
+ 9
]
},
- "2,1": {
+ "0,7": {
+ "floorId": "KTV",
+ "loc": [
+ 3,
+ 12
+ ]
+ },
+ "4,2": {
"floorId": "KTV",
"loc": [
12,
10
]
+ },
+ "8,12": {
+ "floorId": "goldkey",
+ "loc": [
+ 6,
+ 12
+ ]
}
},
"beforeBattle": {},
@@ -82,19 +110,19 @@ main.floors.changguan2=
"cannotMove": {},
"cannotMoveIn": {},
"map": [
- [140193,130178,120010,120011, 0, 91, 91, 0,140184,140,140,140,140186],
- [140193,130178, 90, 0, 0, 0, 0, 0,140192,140,140,140,140194],
- [140193,130178,40163,120019, 0, 0, 0, 0,140200,140195,140,140,140194],
- [140193,143,143,120027, 0, 0, 0, 0,70128,140192,140,140,140194],
- [140193,210148,143,143, 0, 0, 0,71826,70136,140192,140,140,140194],
- [140193,143,143,143,71226, 0, 0, 0,50151,140200,140201,140201,140202],
- [70165,70165,70165,70166,71819, 0, 0, 0, 0,70128,70129,70129,70130],
- [140193,210153,143,70174,71827, 0, 0, 0,71826,120056,70137,70137,70138],
- [140193,210153,210156,143,71695, 0, 0, 0, 0, 0, 0, 0, 94],
- [140193,143,143,143, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [140193,140193,130178,70130, 0, 0, 0, 0, 0, 0, 0,140,140],
- [140193,140193,130178,40165,200199, 0, 0,71791, 0, 0,140192,140,140],
- [140193,140193,130186,110114,110114, 93, 93, 0,143, 0,140192,140,140]
+ [110266,110267,110268,120010,120011, 0, 91, 0,110122, 0,110261,110262,110263],
+ [110274,110275,110276, 0,120047, 0, 0, 0, 0,71826,110269,110270,110271],
+ [110282,110283,110284, 0, 90, 0, 0, 0, 0, 0,110277,110278,110279],
+ [110290,110289,110292, 0,120019, 0, 0, 0, 0, 0,110285,110286,110286],
+ [110298,110297,110300,120026,120027, 0, 0, 0, 0, 0,110293,110294,110294],
+ [200550,110304,110308,40163, 0, 0, 0, 0, 0, 0,110301,110302,110302],
+ [200558,110312,110316, 0, 0, 0, 0, 0,110122,110122,110309,110310,110310],
+ [ 90, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0,200199, 0, 0, 0, 0, 0, 0, 0],
+ [200033,200033,200034,200035,200036,200038, 0, 0, 0, 0, 0, 0, 94],
+ [200041,200041,200042,200043,200044,200046, 0, 0, 0, 0, 0, 0, 0],
+ [200049,200049,200050,200051,200052,200054,210068,210069, 0,210070,210071,140184,140],
+ [200057,200057,200058,200059,200060,200062,210076,210077, 90,210078,210079,140192,140]
],
"areas": "牢狱",
"bgmap": [
@@ -113,34 +141,34 @@ main.floors.changguan2=
[90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078]
],
"fgmap": [
- [140,140194, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [140,140194, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [140,140194, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [140,140,140,140186, 0, 0, 0,71818, 0, 0, 0, 0, 0],
- [140,140,140,140194,71218, 0, 0, 0,71818, 0, 0, 0, 0],
- [140201,140201,140201,140202, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0,71685, 0, 0, 0,71818, 0,90587, 0, 0],
- [140,140,140,140186,71844, 0, 0, 0, 0, 0, 0, 0, 0],
- [140,140,140,140194,200175, 0, 0, 0, 0, 0, 0, 0, 0],
- [140,140,140196,140202,200183, 0, 0, 0, 0, 0, 0, 0, 0],
- [140,140,140194, 0,200191, 0, 0, 0, 0,71818,140184,140,140],
- [140,140,140194, 0, 0, 0, 0, 0,71832,71833,140192,140,140],
- [140,140,140194, 0,110117, 0, 0,140184,140,140,140,140,140]
+ [ 0, 0, 0,140087, 0, 0, 0, 0, 0,71818, 0, 0, 0],
+ [ 0, 0, 0,140095, 0, 0, 0, 0, 0,50166, 0, 0, 0],
+ [ 0, 0, 0,140103, 0, 0, 0, 0, 0,71818, 0, 0, 0],
+ [ 0,90442, 0,140111, 0, 0, 0, 0, 0,50151, 0, 0, 0],
+ [ 0,90450, 0, 0, 0, 0, 0, 0, 0,71818, 0, 0, 0],
+ [140092,140093, 0, 0, 0,200175, 0, 0,110114,110114,140091,140092,140092],
+ [140100,140101, 0, 0, 0,200183, 0, 0, 0, 0,140099,140100,140100],
+ [140108,140109, 0, 0, 0,200191, 0, 0, 0, 0,140107,140108,140108],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"bg2map": [
- [ 0, 0, 0, 0, 0, 0, 0, 0,110293,110294,110294,110294,110294],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0,110293,110294,110294,110294],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0,71826, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,120034,120035, 0, 0, 0, 0,71826, 0, 0, 0],
+ [ 0, 0, 0,40171, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0,71826, 0, 0, 0, 0],
- [ 0, 0, 0, 0,71693, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0,70136, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0,120064, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0,70138, 0, 0, 0, 0, 0,71826, 0, 0, 0],
- [ 0, 0, 0,40173, 0, 0, 0,71799,71840,71841, 0, 0, 0]
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"fg2map": [
diff --git a/project/floors/goldkey.js b/project/floors/goldkey.js
index 287f326..9fe3cdf 100644
--- a/project/floors/goldkey.js
+++ b/project/floors/goldkey.js
@@ -15,7 +15,15 @@ main.floors.goldkey=
"eachArrive": [],
"parallelDo": "",
"events": {},
- "changeFloor": {},
+ "changeFloor": {
+ "6,12": {
+ "floorId": "changguan2",
+ "loc": [
+ 8,
+ 12
+ ]
+ }
+ },
"beforeBattle": {},
"afterBattle": {},
"afterGetItem": {},
diff --git a/project/floors/guangchang.js b/project/floors/guangchang.js
index 3427e91..01e5f9f 100644
--- a/project/floors/guangchang.js
+++ b/project/floors/guangchang.js
@@ -26,7 +26,7 @@ main.floors.guangchang=
6,
7
],
- "time": 500,
+ "time": 400,
"keep": true,
"async": true,
"steps": [
@@ -45,7 +45,7 @@ main.floors.guangchang=
8,
8
],
- "time": 500,
+ "time": 400,
"keep": true,
"async": true,
"steps": [
@@ -63,7 +63,7 @@ main.floors.guangchang=
4,
9
],
- "time": 500,
+ "time": 400,
"keep": true,
"steps": [
"right:1"
@@ -75,7 +75,7 @@ main.floors.guangchang=
{
"type": "autoText",
"text": "浮游都市,《诺瓦斯·艾蒂尔》。",
- "time": 2000
+ "time": 1000
},
{
"type": "move",
@@ -83,7 +83,7 @@ main.floors.guangchang=
6,
5
],
- "time": 500,
+ "time": 400,
"keep": true,
"async": true,
"steps": [
@@ -96,7 +96,7 @@ main.floors.guangchang=
6,
7
],
- "time": 500,
+ "time": 400,
"keep": true,
"steps": [
"up:1"
@@ -115,7 +115,7 @@ main.floors.guangchang=
6,
3
],
- "time": 500,
+ "time": 400,
"async": true,
"steps": [
"down:9"
@@ -127,7 +127,7 @@ main.floors.guangchang=
5,
4
],
- "time": 500,
+ "time": 400,
"keep": true,
"async": true,
"steps": [
@@ -141,7 +141,7 @@ main.floors.guangchang=
6,
6
],
- "time": 300,
+ "time": 400,
"keep": true,
"async": true,
"steps": [
@@ -158,7 +158,7 @@ main.floors.guangchang=
8,
6
],
- "time": 500,
+ "time": 400,
"keep": true,
"steps": [
"left:1"
@@ -181,7 +181,7 @@ main.floors.guangchang=
7,
6
],
- "time": 500,
+ "time": 400,
"keep": true,
"async": true
},
@@ -191,7 +191,7 @@ main.floors.guangchang=
6,
3
],
- "time": 500,
+ "time": 400,
"async": true,
"steps": [
"up:2"
@@ -203,7 +203,7 @@ main.floors.guangchang=
7,
9
],
- "time": 500,
+ "time": 400,
"async": true,
"steps": [
"up:1",
@@ -332,8 +332,8 @@ main.floors.guangchang=
[140091,140092,140093, 0, 0, 0, 0, 0, 0,200191, 0, 0, 0],
[140099,140100,140101, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[362,362,362, 0, 0, 0, 0, 0, 0, 0, 0,110242, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,110249,110250,110251],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0,110256,110257,110258,110259]
+ [ 0,110327, 0, 0, 0, 0, 0, 0, 0, 0,110249,110250,110251],
+ [ 0,110335, 0, 0, 0, 0, 0, 0, 0,110256,110257,110258,110259]
],
"bg2map": [
[200195,200196, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
diff --git a/project/floors/guangchang2.js b/project/floors/guangchang2.js
index 2d9947a..00672b7 100644
--- a/project/floors/guangchang2.js
+++ b/project/floors/guangchang2.js
@@ -18,7 +18,7 @@ main.floors.guangchang2=
},
{
"type": "sleep",
- "time": 2000
+ "time": 1500
},
{
"type": "setCurtain",
@@ -78,8 +78,8 @@ main.floors.guangchang2=
[ 92, 0, 0, 0,110384,110385,110376, 0,90652,90648,90649, 0,120168],
[ 0, 0, 0, 0,110384, 0,122, 0,90653, 0,122, 0,120176],
[362,362,363, 0, 0, 0, 0, 0, 0, 0, 0, 0,90266],
- [210181,210181,210181, 0, 0, 0, 0, 0, 0, 0, 0, 0,110189],
- [210186,210186,210186,361,362,362,362,362,362,362,362,362,110197]
+ [210181,210181,210181, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [210186,210186,210186,361,362,362,362,362,362,362,362,362,362]
],
"areas": "牢狱",
"bgmap": [
@@ -108,9 +108,9 @@ main.floors.guangchang2=
[ 0, 0, 0, 0, 0,140094,140095, 0, 0,140094,140095, 0, 0],
[ 0, 0, 0, 0, 0,140102,140103, 0, 0,140102,140103, 0, 0],
[ 0, 0, 0, 0, 0,140110,140111, 0, 0,140110,140111, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+ [ 0,110319, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,110327, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,110335,200032,200033,200033,200033,200033,200033,200033,200033,200033,200038, 0]
],
"bg2map": [
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
@@ -125,7 +125,7 @@ main.floors.guangchang2=
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[110239,110239,110239,364, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0,364, 0, 0, 0, 0, 0, 0, 0, 0,90266],
- [ 0, 0, 0,110239,110239,110239,110239,110239,110239,110239,110239,110239, 0]
+ [ 0, 0, 0,110239,110239,110239,110239,110239,110239,110239,110239,110239,110239]
],
"fg2map": [
diff --git a/project/floors/guangchang3.js b/project/floors/guangchang3.js
index 06fa931..cefe2e9 100644
--- a/project/floors/guangchang3.js
+++ b/project/floors/guangchang3.js
@@ -18,7 +18,7 @@ main.floors.guangchang3=
},
{
"type": "sleep",
- "time": 2000
+ "time": 1500
},
{
"type": "setCurtain",
diff --git a/project/floors/guangchang4.js b/project/floors/guangchang4.js
index cb6d123..614798d 100644
--- a/project/floors/guangchang4.js
+++ b/project/floors/guangchang4.js
@@ -19,7 +19,7 @@ main.floors.guangchang4=
{
"type": "autoText",
"text": "是被险峻的峭壁环绕,与世隔绝的,都市的最底部",
- "time": 2000
+ "time": 1000
},
{
"type": "setCurtain",
diff --git a/project/floors/guangchang5.js b/project/floors/guangchang5.js
index 86715ef..ef4ce33 100644
--- a/project/floors/guangchang5.js
+++ b/project/floors/guangchang5.js
@@ -19,7 +19,7 @@ main.floors.guangchang5=
{
"type": "autoText",
"text": "《特别受灾地区》——",
- "time": 2000
+ "time": 1000
},
{
"type": "setCurtain",
@@ -41,9 +41,22 @@ main.floors.guangchang5=
]
}
],
- "eachArrive": [],
+ "eachArrive": null,
"parallelDo": "",
- "events": {},
+ "events": {
+ "11,9": [
+ {
+ "type": "comment",
+ "text": "这里暂且拿个东西堵住吧,剧情结束扣掉这个块"
+ }
+ ],
+ "6,11": [
+ {
+ "type": "insert",
+ "name": "序章零三"
+ }
+ ]
+ },
"changeFloor": {
"6,12": {
"floorId": "guangchang",
@@ -84,7 +97,7 @@ main.floors.guangchang5=
[362,363,210070,210071,210184, 0, 0, 0,210184,210068,210069,210178,210166],
[210181,210184,210078,210079,210192, 0, 0, 0,210192,210076,210077,210194,210194],
[210178,210184,210086,210087, 0, 0, 0, 0, 0,210084,210085,110239,110239],
- [210194,210192, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 94],
+ [210194,210192, 0, 0, 0, 0, 0, 0, 0, 0, 0, 16, 94],
[200171,200172,120031,120031,120020, 0, 0, 0, 0, 0, 0, 0, 0],
[200179,200180,122, 0, 0, 0, 0, 0,200199, 0,130180,130181,130182],
[200187,200188, 0, 0, 0, 0, 93, 0, 0,130187,130188,130189,130190]
diff --git a/project/floors/guangchang6.js b/project/floors/guangchang6.js
index 3b9dd67..76c7208 100644
--- a/project/floors/guangchang6.js
+++ b/project/floors/guangchang6.js
@@ -52,17 +52,17 @@ main.floors.guangchang6=
"map": [
[140095,120160,120161,120162,120163,120164,365, 0, 0, 0, 0,143,143],
[140095,120168,120169,120170,120171,120172,365, 0, 0, 0, 0,143,143],
- [140103,120176,120177,20122,120179,120180,365, 0, 0, 0, 0,143,143],
- [140111,20110,140107,140108,140109,20110,365, 0, 0, 0, 0,130192,130193],
- [362,362,362,362,362,362,362, 0, 0, 0, 0,130200,130201],
- [210178,210178,210178,210167,210178,210178,210176, 0, 0, 0, 0,140099,140100],
- [210178,210178,210178,210178,210178,210178,210184, 0, 0, 0, 0,140107,140108],
- [210194,210175,210194,210194,210194,210194,210192, 0, 0, 0, 0, 0, 94],
- [110239, 0, 0, 0, 0, 0,365, 0, 0, 0, 0,120109,120110],
- [ 92, 0, 0, 0,362, 0,363, 0, 0, 0, 0,120117,120118],
- [ 0, 0, 0, 0, 17,130046, 17, 0, 0, 0,140086,120125,120126],
- [130183, 0, 0, 0, 17,130046, 17, 0, 0, 0,140094,120133,120134],
- [130191, 0, 93, 0, 17, 0, 0, 0, 0, 0,140102,120141,120142]
+ [140103,120176,120177,20122,120179,120180,365,20122,122, 0, 0,143,143],
+ [140111,20110,140107,140108,140109,20110,365,20130, 0, 0,130075,130192,130193],
+ [362,362,362,362,362,362,362,20113, 0, 0,130082,130200,130201],
+ [210178,210178,210178,210167,210178,210178,210176, 0, 0, 0,137,140099,140100],
+ [210178,210178,210178,120072,210178,210178,210184,20113,121, 0, 0,140107,140108],
+ [210194,210175,210194,120080,210194,210194,210192,20114, 0, 0, 0, 0, 94],
+ [110239, 0, 0, 0, 0, 0,365, 0, 0, 0, 0, 0, 0],
+ [ 92, 0, 0, 0,362, 0,363,128, 0, 0,10165,120117,120118],
+ [ 0, 0, 0, 0, 17, 0, 17, 0, 0, 0,10173,120125,120126],
+ [130183, 0, 0, 0, 17, 0, 17, 0, 0, 0,10173,120133,120134],
+ [130191, 0, 93, 0, 17, 0, 0, 0, 0,138,10157,120141,120142]
],
"areas": "牢狱",
"bgmap": [
@@ -71,9 +71,9 @@ main.floors.guangchang6=
[30052,30052,30052,30052,30052,30052,30052,90078, 0,90078,90078,90078,90078],
[30052,30052,30052,30052,30052,30052,30052,90078,90078,90078,90078,90078,90078],
[30052,30052,30052,30052,30052,30052,30052,90078,90078,90078,90078,90078,90078],
- [30052,30052,30052,30052, 0, 0, 0,90078,90078,90078,90078,90078,90078],
- [30052,30052,30052,30052, 0, 0, 0, 0,90078,90078,90078,90078,90078],
- [30052,30052,30052,30052, 0, 0, 0,90078,90078,90078,90078,90078,90078],
+ [30052,30052,30052,30052,30052,30052,30052,90078,90078,90078,90078,90078,90078],
+ [30052,30052,30052,30052,30052,30052,30052, 0,90078,90078,90078,90078,90078],
+ [30052,30052,30052,30052,30052,30052,30052,90078,90078,90078,90078,90078,90078],
[30052,30052,30052,30052,30052,30052,30052,90078,90078,90078,90078,90078,90078],
[30052,30052,30052,30052,30052,30052,30052,90078,90078,90078,90078,90078,90078],
[30052,30052,30052,30052,210187,210178,210187,90078,90078,90078,90078,90078,90078],
@@ -81,29 +81,29 @@ main.floors.guangchang6=
[30052,30052,30052,30052,90078,90078,90078,90078,90078,90078,90078,90078,90078]
],
"fgmap": [
- [ 0, 0, 0, 0, 0, 0, 0,140087, 0, 0, 0, 0, 0],
- [ 0, 0,140091,140092,140093, 0, 0,140095, 0, 0, 0, 0, 0],
- [ 0,20102,140099,140100,140101,20102, 0,140103, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0,140087, 0, 0,140094, 0, 0],
+ [ 0, 0,140091,140092,140093, 0, 0,140095, 0, 0,140102, 0, 0],
+ [ 0,20102,140099,140100,140101,20102, 0,140103, 0, 0,140110, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0,140111, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0,140087, 0, 0, 0,140091,140092],
- [ 0, 0, 0, 0, 0, 0, 0,140095, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0,140103, 0, 0, 0, 0, 0],
+ [ 0,210142, 0, 0,210142, 0, 0,140095, 0, 0, 0, 0, 0],
+ [ 0,210150, 0, 0,210150, 0, 0,140103, 0, 0, 0, 0, 0],
[110231, 0, 0, 0, 0, 0,365,140111, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,120109,120110],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,140086, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,140094, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,140102, 0, 0]
],
"bg2map": [
[ 0, 0, 0, 0, 0, 0,160032, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0,160032, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0,120178, 0, 0,160032, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0,20130, 0, 0,160032, 0, 0, 0, 0, 0, 0],
- [120103,120103,120103,120103,120103,120103,120103, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,20130, 0, 0,160032, 0, 0, 0,130088, 0, 0],
+ [120103,120103,120103,120103,120103,120103,120103, 0, 0, 0,130096, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,130076,130076],
+ [ 0, 0, 0,210178, 0, 0, 0, 0, 0, 0, 0,130084,130084],
+ [ 0, 0, 0,210194, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0,365, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0,365,130045,130046,130047, 0, 0, 0, 0, 0, 0],
diff --git a/project/floors/jiaocheng01.js b/project/floors/jiaocheng01.js
index 6d6a5ba..79d929c 100644
--- a/project/floors/jiaocheng01.js
+++ b/project/floors/jiaocheng01.js
@@ -237,6 +237,31 @@ main.floors.jiaocheng01=
]
}
],
+ "5,11": [
+ {
+ "type": "menu",
+ "text": "流浪者",
+ "choices": [
+ {
+ "type": "context",
+ "text": "对话",
+ "action": [
+ "\t[流浪者]你好啊"
+ ]
+ },
+ {
+ "type": "taskContext",
+ "text": "任务",
+ "text1": "新手任务",
+ "text2": "task1,task2",
+ "condition": "'新手任务'.split(',').some(v=>core.plugin.可接取任务.includes(v))||'task1,task2'.split(',').some(v=>core.taskSystem.tasksInfo.find(a => a.name ===v.name))",
+ "action": [
+ "这个东西还没做"
+ ]
+ }
+ ]
+ }
+ ],
"2,11": [
{
"type": "insert",
@@ -272,7 +297,7 @@ main.floors.jiaocheng01=
[ 0, 0, 0, 1, 21, 1, 1, 1, 0, 1, 0, 0, 0],
[403, 0,404, 1, 23, 1, 21, 1, 0, 1, 34, 0, 33],
[ 1, 1, 1, 1, 1, 1, 0, 1, 81, 1, 1, 1, 1],
- [129, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,129],
+ [129, 0, 0, 0, 0,121, 0, 0, 0, 0, 0, 0,129],
[ 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1]
],
"areas": "教程",
diff --git a/project/floors/jiaocheng02.js b/project/floors/jiaocheng02.js
index 7990160..0aa7b43 100644
--- a/project/floors/jiaocheng02.js
+++ b/project/floors/jiaocheng02.js
@@ -76,9 +76,9 @@ main.floors.jiaocheng02=
],
"11,4": [
"\t[小妖精,fairy]与其他魔塔游戏不同的是,本作不仅引入了“速度”属性,还引入了实时战斗系统。\n这将带来比回合制战斗更丰富,更具有策略性的战斗体验。",
- "\t[小妖精,fairy]在本作中,“速度”意味着角色进行一次攻击前摇的快慢程度。没有特殊说明的话,本作不涉及攻击后摇。\n现在角色的速度为16,这意味着在单位时间内,角色可以攻击16次。\n战斗开始时,参战的双方互相向对方表露敌意,并开始分别计算攻击前摇。\n另一方面,速度和攻击前摇挂钩,意味着角色下一次攻击的时刻以上一次攻击落下时的速度为准;在此之后受到任何额外的减速效果,都只会影响到再下一次攻击。",
- "\t[小妖精,fairy]在刚才的战斗中,怪物的速度为18,角色的速度为16。\n因此在互相展现敌意后,怪物的攻击先命中角色,随后才是角色对怪物造成伤害。\n此后双方一直匀速造成伤害。",
- "\t[小妖精,fairy]战斗结束于8次攻击/16速度=0.5时刻。\n此时角色攻击8次,完成对怪物的击杀;与此同时,怪物的第9次攻击前摇刚好准备完毕。\n在本作的战斗系统中,如果怪物死亡时刻正好作出一次攻击(时刻完全相同)的话,视为这次攻击有效!\n因此,角色在之前的战斗中受到怪物刚好9次伤害。",
+ "\t[小妖精,fairy]在本作中,“速度”意味着角色进行一次攻击前摇的快慢程度。没有特殊说明的话,本作不涉及攻击后摇。\n现在角色的速度为16,这意味着在单位时间内,角色可以攻击16次。\n战斗开始时,参战的双方互相向对方表露敌意,并开始分别计算攻击前摇。\n由于角色是主动出击的一方,角色的首次攻击仅需一半的时间即可完成准备\n另一方面,速度和攻击前摇挂钩,意味着角色下一次攻击的时刻以上一次攻击落下时的速度为准;在此之后受到任何额外的减速效果,都只会影响到再下一次攻击。",
+ "\t[小妖精,fairy]在刚才的战斗中,怪物的速度为20,角色的速度为16。\n因此在互相展现敌意后,角色借助主动战斗的优势先攻击怪物,随后才是怪物对角色造成伤害。\n此后双方一直匀速造成伤害。",
+ "\t[小妖精,fairy]战斗结束于(8次攻击-0.5)/16速度=0.47时刻。\n此时角色攻击8次,完成对怪物的击杀;在此前,怪物刚刚完成第9次攻击。\n另外,在本作的战斗系统中,如果怪物死亡时刻正好作出一次攻击(时刻完全相同)的话,视为这次攻击有效!",
"\t[小妖精,fairy]接下来,请获取黄门中的2颗黄宝石,将角色的速度从16提升到20。\n面对相同的敌人,提升速度又会展现什么效果呢?",
{
"type": "jump",
@@ -104,14 +104,14 @@ main.floors.jiaocheng02=
],
"false": [
"\t[小妖精,fairy]在提升速度后,角色可以在更短的时间内打出足以击杀怪物的攻击频率。\n相比获取宝石之前,角色的攻击前摇快了25%。",
- "\t[小妖精,fairy]虽然攻击威力没有变化,仍然需要8次攻击才能击杀怪物,但战斗时间却实打实地从0.5降低到了0.4。\n在0.4时刻之前,怪物最多只能打出18*0.4=7次攻击。\n当然,提升攻击力降低战斗伤害的本质也是缩短战斗时间,从而让怪物的攻击频率缩短。",
- "\t[小妖精,fairy]但要注意——不是所有时候提升速度都能降低角色受到的攻击次数。\n如果角色的速度从21提升到24,击杀怪物需要的时间将由8/21=0.381变为0.333。(实际计算中具体时刻将保留14位小数,确保精确)\n怪物的第6次攻击于0.333时刻落下,而第7次攻击将于0.389时刻落下。\n因此,将击杀怪物的时刻从0.381提前到0.333,不影响怪物的第6和第7次攻击,从而不会降低伤害。",
- "\t[小妖精,fairy]因此,能带来战斗伤害减少的速度提升节点也特别重要——我们也称之为“临界”。\n从最初的需要8次攻击击杀,16点速度,0.5时刻击杀怪物开始计算(当然是计算怪物的时间轴)——\n怪物的第8次攻击落于0.444时刻,第9次攻击落于0.5时刻。\n速度达到17时,击杀时刻为8/17=0.471;速度达到19时,击杀时刻为8/19=0.421,刚好在怪物的第9次和第8次攻击之前。",
+ "\t[小妖精,fairy]虽然攻击威力没有变化,仍然需要8次攻击才能击杀怪物,但战斗时间却实打实地从0.47降低到了0.375。\n在0.375时刻之前,怪物最多只能打出20*0.375=7次攻击。\n当然,提升攻击力降低战斗伤害的本质也是缩短战斗时间,从而让怪物的攻击频率缩短。",
+ "\t[小妖精,fairy]但要注意——不是所有时候提升速度都能降低角色受到的攻击次数。\n如果角色的速度从20提升到21,击杀怪物需要的时间将由7.5/20=0.375变为0.357。(实际计算中具体时刻将保留14位小数,确保精确)\n怪物的第7次攻击于0.35时刻落下,而第8次攻击将于0.4时刻落下。\n因此,将击杀怪物的时刻从0.375提前到0.357,不影响怪物的第7和第8次攻击,从而不会降低伤害。",
+ "\t[小妖精,fairy]因此,能带来战斗伤害减少的速度提升节点也特别重要——我们也称之为“临界”。\n",
{
"type": "callBook"
},
- "\t[小妖精,fairy]同理,以现在的状态开始计算。现在我们需要0.4的攻击时间击杀怪物。\n怪物最后一次的攻击时刻为0.389;我们提升1点速度将会使我们的最后一次攻击时刻提前到0.381,从而少受到一次怪物的攻击——这1点速度就是一个速度临界值。继续提升速度,就需要考虑怪物在0.333时刻的攻击。",
- "\t[小妖精,fairy]我们的速度距离下一个临界点还差1点;达到临界点可以让我们受到的伤害减少50点。\n在怪物手册中记作[1,50]或\"1:50\"。速度临界值和临界表暂时需要到怪物手册中才能查阅。",
+ "\t[小妖精,fairy]以现在的状态开始计算。现在我们需要0.375的攻击时间击杀怪物。\n怪物最后一次的攻击时刻为0.35;我们提升2点速度将会使我们的最后一次攻击时刻提前到0.341,从而少受到一次怪物的攻击——这2点速度就是一个速度临界值。继续提升速度,就需要考虑怪物在0.3时刻的攻击。",
+ "\t[小妖精,fairy]我们的速度距离下一个临界点还差2点;达到临界点可以让我们受到的伤害减少50点。\n在怪物手册中记作[2,50]或\"2:50\"。速度临界值和临界表暂时需要到怪物手册中才能查阅。",
"\t[小妖精,fairy]捡起后面的血瓶和黄钥匙,补充生命值继续后面的内容吧!",
{
"type": "jump",
@@ -284,29 +284,6 @@ main.floors.jiaocheng02=
"type": "hide",
"remove": true
}
- ],
- "3,8": [
- {
- "type": "animationDrawable",
- "allFarme": 30,
- "color": [
- 0,
- 0,
- 0
- ],
- "imageList": [
- {
- "image": ""
- }
- ],
- "soundList": [
- {
- "sound": "",
- "startfarme": 0,
- "stopbefore": false
- }
- ]
- }
]
},
"changeFloor": {
diff --git a/project/floors/jiaocheng03.js b/project/floors/jiaocheng03.js
index 756affb..085352a 100644
--- a/project/floors/jiaocheng03.js
+++ b/project/floors/jiaocheng03.js
@@ -101,8 +101,8 @@ main.floors.jiaocheng03=
"\t[小妖精,fairy]刚才你应该是选择了1黄宝石1红宝石的组合,但——到底是什么原理?",
"\t[小妖精,fairy]接下来要讲的是本作一个非常隐蔽的现象——混合临界。\n混合临界仅会出现在角色的速度高于怪物速度的时候。\n出现混合临界的条件是,在怪物对角色进行最后一次攻击后,角色进行了两次以上的攻击才击杀了怪物。\n为了方便理解,可以画一个时间轴,从怪物最后一次攻击算起。",
"\t[小妖精,fairy]单纯提高攻击力来降低被攻击次数的话,需要让角色击杀怪物的攻击次数减少2,而不是1。\n在刚才的战斗中,角色的攻击力为32,击杀怪物需要162/(32-1)=6次攻击。\n要达到降低被攻击次数效果的话,将攻击力提升至162/5+1=34点并不足够。\n需要将攻击力提升至162/4+1=42点。",
- "\t[小妖精,fairy]同样地,单纯提高速度来降低被攻击次数的话,需要让角色的最后一次攻击提前到怪物攻击之前,而不是倒数第二次攻击。\n在刚才的战斗中,怪物最后一次攻击的时刻为3/14=0.214。\n角色在5/22=0.227,6/22=0.273两个时刻分别攻击了怪物,其中0.273时刻对怪物的攻击造成了击杀。\n要达到降低被攻击次数效果的话,将速度提升至5+/0.214=24点并不足够,因为角色需要6次攻击才能击杀怪物。\n需要将速度提升至6+/0.214=29点。",
- "\t[小妖精,fairy]但值得庆幸的是,我们还要第三种办法——同时增强速度和攻击。\n我们少量提升攻击力至34点,使击杀怪物仅需要5次攻击。\n然后再少量提升速度至24点,使我们的第5次攻击落在0.214时刻,即怪物的最后一次攻击前。\n这样,我们仅用了4点能力提升,就达到了单独提升某项能力10点或7点的效果。",
+ "\t[小妖精,fairy]同样地,单纯提高速度来降低被攻击次数的话,需要让角色的最后一次攻击提前到怪物攻击之前,而不是倒数第二次攻击。\n在刚才的战斗中,怪物最后一次攻击的时刻为3.5/16=0.219。\n角色在5/22=0.227,6/22=0.273两个时刻分别攻击了怪物,其中0.273时刻对怪物的攻击造成了击杀。\n要达到降低被攻击次数效果的话,将速度提升至5+/0.219=23点并不足够,因为角色需要6次攻击才能击杀怪物。\n需要将速度提升至6+/0.214=28点。",
+ "\t[小妖精,fairy]但值得庆幸的是,我们还要第三种办法——同时增强速度和攻击。\n我们少量提升攻击力至34点,使击杀怪物仅需要5次攻击。\n然后再少量提升速度至23点,使我们的第5次攻击落在0.217时刻,即怪物的最后一次攻击前。\n这样,我们仅用了3点能力提升,就达到了单独提升某项能力10点或6点的效果。",
"\t[小妖精,fairy]接下来是法强(护盾)和防御的价值判断。\n希望你能在这三扇黄门中打开正确的一扇。",
{
"type": "jump",
@@ -156,7 +156,7 @@ main.floors.jiaocheng03=
[ 1, 1, 1, 1, 1, 1,240, 1, 1, 1, 1, 1, 1],
[ 0, 33, 0, 21, 0,403, 0, 1,401, 1,402, 1, 31],
[ 83, 1, 83, 1, 83, 1,204, 1, 81, 1, 81, 1, 81],
- [402, 1,404, 1,401,129,124,204, 0, 33, 0, 23, 0],
+ [402, 1,404, 1,401, 1,124,204, 0, 33, 0, 23, 0],
[ 1, 1, 1, 1, 1, 1, 93, 1, 1, 1, 1, 1, 1]
],
"areas": "牢狱",
diff --git a/project/floors/jiuguan.js b/project/floors/jiuguan.js
index 07f4309..523052a 100644
--- a/project/floors/jiuguan.js
+++ b/project/floors/jiuguan.js
@@ -26,30 +26,6 @@ main.floors.jiuguan=
],
"direction": "down"
}
- ],
- "4,10": [
- {
- "type": "over",
- "text": "这段话将在屏幕中心",
- "image": "bg_5043.png",
- "memory": false,
- "time": 3000,
- "hidetime": 30,
- "sound": "",
- "textColor": [
- 255,
- 255,
- 255,
- 1
- ],
- "boldColor": [
- 0,
- 0,
- 0,
- 1
- ],
- "font": "bold 48px Verdana"
- }
]
},
"changeFloor": {},
diff --git a/project/floors/street01.js b/project/floors/street01.js
index 62ca09a..6f291a7 100644
--- a/project/floors/street01.js
+++ b/project/floors/street01.js
@@ -28,18 +28,11 @@ main.floors.street01=
]
},
"changeFloor": {
- "12,9": {
- "floorId": "zhujuejia",
- "loc": [
- 0,
- 9
- ]
- },
- "0,8": {
- "floorId": "changguan2",
+ "0,7": {
+ "floorId": "changguan1",
"loc": [
12,
- 8
+ 7
]
}
},
@@ -61,25 +54,25 @@ main.floors.street01=
]
},
"map": [
- [110121,110122,200040,200225,200138,200227,200228,200225,200250,200227,200228,200046,130090],
- [110124, 0,200048,200233,200146,200235,200236,200233,200250,200235,200228,200054,130098],
- [110124, 0,200056,200153,200154,200155,200244,200272,200154,200276,200228,200054,130060],
- [110124, 0,200272,200161,200162,200163,200276,200168,200171,200172, 0,70327,130068],
- [110124, 0,200168,200169,200170,200171,200172,200080,200081,200086, 0,70335,110114],
- [110124, 0,200176,200177,200178,200179,71786,90064,90064,90064, 0,90064,110125],
- [110124, 0,200088,200089,200004,200005,200006,71795, 0, 0, 0, 0,110125],
- [110118,110118,200096,110116,110020, 0,200014, 0, 0, 0, 0, 0,110125],
- [ 92, 0, 0,110124, 0, 0, 0, 0,110125,110122,110122,110122,110122],
- [ 0, 0, 0,110118,110118, 0,110118,110118,110122, 0, 0, 0, 94],
- [140, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [140, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,140,140],
- [140,140,140,140,140,140186,110138,110138,140184,140,140,140,140]
+ [110276, 0,200040,200225,200138,200227,200228,200225,200250,200227,200228,200046, 0],
+ [110284, 0,200048,200233,200146,200235,200236,200233,200250,200235,200228,200054,130090],
+ [110292, 0,200056,200153,200154,200155,200244,200272,200154,200276,200228,200054,130098],
+ [110300, 0,200272,200161,200162,200163,200276,200168,200171,200172, 0,70327,130060],
+ [110308, 0,200168,200169,200170,200171,200172,200080,200081,200086, 0,70335,110114],
+ [110316,110138,200176,200177,200178,200179,71786,90064,90064,90064, 0,90064,110125],
+ [ 0,110130,200088,200089,200004,200005,200006,71795, 0, 0, 0, 0,110125],
+ [ 92, 0,200096,110116,110020, 0,200014, 0, 0, 0, 0, 0,110125],
+ [120111, 0, 0,110124, 0, 0, 0, 0,110125,110122,110122,110122,110122],
+ [120119, 0, 0,110118,110118, 0,110118,110118,110122, 0, 0, 0, 0],
+ [120127, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [120135, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [120151, 0, 0,120117,120118,120118,120118,120118,120118,120118,120118,120119, 0]
],
"areas": "牢狱",
"bgmap": [
- [90078, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,90078],
- [90078, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,90078],
- [90078, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,90078],
+ [90078,210177, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,210177],
+ [90078,210185, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,210185],
+ [90078,210193, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,210193],
[90078,71818,71819, 0, 0, 0, 0, 0, 0, 0,10036, 0,90078],
[90078,71826,71827, 0, 0, 0, 0, 0, 0, 0, 0, 0,90078],
[90078, 0, 0, 0, 0, 0,71786, 0,60135,60135,60135,60135,90078],
@@ -92,18 +85,18 @@ main.floors.street01=
[ 0, 0, 0, 0, 0, 0,90078,90078, 0, 0, 0, 0, 0]
],
"fgmap": [
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,130076],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,130084],
- [ 0, 0,200110,200111, 0,200108,200109, 0, 0, 0, 0, 0, 0],
+ [ 0, 0,200110,200111, 0,200108,200109, 0, 0, 0, 0, 0,130084],
[ 0, 0,200118,200119, 0,200116,200117, 0, 0, 0, 0, 0, 0],
[ 0,20241, 0, 0, 0, 0, 0, 0, 0,70552, 0,70554, 0],
- [ 0, 0, 0, 0, 0, 93,200180,71787, 0,70560, 0,70562, 0],
- [110114,110114, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,90173, 0, 93,200180,71787, 0,70560, 0,70562, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0,110143,110114,110114,110114,110114],
[ 0, 0, 0,110114,120095, 0,120095,120095,110114, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0,140186, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0,140194, 0, 0, 0, 0, 0, 0, 0, 0,140184, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,120109,120110,120110,120110,120110,120110,120110,120110,120111, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"bg2map": [
@@ -111,9 +104,9 @@ main.floors.street01=
[ 0,90650,90651, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0,90658,90659, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0,70163,70325,70325,70326, 0,200162, 0],
- [ 0, 0, 0, 0, 0, 0,70171,70333,70333,70334,70553,200162, 0],
- [ 0,71834,71835, 0, 0, 0,90064, 0, 0, 0,70561, 0,110122],
- [ 0,71842,71843,200089,200004,200005,71794, 0,90617,70568,70569,70570, 0],
+ [ 0, 0, 0, 0, 0, 0,70171,70333,70333,70334,70553,200162,130068],
+ [ 0, 0,110138, 0, 0, 0,90064, 0, 0, 0,70561, 0,110122],
+ [ 0,110146,110146,200089,200004,200005,71794, 0,90617,70568,70569,70570, 0],
[ 0, 0, 0,200097,200012,200013,110012, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0,110028,90244, 0,120108,120108,110134,110134,110134,110134],
[ 0, 0, 0, 0,120103,90244,120103,120103, 0, 0, 0, 0, 0],
diff --git a/project/floors/xiaoxiang01.js b/project/floors/xiaoxiang01.js
index 6cc4e72..88b502b 100644
--- a/project/floors/xiaoxiang01.js
+++ b/project/floors/xiaoxiang01.js
@@ -29,13 +29,6 @@ main.floors.xiaoxiang01=
6,
0
]
- },
- "0,7": {
- "floorId": "guangchang2",
- "loc": [
- 12,
- 10
- ]
}
},
"beforeBattle": {},
@@ -56,7 +49,7 @@ main.floors.xiaoxiang01=
[120164,225,200998,200999,201037, 81,201029, 0, 0, 0,110116, 0, 94],
[120172, 0,222, 0,221, 0,201029, 81,110116,225,110137,110138,90650],
[120180,201037,201037, 81,201037,201037,201037,246,110124, 0, 81, 31,90658],
- [ 92, 32, 32, 22, 21,80089, 31, 0,110132, 0,110122,110122,110197],
+ [ 0, 32, 32, 22, 21,80089, 31, 0,110132, 0,110122,110122,110197],
[140,110191, 21, 21, 21,80089, 0,246, 81, 0,222, 29,110197],
[140,140,140,110191,80083,80097, 93,110138,110138,140189,140,140,140]
],
diff --git a/project/floors/yiqu1.js b/project/floors/yiqu1.js
index 7f652a3..e7227a7 100644
--- a/project/floors/yiqu1.js
+++ b/project/floors/yiqu1.js
@@ -60,15 +60,15 @@ main.floors.yiqu1=
[143,143,143,143,130060,130061,130062,130201,130201,143,143,143,143],
[143,130193,130193,130194,130068,130069,130070, 0,120023,130192,130193,130193,143],
[130194,130201,130201,130202,130007,130006,130099,130098,120031,130200,130201,130201,143],
- [130202, 32, 0, 21,201021,401,110116, 0,201, 81, 0, 21,130192],
- [140101, 0,205, 0,201037,421,110124, 31, 0,110116, 31, 0,130200],
- [140109,201037, 0,201037,200199, 81,110140,110138, 81,110138,110138,202,90667],
- [ 92,201, 0, 0, 31, 0,202, 0, 0, 82, 0, 0,90675],
- [120111, 0, 0, 21, 0, 0,201021,205,110138,110138,201021, 0, 94],
- [120119,110122, 81,110122,201037,201,201029,402, 0, 21,201029,205,90650],
+ [130202, 32, 0, 21,201021,401,220008, 0,201, 81, 0, 21,130192],
+ [140101, 0,205, 0,201037,421,220008, 31, 0,220008, 31, 0,130200],
+ [140109,201037, 0,201037,200199, 81,220013,220013, 81,220012,220013,202,140099],
+ [ 92,201, 0, 0, 31, 0,202, 0, 0, 82, 0, 0,140107],
+ [120041, 0, 0, 21,201021, 0,110138,205,110138,110138,110138, 0, 94],
+ [120119,220013, 81,220013,201037,201,201029,402, 0, 21,201029,205,90650],
[120127,202, 31,202,201037, 0,201029, 0, 21, 0,201029, 0,110189],
- [120135, 22,205,403,201037,202,201037,110122,110122, 81,201037,201,110197],
- [120143,110138,110138,110138,201029, 0,201, 0, 31, 0, 21, 0,110197]
+ [120135, 22,205,403,201037,202,201037,220013,220013, 81,201037,201,110197],
+ [120143,220001,220001,220001,201037, 0,201, 0, 31, 0, 21, 0,110197]
],
"bgmap": [
[90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078],
@@ -90,27 +90,27 @@ main.floors.yiqu1=
[ 0, 0, 0, 0, 0, 0, 0, 0,120074, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0,130091,130090, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0,200175, 0, 0, 0, 0, 0, 0, 0, 0],
- [140093, 0, 0, 0,200183, 0, 0, 0, 0,110152, 0, 0, 0],
- [ 0,201021, 0,201021,200191, 0, 0, 0, 0,110160, 0, 0,90667],
+ [140093, 0, 0, 0,200183, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,201021, 0,201021,200191, 0, 0,220009, 0, 0,220009, 0,140091],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0,110114, 0,110114,201021, 0, 0, 0, 0, 0, 0, 0, 0],
+ [120111,220009, 0,220009, 0, 0,201021, 0, 0, 0,201021, 0, 0],
[ 0, 0, 0, 0,201021, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0,201021, 0, 0,110114,110114, 0, 0, 0, 0],
+ [ 0, 0, 0, 0,201021, 0, 0,220009,220009, 0, 0, 0, 0],
[ 0, 0, 0, 0,201021, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+ [ 0, 0, 0, 0,220001, 0, 0, 0, 0, 0, 0, 0, 0]
],
"bg2map": [
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0,120082, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0,130193, 0, 0, 0, 0, 0,120082, 0,130193, 0, 0],
+ [ 0, 0,130201, 0, 0, 0, 0, 0, 0, 0,130201, 0, 0],
[ 0, 0, 0, 0,130015, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0,110129, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0,110146,110146, 0,110146,110146, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0,110146,110146, 0, 0, 0],
+ [130076, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [130084, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,130058],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,130066],
+ [ 0, 0, 0, 0,120041, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0,220013, 0, 0, 0,110146,110146, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,90658],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
diff --git a/project/floors/yiqu11.js b/project/floors/yiqu11.js
new file mode 100644
index 0000000..e23219f
--- /dev/null
+++ b/project/floors/yiqu11.js
@@ -0,0 +1,53 @@
+main.floors.yiqu11=
+{
+ "floorId": "yiqu11",
+ "title": "主塔 10 层",
+ "name": "10",
+ "width": 13,
+ "height": 13,
+ "canFlyTo": true,
+ "canFlyFrom": true,
+ "canUseQuickShop": true,
+ "images": [],
+ "ratio": 1,
+ "defaultGround": "X90078",
+ "firstArrive": [],
+ "eachArrive": [],
+ "parallelDo": "",
+ "events": {},
+ "changeFloor": {},
+ "beforeBattle": {},
+ "afterBattle": {},
+ "afterGetItem": {},
+ "afterOpenDoor": {},
+ "autoEvent": {},
+ "cannotMove": {},
+ "cannotMoveIn": {},
+ "map": [
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+],
+ "bgmap": [
+
+],
+ "fgmap": [
+
+],
+ "bg2map": [
+
+],
+ "fg2map": [
+
+]
+}
\ No newline at end of file
diff --git a/project/floors/yiqu12.js b/project/floors/yiqu12.js
new file mode 100644
index 0000000..b8b62bf
--- /dev/null
+++ b/project/floors/yiqu12.js
@@ -0,0 +1,53 @@
+main.floors.yiqu12=
+{
+ "floorId": "yiqu12",
+ "title": "主塔 6 层",
+ "name": "6",
+ "width": 13,
+ "height": 13,
+ "canFlyTo": true,
+ "canFlyFrom": true,
+ "canUseQuickShop": true,
+ "images": [],
+ "ratio": 1,
+ "defaultGround": "X90078",
+ "firstArrive": [],
+ "eachArrive": [],
+ "parallelDo": "",
+ "events": {},
+ "changeFloor": {},
+ "beforeBattle": {},
+ "afterBattle": {},
+ "afterGetItem": {},
+ "afterOpenDoor": {},
+ "autoEvent": {},
+ "cannotMove": {},
+ "cannotMoveIn": {},
+ "map": [
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+],
+ "bgmap": [
+
+],
+ "fgmap": [
+
+],
+ "bg2map": [
+
+],
+ "fg2map": [
+
+]
+}
\ No newline at end of file
diff --git a/project/floors/yiqu13.js b/project/floors/yiqu13.js
new file mode 100644
index 0000000..1710543
--- /dev/null
+++ b/project/floors/yiqu13.js
@@ -0,0 +1,53 @@
+main.floors.yiqu13=
+{
+ "floorId": "yiqu13",
+ "title": "主塔 6 层",
+ "name": "6",
+ "width": 13,
+ "height": 13,
+ "canFlyTo": true,
+ "canFlyFrom": true,
+ "canUseQuickShop": true,
+ "images": [],
+ "ratio": 1,
+ "defaultGround": "X90078",
+ "firstArrive": [],
+ "eachArrive": [],
+ "parallelDo": "",
+ "events": {},
+ "changeFloor": {},
+ "beforeBattle": {},
+ "afterBattle": {},
+ "afterGetItem": {},
+ "afterOpenDoor": {},
+ "autoEvent": {},
+ "cannotMove": {},
+ "cannotMoveIn": {},
+ "map": [
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+],
+ "bgmap": [
+
+],
+ "fgmap": [
+
+],
+ "bg2map": [
+
+],
+ "fg2map": [
+
+]
+}
\ No newline at end of file
diff --git a/project/floors/yiqu2.js b/project/floors/yiqu2.js
index 16400e4..eaa6c56 100644
--- a/project/floors/yiqu2.js
+++ b/project/floors/yiqu2.js
@@ -14,7 +14,43 @@ main.floors.yiqu2=
"firstArrive": [],
"eachArrive": [],
"parallelDo": "",
- "events": {},
+ "events": {
+ "3,3": {
+ "trigger": "action",
+ "enable": true,
+ "noPass": true,
+ "displayDamage": true,
+ "opacity": 1,
+ "filter": {
+ "blur": 0,
+ "hue": 0,
+ "grayscale": 0,
+ "invert": false,
+ "shadow": 0
+ },
+ "data": [
+ {
+ "type": "if",
+ "condition": "(!switch:A)",
+ "true": [
+ {
+ "type": "function",
+ "function": "function(){\ncore.getItem(\"blueKey\", null, 3,3)\n}"
+ },
+ {
+ "type": "setBlock",
+ "number": "X130061"
+ },
+ {
+ "type": "setValue",
+ "name": "switch:A",
+ "value": "true"
+ }
+ ]
+ }
+ ]
+ }
+ },
"changeFloor": {
"12,7": {
"floorId": "yiqu3",
@@ -39,22 +75,22 @@ main.floors.yiqu2=
"cannotMove": {},
"cannotMoveIn": {},
"map": [
- [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 22, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 81, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 22],
- [ 1, 81, 1, 1, 1, 1, 1, 1, 1, 0, 83, 0,403],
- [ 31, 0,401,209, 0,402, 1, 0, 34, 0, 1,209, 0],
- [ 0,202, 0, 1, 32, 0, 1,405, 0,408, 1, 81, 1],
- [ 1, 81, 1, 1, 0,421, 1, 0,204, 0, 1, 0, 94],
- [ 92, 0, 21, 1, 1, 81, 1, 1, 82, 1, 1,205, 1],
- [ 1, 1, 0,202, 0, 0, 32,209, 0, 1, 21, 0, 1],
- [ 0,201, 0, 1, 81, 1, 1, 1, 0,205, 0, 0,421],
- [202, 1, 1, 1, 0, 1,402, 1,201, 1, 31, 1, 0],
- [ 0, 21, 21, 1, 0,202, 0,201, 0, 1, 1, 1, 22]
+ [143,120034,200990,200991,120034,120012,120033, 0,110089,110090, 0,110024,140],
+ [143,170007,200998,200999,170007,120019,120017, 0,110097,110098, 0,100378,140],
+ [143, 0, 0, 0, 0,120019,120017, 0,110105,110106, 0,110016,140],
+ [143, 81, 0, 22, 0,120020,120003, 0,140128,140129, 0,110024,130192],
+ [130194, 81,120014,110015,120010,120010,120011, 22, 0,403, 0,209,130200],
+ [130202, 31, 0,209, 0,402,120029,120010, 83,110015,120010, 81,140099],
+ [140101,401,202,120041, 32, 0,201029, 0, 34, 0,201029, 0,140107],
+ [140109,120041, 81,201029, 0,421,201029,405,204,408,201029, 0, 94],
+ [ 92, 0, 21,201037,220013, 81,201037,220013, 82,220013,201037,205,130058],
+ [90651,120048, 0, 0,202, 0, 32,209, 0,120041, 21, 0,130066],
+ [110190,110191,201,201023,120041, 81,220013,220013, 0,205, 0, 0,421],
+ [110198,110199,202,201031,201029,202, 0,10173,201,90667, 31,90667, 0],
+ [110198,110199, 21, 21,201029, 0,402,201, 0,90667,90667,90667, 22]
],
"bgmap": [
- [90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078],
+ [90078,90078,180025,180025,90078,90078,90078,90078,90078,90078,90078,90078,90078],
[90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078],
[90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078],
[90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078],
@@ -69,10 +105,34 @@ main.floors.yiqu2=
[90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078,90078]
],
"fgmap": [
-
+ [ 0, 0, 0, 0, 0, 0,120017,110088, 0, 0,110091, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0,110096, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0,140120,140121, 0, 0, 0],
+ [ 0, 0,120002,120002,120002,120002, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0,120001,120002, 0,120002,120002, 0,140091],
+ [140093, 0, 0, 0, 0, 0,201021, 0, 0, 0,201021, 0, 0],
+ [ 0, 0, 0,201021, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0,220009, 0, 0,220009, 0,220009, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0,120048, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0,220009,220009, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0,201021, 0, 0,10165, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"bg2map": [
-
+ [ 0,180025,120034,120034,180025,180026, 0,120034,120034,120034,120034,120034, 0],
+ [ 0,180025,180025,180025,180025,180026, 0, 0, 0, 0,110099, 0, 0],
+ [ 0,180025,180025,180025,180025,180026, 0, 0, 0, 0,110107,100402, 0],
+ [ 0, 0,180025,130061,130060,180026,120017, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,130056],
+ [130059, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,130064],
+ [130067, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,120041, 0, 0, 0, 0, 0, 0, 0,120064, 0, 0, 0],
+ [ 0,120064, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,201039, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"fg2map": [
diff --git a/project/floors/yiqu3.js b/project/floors/yiqu3.js
index 6acf6a5..edd9b2b 100644
--- a/project/floors/yiqu3.js
+++ b/project/floors/yiqu3.js
@@ -14,21 +14,57 @@ main.floors.yiqu3=
"firstArrive": [],
"eachArrive": [],
"parallelDo": "",
- "events": {},
+ "events": {
+ "12,8": {
+ "trigger": "action",
+ "enable": true,
+ "noPass": true,
+ "displayDamage": true,
+ "opacity": 1,
+ "filter": {
+ "blur": 0,
+ "hue": 0,
+ "grayscale": 0,
+ "invert": false,
+ "shadow": 0
+ },
+ "data": [
+ {
+ "type": "if",
+ "condition": "(!switch:A)",
+ "true": [
+ {
+ "type": "function",
+ "function": "function(){\ncore.getItem(\"redPotion\", null, 8, 12)\n}"
+ },
+ {
+ "type": "setBlock",
+ "number": "X60150"
+ },
+ {
+ "type": "setValue",
+ "name": "switch:A",
+ "value": "true"
+ }
+ ]
+ }
+ ]
+ }
+ },
"changeFloor": {
+ "5,1": {
+ "floorId": "yiqu4",
+ "loc": [
+ 5,
+ 12
+ ]
+ },
"0,7": {
"floorId": "yiqu2",
"loc": [
12,
7
]
- },
- "5,0": {
- "floorId": "yiqu4",
- "loc": [
- 5,
- 12
- ]
}
},
"beforeBattle": {},
@@ -37,30 +73,56 @@ main.floors.yiqu3=
"afterOpenDoor": {},
"autoEvent": {},
"cannotMove": {},
- "cannotMoveIn": {},
+ "cannotMoveIn": {
+ "12,8": []
+ },
"map": [
- [ 1, 1, 1, 1, 1, 91, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 1, 1, 1, 1, 0, 1, 1, 1, 31, 21, 1, 1],
- [ 1, 1, 1, 1, 1,203, 1, 1, 1, 1, 21, 1, 1],
- [ 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 0, 1, 1],
- [ 1, 1, 1, 1, 1,205, 1, 1, 1, 1, 82, 1, 1],
- [ 1, 0,202, 0,421, 0,421, 0, 31, 0, 0, 1, 1],
- [ 1,201, 1, 1, 81, 1, 1, 1, 1, 1, 81, 1, 1],
- [ 92, 0, 1, 31, 0,209, 0, 1,403, 0,209, 1, 1],
- [ 1, 81, 1, 0,244, 0, 31, 1, 0,403, 0, 1, 23],
- [205, 0, 1, 1, 1, 1, 82, 1,205, 1, 1, 1, 0],
- [ 0,209, 1,401,402, 0, 0, 1, 0, 1,244, 0, 31],
- [205, 0, 1, 1, 1, 1,216, 1, 81, 1, 0, 81, 0],
- [ 21, 0,203, 0, 31, 21, 0, 81, 0, 82,216, 0,203]
+ [140,140,140204,140206,140206, 0,140206,140206,140203,140,110204,110206,110206],
+ [140,140,140199,170255,170252, 91,170254,170255,140197,140,140199,130192,130193],
+ [140206,140206,140207,170263,170260,203,170262,170263,140205,140206,140207,130200,130201],
+ [130193,130193,130194,71835,170268, 0,170270,90648,130192,130193,130194, 31, 0],
+ [130201,130201,130202,71843,110122,205,110122,90649,130200,130201,130202, 0, 21],
+ [140101, 0,202, 0,421, 0,421, 0, 31, 0, 82, 21, 0],
+ [140109,201,201021,220013, 81,220013,220013,201021, 81,220013,220013,220013,220013],
+ [ 92, 0,201029, 31, 0,209, 0,201029,209, 0,403,201029,71792],
+ [130059, 0,201029, 0,244, 0, 31,201029, 0,403, 0,201029, 31],
+ [130067, 81,201029,220013,220013, 82,220013,201029, 81,220013,220013,201037, 0],
+ [205, 0,201029,401, 0, 0,402,201029,205,120041,244, 0, 23],
+ [ 0,209,201037,220013,216,220013,220013,201037, 0,201037, 0, 81, 0],
+ [205, 21, 0,203, 0, 31, 21, 81, 0, 82,216, 0,203]
],
"bgmap": [
],
"fgmap": [
-
+ [ 0, 0, 0, 0, 0,140206,110319, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0,170253,110327, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0,110335, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0,110114, 0,110114, 0, 0, 0, 0, 0, 0],
+ [140093, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,201021,71784],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0,201021, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"bg2map": [
-
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,170271, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [130057, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [130065, 0,220013, 0, 0, 0, 0,220013, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,60150],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,60158],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"fg2map": [
diff --git a/project/floors/yiqu4.js b/project/floors/yiqu4.js
index 7462679..d7ac2b0 100644
--- a/project/floors/yiqu4.js
+++ b/project/floors/yiqu4.js
@@ -39,28 +39,64 @@ main.floors.yiqu4=
"cannotMove": {},
"cannotMoveIn": {},
"map": [
- [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 1, 1,421, 0,205, 0,421, 1, 1, 1, 1, 1],
- [ 1, 1, 1, 0, 1, 81, 1, 0, 81, 81, 0,205, 0],
- [ 0,244, 0, 31, 1, 0, 1, 31, 1, 1,216, 1, 31],
- [ 0, 1,425, 1, 1, 31, 1, 1, 22, 1, 0, 1, 1],
- [ 31, 1, 0, 1,401, 1,402, 1, 0, 1, 32, 1,403],
- [ 0, 81, 21, 1, 0, 1, 0, 1,244, 81, 0, 81, 0],
- [403, 1, 0, 1, 82, 1, 82, 1, 1, 1,216, 1, 1],
- [ 0, 1,421, 0, 21, 0, 32, 0,240, 21, 0,425, 94],
- [ 0,216, 0, 1, 1, 93, 1, 1, 1, 1, 1, 1, 1]
+ [120138,120139,120140,200072,200073,200074,200075,200076,200077,200078,120144,120145,120146],
+ [120146,120147,120148,200176,200177,200178,200083,200084,200085,200086,120152,120153,120154],
+ [120154,120155,120156,200184,200185,200186,200091,200092,200093,200094,120160,120161,120162],
+ [120162,120163,120164,120056,200193,200194,200099,200100,140017,140018,120168,120169,120170],
+ [120170,120171,120172, 0,110071, 0, 31, 0, 0, 0,120176,120177,120178],
+ [120178,120179,120180,120010,120018, 81,120010,120010,120010,120010,120028, 0, 31],
+ [244, 0, 0, 31,421,205,421, 31, 81, 81, 0,205, 0],
+ [ 0,110004,425,201021,220013,201021,220013,201021,220013,201021,216,201021,220013],
+ [ 0, 81, 0,401,201029,201029,402,201029, 22,201037, 32,201037,403],
+ [ 31,200199, 21,201029, 0,201029, 0,201029,244, 81, 0, 81, 0],
+ [ 0,216, 0,201037, 82,201037, 82,201037,220013,130006,216,130006,220013],
+ [403,201021,421, 0, 21, 0, 32, 0,240, 21, 0,425, 94],
+ [140,140,140,140,140, 93,140,140,140,140,140,140,140]
],
"bgmap": [
-
+ [ 0, 0, 0,210186, 0, 0, 0, 0, 0,210186, 0, 0, 0],
+ [ 0, 0, 0,210194, 0, 0, 0, 0, 0,210194, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0,201037, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"fgmap": [
-
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,120006,120006, 0,120006,120006,120006,120006,120020, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,200175, 0,220009,220009,220009,220009,220009,220009,220009, 0,220009,220009],
+ [ 0,200183, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,200191, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0,220009, 0, 0, 0,220009],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"bg2map": [
-
+ [ 0, 0, 0,210184, 0, 0, 0, 0, 0,120066, 0, 0, 0],
+ [ 0, 0, 0,210192, 0, 0, 0, 0, 0,120074, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0,120082, 0, 0, 0],
+ [ 0, 0, 0,200096, 0, 0, 0, 0,200101,200102, 0, 0, 0],
+ [ 0, 0, 0,120064, 0, 0, 0, 0,140025,140026, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,220013, 0,220013, 0,220013, 0,220013, 0,220013,220013],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,120041, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"fg2map": [
diff --git a/project/floors/yiqu5.js b/project/floors/yiqu5.js
index 2ebfddd..e1260f1 100644
--- a/project/floors/yiqu5.js
+++ b/project/floors/yiqu5.js
@@ -14,7 +14,78 @@ main.floors.yiqu5=
"firstArrive": [],
"eachArrive": [],
"parallelDo": "",
- "events": {},
+ "events": {
+ "9,3": {
+ "trigger": "action",
+ "enable": true,
+ "noPass": true,
+ "displayDamage": true,
+ "opacity": 1,
+ "filter": {
+ "blur": 0,
+ "hue": 0,
+ "grayscale": 0,
+ "invert": false,
+ "shadow": 0
+ },
+ "data": [
+ {
+ "type": "if",
+ "condition": "(!switch:A)",
+ "true": [
+ {
+ "type": "function",
+ "function": "function(){\ncore.getItem(\"redPotion\", null, 3, 9)\n}"
+ },
+ {
+ "type": "setBlock",
+ "number": "X60150"
+ },
+ {
+ "type": "setValue",
+ "name": "switch:A",
+ "value": "true"
+ }
+ ]
+ }
+ ]
+ },
+ "3,2": {
+ "trigger": "action",
+ "enable": true,
+ "noPass": true,
+ "displayDamage": true,
+ "opacity": 1,
+ "filter": {
+ "blur": 0,
+ "hue": 0,
+ "grayscale": 0,
+ "invert": false,
+ "shadow": 0
+ },
+ "data": [
+ {
+ "type": "if",
+ "condition": "(!switch:A)",
+ "true": [
+ {
+ "type": "function",
+ "function": "function(){\ncore.getItem(\"bluePotion\", null, 2, 3)\n}"
+ },
+ {
+ "type": "setBlock",
+ "number": "X60150"
+ },
+ {
+ "type": "setValue",
+ "name": "switch:A",
+ "value": "true"
+ }
+ ]
+ }
+ ]
+ }
+ },
"changeFloor": {
"0,11": {
"floorId": "yiqu4",
@@ -25,35 +96,89 @@ main.floors.yiqu5=
}
},
"beforeBattle": {},
- "afterBattle": {},
+ "afterBattle": {
+ "6,2": [
+ {
+ "type": "setValue",
+ "name": "item:I427",
+ "operator": "+=",
+ "value": "1"
+ },
+ "一段剧情(奖励是匕首),然后飞去2区",
+ {
+ "type": "changeFloor",
+ "floorId": "yiqu6",
+ "loc": [
+ 12,
+ 6
+ ]
+ }
+ ]
+ },
"afterGetItem": {},
"afterOpenDoor": {},
"autoEvent": {},
"cannotMove": {},
"cannotMoveIn": {},
"map": [
- [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
- [ 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1, 1, 1],
- [ 1, 0, 32, 1, 1, 1,426, 1, 1, 1, 1, 1, 1],
- [ 1, 82, 1, 1, 1, 1, 0, 1, 1, 31, 1, 1, 1],
- [216, 0,216, 1, 1, 1, 83, 1, 1, 0, 1, 1, 1],
- [ 0, 1, 0, 1, 1,209, 0,209, 1, 81, 1, 1, 1],
- [ 32, 1, 32, 0, 81, 0, 82, 0, 32, 0,216, 0, 22],
- [ 1, 1, 0, 1, 1,244, 1, 1, 81, 1, 1, 1, 1],
- [ 31, 1,209, 1, 31, 0,403, 1,203, 0,244, 1, 31],
- [ 0,216, 0, 1, 1, 1, 1, 1, 0,203, 0, 1, 0],
- [ 1, 1, 32, 82, 0,402, 1, 1,209, 0, 34, 1, 81],
- [ 92, 0, 0, 1, 1, 1, 1, 21, 1, 1, 21, 1, 22],
- [ 1, 1, 31, 82, 0,401, 1, 32, 0,425, 0,213, 0]
+ [210194,210194,210186,210186,210186,210192,210185,210186,210186,210186,210194,210194,210194],
+ [120155,120156,210194,210194,210194,210192,210193,210194,210194,210194,120144,120145,120146],
+ [120163,120164, 0, 32,120012, 0,426, 0,120013,120030,120152,120153,120154],
+ [120171,120172, 0, 0,120020, 0, 0, 0,120019, 31,120160,120161,120162],
+ [120179,120180, 82,120015,120010,120010, 83,120010,120045, 0,120168,120169,120170],
+ [216, 0,216,71792,71793,209, 0,209,120029, 81,120176,120177,120178],
+ [ 32,120041, 0, 32, 81, 0, 82, 0, 32, 0,216, 0, 22],
+ [220013,220013, 0,220013,220013,244,220013,220013, 81,220013,220013,220013,220013],
+ [ 31,120064,209,201029, 31, 0,403,201029,209, 0,244,201029, 31],
+ [ 0,216, 0,201037,220013,220013,220013,201029, 0,209, 0,201029, 0],
+ [220013,220013, 32, 82, 0, 0,402,201029,203, 0, 34,201029, 81],
+ [ 92, 0, 0,220013,220013,220013,220013,220012,220013,220013, 21,220014, 22],
+ [140,110191, 31, 82, 0,401,120064, 21, 32,425, 0,213, 0]
],
"bgmap": [
-
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,120031, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"fgmap": [
-
+ [120147,120148, 0, 0, 0, 0, 0, 0, 0, 0,120136,120137,120138],
+ [ 0, 0,120023,120023,120004, 0, 0, 0,120005,120022, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,120007,110023,110023, 0,110023,120020, 0, 0, 0, 0],
+ [ 0, 0, 0,71784,71785, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [220009,220009, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0,120056, 0,201021, 0, 0, 0,201021, 0, 0, 0,201021, 0],
+ [ 0,120041, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [220009,220009, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0,120056, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0,120041, 0, 0, 0, 0, 0, 0]
],
"bg2map": [
-
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0,120031,50134, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0,50142, 0, 0, 0, 0, 0,50134, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0,50142, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0,201037, 0, 0, 0,201037, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
],
"fg2map": [
diff --git a/project/floors/yiqu6.js b/project/floors/yiqu6.js
index 633e6a3..19a2d62 100644
--- a/project/floors/yiqu6.js
+++ b/project/floors/yiqu6.js
@@ -14,29 +14,52 @@ main.floors.yiqu6=
"firstArrive": [],
"eachArrive": [],
"parallelDo": "",
- "events": {},
- "changeFloor": {},
+ "events": {
+ "10,5": [
+ "\t[冥蓝海,sign]想要做的怪物特性:\n1. 暴击:怪物的首次攻击必定暴击,暴击额外造成x%的伤害;除此以外,怪物每y次攻击就将打出一次暴击。\n2. 硬化/抗魔:怪物受到的物理/魔法伤害将减免x%。\n3. 反击:怪物的首次攻击附加怪物当前已损失生命值的100%作为伤害。\n4. 破甲:怪物攻击时无视角色x%的防御力;首次攻击时,怪物额外无视角色y%的防御力(加算)。\n5. 吸血:怪物造成的物理伤害以x%回复怪物自身的生命值,不计对护盾造成的破坏。\n6. 诅咒:当怪物的攻击同时造成了物理伤害和魔法伤害(不计对护盾造成的破坏),则魔法伤害按x倍计算。\n7. 闪避:怪物受到的首次普通攻击将被闪避而无效化;除此以外,怪物每受到x次普通攻击造成的伤害就将闪避一次。\n8. 寒霜:怪物的前x次(x=0则为所有)普通攻击命中角色时,将使角色在该场战斗中的速度下降y点。\n9. 灼炎:怪物的普通攻击命中角色时,将在该场战斗中熔毁角色的防御x点。\n10. 风行:怪物的基础速度将不低于角色的基础速度;怪物每次攻击命中或闪避攻击时,其速度提高x点。\n11. 撕裂:怪物的普通攻击附加角色当前已损失生命值的x%作为伤害,不计对护盾造成的破坏。\n12. 献祭:怪物身周萦绕着火焰,火焰每次对角色造成x点魔法伤害,伤害速度等于怪物的初始生命。\n13. 闪电:怪物对角色护盾的破坏效率提升x倍。[ver2:完全破坏护盾时,剩余的伤害也按x倍结算]\n14. 毒素:怪物的普通攻击造成物理伤害时(不计对护盾造成的破坏)将附加一层毒素效果,每层毒素效果将使角色在该场战斗中攻击时流失x点生命值。\n15. 汲取:怪物对角色护盾造成破坏时,将窃取破坏数值的x%作为自身护盾。\n16. 重力:怪物操纵角色的重力,每携带一件双手装备速度下降4x%,每携带一件单手装备速度下降2x%,每携带一件其他装备速度下降x%。\n17. 潜影:角色可穿过怪物。穿过怪物并行走x步之后,若角色仍处于怪物可见直线内,则与怪物强制战斗,且怪物首先攻击,其首次攻击攻击力提升至x倍。"
+ ]
+ },
+ "changeFloor": {
+ "12,6": {
+ "floorId": "yiqu5",
+ "loc": [
+ 0,
+ 11
+ ]
+ },
+ "0,5": {
+ "floorId": "yiqu7",
+ "loc": [
+ 12,
+ 5
+ ]
+ }
+ },
"beforeBattle": {},
"afterBattle": {},
- "afterGetItem": {},
+ "afterGetItem": {
+ "11,6": [
+ "这个血瓶也放到间章剧情部分"
+ ]
+ },
"afterOpenDoor": {},
"autoEvent": {},
"cannotMove": {},
"cannotMoveIn": {},
"map": [
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
+ [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
+ [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
+ [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
+ [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
+ [ 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1],
+ [ 92, 1, 1, 1, 1, 1, 1, 1, 1, 1,129, 1, 1],
+ [213, 0, 32,204, 0,203, 0, 22, 0,213, 0, 33, 94],
+ [ 1, 81, 1, 1, 81, 1, 1, 1, 81, 1, 81, 1, 1],
+ [ 0, 0,244, 21, 0, 1, 31, 0,213, 1,203, 0,403],
+ [206, 1, 1, 1,210, 1, 0,402, 0, 1, 0, 31, 0],
+ [ 0,221, 22, 1, 0, 1, 81, 1, 1, 1, 1, 1, 81],
+ [ 21, 0,221, 1, 31, 1,428, 0, 32, 1, 32, 0,425],
+ [ 0, 34, 0,240, 0, 81, 0,404, 0, 82, 0,401, 0]
],
"bgmap": [
diff --git a/project/floors/yiqu7.js b/project/floors/yiqu7.js
index 459aded..7e9f3a6 100644
--- a/project/floors/yiqu7.js
+++ b/project/floors/yiqu7.js
@@ -15,7 +15,15 @@ main.floors.yiqu7=
"eachArrive": [],
"parallelDo": "",
"events": {},
- "changeFloor": {},
+ "changeFloor": {
+ "12,5": {
+ "floorId": "yiqu6",
+ "loc": [
+ 0,
+ 5
+ ]
+ }
+ },
"beforeBattle": {},
"afterBattle": {},
"afterGetItem": {},
@@ -29,7 +37,7 @@ main.floors.yiqu7=
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 94],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
diff --git a/project/floors/zhujuejia.js b/project/floors/zhujuejia.js
index bbee16b..e2cb6bd 100644
--- a/project/floors/zhujuejia.js
+++ b/project/floors/zhujuejia.js
@@ -19,7 +19,7 @@ main.floors.zhujuejia=
"events": {},
"changeFloor": {
"0,9": {
- "floorId": "street01",
+ "floorId": "changguan2",
"loc": [
12,
9
@@ -44,13 +44,13 @@ main.floors.zhujuejia=
[120125,120126,120127,120157,120164,120161,120160,120159,120149,120150,120151,120159,120002],
[120133,120134,120135,120165,120172,200550,120168,120167,120157,120158,120159,120167,120010],
[120141,120142,120143,120173,120065,200558,120176,120175,120165,120166,120167,140132,140133],
- [120149,120150,120151,120017, 0,90244, 0, 0,120173,120174,120175,110011,140141],
- [120157,120158,120159,120017, 0,90244, 0, 0, 0, 0,120021,120002,120002],
- [120165,120166,120167,110030, 0, 0, 0,120015,120010,120010,120010,120010,120010],
- [120173,120174,120175, 0, 0, 0, 0, 0, 0, 0, 0, 0,90266],
+ [110286,120150,120151,120017, 0, 0, 0, 0,120173,120174,120175,110011,140141],
+ [110294,120158,120159,120017, 0, 0, 0, 0, 0, 0,120021,120002,120002],
+ [110302,120166,120167,110030, 0, 0, 0,120015,120010,120010,120010,120010,120010],
+ [110310,120174,120175, 0, 0, 0, 0, 0, 0, 0, 0, 0,90266],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,90266],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,90266],
- [ 92, 0, 0, 0, 0, 0,200199, 0, 0, 0, 0,140184,140],
+ [ 0, 0, 0, 0, 0, 0,210113,210114,210115, 0, 0, 0,90266],
+ [ 92, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,140184,140],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,140192,140],
[140,140,140186, 0, 0, 0, 0, 0, 0, 0, 0,140192,140],
[140,140,140,140,140,140,140,140,140,140,140,140,140]
@@ -76,10 +76,10 @@ main.floors.zhujuejia=
[ 0, 0, 0,120038, 0, 90,140099,140100, 0,90223, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0,140107,140108, 0,90231,120039, 0, 0],
[ 0, 0, 0,110022, 0, 0, 0,120007,120007,120007,120007, 0, 0],
- [140091,140092,140093, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
- [140099,140100,140101, 0, 0, 0,200175, 0, 0, 0, 0, 0, 0],
- [140107,140108,140109, 0, 0, 0,200183, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0,200191, 0, 0, 0, 0, 0, 0],
+ [140092,140092,140093, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [140100,140100,140101, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [140108,140108,140109, 0, 0, 0,210105,210106,210107, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0,140186,71832,71833,71759,71758,71786,71787,71784,71785, 0, 0],
@@ -89,13 +89,13 @@ main.floors.zhujuejia=
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0,120180, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0,120073, 0, 0, 0, 0, 0, 0, 0, 0],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,110004,140149],
- [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0,120073,90244, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0,90244, 0, 0, 0, 0, 0,110004,140149],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
+ [ 0, 0, 0, 0, 0, 0,210121,210122,210123, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0],
[ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0]
diff --git a/project/fonts/Verdana.ttf b/project/fonts/Verdana.ttf
index 8f25a64..ea3c090 100644
Binary files a/project/fonts/Verdana.ttf and b/project/fonts/Verdana.ttf differ
diff --git a/project/fonts/simhei.ttf b/project/fonts/simhei.ttf
deleted file mode 100644
index 5bd4687..0000000
Binary files a/project/fonts/simhei.ttf and /dev/null differ
diff --git a/project/functions.js b/project/functions.js
index fc50b74..f7bb7ef 100644
--- a/project/functions.js
+++ b/project/functions.js
@@ -145,7 +145,6 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
// ---------- 重绘新地图;这一步将会设置core.status.floorId ---------- //
core.drawMap(floorId);
-
// 切换楼层BGM
if (core.status.maps[floorId].bgm) {
var bgm = core.status.maps[floorId].bgm;
@@ -190,14 +189,23 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
} else {
// 每次抵达楼层执行的事件
core.insertAction(core.floors[floorId].eachArrive);
- core.ui.statusBar._update_map();
+ core.taskSystem.tasksInfo.forEach(v => v.tasks.forEach(a => {
+ if (a.type === "arrival" && a.floorId === floorId) {
+ a.has = 1;
+ } else if (a.type === "gosthFloor" && (!a.floorId || a.floorId.includes(core.status.floorId))) {
+ a.has++;
+ }
+
+ }));
// 首次抵达楼层时执行的事件(后插入,先执行)
if (!core.hasVisitedFloor(floorId)) {
core.insertAction(core.floors[floorId].firstArrive);
core.visitFloor(floorId);
core.plugin.bfs();
}
+
}
+
if (!core.isReplaying()) core.plugin.drawCommentSign()
},
"flyTo": function (toId, callback) {
@@ -315,6 +323,7 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
}
// 获得战斗伤害信息
var damageInfo = core.getDamageInfo(enemyId, null, x, y) || {};
+
if ((!core.getFlag("noAnimate") || damageInfo.damage >= core.status.hero.hp) && (!main.replayChecking && !core.isReplaying())) await core.attackAnimate(
enemyId,
damageInfo.start[0],
@@ -331,7 +340,7 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
// 当前战斗回合数,可用于战后所需的判定
var turn = damageInfo.turn;
// 判定是否致死
- if (damage == null || damage >= core.status.hero.hp) {
+ if (damage == null || damage >= core.status.hero.hp || damageInfo.致死) {
core.status.hero.hp = 0;
core.updateStatusBar(false, true);
core.events.lose('战斗失败');
@@ -343,27 +352,15 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
core.status.hero.statistics.battleDamage += damage;
core.status.hero.statistics.battle++;
- // 计算当前怪物的支援怪物
- var guards = [];
- if (x != null && y != null) {
- guards = core.getFlag("__guards__" + x + "_" + y, []);
- core.removeFlag("__guards__" + x + "_" + y);
- }
+
// 获得金币
- var money = guards.reduce(function (curr, g) {
- return curr + core.material.enemys[g[2]].money;
- }, core.getEnemyValue(enemy, "money", x, y));
- if (core.hasItem('coin')) money *= 2; // 幸运金币:双倍
- if (core.hasFlag('curse')) money = 0; // 诅咒效果
+ var money = core.getEnemyValue(enemy, "money", x, y)
core.status.hero.money += money;
core.status.hero.statistics.money += money;
// 获得经验
- var exp = guards.reduce(function (curr, g) {
- return curr + core.material.enemys[g[2]].exp;
- }, core.getEnemyValue(enemy, "exp", x, y));
- if (core.hasFlag('curse')) exp = 0;
+ var exp = core.getEnemyValue(enemy, "exp", x, y);
core.status.hero.exp += exp;
core.status.hero.statistics.exp += exp;
@@ -374,36 +371,6 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
hint += ',' + core.getStatusLabel('exp') + '+' + exp; // hint += ",经验+" + exp;
core.drawTip(hint, enemy.id);
- // 中毒
- if (core.enemys.hasSpecial(special, 12)) {
- core.triggerDebuff('get', 'poison');
- }
- // 衰弱
- if (core.enemys.hasSpecial(special, 13)) {
- core.triggerDebuff('get', 'weak');
- }
- // 诅咒
- if (core.enemys.hasSpecial(special, 14)) {
- core.triggerDebuff('get', 'curse');
- }
- // 仇恨怪物将仇恨值减半
- if (core.enemys.hasSpecial(special, 17)) {
- core.setFlag('hatred', Math.floor(core.getFlag('hatred', 0) / 2));
- }
- // 自爆
- if (core.enemys.hasSpecial(special, 19)) {
- core.status.hero.statistics.battleDamage += core.status.hero.hp - 1;
- core.status.hero.hp = 1;
- }
- // 退化
- if (core.enemys.hasSpecial(special, 21)) {
- core.status.hero.atk -= core.getEnemyValue(enemy, "atkValue", x, y) || 0;
- core.status.hero.def -= core.getEnemyValue(enemy, "defValue", x, y) || 0;
- if (core.status.hero.atk < 0) core.status.hero.atk = 0;
- if (core.status.hero.def < 0) core.status.hero.def = 0;
- }
- // 增加仇恨值
- core.setFlag('hatred', core.getFlag('hatred', 0) + core.values.hatred);
// 战后的技能处理,比如扣除魔力值
if (core.flags.statusBarItems.indexOf('enableSkill') >= 0) {
@@ -422,9 +389,7 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
var todo = [];
// 加点事件
- var point = guards.reduce(function (curr, g) {
- return curr + core.material.enemys[g[2]].point;
- }, core.getEnemyValue(enemy, "point", x, y)) || 0;
+ var point = core.getEnemyValue(enemy, "point", x, y) || 0;
if (core.flags.enableAddPoint && point > 0) {
core.push(todo, [{ "type": "insert", "name": "加点事件", "args": [point] }]);
}
@@ -453,15 +418,36 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
// 因为removeBlock和hideBlock都会刷新状态栏,因此将删除部分移动到这里并保证刷新只执行一次,以提升效率
if (core.getBlock(x, y) != null) {
// 检查是否是重生怪物;如果是则仅隐藏不删除
- if (core.hasSpecial(special, 23)) {
- core.hideBlock(x, y);
- } else {
- core.removeBlock(x, y);
- }
+
+ core.removeBlock(x, y);
+
} else {
core.updateStatusBar();
}
+ core.taskSystem.tasksInfo.forEach(v => v.tasks.forEach(a => {
+ switch (a.type) {
+ case "kill":
+ if (a.kill === enemyId && (!a.floorId || a.floorId.includes(core.status.floorId))) a.has++
+ else if (!a.kill && (!a.floorId || a.floorId.includes(core.status.floorId))) a.has++
+ break
+ case "killLocs":
+ if (core.status.floorId === a.floorId) {
+ a.killLocs.forEach(b => {
+ if (x === b[0] && y === b[1]) a.has++
+ })
+ }
+ break
+
+ case "killSpecial":
+ if (!a.floorId || a.floorId.includes(core.status.floorId)) {
+
+ if (core.hasSpecial(special, a.killSpecial)) a.has++
+ }
+ break
+ }
+
+ }))
// 如果已有事件正在处理中
if (core.status.event.id == null)
core.continueAutomaticRoute();
@@ -545,215 +531,34 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
// 第五项为该特殊属性的标记;目前 1 代表是地图类技能(需要进行遍历全图)
// 名字和描述可以直接写字符串,也可以写个function将怪物传进去
return [
- [1, "先攻", "怪物首先攻击", "#ffcc33"], //√
- //[2, "魔攻", "怪物无视角色的防御", "#bbb0ff"],
- [3, "坚固", "怪物防御不小于角色攻击-1", "#c0b088"], //√
- [
- 6,
- function (enemy) {
- return (enemy.n || "") + "连击";
- },
- function (enemy) {
- return "怪物每回合攻击" + (enemy.n || 4) + "次";
- },
- "#ffee77",
- ], //想改成“以XX%、XX%攻击力各攻击一次”
- [
- 7,
- "破甲",
- function (enemy) {
- return (
- "怪物无视角色防御的" +
- Math.floor(
- 100 * (enemy.breakArmor || core.values.breakArmor || 0)
- ) +
- "%"
- );
- },
- "#88c0ff",
- ], //√
- [
- 8,
- "反击",
- function (enemy) {
- return (
- "战斗时,怪物每回合附加角色攻击的" +
- Math.floor(
- 100 * (enemy.counterAttack || core.values.counterAttack || 0)
- ) +
- "%作为伤害,无视角色防御"
- );
- },
- "#ffaa44",
- ],
- [
- 9,
- "净化",
- function (enemy) {
- return (
- "战斗前,怪物附加角色护盾的" +
- (enemy.purify || core.values.purify) +
- "倍作为伤害"
- );
- },
- "#80eed6",
- ],
- [10, "模仿", "怪物的攻防和角色攻防相等", "#b0c0dd"],
- [
- 11,
- "吸血",
- function (enemy) {
- return (
- "战斗前,怪物首先吸取角色的" +
- Math.floor(100 * enemy.vampire || 0) +
- "%生命(约" +
- Math.floor((enemy.vampire || 0) * core.getStatus("hp")) +
- "点)作为伤害" +
- (enemy.add ? ",并把伤害数值加到自身生命上" : "")
- );
+ [1, "先攻", "怪物起始行动条为50%", "#ffcc33"], //√
+ [2, "暴击", function (enemy) { return `怪物的首次攻击必定暴击,暴击额外造成${enemy.baoshang}%的伤害;除此以外,怪物每${enemy.baoji}次攻击就将打出一次暴击。` }, "#ffcc33"],
+ [3, "坚固", "每次至多受到1点物理伤害", "#c0b088"], //√
+ [4, "反击", "怪物的首次攻击附加怪物当前已损失生命值的100%作为伤害", "#c0b088"],
+ [5, "破甲", function (enemy) { return `怪物攻击时无视角色${enemy.breakArmor}%的防御力;首次攻击时,怪物额外无视角色${enemy.onceBreakArmor}%的防御力(加算)` }, "#88c0ff", ], //√
+ [6, "吸血", function (enemy) {
+ return `怪物造成的物理伤害以${enemy.vampire}%回复怪物自身的生命值,不计对护盾造成的破坏`;
},
"#dd4448",
],
- [
- 12,
- "中毒",
- "战斗后,角色陷入中毒状态,每一步损失生命" +
- core.values.poisonDamage +
- "点",
- "#99ee88",
- ],
- [
- 13,
- "衰弱",
- "战斗后,角色陷入衰弱状态,攻防暂时下降" +
- (core.values.weakValue >= 1 ?
- core.values.weakValue + "点" :
- parseInt(core.values.weakValue * 100) + "%"),
- "#f0bbcc",
- ],
- [
- 14,
- "诅咒",
- "战斗后,角色陷入诅咒状态,战斗无法获得金币和经验",
- "#bbeef0",
- ],
- [
- 15,
- "领域",
- function (enemy) {
- return (
- "经过怪物周围" +
- (enemy.zoneSquare ? "九宫格" : "十字") +
- "范围内" +
- (enemy.range || 1) +
- "格时自动减生命" +
- (enemy.zone || 0) +
- "点"
- );
- },
- "#c677dd",
- ],
- [16, "夹击", "经过两只相同的怪物中间,角色生命值变成一半", "#bb99ee"],
- [
- 17,
- "仇恨",
- "战斗前,怪物附加之前积累的仇恨值作为伤害;战斗后,释放一半的仇恨值。(每杀死一个怪物获得" +
- (core.values.hatred || 0) +
- "点仇恨值)",
- "#b0b666",
- ],
- [
- 18,
- "阻击",
- function (enemy) {
- return (
- "经过怪物周围" +
- (enemy.zoneSquare ? "九宫格" : "十字") +
- "时自动减生命" +
- (enemy.repulse || 0) +
- "点,同时怪物后退一格"
- );
- },
- "#8888e6",
- ],
- [19, "自爆", "战斗后角色的生命值变成1", "#ff6666"],
+ [7, "诅咒", function (enemy) { return `当怪物的攻击同时造成了物理伤害和魔法伤害(护盾优先抵挡物理伤害),则魔法伤害提升${enemy.curseValue}%` }, "#bbeef0", ],
+ [8, "闪避", function (enemy) { return `怪物受到的首次普通攻击将被闪避而无效化;除此以外,怪物每受到${enemy.duck}次普通攻击造成的伤害就将闪避一次。` }, "#99ee88", ],
+ [9, "寒霜", function (enemy) { return `怪物的${enemy.cold===0?"每次":"前"+enemy.cold+"次"}普通攻击命中角色时,将使角色在该场战斗中的速度下降${enemy.coldValue}点(速度最低为1)` }, "#99ee88", ],
+ [10, "灼炎", function (enemy) { return `怪物的普通攻击命中角色时,将在该场战斗中熔毁角色的防御${enemy.fire}点` }, "#99ee88", ],
+ [11, "风行", function (enemy) { return `怪物的基础速度将不低于角色的基础速度;怪物每次攻击命中或闪避攻击时,其速度提高${enemy.wind}点` }, "#99ee88", ],
+ [12, "撕裂", function (enemy) { return `怪物的普通攻击附加角色当前已损失生命值的${enemy.tear}%作为伤害,不计对护盾造成的破坏` }, "#99ee88", ],
+ [13, "献祭", function (enemy) { return `怪物身周萦绕着火焰,火焰每次对角色造成${enemy.immolate}点魔法伤害,伤害速度等于怪物的初始生命` }, "#99ee88", ],
+ [14, "闪电", function (enemy) { return `怪物对角色护盾的破坏效率提升${enemy.light}%。(击破护盾的那次攻击,剩余的伤害也计算闪电加成)` }, "#99ee88", ],
+
+ [15, "警戒", function (enemy) { return ("经过怪物周围" + (enemy.zoneSquare ? "九宫格" : "十字") + "范围内" + (enemy.range || 1) + "格时受到一次仅有20%护盾生效的攻击,扣除护盾后伤害为" + (Math.max(Math.max(enemy.atk - core.getRealStatusOrDefault(void 0, "def"), 0) + Math.floor(enemy.spell * (100 - core.getRealStatusOrDefault(void 0, "mdef")) / 100) - Math.floor(core.getRealStatusOrDefault(void 0, "spell") * core.getRealStatusOrDefault(void 0, "mhp") / 100 * 0.2), 0) || 0) + "点"); }, "#c677dd", ],
+ [16, "毒素", function (enemy) { return `怪物的普通攻击造成物理伤害时(不计对护盾造成的破坏)将附加一层毒素效果,每层毒素效果将使角色在该场战斗中攻击时流失${enemy.poison}点生命值` }, "#99ee88", ],
+
+ [17, "汲取", function (enemy) { return `怪物对角色护盾造成破坏时,将窃取破坏数值的${enemy.absorb}%作为自身护盾` }, "#bbeef0", ],
+ [18, "重力", function (enemy) { return `怪物操纵角色的重力,每携带一件双手装备速度下降${4*enemy.gravity}%,每携带一件单手装备速度下降${2*enemy.gravity}%,每携带一件其他装备速度下降${enemy.gravity}%` }, "#bbeef0", ],
[20, "无敌", "角色无法打败怪物,除非拥有十字架", "#aaaaaa"],
- [
- 21,
- "退化",
- function (enemy) {
- return (
- "战斗后角色永久下降" +
- (enemy.atkValue || 0) +
- "点攻击和" +
- (enemy.defValue || 0) +
- "点防御"
- );
- },
- ],
- [
- 22,
- "固伤",
- function (enemy) {
- return (
- "战斗前,怪物对角色造成" +
- (enemy.damage || 0) +
- "点固定伤害,未开启负伤时无视角色护盾。"
- );
- },
- "#ff9977",
- ],
- [23, "重生", "怪物被击败后,角色转换楼层则怪物将再次出现", "#a0e0ff"],
- [
- 24,
- "激光",
- function (enemy) {
- return "经过怪物同行或同列时自动减生命" + (enemy.laser || 0) + "点";
- },
- "#dda0dd",
- ],
- [
- 25,
- "光环",
- function (enemy) {
- return (
- (enemy.range != null ?
- (enemy.haloSquare ? "该怪物九宫格" : "该怪物十字") +
- enemy.haloRange +
- "格范围内" :
- "同楼层所有") +
- "怪物生命提升" +
- (enemy.hpBuff || 0) +
- "%,攻击提升" +
- (enemy.atkBuff || 0) +
- "%,防御提升" +
- (enemy.defBuff || 0) +
- "%," +
- (enemy.haloAdd ? "可叠加" : "不可叠加")
- );
- },
- "#e6e099",
- 1,
- ],
- [
- 26,
- "支援",
- "当周围一圈的怪物受到攻击时将上前支援,并组成小队战斗。",
- "#77c0b6",
- 1,
- ],
- [
- 27,
- "捕捉",
- function (enemy) {
- return (
- "当走到怪物周围" +
- (enemy.zoneSquare ? "九宫格" : "十字") +
- "时会强制进行战斗。"
- );
- },
- "#c0ddbb",
- ],
+
+ [25, "光环", function (enemy) { return ((enemy.range != null ? (enemy.haloSquare ? "该怪物九宫格" : "该怪物十字") + enemy.haloRange + "格范围内" : "同楼层所有") + "怪物生命提升" + (enemy.hpBuff || 0) + "%,攻击提升" + (enemy.atkBuff || 0) + "%,防御提升" + (enemy.defBuff || 0) + "%," + (enemy.haloAdd ? "可叠加" : "不可叠加")); }, "#e6e099", 1, ],
+ [27, "捕捉", function (enemy) { return ("当走到怪物周围" + (enemy.zoneSquare ? "九宫格" : "十字") + "时会强制进行战斗。"); }, "#c0ddbb", ],
];
},
"getEnemyInfo": function (enemy, hero, x, y, floorId) {
@@ -786,18 +591,8 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
mon_point = core.getEnemyValue(enemy, "point", x, y, floorId);
var mon_barrier = 0,
mon_absorb_damage = 0;
- // 模仿
- if (core.hasSpecial(mon_special, 10)) {
- mon_atk = hero_atk;
- mon_def = hero_def;
- }
- // 坚固
- if (core.hasSpecial(mon_special, 3) && mon_def < hero_atk - 1) {
- mon_def = hero_atk - 1;
- }
-
- var guards = [];
- // 光环和支援检查
+ if (core.hasSpecial(mon_special, 11)) mon_speed = Math.max(mon_speed, hero_speed + 1)
+ // 光环检查
if (!core.status.checkBlock) core.status.checkBlock = {};
if (core.status.checkBlock.needCache) {
@@ -843,21 +638,6 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
usedEnemyIds[enemy.id] = true;
}
}
- // 检查【支援】技能,数字26
- if (
- enemy &&
- core.hasSpecial(enemy.special, 26) &&
- // 检查支援条件,坐标存在,距离为1,且不能是自己
- // 其他类型的支援怪,比如十字之类的话.... 看着做是一样的
- x != null &&
- y != null &&
- Math.abs(block.x - x) <= 1 &&
- Math.abs(block.y - y) <= 1 &&
- !(x == block.x && y == block.y)
- ) {
- // 记录怪物的x,y,ID
- guards.push([block.x, block.y, id]);
- }
// TODO:如果有其他类型光环怪物在这里仿照添加检查
// 注:新增新的类光环属性(需要遍历全图的)需要在特殊属性定义那里的第五项写1,参见光环和支援的特殊属性定义。
@@ -868,14 +648,14 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
hp_buff: hp_buff,
atk_buff: atk_buff,
def_buff: def_buff,
- guards: guards,
+
};
} else {
// 直接使用缓存数据
hp_buff = cache.hp_buff;
atk_buff = cache.atk_buff;
def_buff = cache.def_buff;
- guards = cache.guards;
+
}
// 增加比例;如果要增加数值可以直接在这里修改
@@ -905,8 +685,7 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
money: Math.floor(mon_money),
exp: Math.floor(mon_exp),
point: Math.floor(mon_point),
- special: mon_special,
- guards: guards // 返回支援情况
+ special: mon_special
};
},
@@ -945,7 +724,7 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
hero_spell = hero?.spell ?? core.status.hero.spell;
}
// 怪物的各项数据
- // 对坚固模仿等处理扔到了脚本编辑-getEnemyInfo之中
+
var enemyInfo = core.enemys.getEnemyInfo(enemy, hero, x, y, floorId);
var mon_hp = enemyInfo.hp,
mon_atk = enemyInfo.atk,
@@ -953,29 +732,31 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
mon_mdef = enemyInfo.mdef,
mon_spell = enemyInfo.spell,
mon_speed = enemyInfo.speed,
- mon_special = enemyInfo.special,
- mon_absorb_damage = enemyInfo.absorb,
- mon_barrier = enemyInfo.barrier;
+ mon_special = enemyInfo.special
const { lcm, gcd } = core.plugin.utils
const equip0 = core.getEquip(0)
//---第一部分:静态属性修正---
//此处写入静态影响勇士属性的勇士或怪物技能(静态影响怪物属性的技能于getEnemyInfo中写入)
// 技能的处理
- if (core.getFlag("skill", 0) == 1) {
- // 开启了技能1:二倍斩
- hero_atk *= 2; // 计算时攻击力翻倍
+
+ var enemyvalue = core.material.enemys[enemy.id]
+
+ if (core.hasSpecial(mon_special, 18)) {
+ let a = 0
+ for (let i = 0; i <= 4; i++) {
+ const equip = core.getEquip(i)
+ if (!equip) continue
+ const cls = core.material.items[equip].equipCls
+ if (cls === "双手剑") a += enemyvalue.gravity * 4
+ else if (['法杖', '单手剑', '匕首', '盾牌'].includes(cls)) a += enemyvalue.gravity * 2
+ else a += enemyvalue.gravity
+ }
+ hero_speed = hero_speed * (100 - a) / 100
}
-
- // 破甲
- if (core.hasSpecial(mon_special, 7))
- hero_def -= Math.floor(
- (enemy.breakArmor || core.values.breakArmor) * hero_def
- );
-
//勇士属性取整
hero_atk = Math.max(0, Math.floor(hero_atk));
hero_def = Math.max(0, Math.floor(hero_def));
- hero_speed = Math.max(0, Math.floor(hero_speed));
+ hero_speed = Math.max(1, Math.floor(hero_speed));
hero_spell = Math.max(0, Math.floor(hero_spell));
hero_matk = Math.min(100, Math.max(0, Math.floor(hero_matk)));
hero_mdef = Math.min(100, Math.max(0, Math.floor(hero_mdef)));
@@ -985,26 +766,6 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
if (core.hasSpecial(mon_special, 20) && !core.hasItem("cross"))
return null; // 不可战斗
- // 战前造成的额外伤害(可被护盾抵消)
- let init_damage = 0;
-
- // 吸血
- if (core.hasSpecial(mon_special, 11)) {
- let vampire_damage = hero_hp * enemy.vampire;
-
- // 如果有神圣盾免疫吸血等可以在这里写
- // 也可以用hasItem和hasEquip来判定装备
- // if (core.hasFlag('shield5')) vampire_damage = 0;
-
- vampire_damage = Math.floor(vampire_damage) || 0;
- // 加到自身
- if (enemy.add)
- // 如果加到自身
- mon_hp += vampire_damage;
-
- init_damage += vampire_damage;
- }
-
//——第二部分:变量定义和初始赋值——
let hero_per_damage = Math.max(hero_atk - mon_def, 0),
@@ -1015,25 +776,17 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
hero_turn = 0,
mon_turn = 0;
let equipInfo = [] //回合生效的装备列表
-
+ if (core.hasSpecial(mon_special, 13)) equipInfo.push({
+ id: "A374", //需注册图标
+ speed: mon_hp
+ })
for (let i = 0; i < 5; i++) {
const a = core.plugin.equip[core.getEquip(i)]
if (a) equipInfo.push(a)
}
- //处理回合条长度
- let oneTurn = [hero_speed, mon_speed];
- if (equipInfo.length > 0) {
- for (let i = 0; i < equipInfo.length; i++) {
- equipInfo[i].now = 0;
- equipInfo[i].isAttack = false;
- oneTurn.push(equipInfo[i].speed);
- }
- }
- //需要变更
- const onegcd = gcd(...oneTurn) //最大公约数
- oneTurn = lcm(...oneTurn) //单次回合长度
+ let oneTurn = 100
//在这里处理equip的初始位置now
equipInfo.forEach(v => {
switch (v.id) {
@@ -1042,25 +795,30 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
v.now = 0
break
}
- v.onAttack = false
- if (v.now === oneTurn) v.onAttack = true //增加正在攻击的标志
- })
- const heroinfo = { hp: hero_hp, atk: hero_atk, def: hero_def, mdef: (!hero?.mdef || hero?.mdef === 100) ? hero_mdef : hero.mdef, spell: hero_spell, mhp: Math.floor(hero_spell * hero_mhp / 100), matk: Math.floor(hero_spell * hero_matk / 100), speed: hero_speed, now: 0, isAttack: false } //勇士属性
- const enemyinfo = { hp: mon_hp, atk: mon_atk, def: mon_def, mdef: mon_mdef, spell: mon_spell, speed: mon_speed, special: mon_special, now: 0, onAttack: false, isAttack: false } //怪物属性
- //先攻,先攻为怪物和勇士勇士行动前怪物出第一刀
- if (core.hasSpecial(mon_special, 1)) {
- enemyinfo.now = oneTurn
- enemyinfo.onAttack = true
- }
- const start = [core.clone(heroinfo), core.clone(enemyinfo), core.clone(equipInfo), oneTurn] //记录开始战斗时的属性并转发
- //---第三部分:递归开始---
+ })
+ const heroinfo = { hp: hero_hp, atk: hero_atk, def: hero_def, mdef: (!hero?.mdef || hero?.mdef === 100) ? hero_mdef : hero.mdef, spell: hero_spell, mhp: Math.floor(hero_spell * hero_mhp / 100), matk: Math.floor(hero_spell * hero_matk / 100), speed: hero_speed, now: 0, isAttack: false, 致死: false } //勇士属性
+ const enemyinfo = { hp: mon_hp, atk: mon_atk, def: mon_def, mhp: 0, mdef: mon_mdef, spell: mon_spell, speed: mon_speed, special: mon_special, now: 0, isAttack: false } //怪物属性
+ //先攻,先攻为怪物50%行动条
+ if (core.hasSpecial(mon_special, 1)) {
+ enemyinfo.now = 50
+ heroinfo.now = 0
+ } else {
+ enemyinfo.now = 0
+ heroinfo.now = 50
+ }
+ let Exspeed = hero_speed
+ const start = [core.clone(heroinfo), core.clone(enemyinfo), core.clone(equipInfo), Exspeed] //记录开始战斗时的属性并转发
+ //---第三部分:循环开始---
+ let poison = 0
const heroDiffList = [],
enemyDiffList = [],
heroanimateList = [],
enemyanimateList = [];
let beforehp = enemyinfo.hp
+
+ let 致死 = false
while (
enemyinfo.hp > 0
) {
@@ -1069,72 +827,11 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
enemy_diff = {},
hero_animate = [],
enemy_animate = [];
- if (enemyinfo.onAttack) { //怪物先攻的场合
- //这里计算怪物攻击时发生的各种变化,同时计入enemy_diff
- let mon_damage = 0
- let hero_damage = 0
- //伤害计算
- let per_damage = Math.max(enemyinfo.atk - heroinfo.def, 0),
- per_mdamage = Math.floor(enemyinfo.spell * (100 - heroinfo.mdef) / 100);
- //这里记录伤害触发后的属性变化和动画,同时计入diff、damage(不要在此直接修改heroinfo和enemyinfo)
- if (core.hasSpecial(mon_special, 6)) {
- hero_damage += per_damage * enemy.n + per_mdamage * enemy.n
- } else {
- hero_damage += per_damage + per_mdamage
- }
- let animate = core.plugin.enemyanimate[enemy.id] ?? "jianji2"
- //这里可通过if更改默认的怪物攻击特效
- hero_animate.push(animate) //勇士身上绘制jianji2动画
- if (heroinfo.mhp + (hero_diff.mhp ?? 0) - hero_damage >= 0) {
- hero_diff.mhp = (hero_diff.mhp ?? 0) - hero_damage
- hero_damage = 0
- hero_diff.hp = (hero_diff.hp ?? 0) - hero_damage
- } else {
- hero_damage -= heroinfo.mhp + (hero_diff.mhp ?? 0)
- hero_diff.mhp = (hero_diff.mhp ?? 0) - heroinfo.mhp - (hero_diff.mhp ?? 0)
-
- hero_diff.hp = (hero_diff.hp ?? 0) - hero_damage
- }
-
- damage += hero_damage
- enemyinfo.onAttack = false
- enemyinfo.now = 0
- onattack = true
-
- }
+ heroinfo.now += heroinfo.speed / Exspeed
+ enemyinfo.now += enemyinfo.speed / Exspeed
equipInfo.forEach(v => {
- if (v.onAttack) {
- let mon_damage = 0
- let hero_damage = 0
- //这里写生效装备的技能效果,同时对双方属性的修改计入diff(不要在此直接修改heroinfo和enemyinfo)
- let animate = core.plugin.equipanimate[v.id] ?? "jianji2"
- //这里可通过if更改默认的道具特效
- enemy_animate.push(animate) //勇士身上绘制动画
-
- v.now = 0
- v.onAttack = false
- onattack = true
- }
- })
- if (onattack) { //先手处理完毕后的数据处理
- heroDiffList.push(hero_diff)
- enemyDiffList.push(enemy_diff)
- heroanimateList.push(hero_animate)
- enemyanimateList.push(enemy_animate)
- //处理属性变化
- for (let v in hero_diff) {
- heroinfo[v] += hero_diff[v]
- }
- for (let v in enemy_diff) {
- enemyinfo[v] += enemy_diff[v]
- }
- continue //进入下一循环
- }
- heroinfo.now += heroinfo.speed
- enemyinfo.now += enemyinfo.speed
- equipInfo.forEach(v => {
- v.now += v.speed
+ v.now += v.speed / Exspeed
})
if (
@@ -1148,14 +845,32 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
//伤害计算
let per_damage = Math.max(heroinfo.atk - enemyinfo.def, 0)
let per_mdamage = Math.max(Math.floor(heroinfo.matk * (100 - enemyinfo.mdef) / 100), 0)
+ //坚固
+ if (core.hasSpecial(mon_special, 3)) per_damage = Math.min(per_damage, 1)
+
mon_damage = per_damage + per_mdamage
+
+ if (enemyinfo.mhp > 0) {
+ if (mon_damage > enemyinfo.mhp + (enemy_diff.mhp ?? 0)) {
+
+ mon_damage -= enemyinfo.mhp + (enemy_diff.mhp ?? 0)
+ enemy_diff.mhp = -enemyinfo.mhp
+ } else {
+ enemy_diff.mhp = (enemy_diff.mhp ?? 0) - mon_damage
+ mon_damage = 0
+ }
+ }
//这里记录伤害触发后的属性变化和动画,同时计入diff(不要在此直接修改heroinfo和enemyinfo)
let animate = core.plugin.heroanimate[equip0] ?? "jianji2"
//这里可通过if更改默认的武器攻击特效
enemy_animate.push(animate)
-
- enemy_diff.hp = (enemy_diff.hp ?? 0) - mon_damage
+ damage += poison
+ if (poison > 0) hero_diff.hp = (hero_diff.hp ?? 0) - poison
+ //闪避
+ enemy_diff.hp = (enemy_diff.hp ?? 0) - (core.hasSpecial(mon_special, 8) && hero_turn % enemyvalue.duck === 0 ? 0 : mon_damage)
+ //风行
+ if (core.hasSpecial(mon_special, 11) && core.hasSpecial(mon_special, 8) && hero_turn % enemyvalue.duck === 0) enemy_diff.speed = (enemy_diff.def ?? 0) + enemyvalue.wind
heroinfo.now -= oneTurn
hero_turn++
onattack = true
@@ -1169,25 +884,69 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
//伤害计算
let per_damage = Math.max(enemyinfo.atk - heroinfo.def, 0),
per_mdamage = Math.floor(enemyinfo.spell * (100 - heroinfo.mdef) / 100);
-
+ //破甲
+ if (core.hasSpecial(mon_special, 5)) per_damage = Math.max(enemyinfo.atk - (mon_turn === 0 ? Math.floor(heroinfo.def * (enemyvalue.breakArmor + enemyvalue.onceBreakArmor) / 100) : Math.floor(heroinfo.def * enemyvalue.breakArmor / 100)), 0)
//这里记录伤害触发后的属性变化和动画,同时计入diff、damage(不要在此直接修改heroinfo和enemyinfo)
- if (core.hasSpecial(mon_special, 6)) {
- hero_damage += per_damage * enemy.n + per_mdamage * enemy.n
- } else {
- hero_damage += per_damage + per_mdamage
+ //反击
+ if (core.hasSpecial(mon_special, 4) && mon_turn === 0) per_damage += Math.max(mon_hp - enemyinfo.hp, 0)
+ //暴击
+ if (core.hasSpecial(mon_special, 2) && mon_turn % enemyvalue.baoji === 0) {
+ per_damage = Math.floor(per_damage * enemyvalue.baoshang / 100)
+ per_mdamage = Math.floor(per_mdamage * enemyvalue.baoshang / 100)
}
+
+
let animate = core.plugin.enemyanimate[enemy.id] ?? "jianji2"
//这里可通过if更改默认的怪物攻击特效
hero_animate.push(animate) //勇士身上绘制sword动画
- if (heroinfo.mhp + (hero_diff.mhp ?? 0) - hero_damage >= 0) {
- hero_diff.mhp = (hero_diff.mhp ?? 0) - hero_damage
+ //闪电
+ if (core.hasSpecial(mon_special, 14) && heroinfo.mhp + (hero_diff.mhp ?? 0) > 0) {
+ per_damage = Math.floor(per_damage * enemyvalue.light / 100)
+ per_mdamage = Math.floor(per_mdamage * enemyvalue.light / 100)
+ }
+ if (heroinfo.mhp + (hero_diff.mhp ?? 0) - per_damage - per_mdamage >= 0) { //完美护盾
+ //汲取
+ if (core.hasSpecial(mon_special, 17)) enemy_diff.mhp = (enemy_diff.mhp ?? 0) + Math.floor((per_damage + per_mdamage) * enemyvalue.absorb / 100)
+ hero_diff.mhp = (hero_diff.mhp ?? 0) - per_damage - per_mdamage
hero_damage = 0
- hero_diff.hp = (hero_diff.hp ?? 0) - hero_damage
- } else {
- hero_damage -= heroinfo.mhp + (hero_diff.mhp ?? 0)
- hero_diff.mhp = (hero_diff.mhp ?? 0) - heroinfo.mhp - (hero_diff.mhp ?? 0)
+ } else if (heroinfo.mhp + (hero_diff.mhp ?? 0) - per_damage >= 0) { //护盾击破但只受到魔法伤害
+ //汲取
+ if (core.hasSpecial(mon_special, 17)) enemy_diff.mhp = (enemy_diff.mhp ?? 0) + Math.floor((heroinfo.mhp + (hero_diff.mhp ?? 0)) * enemyvalue.absorb / 100)
+ //诅咒
+ hero_damage = per_damage + (core.hasSpecial(mon_special, 7) && heroinfo.mhp > 0 ? 2 * per_mdamage : per_mdamage) - heroinfo.mhp
+ hero_diff.mhp = -heroinfo.mhp
+ //撕裂
+ if (core.hasSpecial(mon_special, 12)) hero_damage = MNath.floor(Math.max(mon_hp - enemyinfo.hp, 0) * enemyvalue.tear / 100)
hero_diff.hp = (hero_diff.hp ?? 0) - hero_damage
+ //灼炎
+ if (core.hasSpecial(mon_special, 10)) hero_diff.def = (hero_diff.def ?? 0) - enemyvalue.fire
+ //风行
+ if (core.hasSpecial(mon_special, 11)) enemy_diff.speed = (enemy_diff.def ?? 0) + enemyvalue.wind
+
+ } else { //护盾击破
+ if (core.hasSpecial(mon_special, 16)) poison++
+ //汲取
+ if (core.hasSpecial(mon_special, 17)) enemy_diff.mhp = (enemy_diff.mhp ?? 0) + Math.floor((heroinfo.mhp + (hero_diff.mhp ?? 0)) * enemyvalue.absorb / 100)
+ const over = per_damage - (hero_diff.mhp ?? 0)
+ //吸血
+ if (core.hasSpecial(mon_special, 6)) hero_diff.hp = (hero_diff.hp ?? 0) + Math.floor(over * enemyvalue.vampire / 100)
+ //诅咒
+ hero_damage = per_damage + (core.hasSpecial(mon_special, 7) && heroinfo.mhp > 0 ? 2 * per_mdamage : per_mdamage) - heroinfo.mhp
+
+ hero_diff.mhp = -heroinfo.mhp
+ //撕裂
+ if (core.hasSpecial(mon_special, 12)) hero_damage = MNath.floor(Math.max(mon_hp - enemyinfo.hp, 0) * enemyvalue.tear / 100)
+ hero_diff.hp = (hero_diff.hp ?? 0) - hero_damage
+ //灼炎
+ if (core.hasSpecial(mon_special, 10)) hero_diff.def = (hero_diff.def ?? 0) - enemyvalue.fire
+ //风行
+ if (core.hasSpecial(mon_special, 11)) enemy_diff.speed = (enemy_diff.def ?? 0) + enemyvalue.wind
+ }
+ //寒霜
+ if (core.hasSpecial(mon_special, 9) && enemyvalue.cold === 0 || enemyvalue.cold > mon_turn) {
+ hero_diff.speed = Math.max(1 - heroinfo.speed, (hero_diff.speed ?? 0) - enemyvalue.coldValue)
+
}
damage += hero_damage
@@ -1199,17 +958,28 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
if (v.now >= oneTurn) {
let mon_damage = 0
let hero_damage = 0
+
+ if (v.id === '献祭') {
+ if (heroinfo.mhp + (hero_diff.mhp ?? 0) - enemyvalue.immolate >= 0) {
+ hero_diff.mhp = (hero_diff.mhp ?? 0) - enemyvalue.immolate
+ } else {
+ hero_damage += enemyvalue.immolate - (hero_diff.mhp ?? 0)
+ hero_diff.mhp = -heroinfo.mhp
+ hero_diff.hp = (hero_diff.hp ?? 0) - hero_damage
+ }
+ }
//这里写生效装备的技能效果,同时对双方属性的修改计入diff(不要在此直接修改heroinfo和enemyinfo)
let animate = core.plugin.equipanimate[v.id] ?? "jianji2"
//这里可通过if更改默认的道具特效
enemy_animate.push(animate) //怪物身上绘制动画
-
+ damage += hero_damage
v.now -= oneTurn
onattack = true
}
})
if (onattack) {
+ if (damage > hero_hp) 致死 = true
//处理完毕后的数据处理
heroDiffList.push(hero_diff)
enemyDiffList.push(enemy_diff)
@@ -1234,78 +1004,9 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
}
- //下面这些还没修改,原有技能除先攻、连击外暂时全部移除,所有技能需要在上方的模拟循环中做修正
- /*
- // 每回合的反击伤害;反击是按照勇士的攻击次数来计算回合
- let counterDamage = 0;
- if (core.hasSpecial(mon_special, 8))
- counterDamage += Math.floor(
- (enemy.counterAttack || core.values.counterAttack) * hero_atk
- );
-
-
- // 净化
- if (core.hasSpecial(mon_special, 9))
- init_damage += Math.floor(
- (enemy.purify || core.values.purify) * hero_mdef
- );
- //上面这些还没修改
- //勇士护盾计算
- let barrier = Math.floor(hero_spell * hero_mhp / 100);
-
-
- // ------ 支援 ----- //
- // 这个递归最好想明白为什么,flag:__extraTurn__是怎么用的
- /*var guards = core.getFlag("__guards__" + x + "_" + y, enemyInfo.guards);
- var guard_before_current_enemy = false; // ------ 支援怪是先打(true)还是后打(false)?
- turn += core.getFlag("__extraTurn__", 0);
- if (guards.length > 0) {
- if (!guard_before_current_enemy) { // --- 先打当前怪物,记录当前回合数
- core.setFlag("__extraTurn__", turn);
- }
- // 获得那些怪物组成小队战斗
- for (var i = 0; i < guards.length; i++) {
- var gx = guards[i][0],
- gy = guards[i][1],
- gid = guards[i][2];
- // 递归计算支援怪伤害信息,这里不传x,y保证不会重复调用
- // 这里的mdef传0,因为护盾应该只会被计算一次
- var info = core.enemys.getDamageInfo(core.material.enemys[gid], { hp: origin_hero_hp, atk: origin_hero_atk, def: origin_hero_def, mdef: 0 });
- if (info == null) { // 小队中任何一个怪物不可战斗,直接返回null
- core.removeFlag("__extraTurn__");
- return null;
- }
- // 已经进行的回合数
- core.setFlag("__extraTurn__", info.turn);
- init_damage += info.damage;
- }
- if (guard_before_current_enemy) { // --- 先打支援怪物,增加当前回合数
- turn += core.getFlag("__extraTurn__", 0);
- }
- }
- core.removeFlag("__extraTurn__");*/
- // ------ 支援END ------ //
- /*
- // 最终伤害:初始伤害 + 怪物对勇士造成的伤害 + 反击伤害
- damage += init_damage + hero_turn * counterDamage;
- // 再扣去护盾
- damage -= barrier;
-
- // 检查是否允许负伤
- if (!core.flags.enableNegativeDamage) damage = Math.max(0, damage);
-
- // 最后处理仇恨和固伤(因为这两个不能被护盾减伤)
- if (core.hasSpecial(mon_special, 17)) {
- // 仇恨
- damage += core.getFlag("hatred", 0);
- }
- if (core.hasSpecial(mon_special, 22)) {
- // 固伤
- damage += enemy.damage2 || 0;
- }
- */
return {
+ 致死,
start: start,
mon_hp: Math.floor(mon_hp),
mon_atk: Math.floor(mon_atk),
@@ -1357,7 +1058,6 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
core.openBook(true);
break;
case 71: // G:使用楼传器
- flags.canMoveFloor = core.canMoveFloor();
core.useItem('fly', true)
core.status.route.push("key:71");
break;
@@ -1606,7 +1306,10 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
time: new Date().getTime(),
cg: cg,
animateObjs: core.status.animateObjs.filter(v => v.loop),
- playing: [...core.plugin.playing].filter(v => v.loop)
+ playing: [...core.plugin.playing].filter(v => v.loop),
+ task: core.taskSystem.save(),
+ 可接取任务: [...core.plugin.可接取任务],
+ 已提交任务: [...core.plugin.已提交任务]
};
return data;
},
@@ -1651,6 +1354,7 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
core.setFlag("__fromLoad__", true);
// TODO:增加自己的一些读档处理
+ core.taskSystem.load(data.task)
core.ui.statusBar.clearItemInfo();
core.ui.statusBar.update();
core.status.animateObjs = data.animateObjs
@@ -1663,6 +1367,8 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
}
core.drawbackground(core.ui.cgText.image, core.ui.cgText.memory)
}
+ core.plugin.可接取任务 = [...data.可接取任务]
+ core.plugin.已提交任务 = [...data.已提交任务]
// 切换到对应的楼层
core.changeFloor(data.floorId, null, data.hero.loc, 0, function () {
// TODO:可以在这里设置读档后播放BGM
@@ -1760,266 +1466,127 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
}
},
"updateStatusBar": function () {
- if (!core.control.noAutoEvents) core.checkAutoEvents()
+
// 更新状态栏
core.ui.statusBar.update();
// 更新阻激夹域的伤害值
core.updateCheckBlock();
// 更新全地图显伤
core.updateDamage();
+
},
"updateCheckBlock": function (floorId) {
- // 领域、夹击、阻击等的伤害值计算
- floorId = floorId || core.status.floorId;
- if (!floorId || !core.status.maps) return;
+ // 领域、夹击、阻击等的伤害值计算
+ floorId = floorId || core.status.floorId;
+ if (!floorId || !core.status.maps) return;
- var width = core.floors[floorId].width,
- height = core.floors[floorId].height;
- var blocks = core.getMapBlocksObj(floorId);
+ var width = core.floors[floorId].width,
+ height = core.floors[floorId].height;
+ var blocks = core.getMapBlocksObj(floorId);
- var damage = {}, // 每个点的伤害值
- type = {}, // 每个点的伤害类型
- repulse = {}, // 每个点的阻击怪信息
- ambush = {}; // 每个点的捕捉信息
- var betweenAttackLocs = {}; // 所有可能的夹击点
- var needCache = false;
- var canGoDeadZone = core.flags.canGoDeadZone;
- core.flags.canGoDeadZone = true;
+ var damage = {}, // 每个点的伤害值
+ type = {}, // 每个点的伤害类型
+ repulse = {}, // 每个点的阻击怪信息
+ ambush = {}; // 每个点的捕捉信息
+ var betweenAttackLocs = {}; // 所有可能的夹击点
+ var needCache = false;
+ var canGoDeadZone = core.flags.canGoDeadZone;
+ core.flags.canGoDeadZone = true;
- // 计算血网和领域、阻击、激光的伤害,计算捕捉信息
- for (var loc in blocks) {
- var block = blocks[loc],
- x = block.x,
- y = block.y,
- id = block.event.id,
- enemy = core.material.enemys[id];
- if (block.disable) continue;
+ // 计算血网和领域、阻击、激光的伤害,计算捕捉信息
+ for (var loc in blocks) {
+ var block = blocks[loc],
+ x = block.x,
+ y = block.y,
+ id = block.event.id,
+ enemy = core.material.enemys[id];
+ if (block.disable) continue;
- type[loc] = type[loc] || {};
+ type[loc] = type[loc] || {};
- // 血网
- // 如需调用当前楼层的ratio可使用 core.status.maps[floorId].ratio
- if (id == "lavaNet" && !core.hasItem("amulet")) {
- damage[loc] = (damage[loc] || 0) + core.values.lavaDamage;
- type[loc][(block.event.name || "血网") + "伤害"] = true;
- }
+ // 血网
+ // 如需调用当前楼层的ratio可使用 core.status.maps[floorId].ratio
+ if (id == "lavaNet" && !core.hasItem("amulet")) {
+ damage[loc] = (damage[loc] || 0) + core.values.lavaDamage;
+ type[loc][(block.event.name || "血网") + "伤害"] = true;
+ }
- // 领域
- // 如果要防止领域伤害,可以直接简单的将 flag:no_zone 设为true
- if (
- enemy &&
- core.hasSpecial(enemy.special, 15) &&
- !core.hasFlag("no_zone")
- ) {
- // 领域范围,默认为1
- var range = enemy.range || 1;
- // 是否是九宫格领域
- var zoneSquare = false;
- if (enemy.zoneSquare != null) zoneSquare = enemy.zoneSquare;
- // 在范围内进行搜索,增加领域伤害值
- for (var dx = -range; dx <= range; dx++) {
- for (var dy = -range; dy <= range; dy++) {
- if (dx == 0 && dy == 0) continue;
- var nx = x + dx,
- ny = y + dy,
- currloc = nx + "," + ny;
- if (nx < 0 || nx >= width || ny < 0 || ny >= height) continue;
- // 如果是十字领域,则还需要满足 |dx|+|dy|<=range
- if (!zoneSquare && Math.abs(dx) + Math.abs(dy) > range) continue;
- damage[currloc] = (damage[currloc] || 0) + (enemy.zone || 0);
- type[currloc] = type[currloc] || {};
- type[currloc]["领域伤害"] = true;
- }
- }
- }
+ // 警戒
+ // 如果要防止警戒伤害,可以直接简单的将 flag:no_zone 设为true
+ if (
+ enemy &&
+ core.hasSpecial(enemy.special, 15) &&
+ !core.hasFlag("no_zone")
+ ) {
+ // 警戒范围,默认为1
+ var range = enemy.range || 1;
+ // 是否是九宫格警戒
+ var zoneSquare = false;
+ if (enemy.zoneSquare != null) zoneSquare = enemy.zoneSquare;
+ // 在范围内进行搜索,增加警戒伤害值
+ for (var dx = -range; dx <= range; dx++) {
+ for (var dy = -range; dy <= range; dy++) {
+ if (dx == 0 && dy == 0) continue;
+ var nx = x + dx,
+ ny = y + dy,
+ currloc = nx + "," + ny;
+ if (nx < 0 || nx >= width || ny < 0 || ny >= height) continue;
+ // 如果是十字警戒,则还需要满足 |dx|+|dy|<=range
+ if (!zoneSquare && Math.abs(dx) + Math.abs(dy) > range) continue;
+ damage[currloc] = (damage[currloc] || 0) + (Math.max(Math.max(enemy.atk - core.getRealStatusOrDefault(void 0, "def"), 0) + Math.floor(enemy.spell * (100 - core.getRealStatusOrDefault(void 0, "mdef")) / 100) - Math.floor(core.getRealStatusOrDefault(void 0, "spell") * core.getRealStatusOrDefault(void 0, "mhp") / 100 * 0.2), 0) || 0);
+ type[currloc] = type[currloc] || {};
+ type[currloc]["警戒伤害"] = true;
+ }
+ }
+ }
- // 阻击
- // 如果要防止阻击伤害,可以直接简单的将 flag:no_repulse 设为true
- if (
- enemy &&
- core.hasSpecial(enemy.special, 18) &&
- !core.hasFlag("no_repulse")
- ) {
- var scan = enemy.zoneSquare ? core.utils.scan2 : core.utils.scan;
- for (var dir in scan) {
- var nx = x + scan[dir].x,
- ny = y + scan[dir].y,
- currloc = nx + "," + ny;
- if (nx < 0 || nx >= width || ny < 0 || ny >= height) continue;
- damage[currloc] = (damage[currloc] || 0) + (enemy.repulse || 0);
- type[currloc] = type[currloc] || {};
- type[currloc]["阻击伤害"] = true;
- var rdir = core.turnDirection(":back", dir);
- // 检查下一个点是否存在事件(从而判定是否移动)
- var rnx = x + scan[rdir].x,
- rny = y + scan[rdir].y;
- if (rnx < 0 || rnx >= width || rny < 0 || rny >= height) continue;
- // 如需禁止阻击被推到已隐藏的事件处(如重生怪处),可将这一句的false改为true
- if (core.getBlock(rnx, rny, floorId, false) != null) continue;
- if (core.utils.scan[rdir] && !core.canMoveHero(x, y, rdir, floorId))
- continue;
- repulse[currloc] = (repulse[currloc] || []).concat([
- [x, y, id, rdir],
- ]);
- }
- }
- // 激光
- // 如果要防止激光伤害,可以直接简单的将 flag:no_laser 设为true
- if (
- enemy &&
- core.hasSpecial(enemy.special, 24) &&
- !core.hasFlag("no_laser")
- ) {
- for (var nx = 0; nx < width; nx++) {
- var currloc = nx + "," + y;
- if (nx != x) {
- damage[currloc] = (damage[currloc] || 0) + (enemy.laser || 0);
- type[currloc] = type[currloc] || {};
- type[currloc]["激光伤害"] = true;
- }
- }
- for (var ny = 0; ny < height; ny++) {
- var currloc = x + "," + ny;
- if (ny != y) {
- damage[currloc] = (damage[currloc] || 0) + (enemy.laser || 0);
- type[currloc] = type[currloc] || {};
- type[currloc]["激光伤害"] = true;
- }
- }
- }
+ // 捕捉
+ // 如果要防止捕捉效果,可以直接简单的将 flag:no_ambush 设为true
+ if (
+ enemy &&
+ core.enemys.hasSpecial(enemy.special, 27) &&
+ !core.hasFlag("no_ambush")
+ ) {
+ var scan = enemy.zoneSquare ? core.utils.scan2 : core.utils.scan;
+ // 给周围格子加上【捕捉】记号
+ for (var dir in scan) {
+ var nx = x + scan[dir].x,
+ ny = y + scan[dir].y,
+ currloc = nx + "," + ny;
+ if (
+ nx < 0 ||
+ nx >= width ||
+ ny < 0 ||
+ ny >= height ||
+ (core.utils.scan[dir] && !core.canMoveHero(x, y, dir, floorId))
+ )
+ continue;
+ ambush[currloc] = (ambush[currloc] || []).concat([
+ [x, y, id, dir]
+ ]);
+ }
+ }
+ }
- // 捕捉
- // 如果要防止捕捉效果,可以直接简单的将 flag:no_ambush 设为true
- if (
- enemy &&
- core.enemys.hasSpecial(enemy.special, 27) &&
- !core.hasFlag("no_ambush")
- ) {
- var scan = enemy.zoneSquare ? core.utils.scan2 : core.utils.scan;
- // 给周围格子加上【捕捉】记号
- for (var dir in scan) {
- var nx = x + scan[dir].x,
- ny = y + scan[dir].y,
- currloc = nx + "," + ny;
- if (
- nx < 0 ||
- nx >= width ||
- ny < 0 ||
- ny >= height ||
- (core.utils.scan[dir] && !core.canMoveHero(x, y, dir, floorId))
- )
- continue;
- ambush[currloc] = (ambush[currloc] || []).concat([[x, y, id, dir]]);
- }
- }
-
- // 夹击;在这里提前计算所有可能的夹击点,具体计算逻辑在下面
- // 如果要防止夹击伤害,可以简单的将 flag:no_betweenAttack 设为true
- if (
- enemy &&
- core.enemys.hasSpecial(enemy.special, 16) &&
- !core.hasFlag("no_betweenAttack")
- ) {
- for (var dir in core.utils.scan) {
- var nx = x + core.utils.scan[dir].x,
- ny = y + core.utils.scan[dir].y,
- currloc = nx + "," + ny;
- if (nx < 0 || nx >= width || ny < 0 || ny >= height) continue;
- betweenAttackLocs[currloc] = true;
- }
- }
-
- // 检查地图范围类技能
- var specialFlag = core.getSpecialFlag(enemy);
- if (specialFlag & 1) needCache = true;
- if (core.status.event.id == "viewMaps") needCache = true;
- if (
- (core.status.event.id == "book" ||
- core.status.event.id == "bool-detail") &&
- core.status.event.ui
- )
- needCache = true;
- }
-
- // 对每个可能的夹击点计算夹击伤害
- for (var loc in betweenAttackLocs) {
- var xy = loc.split(","),
- x = parseInt(xy[0]),
- y = parseInt(xy[1]);
- // 夹击怪物的ID
- var enemyId1 = null,
- enemyId2 = null;
- // 检查左右夹击
- var leftBlock = blocks[x - 1 + "," + y],
- rightBlock = blocks[x + 1 + "," + y];
- var leftId = core.getFaceDownId(leftBlock),
- rightId = core.getFaceDownId(rightBlock);
- if (
- leftBlock &&
- !leftBlock.disable &&
- rightBlock &&
- !rightBlock.disable &&
- leftId == rightId
- ) {
- if (core.hasSpecial(leftId, 16)) enemyId1 = leftId;
- }
- // 检查上下夹击
- var topBlock = blocks[x + "," + (y - 1)],
- bottomBlock = blocks[x + "," + (y + 1)];
- var topId = core.getFaceDownId(topBlock),
- bottomId = core.getFaceDownId(bottomBlock);
- if (
- topBlock &&
- !topBlock.disable &&
- bottomBlock &&
- !bottomBlock.disable &&
- topId == bottomId
- ) {
- if (core.hasSpecial(topId, 16)) enemyId2 = topId;
- }
-
- if (enemyId1 != null || enemyId2 != null) {
- var leftHp = core.status.hero.hp - (damage[loc] || 0);
- if (leftHp > 1) {
- // 夹击伤害值
- var value = Math.floor(leftHp / 2);
- // 是否不超过怪物伤害值
- if (core.flags.betweenAttackMax) {
- var enemyDamage1 = core.getDamage(enemyId1, x, y, floorId);
- if (enemyDamage1 != null && enemyDamage1 < value)
- value = enemyDamage1;
- var enemyDamage2 = core.getDamage(enemyId2, x, y, floorId);
- if (enemyDamage2 != null && enemyDamage2 < value)
- value = enemyDamage2;
- }
- if (value > 0) {
- damage[loc] = (damage[loc] || 0) + value;
- type[loc] = type[loc] || {};
- type[loc]["夹击伤害"] = true;
- }
- }
- }
- }
-
- // 取消注释下面这一段可以让护盾抵御阻激夹域伤害
- /*
+ // 取消注释下面这一段可以让护盾抵御阻激夹域伤害
+ /*
for (var loc in damage) {
damage[loc] = Math.max(0, damage[loc] - core.getRealStatus('mdef'));
}
*/
- core.flags.canGoDeadZone = canGoDeadZone;
- core.status.checkBlock = {
- damage: damage,
- type: type,
- repulse: repulse,
- ambush: ambush,
- needCache: needCache,
- cache: {}, // clear cache
- };
- },
+ core.flags.canGoDeadZone = canGoDeadZone;
+ core.status.checkBlock = {
+ damage: damage,
+ type: type,
+ repulse: repulse,
+ ambush: ambush,
+ needCache: needCache,
+ cache: {}, // clear cache
+ };
+},
"moveOneStep": function (callback) {
// 勇士每走一步后执行的操作。callback为行走完毕后的回调
// 这个函数执行在“刚走完”的时候,即还没有检查该点的事件和领域伤害等。
@@ -2033,19 +1600,7 @@ var functions_d6ad677b_427a_4623_b50f_a445a3b0ef8a =
// 更新跟随者状态,并绘制
core.updateFollowers();
core.drawHero();
- // 检查中毒状态的扣血和死亡
- if (core.hasFlag("poison")) {
- core.status.hero.statistics.poisonDamage += core.values.poisonDamage;
- core.status.hero.hp -= core.values.poisonDamage;
- if (core.status.hero.hp <= 0) {
- core.status.hero.hp = 0;
- core.updateStatusBar(false, true);
- core.events.lose();
- return;
- } else {
- core.updateStatusBar(false, true);
- }
- }
+
// 从v2.7开始,每一步行走不会再刷新状态栏。
// 如果有特殊要求(如每走一步都加buff之类),可手动取消注释下面这一句:
diff --git a/project/icons.js b/project/icons.js
index 14e3c91..0d40858 100644
--- a/project/icons.js
+++ b/project/icons.js
@@ -152,7 +152,8 @@ var icons_4665ee12_3a1f_44a4_bea3_0fccba634dc1 =
"rightPortal": 25,
"upPortal": 26,
"ice": 27,
- "magentaWall": 28
+ "magentaWall": 28,
+ "A437": 29
},
"npcs": {
"man": 0,
@@ -259,7 +260,16 @@ var icons_4665ee12_3a1f_44a4_bea3_0fccba634dc1 =
"E421": 73,
"E422": 73,
"E425": 74,
- "E426": 75
+ "E426": 75,
+ "E428": 76,
+ "E429": 77,
+ "E430": 78,
+ "E431": 79,
+ "E432": 80,
+ "E433": 81,
+ "E434": 82,
+ "E435": 83,
+ "E436": 84
},
"enemy48": {
"angel": 0,
@@ -356,7 +366,8 @@ var icons_4665ee12_3a1f_44a4_bea3_0fccba634dc1 =
"I419": 81,
"I420": 82,
"I423": 83,
- "I424": 84
+ "I424": 84,
+ "I427": 85
},
"autotile": {
"autotile": 0,
diff --git a/project/items.js b/project/items.js
index 53adda0..719e76a 100644
--- a/project/items.js
+++ b/project/items.js
@@ -298,8 +298,8 @@ var items_296f5d02_12fd_4166_a7c1_b5e830c9ee3a =
"text": "可以自由往来去过的楼层",
"hideInReplay": true,
"hideInToolbox": true,
- "useItemEffect": "//core.ui.drawFly(core.floorIds.indexOf(core.status.floorId));\nflags.canMoveFloor = core.canMoveFloor()\nif (!main.replayChecking && !core.isReplaying()) core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));",
- "canUseItemEffect": "(function () {\n\tif (core.flags.flyNearStair && !core.nearStair() && !core.canMoveFloor())\n\t\treturn false;\n\treturn core.status.maps[core.status.floorId].canFlyFrom;\n})();"
+ "useItemEffect": "core.ui.drawFly(core.floorIds.indexOf(core.status.floorId));",
+ "canUseItemEffect": "(function () {\n\tif (core.flags.flyNearStair && !core.nearStair())\n\t\treturn false;\n\treturn core.status.maps[core.status.floorId].canFlyFrom;\n})();"
},
"coin": {
"cls": "constants",
@@ -813,5 +813,21 @@ var items_296f5d02_12fd_4166_a7c1_b5e830c9ee3a =
"cls": "items",
"name": "新物品",
"canUseItemEffect": "true"
+ },
+ "I427": {
+ "cls": "equips",
+ "name": "生铁短匕",
+ "text": "匕首有些沉重,也不太合手,但它的边缘相当锐利,可以完成一些基础的刺杀工作。",
+ "equip": {
+ "type": 0,
+ "animate": "sword",
+ "value": {
+ "atk": 6
+ },
+ "percentage": {}
+ },
+ "itemEffect": "core.status.hero.atk += 0",
+ "itemEffectTip": ",攻击+0",
+ "equipCls": "匕首"
}
}
\ No newline at end of file
diff --git a/project/maps.js b/project/maps.js
index e9b9cf2..717d595 100644
--- a/project/maps.js
+++ b/project/maps.js
@@ -325,6 +325,17 @@ var maps_90f36752_8815_4be8_b32b_d7fad1d0542e =
"424": {"cls":"items","id":"I424"},
"425": {"cls":"enemys","id":"E425"},
"426": {"cls":"enemys","id":"E426"},
+ "427": {"cls":"items","id":"I427"},
+ "428": {"cls":"enemys","id":"E428"},
+ "429": {"cls":"enemys","id":"E429"},
+ "430": {"cls":"enemys","id":"E430"},
+ "431": {"cls":"enemys","id":"E431"},
+ "432": {"cls":"enemys","id":"E432"},
+ "433": {"cls":"enemys","id":"E433"},
+ "434": {"cls":"enemys","id":"E434"},
+ "435": {"cls":"enemys","id":"E435"},
+ "436": {"cls":"enemys","id":"E436"},
+ "437": {"cls":"animates","id":"A437"},
"20034": {"cls":"tileset","id":"X20034","canPass":true},
"20154": {"cls":"tileset","id":"X20154","canPass":true},
"20216": {"cls":"tileset","id":"X20216","canPass":true},
diff --git a/project/materials/animates.png b/project/materials/animates.png
index 89d8789..2769cbc 100644
Binary files a/project/materials/animates.png and b/project/materials/animates.png differ
diff --git a/project/materials/enemys.png b/project/materials/enemys.png
index 44fb811..a6b1b50 100644
Binary files a/project/materials/enemys.png and b/project/materials/enemys.png differ
diff --git a/project/materials/items.png b/project/materials/items.png
index bf1a755..80da4a0 100644
Binary files a/project/materials/items.png and b/project/materials/items.png differ
diff --git a/project/plugins.js b/project/plugins.js
index 261b5cc..9104444 100644
--- a/project/plugins.js
+++ b/project/plugins.js
@@ -2,6 +2,56 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
{
"init": function () {
this._afterLoadResources = function () {
+ if (!main.replayChecking) {
+ function loadFont(_fontName, _fontUrl) {
+ // let reg = new RegExp('\\b' + _fontName + '\\b')
+
+ // let _fontFamily = document.body.style.fontFamily
+
+ // if (reg.test(_fontFamily)) {
+ // return
+ // }
+
+ /*if (checkFont(_fontName)) {
+ console.log('已有字体:', _fontName)
+ return
+ }*/
+
+ let prefont = new FontFace(
+ _fontName,
+ 'url(' + _fontUrl + ')'
+ );
+
+ //强制加载
+ prefont.load().then(function (loaded_face) {
+
+ document.fonts.add(loaded_face);
+ // document.body.style.fontFamily = (_fontFamily ? _fontFamily + ',' : _fontFamily) + _fontName;
+
+
+ }).catch(function (error) {
+ console.log('字体加载失败', error)
+ })
+ }
+ // 检测字体文件是否已加载
+ function checkFont(name) {
+ let values = document.fonts.values();
+ let isHave = false;
+ let item = values.next();
+ while (!item.done && !isHave) {
+ let fontFace = item.value;
+ if (fontFace.family == name) {
+ isHave = true;
+ }
+ item = values.next();
+ }
+ return isHave;
+ }
+ loadFont("HATTEN", 'project/fonts/HATTEN.ttf')
+ loadFont("Verdana", 'project/fonts/Verdana.ttf')
+ loadFont("pala", 'project/fonts/pala.ttf')
+ loadFont("number", 'project/fonts/number.ttf')
+ }
// 本函数将在所有资源加载完毕后,游戏开启前被执行
core.ui.statusBar.init();
core.dom.playGame.style.fontFamily = "pala";
@@ -29,6 +79,24 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.removeMouse(data.div);
core.doAction();
});
+ core.registerEvent("specialDoor", function (data) {
+
+ let bool = true;
+ let loc_arr = data.loc[0] instanceof Array ? data.loc : [data.loc]
+ loc_arr.forEach(loc => {
+ if (core.getBlockCls(loc[0], loc[1]) && core.getBlockCls(loc[0], loc[1]).startsWith("enemys")) {
+ bool = false;
+ }
+ });
+ if (bool) {
+ let doors = data.doors[0] instanceof Array ? data.doors : [data.doors]
+ let action = []
+ doors.forEach(v => action.push({ "type": "openDoor", "loc": [v[0], v[1]], "async": true }))
+ action.push({ "type": "waitAsync" })
+ core.insertAction(action)
+ }
+ core.doAction();
+ });
core.registerEvent("animationDrawable", function (data) {
if (!main.replayChecking && !core.isReplaying()) {
core.animationDrawable(
@@ -273,7 +341,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
data.sound :
core.plugin[core.ui.cgText.textList][data.index][2] || "";
core.ui.cgText.bodyList = core.clone(data.bodyList);
- main.dom.cgText.style.display = "block";
+ main.dom.cg.style.display = "block";
core.ui.cgText.update();
} else {
core.doAction();
@@ -2586,48 +2654,48 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
main.dom.statusBar.style.display = "none";
main.dom.toolBar.style.display = "none";
//所有数据*3是为了实现高清画布
- const GAMEVIEW_WIDTH = 676 * 3; //横屏画面宽度
- const GAMEVIEW_HEIGHT = 416 * 3; //横屏画面高度
+ const GAMEVIEW_WIDTH = 676; //横屏画面宽度
+ const GAMEVIEW_HEIGHT = 416; //横屏画面高度
- const GAMEVIEW_WIDTH_VERTICAL = 416 * 3; //竖屏画面宽度
- const GAMEVIEW_HEIGHT_VERTICAL = 676 * 3; //竖屏画面高度
+ const GAMEVIEW_WIDTH_VERTICAL = 416; //竖屏画面宽度
+ const GAMEVIEW_HEIGHT_VERTICAL = 676; //竖屏画面高度
- const BAR_WIDTH = 130 * 3; //横屏左侧额外距离(即边栏宽度)
- const BAR_HEIGHT_VERTICAL = 130 * 3; //竖屏上侧额外距离(即边栏高度)
+ const BAR_WIDTH = 130; //横屏左侧额外距离(即边栏宽度)
+ const BAR_HEIGHT_VERTICAL = 130; //竖屏上侧额外距离(即边栏高度)
const BORDER_WIDTH = 0; //游戏画面左侧偏移距离
const BORDER_HEIGHT = 0; //游戏画面上侧偏移距离
- const ITEM_BOX_LEFT = 549 * 3; //横屏道具栏左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
- const ITEM_BOX_TOP = 175 * 3; //横屏道具栏上侧距离
- const ITEM_BOX_LEFT_VERTICAL = 160 * 3; //竖屏道具栏左侧距离
- const ITEM_BOX_TOP_VERTICAL = 549 * 3; //竖屏道具栏上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
+ const ITEM_BOX_LEFT = 549; //横屏道具栏左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
+ const ITEM_BOX_TOP = 175; //横屏道具栏上侧距离
+ const ITEM_BOX_LEFT_VERTICAL = 160; //竖屏道具栏左侧距离
+ const ITEM_BOX_TOP_VERTICAL = 549; //竖屏道具栏上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
- const EQUIP_BLOCK_LEFT = 549 * 3; //横屏装备栏左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
- const EQUIP_BLOCK_TOP = 10 * 3; //横屏装备栏上侧距离
- const EQUIP_BLOCK_LEFT_VERTICAL = 10 * 3; //竖屏装备栏左侧距离
- const EQUIP_BLOCK_TOP_VERTICAL = 549 * 3; //竖屏装备栏上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
+ const EQUIP_BLOCK_LEFT = 549; //横屏装备栏左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
+ const EQUIP_BLOCK_TOP = 10; //横屏装备栏上侧距离
+ const EQUIP_BLOCK_LEFT_VERTICAL = 10; //竖屏装备栏左侧距离
+ const EQUIP_BLOCK_TOP_VERTICAL = 549; //竖屏装备栏上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
- const MAP_BLOCK_LEFT = 551 * 3; //横屏小地图左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
+ const MAP_BLOCK_LEFT = 551; //横屏小地图左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
const MAP_BLOCK_TOP = 0; //横屏小地图上侧距离
const MAP_BLOCK_LEFT_VERTICAL = 0; //竖屏小地图左侧距离
- const MAP_BLOCK_TOP_VERTICAL = 551 * 3; //竖屏小地图上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
+ const MAP_BLOCK_TOP_VERTICAL = 551; //竖屏小地图上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
const KEY_BLOCK_LEFT = EQUIP_BLOCK_LEFT; //横屏钥匙栏左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
- const KEY_BLOCK_TOP = 130 * 3; //横屏钥匙栏上侧距离
- const KEY_BLOCK_LEFT_VERTICAL = 110 * 3; //竖屏钥匙栏左侧距离
+ const KEY_BLOCK_TOP = 130; //横屏钥匙栏上侧距离
+ const KEY_BLOCK_LEFT_VERTICAL = 110; //竖屏钥匙栏左侧距离
const KEY_BLOCK_TOP_VERTICAL = EQUIP_BLOCK_TOP_VERTICAL; //竖屏钥匙栏上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
- const INFO_BLOCK_LEFT = 10 * 3; //横屏道具说明左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
- const INFO_BLOCK_TOP = 290 * 3; //横屏道具说明上侧距离
- const INFO_BLOCK_LEFT_VERTICAL = 113 * 3; //竖屏道具说明左侧距离
- const INFO_BLOCK_TOP_VERTICAL = 8 * 3; //竖屏道具说明上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
+ const INFO_BLOCK_LEFT = 10; //横屏道具说明左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
+ const INFO_BLOCK_TOP = 290; //横屏道具说明上侧距离
+ const INFO_BLOCK_LEFT_VERTICAL = 113; //竖屏道具说明左侧距离
+ const INFO_BLOCK_TOP_VERTICAL = 8; //竖屏道具说明上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
const TOOL_BOX_LEFT = EQUIP_BLOCK_LEFT; //横屏工具栏左侧距离(右侧边栏需增加BAR_WIDTH+GAMEVIEW_HEIGHT)
- const TOOL_BOX_TOP = 348 * 3; //横屏工具栏上侧距离
- const TOOL_BOX_LEFT_VERTICAL = 348 * 3; //竖屏工具栏左侧距离
- const TOOL_BOX_TOP_VERTICAL = 549 * 3; //竖屏工具栏上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
+ const TOOL_BOX_TOP = 348; //横屏工具栏上侧距离
+ const TOOL_BOX_LEFT_VERTICAL = 348; //竖屏工具栏左侧距离
+ const TOOL_BOX_TOP_VERTICAL = 549; //竖屏工具栏上侧距离(下侧边栏需增加BAR_HEIGHT_VERTICAL+GAMEVIEW_WIDTH_VERTICAL)
- const TOOL_ICON_OUTER_SIZE = 34 * 3;
+ const TOOL_ICON_OUTER_SIZE = 34;
const TEXT_COLOR = "#FFFFFF"; //默认文字颜色
const globalAlpha = 0.7; //默认底框透明度
@@ -2661,7 +2729,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const top = core.dom.gameGroup.offsetTop;
const px = Math.floor((e.clientX - left) / core.domStyle.scale),
py = Math.floor((e.clientY - top) / core.domStyle.scale);
- core.ui.statusBar.onclick(px * 3, py * 3);
+ core.ui.statusBar.onclick(px, py);
} catch (ee) {
main.log(ee);
}
@@ -2674,35 +2742,32 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
gameGroup.style.height = obj.totalHeight + "px";
gameGroup.style.left = (obj.clientWidth - obj.totalWidth) / 2 + "px";
gameGroup.style.top = (obj.clientHeight - obj.totalHeight) / 2 + "px";
- //floorMsgGroup为切换楼层中生效,显示时间可通过‘全塔属性’——‘切换楼层时间’或游戏内设置调整
- //显示内容为游戏名/版本号/楼层名
// floorMsgGroup
var floorMsgGroup = core.dom.floorMsgGroup;
var globalAttribute =
core.status.globalAttribute || core.initStatus.globalAttribute;
floorMsgGroup.style = globalAttribute.floorChangingStyle;
floorMsgGroup.style.height = floorMsgGroup.style.width =
- (GAMEVIEW_HEIGHT / 3) * core.domStyle.scale + "px";
+ GAMEVIEW_HEIGHT * core.domStyle.scale + "px";
floorMsgGroup.style.fontSize = 16 * core.domStyle.scale + "px";
if (core.domStyle.isVertical) {
floorMsgGroup.style.left = "0px";
floorMsgGroup.style.top =
- ((GAMEVIEW_HEIGHT_VERTICAL / 3 - GAMEVIEW_WIDTH_VERTICAL / 3) *
+ ((GAMEVIEW_HEIGHT_VERTICAL - GAMEVIEW_WIDTH_VERTICAL) *
core.domStyle.scale) /
2 +
"px";
} else {
floorMsgGroup.style.left =
- ((GAMEVIEW_WIDTH / 3 - GAMEVIEW_HEIGHT / 3) * core.domStyle.scale) /
- 2 +
- "px";
+ ((GAMEVIEW_WIDTH - GAMEVIEW_HEIGHT) * core.domStyle.scale) / 2 + "px";
floorMsgGroup.style.top = "0px";
}
+
core.dom.musicBtn.style.right =
(obj.clientWidth - obj.totalWidth) / 2 + "px";
core.dom.musicBtn.style.bottom =
- (obj.clientHeight - obj.totalHeight) / 2 - 27 + "px";
+ (obj.clientHeight - obj.totalHeight) / 2 - 9 + "px";
let startBackground = core.domStyle.isVertical ?
main.styles.startVerticalBackground || main.styles.startBackground :
main.styles.startBackground;
@@ -2713,16 +2778,16 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const span = document
.getElementById("startButtons")
.getElementsByTagName("span");
- let font = (GAMEVIEW_WIDTH / 100) * core.domStyle.scale;
+ let font = (GAMEVIEW_WIDTH * 3 / 100) * core.domStyle.scale;
if (core.domStyle.isVertical)
- font = ((GAMEVIEW_WIDTH_VERTICAL * 2) / 100) * core.domStyle.scale;
+ font = ((GAMEVIEW_WIDTH_VERTICAL * 6) / 100) * core.domStyle.scale;
core.dom.playGame.style.fontSize = font + "px";
core.dom.loadGame.style.fontSize = font + "px";
core.dom.CGMode.style.fontSize = font + "px";
core.dom.musicMode.style.fontSize = font + "px";
core.dom.replayGame.style.fontSize = font + "px";
- core.dom.startButtonGroup.style.padding = font * 0.3 + "px 25px";
+ core.dom.startButtonGroup.style.padding = font * 0.3 + "px 8px";
};
const _resize_canvas = function (obj) {
//自适应画布
@@ -2731,73 +2796,63 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
main.dom.outerUI.style.width = obj.totalWidth + "px";
main.dom.outerUI.style.height = obj.totalHeight + "px";
if (main.dom.CGUI) {
- main.dom.CGUI.style.width = obj.totalWidth + 3 + "px";
- main.dom.CGUI.style.height = obj.totalHeight + 3 + "px";
+ main.dom.CGUI.style.width = obj.totalWidth + "px";
+ main.dom.CGUI.style.height = obj.totalHeight + "px";
}
if (main.dom.music) {
- main.dom.music.style.width = obj.totalWidth + 3 + "px";
- main.dom.music.style.height = obj.totalHeight + 3 + "px";
+ main.dom.music.style.width = obj.totalWidth + "px";
+ main.dom.music.style.height = obj.totalHeight + "px";
}
- if (main.dom.cgText) {
- main.dom.cgText.style.width = obj.totalWidth + 3 + "px";
- main.dom.cgText.style.height = obj.totalHeight + 3 + "px";
+ if (main.dom.cg) {
+ main.dom.cg.style.width = obj.totalWidth + "px";
+ main.dom.cg.style.height = obj.totalHeight + "px";
}
if (main.dom.logcanvas) {
- main.dom.logcanvas.style.width = obj.totalWidth + 3 + "px";
- main.dom.logcanvas.style.height = obj.totalHeight + 3 + "px";
+ main.dom.logcanvas.style.width = obj.totalWidth + "px";
+ main.dom.logcanvas.style.height = obj.totalHeight + "px";
}
if (main.dom.over) {
- main.dom.over.style.width = obj.totalWidth + 3 + "px";
- main.dom.over.style.height = obj.totalHeight + 3 + "px";
+ main.dom.over.style.width = obj.totalWidth + "px";
+ main.dom.over.style.height = obj.totalHeight + "px";
}
if (main.dom.book) {
- main.dom.book.style.width = obj.totalWidth + 3 + "px";
- main.dom.book.style.height = obj.totalHeight + 3 + "px";
+ main.dom.book.style.width = obj.totalWidth + "px";
+ main.dom.book.style.height = obj.totalHeight + "px";
}
if (main.dom.video) {
- main.dom.video.style.width = obj.totalWidth + 3 + "px";
- main.dom.video.style.height = obj.totalHeight + 3 + "px";
- if (core.domStyle.isVertical)
- main.dom.video.style.width = obj.totalHeight + 3 + "px";
- if (core.domStyle.isVertical)
- main.dom.video.style.height = obj.totalWidth + 3 + "px";
- main.dom.video.style.top = "50%";
- main.dom.video.style.left = "50%";
+ main.dom.video.style.width = obj.totalWidth + "px";
+ main.dom.video.style.height = obj.totalHeight + "px";
- main.dom.video.style.transform = "translate(-50%,-50%)";
-
- if (core.domStyle.isVertical)
- main.dom.video.style.transform = "translate(-50%,-50%) rotate(90deg)";
}
if (main.dom.video1) {
- main.dom.video1.style.width = obj.totalWidth + 3 + "px";
- main.dom.video1.style.height = obj.totalHeight + 3 + "px";
+ main.dom.video1.style.width = obj.totalWidth + "px";
+ main.dom.video1.style.height = obj.totalHeight + "px";
}
- main.dom.boss1.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss1.style.height = obj.totalHeight + 3 + "px";
+ main.dom.boss1.style.width = obj.totalWidth + "px";
+ main.dom.boss1.style.height = obj.totalHeight + "px";
- main.dom.boss2.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss2.style.height = obj.totalHeight + 3 + "px";
+ main.dom.boss2.style.width = obj.totalWidth + "px";
+ main.dom.boss2.style.height = obj.totalHeight + "px";
- main.dom.boss3.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss3.style.height = obj.totalHeight + 3 + "px";
+ main.dom.boss3.style.width = obj.totalWidth + "px";
+ main.dom.boss3.style.height = obj.totalHeight + "px";
- main.dom.boss4.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss4.style.height = obj.totalHeight + 3 + "px";
+ main.dom.boss4.style.width = obj.totalWidth + "px";
+ main.dom.boss4.style.height = obj.totalHeight + "px";
- main.dom.boss5.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss5.style.height = obj.totalHeight + 3 + "px";
- main.dom.boss6.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss6.style.height = obj.totalHeight + 3 + "px";
- main.dom.boss7.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss7.style.height = obj.totalHeight + 3 + "px";
- main.dom.boss8.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss8.style.height = obj.totalHeight + 3 + "px";
- main.dom.saveLoad.style.width = obj.totalWidth + 3 + "px";
- main.dom.saveLoad.style.height = obj.totalHeight + 3 + "px";
- main.dom.boss.style.width = obj.totalWidth + 3 + "px";
- main.dom.boss.style.height = obj.totalHeight + 3 + "px";
+ main.dom.boss5.style.width = obj.totalWidth + "px";
+ main.dom.boss5.style.height = obj.totalHeight + "px";
+ main.dom.boss6.style.width = obj.totalWidth + "px";
+ main.dom.boss6.style.height = obj.totalHeight + "px";
+ main.dom.boss7.style.width = obj.totalWidth + "px";
+ main.dom.boss7.style.height = obj.totalHeight + "px";
+ main.dom.boss8.style.width = obj.totalWidth + "px";
+ main.dom.boss8.style.height = obj.totalHeight + "px";
+ main.dom.saveLoad.style.width = obj.totalWidth + "px";
+ main.dom.saveLoad.style.height = obj.totalHeight + "px";
+ main.dom.boss.style.width = obj.totalWidth + "px";
+ main.dom.boss.style.height = obj.totalHeight + "px";
const innerSize = obj.canvasWidth * core.domStyle.scale + "px";
for (let i = 0; i < core.dom.gameCanvas.length; ++i)
@@ -2809,6 +2864,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.dom.gameDraw.style.width = core.dom.gameDraw.style.height =
innerSize;
+
core.dom.gameDraw.style.top =
obj.gameDrawBox.top * core.domStyle.scale + "px";
core.dom.gameDraw.style.left =
@@ -2828,8 +2884,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const ctx = core.dymCanvas[name],
canvas = ctx.canvas;
const ratio = canvas.hasAttribute("isHD") ? core.domStyle.ratio : 1;
- canvas.style.width = (innerSize / ratio) * core.domStyle.scale + "px";
- canvas.style.height = (innerSize / ratio) * core.domStyle.scale + "px";
+ canvas.style.width = core.__PIXELS__ * core.domStyle.scale + "px";
+ canvas.style.height = core.__PIXELS__ * core.domStyle.scale + "px";
canvas.style.left =
parseFloat(canvas.getAttribute("_left")) * core.domStyle.scale + "px";
canvas.style.top =
@@ -2845,52 +2901,51 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const uictx = main.dom.outerUI.getContext("2d");
let now = 0;
core.registerAnimationFrame("lightFloor", true, function (timestamp) {
- if (!core.status.floorId) return
- if (timestamp - now > 1000 / 60) {
- now = timestamp;
- globalAlphafloor += globalAlphafloorStatus;
- if (globalAlphafloor === 100) globalAlphafloorStatus = -2;
- if (globalAlphafloor === 0) globalAlphafloorStatus = 2;
+ if (!core.status.floorId || timestamp - now < 50) return
+ now = timestamp;
+ globalAlphafloor += globalAlphafloorStatus;
+ if (globalAlphafloor === 100) globalAlphafloorStatus = -4;
+ if (globalAlphafloor === 0) globalAlphafloorStatus = 4;
- if (core.domStyle.isVertical) {
- core.clearMap(
- uictx,
- MAP_BLOCK_LEFT_VERTICAL,
- MAP_BLOCK_TOP_VERTICAL,
- 340,
- 360
- );
- if (core.status.event.id === "viewMaps") {
- core.ui.statusBar._update_map(core.status.event.data.floorId);
- } else {
- core.ui.statusBar._update_map();
- }
-
- uictx.globalAlpha = globalAlphafloor / 100;
- core.drawImage(
- uictx,
- "green.webp",
- MAP_BLOCK_LEFT_VERTICAL + 135,
- MAP_BLOCK_TOP_VERTICAL + 170
- );
- uictx.globalAlpha = 1;
+ if (core.domStyle.isVertical) {
+ core.clearMap(
+ uictx,
+ MAP_BLOCK_LEFT_VERTICAL,
+ MAP_BLOCK_TOP_VERTICAL,
+ 113,
+ 120
+ );
+ if (core.status.event.id === "viewMaps" && core.status.event.data) {
+ core.ui.statusBar._update_map(core.status.event.data.floorId);
} else {
- core.clearMap(uictx, MAP_BLOCK_LEFT, MAP_BLOCK_TOP, 340, 360);
- if (core.status.event.id === "viewMaps") {
- core.ui.statusBar._update_map(core.status.event.data.floorId);
- } else {
- core.ui.statusBar._update_map();
- }
- uictx.globalAlpha = globalAlphafloor / 100;
- core.drawImage(
- uictx,
- "green.webp",
- MAP_BLOCK_LEFT + 150,
- MAP_BLOCK_TOP + 180
- );
- uictx.globalAlpha = 1;
+ core.ui.statusBar._update_map();
}
+
+ uictx.globalAlpha = globalAlphafloor / 100;
+ core.drawImage(
+ uictx,
+ "green.webp",
+ MAP_BLOCK_LEFT_VERTICAL + 44,
+ MAP_BLOCK_TOP_VERTICAL + 57, 20, 20
+ );
+ uictx.globalAlpha = 1;
+ } else {
+ core.clearMap(uictx, MAP_BLOCK_LEFT, MAP_BLOCK_TOP, 113, 120);
+ if (core.status.event.id === "viewMaps" && core.status.event.data) {
+ core.ui.statusBar._update_map(core.status.event.data.floorId);
+ } else {
+ core.ui.statusBar._update_map();
+ }
+ uictx.globalAlpha = globalAlphafloor / 100;
+ core.drawImage(
+ uictx,
+ "green.webp",
+ MAP_BLOCK_LEFT + 50,
+ MAP_BLOCK_TOP + 60, 20, 20
+ );
+ uictx.globalAlpha = 1;
}
+
});
core.control.resize = function () {
@@ -2905,11 +2960,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.domStyle.isVertical = isVertical;
const totalWidth = isVertical ?
- GAMEVIEW_WIDTH_VERTICAL / 3 :
- GAMEVIEW_WIDTH / 3,
+ GAMEVIEW_WIDTH_VERTICAL :
+ GAMEVIEW_WIDTH,
totalHeight = isVertical ?
- GAMEVIEW_HEIGHT_VERTICAL / 3 :
- GAMEVIEW_HEIGHT / 3;
+ GAMEVIEW_HEIGHT_VERTICAL :
+ GAMEVIEW_HEIGHT;
const maxRatio = Math.min(
clientWidth / totalWidth,
@@ -2938,9 +2993,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
totalHeightScaled = totalHeight * core.domStyle.scale;
const gameDrawBox = isVertical ? {
- left: BORDER_WIDTH / 3,
- top: BAR_HEIGHT_VERTICAL / 3 + BORDER_HEIGHT / 3,
- } : { left: BAR_WIDTH / 3 + BORDER_WIDTH / 3, top: BORDER_HEIGHT / 3 };
+ left: BORDER_WIDTH,
+ top: BAR_HEIGHT_VERTICAL + BORDER_HEIGHT,
+ } : { left: BAR_WIDTH + BORDER_WIDTH, top: BORDER_HEIGHT };
const obj = {
clientWidth: clientWidth,
@@ -2956,6 +3011,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
_resize_canvas(obj);
if (core.status.automaticRoute == null) core.status.automaticRoute = {};
+
+
core.updateStatusBar();
if (main.dom.CGUI && main.dom.CGUI.style.display === "block")
core.ui.CG.update();
@@ -2971,6 +3028,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.overupdate()
if (main.dom.saveLoad && main.dom.saveLoad.style.display === "block")
core.saveLoad.update();
+ if (core.status.event.data?.type == "menu") core.menu.update()
};
class StatusBar {
@@ -3021,31 +3079,32 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
_redrawMap() {
if (core.domStyle.isVertical) {
+
core.clearMap(
uictx,
MAP_BLOCK_LEFT_VERTICAL,
MAP_BLOCK_TOP_VERTICAL,
- 340,
- 360
+ 113,
+ 120
);
this._update_map();
uictx.globalAlpha = globalAlphafloor / 100;
core.drawImage(
uictx,
"green.webp",
- MAP_BLOCK_LEFT_VERTICAL + 125,
- MAP_BLOCK_TOP_VERTICAL + 170
+ MAP_BLOCK_LEFT_VERTICAL + 44,
+ MAP_BLOCK_TOP_VERTICAL + 57, 20, 20
);
uictx.globalAlpha = 1;
} else {
- core.clearMap(uictx, MAP_BLOCK_LEFT, MAP_BLOCK_TOP, 340, 360);
+ core.clearMap(uictx, MAP_BLOCK_LEFT, MAP_BLOCK_TOP, 100, 120);
this._update_map();
uictx.globalAlpha = globalAlphafloor / 100;
core.drawImage(
uictx,
"green.webp",
- MAP_BLOCK_LEFT + 150,
- MAP_BLOCK_TOP + 170
+ MAP_BLOCK_LEFT + 50,
+ MAP_BLOCK_TOP + 60, 20, 20
);
uictx.globalAlpha = 1;
}
@@ -3053,11 +3112,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
//更新背景
_update_background() {
if (core.domStyle.isVertical) {
- bgctx.canvas.width = GAMEVIEW_WIDTH_VERTICAL;
- bgctx.canvas.height = GAMEVIEW_HEIGHT_VERTICAL;
- uictx.canvas.width = GAMEVIEW_WIDTH_VERTICAL;
- uictx.canvas.height = GAMEVIEW_HEIGHT_VERTICAL;
-
+ core.maps._setHDCanvasSize(bgctx, GAMEVIEW_WIDTH_VERTICAL, GAMEVIEW_HEIGHT_VERTICAL)
+ core.maps._setHDCanvasSize(uictx, GAMEVIEW_WIDTH_VERTICAL, GAMEVIEW_HEIGHT_VERTICAL)
const bg = core.material.images.images["status.webp"]; //竖屏背景(上)
bgctx.drawImage(
bg,
@@ -3078,11 +3134,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
bgctx.globalAlpha = 1;
core.setTextAlign("outerUI", "center");
} else {
- bgctx.canvas.width = GAMEVIEW_WIDTH;
- bgctx.canvas.height = GAMEVIEW_HEIGHT;
- uictx.canvas.width = GAMEVIEW_WIDTH;
- uictx.canvas.height = GAMEVIEW_HEIGHT;
-
+ core.maps._setHDCanvasSize(bgctx, GAMEVIEW_WIDTH, GAMEVIEW_HEIGHT)
+ core.maps._setHDCanvasSize(uictx, GAMEVIEW_WIDTH, GAMEVIEW_HEIGHT)
const bg = core.material.images.images["status.webp"]; //横屏背景(左)
bgctx.drawImage(bg, 0, 0, BAR_WIDTH, GAMEVIEW_HEIGHT);
const bg2 = core.material.images.images["status.webp"]; //横屏背景(右)
@@ -3114,6 +3167,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"mhp",
"speed",
"money",
+ "exp"
]; //属性列表,图标在函数复写core.statusBar.icons中声明,数字为project\materials\icons.png中的图标序号(可使用便捷ps追加,第一个序号为0)
const drawStatusList = (baseX, baseY) => {
let curh = baseY;
@@ -3128,19 +3182,17 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
22 * 3,
22 * 3
);*/
- core.strokeRect("outerUI", baseX - 96 * 3,
- curh - 16 * 3, 100 * 3, 22 * 3, "#FFFFFF", 3)
- core.setFont("outerUI", "bold 24px Verdana");
- core.fillBoldText1(
+ core.strokeRect("outerUI", baseX - 96,
+ curh - 16, 100, 22, "#FFFFFF", 1)
+ core.setFont("outerUI", " 10px Verdana");
+ core.fillText(
"outerUI",
core.getStatusLabel(item),
- baseX - 65 * 3,
- curh - 4 * 3,
- TEXT_COLOR,
- "#000000",
- 6
+ baseX - 65,
+ curh - 4,
+ TEXT_COLOR
);
- core.setFont("outerUI", "bold 36px Verdana");
+ core.setFont("outerUI", " 12px Verdana");
// 四舍五入
core.status.hero[item] = Math.round(core.status.hero[item]);
let text = core.getRealStatus(item);
@@ -3151,59 +3203,54 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
break;
case "matk":
case "mhp":
- text = `${Math.floor(core.getRealStatus("spell")* core.getRealStatus(item)/100)}(${text}%)`;
+ text = `${Math.floor(core.getRealStatus("spell")* core.getRealStatus(item)/100)}(${text}%)`;
break;
}
- core.fillBoldText1(
+ core.fillText(
"outerUI",
text,
baseX,
curh,
- TEXT_COLOR,
- "#000000",
- 6
- );
+ TEXT_COLOR
- curh += 24 * 3;
- if (curh > 130 * 3 && core.domStyle.isVertical) {
- curh = 24 * 3;
- baseX += 105 * 3;
+ )
+
+ curh += 24;
+ if (curh > 130 && core.domStyle.isVertical) {
+ curh = 24;
+ baseX += 105;
}
});
core.setTextAlign("outerUI", "center");
};
if (core.domStyle.isVertical) {
- core.clearMap("outerUI", 10 * 3, 0, 210 * 3, 120 * 3);
- core.setFont("outerUI", "bold 42px Verdana");
+ core.clearMap("outerUI", 10, 0, 210, 120);
+ core.setFont("outerUI", " 14px Verdana");
if (updatedFloorTitle) {
- core.fillBoldText1(
+ core.fillText(
"outerUI",
updatedFloorTitle,
- 60 * 3,
- 22 * 3,
- TEXT_COLOR,
- "#000000",
- 6
+ 60,
+ 22,
+ TEXT_COLOR
);
}
- drawStatusList(96 * 3, 46 * 3);
+ drawStatusList(96, 46);
//core.drawImage("outerUI", "lane1.png", 0, 0)
//core.drawImage("outerUI", "cao.webp", 0, 0);
} else {
- core.clearMap("outerUI", 10 * 3, 40 * 3, 105 * 3, 250 * 3);
- core.setFont("outerUI", "bold 48px Verdana");
+ core.clearMap("outerUI", 10, 40, 105, 250);
+ core.setFont("outerUI", " 16px Verdana");
if (updatedFloorTitle) {
- core.fillBoldText1(
+ core.fillText(
"outerUI",
updatedFloorTitle,
- 62 * 3,
- 41 * 3,
- TEXT_COLOR,
- "#000000",
- 6
+ 62,
+ 41,
+ TEXT_COLOR
);
}
- drawStatusList(110 * 3, 93 * 3);
+ drawStatusList(110, 93);
//core.drawImage("outerUI", "lane1.png", 0, 30);
core.drawImage(
"outerUI",
@@ -3213,9 +3260,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
400,
350,
0,
- 30,
- 360,
- 315
+ 0,
+ 120,
+ 105
);
}
}
@@ -3241,8 +3288,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
32,
posx,
posy,
- 30 * 3,
- 30 * 3
+ 30,
+ 30
);
const cnt = core.itemCount(item);
if (
@@ -3252,10 +3299,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillText(
"outerUI",
cnt,
- posx + 25 * 3,
- posy + 28 * 3,
+ posx + 25,
+ posy + 28,
"#FFFFFF",
- "bold 36px Verdana"
+ "bold 12px Verdana"
);
}
};
@@ -3264,14 +3311,14 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
ITEM_BOX_LEFT_VERTICAL,
ITEM_BOX_TOP_VERTICAL,
- 185 * 3,
- 125 * 3
+ 185,
+ 125
);
drawItemMx((i, j, item) => {
if (core.hasItem(item)) {
- const posx = ITEM_BOX_LEFT_VERTICAL + i * 30 * 3,
- posy = ITEM_BOX_TOP_VERTICAL + j * 31 * 3;
+ const posx = ITEM_BOX_LEFT_VERTICAL + i * 30,
+ posy = ITEM_BOX_TOP_VERTICAL + j * 31;
drawItem(item, posx, posy);
}
});
@@ -3280,14 +3327,14 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
ITEM_BOX_LEFT,
ITEM_BOX_TOP,
- 125 * 3,
- 185 * 3
+ 125,
+ 185
);
drawItemMx((i, j, item) => {
if (core.hasItem(item)) {
- const posx = ITEM_BOX_LEFT + j * 30 * 3,
- posy = ITEM_BOX_TOP + i * 31 * 3;
+ const posx = ITEM_BOX_LEFT + j * 30,
+ posy = ITEM_BOX_TOP + i * 31;
drawItem(item, posx, posy);
}
});
@@ -3306,19 +3353,19 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const info = core.plugin.getMapDrawInfo(floorId, Infinity, true);
core.setTextAlign("outerUI", "center");
- core.plugin.drawSmallMap(uictx, info, floorId, x, y, 300, 300);
+ core.plugin.drawSmallMap(uictx, info, floorId, x, y, 100, 100);
}
_update_equips() {
return;
- core.setFont("outerUI", "bold 48px Verdana");
+ core.setFont("outerUI", "bold 16px Verdana");
const drawEquip = (baseX, baseY, id, color, back) => {
if (!id)
core.fillText(
"outerUI",
back,
- baseX + 20 * 3,
- baseY + 22 * 3,
+ baseX + 20,
+ baseY + 22,
color
);
else {
@@ -3330,10 +3377,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
32 * icon,
32,
32,
- baseX + 5 * 3,
+ baseX + 5,
baseY,
- 32 * 3,
- 32 * 3
+ 32,
+ 32
);
}
};
@@ -3342,8 +3389,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
EQUIP_BLOCK_LEFT_VERTICAL,
EQUIP_BLOCK_TOP_VERTICAL,
- 90 * 3,
- 130 * 3
+ 90,
+ 130
);
drawEquip(
EQUIP_BLOCK_LEFT_VERTICAL,
@@ -3353,7 +3400,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"无"
);
drawEquip(
- EQUIP_BLOCK_LEFT_VERTICAL + 45 * 3,
+ EQUIP_BLOCK_LEFT_VERTICAL + 45,
EQUIP_BLOCK_TOP_VERTICAL,
core.getEquip(1),
"#D1CEFF",
@@ -3361,28 +3408,28 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
);
drawEquip(
EQUIP_BLOCK_LEFT_VERTICAL,
- EQUIP_BLOCK_TOP_VERTICAL + 45 * 3,
+ EQUIP_BLOCK_TOP_VERTICAL + 45,
core.getEquip(2),
"#D1CEFF",
"无"
);
drawEquip(
- EQUIP_BLOCK_LEFT_VERTICAL + 45 * 3,
- EQUIP_BLOCK_TOP_VERTICAL + 45 * 3,
+ EQUIP_BLOCK_LEFT_VERTICAL + 45,
+ EQUIP_BLOCK_TOP_VERTICAL + 45,
core.getEquip(3),
"#D1CEFF",
"无"
);
drawEquip(
EQUIP_BLOCK_LEFT_VERTICAL,
- EQUIP_BLOCK_TOP_VERTICAL + 90 * 3,
+ EQUIP_BLOCK_TOP_VERTICAL + 90,
core.getEquip(4),
"#D1CEFF",
"无"
);
drawEquip(
- EQUIP_BLOCK_LEFT_VERTICAL + 45 * 3,
- EQUIP_BLOCK_TOP_VERTICAL + 90 * 3,
+ EQUIP_BLOCK_LEFT_VERTICAL + 45,
+ EQUIP_BLOCK_TOP_VERTICAL + 90,
core.getEquip(5),
"#D1CEFF",
"无"
@@ -3392,8 +3439,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
EQUIP_BLOCK_LEFT,
EQUIP_BLOCK_TOP,
- 130 * 3,
- 95 * 3
+ 130,
+ 95
);
drawEquip(
EQUIP_BLOCK_LEFT,
@@ -3403,14 +3450,14 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"无"
);
drawEquip(
- EQUIP_BLOCK_LEFT + 42 * 3,
+ EQUIP_BLOCK_LEFT + 42,
EQUIP_BLOCK_TOP,
core.getEquip(1),
"#D1CEFF",
"无"
);
drawEquip(
- EQUIP_BLOCK_LEFT + 85 * 3,
+ EQUIP_BLOCK_LEFT + 85,
EQUIP_BLOCK_TOP,
core.getEquip(2),
"#D1CEFF",
@@ -3418,21 +3465,21 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
);
drawEquip(
EQUIP_BLOCK_LEFT,
- EQUIP_BLOCK_TOP + 45 * 3,
+ EQUIP_BLOCK_TOP + 45,
core.getEquip(3),
"#D1CEFF",
"无"
);
drawEquip(
- EQUIP_BLOCK_LEFT + 42 * 3,
- EQUIP_BLOCK_TOP + 45 * 3,
+ EQUIP_BLOCK_LEFT + 42,
+ EQUIP_BLOCK_TOP + 45,
core.getEquip(4),
"#D1CEFF",
"无"
);
drawEquip(
- EQUIP_BLOCK_LEFT + 85 * 3,
- EQUIP_BLOCK_TOP + 45 * 3,
+ EQUIP_BLOCK_LEFT + 85,
+ EQUIP_BLOCK_TOP + 45,
core.getEquip(5),
"#D1CEFF",
"无"
@@ -3451,7 +3498,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let dn = 3;
for (let i = 0; i <= dn; i++) {
- let delta = i * 32 * 3;
+ let delta = i * 33;
if (core.domStyle.isVertical) {
this.drawKey(keyList[i], baseX, baseY + delta);
@@ -3459,14 +3506,14 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
this.drawKey(keyList[i], baseX + delta, baseY);
}
- core.setFont("outerUI", "bold 48px Verdana");
+ core.setFont("outerUI", "bold 16px Verdana");
core.setTextAlign("outerUI", "left");
if (core.domStyle.isVertical) {
core.fillText(
"outerUI",
todraw[i],
- baseX + 20 * 3,
- baseY + 14 * 3 + delta,
+ baseX + 20,
+ baseY + 14 + delta,
TEXT_COLOR
);
} else {
@@ -3474,7 +3521,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
todraw[i],
baseX + delta,
- baseY + 32 * 3,
+ baseY + 32,
TEXT_COLOR
);
}
@@ -3485,22 +3532,22 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
KEY_BLOCK_LEFT_VERTICAL,
KEY_BLOCK_TOP_VERTICAL,
- 45 * 3,
- 130 * 3
+ 45,
+ 130
);
drawKeyList(
- KEY_BLOCK_LEFT_VERTICAL + 3 * 3,
- KEY_BLOCK_TOP_VERTICAL + 5 * 3
+ KEY_BLOCK_LEFT_VERTICAL + 3,
+ KEY_BLOCK_TOP_VERTICAL + 5
);
} else {
core.clearMap(
"outerUI",
KEY_BLOCK_LEFT,
KEY_BLOCK_TOP,
- 130 * 3,
- 45 * 3
+ 130,
+ 45
);
- drawKeyList(KEY_BLOCK_LEFT + 10 * 3, KEY_BLOCK_TOP);
+ drawKeyList(KEY_BLOCK_LEFT + 10, KEY_BLOCK_TOP);
}
}
drawKey(key, x, y) {
@@ -3520,8 +3567,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
26,
x,
y,
- 13 * 3,
- 26 * 3
+ 13,
+ 26
);
}
_update_infoWindow() {
@@ -3536,8 +3583,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
INFO_BLOCK_LEFT_VERTICAL,
INFO_BLOCK_TOP_VERTICAL,
- 300 * 3,
- 120 * 3
+ 300,
+ 120
);
if (this.selectedItem) {
@@ -3546,8 +3593,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillText(
"outerUI",
core.material.items[itemId].name,
- INFO_BLOCK_LEFT_VERTICAL + 50 * 3,
- INFO_BLOCK_TOP_VERTICAL + 27 * 3,
+ INFO_BLOCK_LEFT_VERTICAL + 50,
+ INFO_BLOCK_TOP_VERTICAL + 27,
"#D1CEFF"
);
core.drawImage(
@@ -3557,17 +3604,17 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
32 * icon,
32,
32,
- INFO_BLOCK_LEFT_VERTICAL + 10 * 3,
- INFO_BLOCK_TOP_VERTICAL + 8 * 3,
- 32 * 3,
- 32 * 3
+ INFO_BLOCK_LEFT_VERTICAL + 10,
+ INFO_BLOCK_TOP_VERTICAL + 8,
+ 32,
+ 32
);
core.ui.drawTextContent("outerUI", text, {
- left: INFO_BLOCK_LEFT_VERTICAL + 10 * 3,
- top: INFO_BLOCK_TOP_VERTICAL + 40 * 3,
- maxWidth: 275 * 3,
+ left: INFO_BLOCK_LEFT_VERTICAL + 10,
+ top: INFO_BLOCK_TOP_VERTICAL + 40,
+ maxWidth: 92,
color: "#D1CEFF",
- fontSize: 24,
+ fontSize: 8,
});
}
} else {
@@ -3575,18 +3622,18 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
INFO_BLOCK_LEFT,
INFO_BLOCK_TOP,
- 115 * 3,
- 230 * 3
+ 115,
+ 230
);
- core.setFont("outerUI", "bold 36px Verdana")
+ core.setFont("outerUI", "bold 12px Verdana")
if (this.selectedItem) {
const icon = core.material.icons.items[itemId];
core.setTextAlign("outerUI", "center");
core.fillText(
"outerUI",
core.material.items[itemId].name,
- INFO_BLOCK_LEFT + 60 * 3,
- INFO_BLOCK_TOP + 25 * 3,
+ INFO_BLOCK_LEFT + 60,
+ INFO_BLOCK_TOP + 25,
"#D1CEFF"
);
core.drawImage(
@@ -3596,17 +3643,17 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
32 * icon,
32,
32,
- INFO_BLOCK_LEFT + 45 * 3,
- INFO_BLOCK_TOP + 30 * 3,
- 32 * 3,
- 32 * 3
+ INFO_BLOCK_LEFT + 45,
+ INFO_BLOCK_TOP + 30,
+ 32,
+ 32
);
core.ui.drawTextContent("outerUI", text, {
- left: INFO_BLOCK_LEFT + 10 * 3,
- top: INFO_BLOCK_TOP + 60 * 3,
- maxWidth: 105 * 3,
+ left: INFO_BLOCK_LEFT + 10,
+ top: INFO_BLOCK_TOP + 60,
+ maxWidth: 105,
color: "#D1CEFF",
- fontSize: 24,
+ fontSize: 8,
});
}
}
@@ -3634,8 +3681,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
TOOL_BOX_LEFT_VERTICAL,
TOOL_BOX_TOP_VERTICAL,
- 115,
- 130
+ 38,
+ 43
);
for (let i = 0; i < tools.length; i++) {
@@ -3643,10 +3690,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawIcon(
"outerUI",
tools[i][j],
- TOOL_BOX_LEFT_VERTICAL + i * 31 * 3,
- TOOL_BOX_TOP_VERTICAL + j * 31 * 3,
- 30 * 3,
- 30 * 3
+ TOOL_BOX_LEFT_VERTICAL + i * 31,
+ TOOL_BOX_TOP_VERTICAL + j * 31,
+ 30,
+ 30
);
}
}
@@ -3655,8 +3702,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
TOOL_BOX_LEFT,
TOOL_BOX_TOP,
- 130 * 3,
- 80 * 3
+ 130,
+ 80
);
for (let i = 0; i < tools.length; i++) {
@@ -3664,10 +3711,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawIcon(
"outerUI",
tools[i][j],
- TOOL_BOX_LEFT + j * 31 * 3,
- TOOL_BOX_TOP + i * 31 * 3,
- 30 * 3,
- 30 * 3
+ TOOL_BOX_LEFT + j * 31,
+ TOOL_BOX_TOP + i * 31,
+ 30,
+ 30
);
}
}
@@ -3696,6 +3743,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
case "book":
core.openBook(true);
break;
+ case "fly":
+ core.useFly(true);
+ break;
default:
core.useItem(itemId);
}
@@ -3714,12 +3764,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (core.domStyle.isVertical) {
const itemBox = makeBox(
[ITEM_BOX_LEFT_VERTICAL, ITEM_BOX_TOP_VERTICAL],
- [30 * 6 * 3, 31 * 4 * 3]
+ [30 * 6, 31 * 4]
);
if (inRect(pos, itemBox)) {
const [gx, gy] = gridify(relativeTo(pos, itemBox[0]), [
- 30 * 3,
- 31 * 3,
+ 30,
+ 31,
]);
const itemId = this.itemMx[gx][gy];
if (
@@ -3739,17 +3789,18 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
const toolBox = makeBox(
[TOOL_BOX_LEFT_VERTICAL, TOOL_BOX_TOP_VERTICAL],
- [31 * 2 * 3, 31 * 4 * 3]
+ [31 * 2, 31 * 4]
);
if (inRect(pos, toolBox)) {
const [col, row] = gridify(relativeTo(pos, toolBox[0]), [
- 31 * 3,
- 31 * 3,
+ 31,
+ 31,
]);
- if (core.status.lockControl || core.isMoving()) return;
+
if (core.isReplaying()) {
this.replayAction[col][row].call(core);
} else if (core.isPlaying()) {
+ if (core.status.lockControl || core.isMoving()) return;
if (col === 0 && row === 3) {
core.doSL("autoSave", "load");
} else if (col === 1 && row === 3) {
@@ -3762,7 +3813,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
const mapBox = makeBox(
[MAP_BLOCK_LEFT_VERTICAL, MAP_BLOCK_TOP_VERTICAL],
- [350, 350]
+ [117, 117]
);
if (inRect(pos, mapBox)) {
if (
@@ -3771,7 +3822,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.isMoving()
)
return;
- core.useItem("fly");
+ core.useFly(true);
return;
}
/*const equipBox = makeBox([EQUIP_BLOCK_LEFT_VERTICAL, EQUIP_BLOCK_TOP_VERTICAL], [90 * 3, 130 * 3])
@@ -3781,7 +3832,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
return;
}*/
} else {
- const mapBox = makeBox([MAP_BLOCK_LEFT, MAP_BLOCK_TOP], [350, 350]);
+ const mapBox = makeBox([MAP_BLOCK_LEFT, MAP_BLOCK_TOP], [117, 117]);
if (inRect(pos, mapBox)) {
if (
core.isReplaying() ||
@@ -3789,7 +3840,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.isMoving()
)
return;
- core.useItem("fly");
+ core.useFly(true);
return;
}
/*
@@ -3801,12 +3852,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}*/
const itemBox = makeBox(
[ITEM_BOX_LEFT, ITEM_BOX_TOP],
- [31 * 4 * 3, 30 * 6 * 3]
+ [31 * 4, 30 * 6]
);
if (inRect(pos, itemBox)) {
const [gx, gy] = gridify(relativeTo(pos, itemBox[0]), [
- 31 * 3,
- 30 * 3,
+ 31,
+ 30,
]);
const itemId = this.itemMx[gy][gx];
if (
@@ -3826,17 +3877,18 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
const toolBox = makeBox(
[TOOL_BOX_LEFT, TOOL_BOX_TOP],
- [31 * 4 * 3, 31 * 2 * 3]
+ [31 * 4, 31 * 2]
);
if (inRect(pos, toolBox)) {
const [row, col] = gridify(relativeTo(pos, toolBox[0]), [
- 31 * 3,
- 31 * 3,
+ 31,
+ 31,
]);
- if (core.status.lockControl || core.isMoving()) return;
+
if (core.isReplaying()) {
this.replayAction[col][row].call(core);
} else if (core.isPlaying()) {
+ if (core.status.lockControl || core.isMoving()) return;
if (col === 0 && row === 3) {
core.doSL("autoSave", "load");
} else if (col === 1 && row === 3) {
@@ -3949,54 +4001,60 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
number,
x,
y,
- floorId
+ floorId,
+ config = {}
) {
var mon_hp = info.mon_hp,
- hero_atk = core.status.hero.atk,
+ hero_atk = config.atk ?? core.status.hero.atk,
mon_def = info.mon_def,
- pre = info.damage;
+ damage=info.damage
+ pre = info.mon_turn;
var list = [];
var start_atk = hero_atk;
if (info.__over__) {
start_atk += info.__overAtk__;
list.push([info.__overAtk__, -info.damage]);
}
+ var start = core.clone(config)
+ var mid = core.clone(config)
+ var end = core.clone(config)
var calNext = function (currAtk, maxAtk) {
- var start = Math.floor(currAtk),
- end = Math.floor(maxAtk);
- if (start > end) return null;
+ start.atk = Math.floor(currAtk)
+ end.atk = Math.floor(maxAtk);
+ if (start.atk > end.atk) return null;
- while (start < end) {
- var mid = Math.floor((start + end) / 2);
- if (mid - start > end - mid) mid--;
+ while (start.atk < end.atk) {
+ mid.atk = Math.floor((start.atk + end.atk) / 2);
+ if (mid.atk - start.atk > end.atk - mid.atk) mid.atk--;
var nextInfo = core.enemys.getDamageInfo(
- enemy, { atk: mid },
+ enemy, mid,
x,
y,
floorId
);
if (nextInfo == null || typeof nextInfo == "number") return null;
- if (pre > nextInfo.damage) end = mid;
- else start = mid + 1;
+ if (pre > nextInfo.mon_turn&&damage>nextInfo.damage) end.atk = mid.atk;
+ else start.atk = mid.atk + 1;
}
var nextInfo = core.enemys.getDamageInfo(
- enemy, { atk: start },
+ enemy, start,
x,
y,
floorId
);
return nextInfo == null ||
typeof nextInfo == "number" ||
- nextInfo.damage >= pre ?
- null : [start, nextInfo.damage];
+ nextInfo.mon_turn >= pre ||nextInfo.damage>=damage?
+ null : [start.atk, nextInfo.damage, nextInfo.mon_turn];
};
var currAtk = start_atk;
while (true) {
- var next = calNext(currAtk + 1, Number.MAX_SAFE_INTEGER, pre);
+ var next = calNext(currAtk + 1, Number.MAX_SAFE_INTEGER,damage, pre);
if (next == null) break;
currAtk = next[0];
- pre = next[1];
- list.push([currAtk - hero_atk, info.damage - pre]);
+ damage=next[1];
+ pre = next[2];
+ list.push([currAtk - hero_atk, info.damage - damage]);
if (pre <= 0 && !core.flags.enableNegativeDamage) break;
if (list.length >= number) break;
}
@@ -4031,110 +4089,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
);
}
};
- events.prototype.openBook = function (fromUserAction) {
- if (core.isReplaying()) return;
- // 如果能恢复事件(从callBook事件触发)
- if (
- core.status.event.id == "book" &&
- core.events.recoverEvents(core.status.event.interval)
- )
- return;
- // 当前是book,且从“浏览地图”打开
- if (core.status.event.id == "book" && core.status.event.ui) {
- core.status.boxAnimateObjs = [];
- core.ui._drawViewMaps(core.status.event.ui);
- return;
- }
- // 从“浏览地图”页面打开
- if (core.status.event.id == "viewMaps" || core.status.event.id == "fly") {
- fromUserAction = false;
- core.status.event.ui = core.status.event.data;
- }
- if (!this._checkStatus("book", fromUserAction, true)) return;
- core.playSound("打开界面");
- core.useItem("book", true);
- };
- ////// 怪物手册界面时,放开某个键的操作 //////
- core.actions._keyUpBook = function (keycode) {
- if (keycode == 27 || keycode == 88) {
- core.playSound("取消");
- if (core.events.recoverEvents(core.status.event.interval)) {
- return;
- } else if (core.status.event.ui != null) {
- core.status.boxAnimateObjs = [];
- if (typeof core.status.event.ui === "number") {
- core.status.event.id = "fly";
- core.ui.drawFly(core.status.event.ui);
- } else {
- core.ui._drawViewMaps(core.status.event.ui);
- }
- } else core.ui.closePanel();
- return;
- }
- if (keycode == 13 || keycode == 32 || keycode == 67) {
- var data = core.status.event.data;
- if (data != null) {
- core.ui._drawBookDetail(data);
- }
- return;
- }
- };
- ////// 怪物手册界面的点击操作 //////
- actions.prototype._clickBook = function (x, y) {
- var pageinfo = core.ui._drawBook_pageinfo();
- // 上一页
- if (
- (x == this._HX_ - 2 || x == this._HX_ - 3) &&
- y === core._HEIGHT_ - 1
- ) {
- core.playSound("光标移动");
- core.ui.drawBook(core.status.event.data - pageinfo.per_page);
- return;
- }
- // 下一页
- if (
- (x == this._HX_ + 2 || x == this._HX_ + 3) &&
- y === core._HEIGHT_ - 1
- ) {
- core.playSound("光标移动");
- core.ui.drawBook(core.status.event.data + pageinfo.per_page);
- return;
- }
- // 返回
- if (x >= this.LAST - 2 && y === core._HEIGHT_ - 1) {
- core.playSound("取消");
- if (core.events.recoverEvents(core.status.event.interval)) {
- return;
- } else if (core.status.event.ui != null) {
- core.status.boxAnimateObjs = [];
- if (typeof core.status.event.ui === "number") {
- core.status.event.id = "fly";
- core.ui.drawFly(core.status.event.ui);
- } else {
- core.ui._drawViewMaps(core.status.event.ui);
- }
- } else core.ui.closePanel();
- return;
- }
- // 怪物信息
- var data = core.status.event.data;
- if (data != null && y < core._HEIGHT_ - 1) {
- var per_page = pageinfo.per_page,
- page = parseInt(data / per_page);
- var u = (core._HEIGHT_ - 1) / per_page;
- for (var i = 0; i < per_page; ++i) {
- if (y >= u * i && y < u * (i + 1)) {
- var index = per_page * page + i;
- core.ui.drawBook(index);
- core.ui._drawBookDetail(index);
- break;
- }
- }
- return;
- }
- return;
- };
-
////// 执行当前自定义事件列表中的下一个事件 //////
events.prototype.doAction = function () {
// 清空boxAnimate和UI层
@@ -4203,221 +4157,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
ctx.strokeText(text, x, y);
ctx.fillStyle = style;
ctx.fillText(text, x, y);
- };
- ////// 绘制 WindowSkin
- ui.prototype.drawWindowSkin = function (
- background,
- ctx,
- x,
- y,
- w,
- h,
- direction,
- px,
- py,
- size = 1
- ) {
- background = background || core.status.textAttribute.background;
+ }
- // 仿RM窗口皮肤 ↓
- // 绘制背景
- core.drawImage(
- ctx,
- background,
- 0,
- 0,
- 128,
- 128,
- x + 2 * size,
- y + 2 * size,
- w - 4 * size,
- h - 4 * size
- );
- // 绘制边框
- // 上方
- core.drawImage(
- ctx,
- background,
- 128,
- 0,
- 16,
- 16,
- x,
- y,
- 16 * size,
- 16 * size
- );
- for (var dx = 0; dx < w - 64 * size; dx += 32 * size) {
- core.drawImage(
- ctx,
- background,
- 144,
- 0,
- 32,
- 16,
- x + dx + 16 * size,
- y,
- 32 * size,
- 16 * size
- );
- core.drawImage(
- ctx,
- background,
- 144,
- 48,
- 32,
- 16,
- x + dx + 16 * size,
- y + h - 16 * size,
- 32 * size,
- 16 * size
- );
- }
- core.drawImage(
- ctx,
- background,
- 144,
- 0,
- (w - dx - 32 * size) / size,
- 16,
- x + dx + 16 * size,
- y,
- w - dx - 32 * size,
- 16 * size
- );
- core.drawImage(
- ctx,
- background,
- 144,
- 48,
- (w - dx - 32 * size) / size,
- 16,
- x + dx + 16 * size,
- y + h - 16 * size,
- w - dx - 32 * size,
- 16 * size
- );
- core.drawImage(
- ctx,
- background,
- 176,
- 0,
- 16,
- 16,
- x + w - 16 * size,
- y,
- 16 * size,
- 16 * size
- );
- // 左右
- for (var dy = 0; dy < h - 64 * size; dy += 32 * size) {
- core.drawImage(
- ctx,
- background,
- 128,
- 16,
- 16,
- 32,
- x,
- y + dy + 16 * size,
- 16 * size,
- 32 * size
- );
- core.drawImage(
- ctx,
- background,
- 176,
- 16,
- 16,
- 32,
- x + w - 16 * size,
- y + dy + 16 * size,
- 16 * size,
- 32 * size
- );
- }
- core.drawImage(
- ctx,
- background,
- 128,
- 16,
- 16,
- (h - dy - 32 * size) / size,
- x,
- y + dy + 16 * size,
- 16 * size,
- h - dy - 32 * size
- );
- core.drawImage(
- ctx,
- background,
- 176,
- 16,
- 16,
- (h - dy - 32 * size) / size,
- x + w - 16 * size,
- y + dy + 16 * size,
- 16 * size,
- h - dy - 32 * size
- );
- //下方
- core.drawImage(
- ctx,
- background,
- 128,
- 48,
- 16,
- 16,
- x,
- y + h - 16 * size,
- 16 * size,
- 16 * size
- );
- core.drawImage(
- ctx,
- background,
- 176,
- 48,
- 16,
- 16,
- x + w - 16 * size,
- y + h - 16 * size,
- 16 * size,
- 16 * size
- );
-
- // arrow
- if (px != null && py != null) {
- if (direction == "up") {
- core.drawImage(
- ctx,
- background,
- 128,
- 96,
- 32,
- 32,
- px,
- y + h - 3 * size,
- 32 * size,
- 32 * size
- );
- } else if (direction == "down") {
- core.drawImage(
- ctx,
- background,
- 160,
- 96,
- 32,
- 32,
- px,
- y - 29 * size,
- 32 * size,
- 32 * size
- );
- }
- }
- // 仿RM窗口皮肤 ↑
- };
events.prototype.battle = function (id, x, y, force, callback) {
core.saveAndStopAutomaticRoute();
id = id || core.getBlockId(x, y);
@@ -4587,6 +4328,78 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
const floor = Math.floor
Math.floor = (a) => floor(a + 1e-8)
+ ui.prototype._drawTip_drawOne = function (tip, k) {
+ core.setAlpha('data', tip.opacity);
+ core.fillRect('data', 5, 5 + 42 * k, tip.width, 42, '#000000');
+ if (tip.image)
+ core.drawImage('data', tip.image, (tip.posX + tip.frame) * 32, tip.posY * tip.height, 32, 32, 10, 10 + 42 * k, 32, 32);
+ core.fillText('data', tip.text, tip.textX, 33 + 42 * k, '#FFFFFF');
+ core.setAlpha('data', 1);
+ }
+ let time = 0
+ control.prototype._animateFrame_tip = function (timestamp) {
+ let delta
+ core.animateFrame.tip ??= []
+ if (core.animateFrame.tip.length === 0) return;
+
+ if (timestamp - time <= 30) return;
+ delta = timestamp - time;
+ time = timestamp;
+
+
+
+ core.setFont("data", "16px Arial");
+ core.setTextAlign("data", "left");
+ core.clearMap("data", 0, 0, core._PX_, core._PX_);
+ core.animateFrame.tip.forEach((v, k) => {
+ core.ui._drawTip_drawOne(v, k);
+ if (v.stage == 1) {
+ v.opacity += 0.05;
+ if (v.opacity >= 0.6) {
+ v.stage = 2;
+ v.displayTime = 0;
+ }
+ } else if (v.stage == 2) {
+ v.displayTime += delta;
+ if (v.displayTime >= 1000) v.stage = 3;
+ } else v.opacity -= 0.05;
+
+ })
+ core.animateFrame.tip = core.animateFrame.tip.filter(v => v.opacity > 0)
+ };
+ core.registerAnimationFrame("tip", true, core.control._animateFrame_tip)
+ ui.prototype.drawTip = function (text, id, frame) {
+ text = core.replaceText(text) || "";
+ var realText = this._getRealContent(text);
+ var one = {
+ text: text,
+ textX: 21,
+ width: 26 + core.calWidth('data', realText, "16px Arial"),
+ opacity: 0.1,
+ stage: 1,
+ frame: frame || 0,
+ time: 0
+ };
+ if (id != null) {
+ var info = core.getBlockInfo(id);
+ if (info == null || !info.image || info.bigImage) {
+ // 检查状态栏图标
+ if (core.statusBar.icons[id] instanceof Image) {
+ info = { image: core.statusBar.icons[id], posX: 0, posY: 0, height: 32 };
+ } else info = null;
+ }
+ if (info != null) {
+ one.image = info.image;
+ one.posX = info.posX;
+ one.posY = info.posY;
+ one.height = info.height;
+ one.textX += 24;
+ one.width += 24;
+ }
+ }
+ core.animateFrame.tip.push(one)
+ if (core.animateFrame.tip.length > 4) core.animateFrame.tip.shift()
+ }
},
"额外信息": function () {
/* 宝石血瓶左下角显示数值
@@ -4756,7 +4569,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
24, // 字体大小
"宋体",//字体
'#FF0000', // 字体颜色
- '#000000', // 描边颜色
0.5, // 水平速度 (speedX)
-10, // 垂直速度 (speedY)
0.5, // 重力 (gravity)
@@ -4792,7 +4604,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
fontSize,
font,
fontColor,
- outlineColor,
speedX,
speedY,
gravity,
@@ -4807,7 +4618,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
fontSize,
font,
fontColor,
- outlineColor,
speedX,
speedY,
gravity,
@@ -4831,7 +4641,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
16, // 默认字体大小
"Arial", //默认字体
null, // 默认颜色
- null, // 默认描边颜色
null, // 默认水平速度
null, // 默认垂直速度
null, // 默认重力
@@ -4856,7 +4665,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
fontSize,
font,
fontColor,
- outlineColor,
speedX,
speedY,
gravity,
@@ -4882,7 +4690,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
fontSize,
font,
fontColor,
- outlineColor,
speedX,
speedY,
gravity,
@@ -4895,7 +4702,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
this._fontSize = fontSize ?? 16; // 默认字体大小
this._font = font ?? "Arial";
this._fontColor = fontColor ?? (damage > 0 ? "#22FF44" : "lightcoral"); // 默认颜色
- this._outlineColor = outlineColor ?? "#FFFFFF"; // 默认描边颜色
this._speedX = speedX ?? -1 + Math.random() * 2; // 水平速度,默认随机
this._speedY = speedY ?? -3 - Math.random() * 4; // 垂直速度,默认随机
this._gravity = gravity ?? 0.3; // 重力加速度,默认 0.3
@@ -4937,8 +4743,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
var canvas = core.getContextByName(this._symbol);
canvas.font = this._fontSize + "px " + this._font; // 动态设置字体大小
canvas.fillStyle = this._fontColor; // 动态设置字体颜色
- canvas.strokeStyle = this._outlineColor; // 动态设置描边颜色
- canvas.strokeText(this._text, 2, this._height);
canvas.fillText(this._text, 2, this._height);
};
@@ -5329,7 +5133,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
var enemyInfo = this.getEnemyInfo(enemy, null, null, null, floorId);
var locEnemyInfo = this.getEnemyInfo(enemy, null, x, y, floorId);
- if (
+ /*if (
!core.flags.enableEnemyPoint ||
(locEnemyInfo.atk == enemyInfo.atk &&
locEnemyInfo.def == enemyInfo.def &&
@@ -5338,24 +5142,24 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
) {
x = null;
y = null;
- } else {
- // 检查enemys里面是否使用了存在的内容
- for (var i = 0; i < enemys.length; ++i) {
- var one = enemys[i];
- if (
- id == one.id &&
- one.locs != null &&
- locEnemyInfo.atk == one.atk &&
- locEnemyInfo.def == one.def &&
- locEnemyInfo.hp == one.hp &&
- core.plugin.arrsame(locEnemyInfo.special, one.special)
- ) {
- one.locs.push([x, y]);
- return;
- }
+ } else {*/
+ // 检查enemys里面是否使用了存在的内容
+ for (var i = 0; i < enemys.length; ++i) {
+ var one = enemys[i];
+ if (
+ id == one.id &&
+ one.locs != null &&
+ locEnemyInfo.atk == one.atk &&
+ locEnemyInfo.def == one.def &&
+ locEnemyInfo.hp == one.hp &&
+ core.plugin.arrsame(locEnemyInfo.special, one.special)
+ ) {
+ one.locs.push([x, y]);
+ return;
}
- enemyInfo = locEnemyInfo;
}
+ enemyInfo = locEnemyInfo;
+ // }
var id = enemy.id + ":" + x + ":" + y;
if (used[id]) return;
@@ -5677,18 +5481,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (nowDamage == null || nextDamage == null) return "???";
return nowDamage - nextDamage;
};
- //防御倍数
- enemys.prototype._getCurrentEnemys_addEnemy_defDamage = function (
- enemy,
- x,
- y,
- floorId
- ) {
- var ratio = core.status.maps[floorId || core.status.floorId].ratio || 1;
- //第一行为按照ratio值计算减防,第二行为1防减伤
- //return this.getDefDamage(enemy, ratio, x, y, floorId);
- return this.getDefDamage(enemy, null, x, y, floorId);
- };
+
},
"新道具栏/装备栏": function () {
// 这个插件有点离谱 个人觉得参数过多只会降低可读性,还不如硬编码
@@ -6744,10 +6537,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillText(ctx, text, x + r, y + lineWidth / 2 + 2, style, font);
var todo = function () {
- //debugger;
var id = getSelectedItem();
+ if (!id) return
let hideInfo = core.getFlag("hideInfo", {});
- console.log(id);
if (hideInfo.hasOwnProperty(id)) {
hideInfo[id] = !hideInfo[id];
core.setFlag("hideInfo", hideInfo);
@@ -8168,879 +7960,880 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.registerReplayAction("skill", control.prototype._replayAction_skill);
},
"animate": function () {
- // -------------------- 插件说明 -------------------- //
+ // -------------------- 插件说明 -------------------- //
- // github仓库:https://github.com/unanmed/animate
- // npm包名:mutate-animate
- // npm地址:https://www.npmjs.com/package/mutate-animate
+ // github仓库:https://github.com/unanmed/animate
+ // npm包名:mutate-animate
+ // npm地址:https://www.npmjs.com/package/mutate-animate
- // 不要去尝试读这个插件,这个插件是经过了打包的,不是人类可读的(
- // 想读的话可以去github读
+ // 不要去尝试读这个插件,这个插件是经过了打包的,不是人类可读的(
+ // 想读的话可以去github读
- // 该插件是一个轻量型多功能动画插件,可以允许你使用内置或自定义的速率曲线或轨迹等
- // 除此之外,你还可以自定义绘制函数,来让你的动画可视化
+ // 该插件是一个轻量型多功能动画插件,可以允许你使用内置或自定义的速率曲线或轨迹等
+ // 除此之外,你还可以自定义绘制函数,来让你的动画可视化
- // -------------------- 安装说明 -------------------- //
+ // -------------------- 安装说明 -------------------- //
- // 直接复制到插件中即可,注意所有插件中不能出现插件名为animate的插件
- // 该插件分为动画和渐变两部分,教程分开,动画在前,渐变在后
+ // 直接复制到插件中即可,注意所有插件中不能出现插件名为animate的插件
+ // 该插件分为动画和渐变两部分,教程分开,动画在前,渐变在后
- // -------------------- 动画使用教程 -------------------- //
+ // -------------------- 动画使用教程 -------------------- //
- // 1. 首先创建一个异步函数
- // async function ani() { }
+ // 1. 首先创建一个异步函数
+ // async function ani() { }
- // 2. 引入插件中的类和函数,引入内容要看个人需求,所有可用的函数在本插件末尾可以看到
- // const { Animation, linear, bezier, circle, hyper, trigo, power, inverseTrigo, shake, sleep } = core.plugin.animate
+ // 2. 引入插件中的类和函数,引入内容要看个人需求,所有可用的函数在本插件末尾可以看到
+ // const { Animation, linear, bezier, circle, hyper, trigo, power, inverseTrigo, shake, sleep } = core.plugin.animate
- // 3. 在函数内部创建一个动画
- // const animate = new Animation();
+ // 3. 在函数内部创建一个动画
+ // const animate = new Animation();
- // 4. 为动画创建一个绘制函数,这里以绘制一个矩形为例,当然也可以使用core.fillRect替代ctx.fillRect来绘制矩形
- // const ctx = core.createCanvas('animate', 0, 0, 416, 416, 100);
- // ctx.save();
- // const fn = () => {
- // ctx.restore();
- // ctx.save();
- // ctx.clearRect(0, 0, 800, 800);
- // ctx.translate(animate.x, animate.y);
- // ctx.rotate(animate.angle * Math.PI / 180);
- // const size = animate.size;
- // ctx.fillRect(-30 * size, -30 * size, 60 * size, 60 * size);
- // }
- // animate.ticker.add(fn);
+ // 4. 为动画创建一个绘制函数,这里以绘制一个矩形为例,当然也可以使用core.fillRect替代ctx.fillRect来绘制矩形
+ // const ctx = core.createCanvas('animate', 0, 0, 416, 416, 100);
+ // ctx.save();
+ // const fn = () => {
+ // ctx.restore();
+ // ctx.save();
+ // ctx.clearRect(0, 0, 800, 800);
+ // ctx.translate(animate.x, animate.y);
+ // ctx.rotate(animate.angle * Math.PI / 180);
+ // const size = animate.size;
+ // ctx.fillRect(-30 * size, -30 * size, 60 * size, 60 * size);
+ // }
+ // animate.ticker.add(fn);
- // 5. 执行动画
+ // 5. 执行动画
- // 下面先对一些概念进行解释
+ // 下面先对一些概念进行解释
- // 动画分为很多种,内置的有move(移动至某一点) rotate(旋转) scale(放缩) moveAs(以指定路径移动) shake(震动)
- // 对于不同的动画种类,其所对应的属性也不同,move moveAs shake均对应x和y这两个属性
- // rotate对应angle,scale对应size。你也可以自定义属性,这个之后会提到
+ // 动画分为很多种,内置的有move(移动至某一点) rotate(旋转) scale(放缩) moveAs(以指定路径移动) shake(震动)
+ // 对于不同的动画种类,其所对应的属性也不同,move moveAs shake均对应x和y这两个属性
+ // rotate对应angle,scale对应size。你也可以自定义属性,这个之后会提到
- // 除了执行动画之外,这里还提供了三个等待函数,可以等待某个动画执行完毕,以及一个等待指定时长的函数
- // 分别是animate.n(等待指定数量的动画执行完毕)
- // animate.w(等待指定类型的动画执行完毕,也可以是自定义类型)
- // animate.all(等待所有动画执行完毕)
- // sleep(等待指定时长)
+ // 除了执行动画之外,这里还提供了三个等待函数,可以等待某个动画执行完毕,以及一个等待指定时长的函数
+ // 分别是animate.n(等待指定数量的动画执行完毕)
+ // animate.w(等待指定类型的动画执行完毕,也可以是自定义类型)
+ // animate.all(等待所有动画执行完毕)
+ // sleep(等待指定时长)
- // 执行动画时,要求一个渐变函数,当然这个插件内置了非常丰富的渐变函数,也就是速率曲线。
+ // 执行动画时,要求一个渐变函数,当然这个插件内置了非常丰富的渐变函数,也就是速率曲线。
- // 线性渐变函数 linear(),该函数返回一个线性变化函数
+ // 线性渐变函数 linear(),该函数返回一个线性变化函数
- // 三角渐变函数 trigo('sin' | 'sec', EaseMode),该函数返回一个指定属性的三角函数变化函数
- // 其中EaseMode可以填'in' 'out' 'in-out' 'center'
- // 分别表示 慢-快 快-慢 慢-快-慢 快-慢-快
+ // 三角渐变函数 trigo('sin' | 'sec', EaseMode),该函数返回一个指定属性的三角函数变化函数
+ // 其中EaseMode可以填'in' 'out' 'in-out' 'center'
+ // 分别表示 慢-快 快-慢 慢-快-慢 快-慢-快
- // 幂函数渐变 power(n, EaseMode),该函数返回一个以x^n变化的函数,n是指数
+ // 幂函数渐变 power(n, EaseMode),该函数返回一个以x^n变化的函数,n是指数
- // 双曲渐变函数 hyper('sin' | 'tan' | 'sec', EaseMode),该函数返回一个双曲函数,分别是双曲正弦、双曲正切、双曲正割
+ // 双曲渐变函数 hyper('sin' | 'tan' | 'sec', EaseMode),该函数返回一个双曲函数,分别是双曲正弦、双曲正切、双曲正割
- // 反三角渐变函数 inverseTrigo('sin' | 'tan', EaseMode),该函数返回一个反三角函数
+ // 反三角渐变函数 inverseTrigo('sin' | 'tan', EaseMode),该函数返回一个反三角函数
- // 贝塞尔曲线渐变函数 bezier(...cps),参数为贝塞尔曲线的控制点纵坐标(横坐标不能自定义,毕竟一个时刻不能对应多个速率)
- // 示例:bezier(0.4, 0.2, 0.7); // 三个控制点的四次贝塞尔曲线渐变函数
+ // 贝塞尔曲线渐变函数 bezier(...cps),参数为贝塞尔曲线的控制点纵坐标(横坐标不能自定义,毕竟一个时刻不能对应多个速率)
+ // 示例:bezier(0.4, 0.2, 0.7); // 三个控制点的四次贝塞尔曲线渐变函数
- // 了解完渐变函数以后,这里还有一个特殊的渐变函数-shake
- // shake(power, timing),这个函数是一个震荡函数,会让一个值来回变化,实现震动的效果
- // 其中power是震动的最大值,timing是渐变函数,描述了power在震动时大小的变化
+ // 了解完渐变函数以后,这里还有一个特殊的渐变函数-shake
+ // shake(power, timing),这个函数是一个震荡函数,会让一个值来回变化,实现震动的效果
+ // 其中power是震动的最大值,timing是渐变函数,描述了power在震动时大小的变化
- // 下面,我们就可以进行动画的执行了,我们以 运动 + 旋转 + 放缩为例
+ // 下面,我们就可以进行动画的执行了,我们以 运动 + 旋转 + 放缩为例
- // animate.mode(hyper('sin', 'out')) // 设置渐变函数为 双曲正弦 快 -> 慢,注意不能加分号
- // .time(1000) // 设置动画的执行时间为1000毫秒
- // .move(300, 300) // 移动至[300, 300]的位置
- // .relative() // 设置相对模式为相对之前,与之前为相加的关系
- // .mode(power(3, 'center')) // 设置为 x^3 快-慢-快 的渐变函数
- // .time(3000)
- // .rotate(720) // 旋转720度
- // .absolute() // 设置相对模式为绝对
- // .mode(trigo('sin', 'in')) // 设置渐变函数为 正弦 慢 -> 快
- // .time(1500)
- // .scale(3); // 放缩大小至3倍
+ // animate.mode(hyper('sin', 'out')) // 设置渐变函数为 双曲正弦 快 -> 慢,注意不能加分号
+ // .time(1000) // 设置动画的执行时间为1000毫秒
+ // .move(300, 300) // 移动至[300, 300]的位置
+ // .relative() // 设置相对模式为相对之前,与之前为相加的关系
+ // .mode(power(3, 'center')) // 设置为 x^3 快-慢-快 的渐变函数
+ // .time(3000)
+ // .rotate(720) // 旋转720度
+ // .absolute() // 设置相对模式为绝对
+ // .mode(trigo('sin', 'in')) // 设置渐变函数为 正弦 慢 -> 快
+ // .time(1500)
+ // .scale(3); // 放缩大小至3倍
- // 这样,我们就把三种基础动画都执行了一遍,同时,这种写法非常直观,出现问题时也可以很快地找到问题所在
- // 下面,我们需要等待动画执行完毕,因为同一种动画不可能同时执行两个
+ // 这样,我们就把三种基础动画都执行了一遍,同时,这种写法非常直观,出现问题时也可以很快地找到问题所在
+ // 下面,我们需要等待动画执行完毕,因为同一种动画不可能同时执行两个
- // await animate.n(1); // 等待任意一个动画执行完毕,别把await忘了
- // await animate.w('scale'); // 等待放缩动画执行完毕
- // await animate.all(); // 等待所有动画执行完毕
- // await sleep(1000); // 等待1000毫秒
+ // await animate.n(1); // 等待任意一个动画执行完毕,别把await忘了
+ // await animate.w('scale'); // 等待放缩动画执行完毕
+ // await animate.all(); // 等待所有动画执行完毕
+ // await sleep(1000); // 等待1000毫秒
- // 下面,还有一个特殊的动画函数-moveAs
- // 这是一个非常强大的函数,它允许你让你的物体按照指定路线运动
- // 说到这,我们需要先了解一下运动函数。
- // 该插件内置了两个运动函数,分别是圆形运动和贝塞尔曲线运动
+ // 下面,还有一个特殊的动画函数-moveAs
+ // 这是一个非常强大的函数,它允许你让你的物体按照指定路线运动
+ // 说到这,我们需要先了解一下运动函数。
+ // 该插件内置了两个运动函数,分别是圆形运动和贝塞尔曲线运动
- // 圆形运动 circle(r, n, timing, inverse),r是圆的半径,n是圈数,timing描述半径大小的变化,inverse说明了是否翻转timing函数,后面三个可以不填
+ // 圆形运动 circle(r, n, timing, inverse),r是圆的半径,n是圈数,timing描述半径大小的变化,inverse说明了是否翻转timing函数,后面三个可以不填
- // 贝塞尔曲线 bezierPath(start, end, ...cps)
- // 其中start和end是起点和结束点,应当填入[x, y]数组,cps是控制点,也是[x, y]数组
- // 示例:bezierPath([0, 0], [200, 200], [100, 50], [300, 150], [200, 180]);
- // 这是一个起点为 [0, 0],终点为[200, 200],有三个控制点的四次贝塞尔曲线
+ // 贝塞尔曲线 bezierPath(start, end, ...cps)
+ // 其中start和end是起点和结束点,应当填入[x, y]数组,cps是控制点,也是[x, y]数组
+ // 示例:bezierPath([0, 0], [200, 200], [100, 50], [300, 150], [200, 180]);
+ // 这是一个起点为 [0, 0],终点为[200, 200],有三个控制点的四次贝塞尔曲线
- // 下面,我们就可以使用路径函数了
+ // 下面,我们就可以使用路径函数了
- // animate.mode(hyper('sin', 'in-out')) // 设置渐变曲线
- // .time(5000)
- // .relative() // 设置为相对模式,这个比较必要,不然的话很可能出现瞬移
- // .moveAs(circle(100, 5, linear())) // 创建一个5圈的半径从0至100逐渐变大的圆轨迹(是个螺旋线)并让物体沿着它运动
- //
- // 最后,还有一个震动函数 shake(x, y),x和y表示了在横向上和纵向上的震动幅度,1表示为震动幅度的100%
- // 示例:
- // animate.mode(shake(5, hyper('sin', 'in')), true) // 这里第二个参数说明是震动函数
- // .time(2000)
- // .shake(1, 0.5)
+ // animate.mode(hyper('sin', 'in-out')) // 设置渐变曲线
+ // .time(5000)
+ // .relative() // 设置为相对模式,这个比较必要,不然的话很可能出现瞬移
+ // .moveAs(circle(100, 5, linear())) // 创建一个5圈的半径从0至100逐渐变大的圆轨迹(是个螺旋线)并让物体沿着它运动
+ //
+ // 最后,还有一个震动函数 shake(x, y),x和y表示了在横向上和纵向上的震动幅度,1表示为震动幅度的100%
+ // 示例:
+ // animate.mode(shake(5, hyper('sin', 'in')), true) // 这里第二个参数说明是震动函数
+ // .time(2000)
+ // .shake(1, 0.5)
- // 这样,所有内置动画就已经介绍完毕
+ // 这样,所有内置动画就已经介绍完毕
- // 6. 自定义动画属性
+ // 6. 自定义动画属性
- // 本插件允许你自定义一个动画属性,但功能可能不会像自带的属性那么强大
- // 你可以在创建动画之后使用animate.register(key, init)来注册一个自定义属性
- // 其中key是自定义属性的名称,init是自定义属性的初始值,这个值应当在0-1之间变化
+ // 本插件允许你自定义一个动画属性,但功能可能不会像自带的属性那么强大
+ // 你可以在创建动画之后使用animate.register(key, init)来注册一个自定义属性
+ // 其中key是自定义属性的名称,init是自定义属性的初始值,这个值应当在0-1之间变化
- // 你可以通过animate.value[key]来获取你注册的自定义属性
+ // 你可以通过animate.value[key]来获取你注册的自定义属性
- // 对于自定义属性的动画,你应当使用animate.apply(key, n, first)
- // 其中,key是你的自定义属性的名称,n是其目标值,first是一个布尔值,说明了是否将该动画插入到目前所有的动画之前,即每帧会优先执行该动画
+ // 对于自定义属性的动画,你应当使用animate.apply(key, n, first)
+ // 其中,key是你的自定义属性的名称,n是其目标值,first是一个布尔值,说明了是否将该动画插入到目前所有的动画之前,即每帧会优先执行该动画
- // 下面是一个不透明度的示例
+ // 下面是一个不透明度的示例
- // animate.register('opacity', 1); // 这句话应该放到刚创建动画之后
+ // animate.register('opacity', 1); // 这句话应该放到刚创建动画之后
- // ctx.globalAlpha = animate.value.opacity; // 这句话应当放到每帧绘制的函数里面,放在绘制之前
+ // ctx.globalAlpha = animate.value.opacity; // 这句话应当放到每帧绘制的函数里面,放在绘制之前
- // animate.mode(bezier(0.9, 0.1, 0.05)) // 设置渐变函数
- // .time(2000)
- // .absolute()
- // .apply('opacity', 0.3); // 将不透明度按照渐变曲线更改为0.3
+ // animate.mode(bezier(0.9, 0.1, 0.05)) // 设置渐变函数
+ // .time(2000)
+ // .absolute()
+ // .apply('opacity', 0.3); // 将不透明度按照渐变曲线更改为0.3
- // 7. 运行动画
+ // 7. 运行动画
- // 还记得刚开始定义的async function 吗,直接调用它就能执行动画了!
- // 示例:ani(); // 执行刚刚写的所有动画
-
- // 8. 自定义速率曲线和路径
-
- // 该插件中,速率曲线和路径均可自定义
-
- // 对于速率曲线,其类型为 (input: number) => number
- // 它接受一个范围在 0-1 的值,输出一个 0-1 的值,表示了动画的完成度,1表示动画已完成,0表示动画刚开始(当前大于1小于0也不会报错,也会执行相应的动画)
-
- // 对于路径,其类型为 (input: number) => [number, number]
- // 它与速率曲线类似,接收一个 0-1 的值,输出一个坐标数组
-
- // 9. 多个属性绑定
-
- // 该插件中,你可以绑定多个动画属性,你可以使用ani.bind(...attr)来绑定。
- // 绑定之后,这三个动画属性可以被一个返回了长度为3的数组的渐变函数执行。
- // 绑定使用ani.bind,设置渐变函数仍然使用ani.mode,注意它与单个动画属性是分开的,也就是它不会影响正常的渐变函数。
- // 然后使用ani.applyMulti即可执行动画
-
- // 例如:
- // // 自定义的一个三属性渐变函数
- // function b(input) {
- // return [input * 100, input ** 2 * 100, input ** 3 * 100];
- // }
- // ani.bind('a', 'b', 'c') // 这样会绑定abc这三个动画属性
- // .mode(b) // 自定义的一个返回了长度为3的数组的函数
- // .time(5000)
- // .absolute()
- // .applyMulti(); // 执行这个动画
-
- // 9. 监听 动画的生命周期钩子
-
- // 这个插件还允许你去监听动画的状态,可以监听动画的开始、结束、运行
- // 你可以使用 animate.listen(type, fn)来监听,fn的类型是 (a: Animation, type: string) => void
- // 当然,一般情况下你不会用到这个功能,插件中已经帮你包装了三个等待函数,他们就是以这些监听为基础的
-
- // 10. 自定义时间获取函数
-
- // 你可以修改ani.getTime来修改动画的时间获取函数,例如想让动画速度变成一半可以写ani.getTime = () => Date.now() / 2
- // 这样可以允许你随意控制动画的运行速度,暂停,甚至是倒退。该值默认为`Date.now`
-
- // -------------------- 渐变使用教程 -------------------- //
-
- // 相比于动画,渐变属于一种较为简便的动画,它可以让你在设置一个属性后使属性缓慢变化值目标值而不是突变至目标值
- // 现在假设你已经了解了动画的使用,下面我们来了解渐变。
-
- // 1. 创建一个渐变实例
- // 与动画类似,你需要使用new来实例化一个渐变,当然别忘了引入
- // const { Transition } = core.plugin.animate;
- // const tran = new Transition();
-
- // 2. 绘制
- // const ctx = core.createCanvas('transition', 0, 0, 416, 416, 100);
- // ctx.save();
- // const fn = () => {
- // ctx.restore();
- // ctx.save();
- // ctx.clearRect(0, 0, 800, 800);
- // ctx.beginPath();
- // ctx.arc(tran.value.x, tran.value.y, 50, 0, Math.PI * 2); // 使用tran.value.xxx获取当前的属性
- // ctx.fill();
- // // 当然也可以用样板的api,例如core.fillCircle();等
- // }
- // animate.ticker.add(fn);
-
- // 3. 设置渐变
- // 同样,与动画类似,你可以使用tran.time()设置渐变时间,使用tran.mode()设置渐变函数,使用tran.absolute()和tran.relative()设置相对模式
- // 例如:
- // tran.time(1000)
- // .mode(hyper('sin', 'out'))
- // .absolute();
-
- // 4. 初始化渐变属性
- // 与动画不同的是,动画在执行一个自定义属性前都需要register,而渐变不需要。
- // 你可以通过tran.value.xxx = yyy来设置动画属性或使用tran.transition('xxx', yyy)来设置
- // 你的首次赋值即是初始化了渐变属性,这时是不会执行渐变的,例如:
- // tran.value.x = 200;
- // tran.transition('y', 200);
- // 上述例子便是将 x 和 y 初始化成了200
-
- // 5. 执行渐变
- // 初始化完成后,便可以直接执行渐变了,有两种方法
- // tran.value.x = 400; // 将 x 缓慢移动至400
- // tran.transition('y', 400); // 将 y 缓慢移动至400
-
- // 6. 自定义时间获取函数
- // 与动画类似,你依然可以通过修改tran.getTime来修改时间获取函数
-
- if (main.replayChecking) return (core.plugin.animate = {});
-
- var M = Object.defineProperty;
- var E = (n, i, t) =>
- i in n
- ? M(n, i, { enumerable: !0, configurable: !0, writable: !0, value: t })
- : (n[i] = t);
- var o = (n, i, t) => (E(n, typeof i != "symbol" ? i + "" : i, t), t);
- let w = [];
- const k = (n) => {
- for (const i of w)
- if (i.status === "running")
- try {
- for (const t of i.funcs) t(n - i.startTime);
- } catch (t) {
- i.destroy(), console.error(t);
- }
- requestAnimationFrame(k);
- };
- requestAnimationFrame(k);
- class I {
- constructor() {
- o(this, "funcs", /* @__PURE__ */ new Set());
- o(this, "status", "stop");
- o(this, "startTime", 0);
- (this.status = "running"),
- w.push(this),
- requestAnimationFrame((i) => (this.startTime = i));
- }
- add(i) {
- return this.funcs.add(i), this;
- }
- remove(i) {
- return this.funcs.delete(i), this;
- }
- clear() {
- this.funcs.clear();
- }
- destroy() {
- this.clear(), this.stop();
- }
- stop() {
- (this.status = "stop"), (w = w.filter((i) => i !== this));
- }
- }
- class F {
- constructor() {
- o(this, "timing");
- o(this, "relation", "absolute");
- o(this, "easeTime", 0);
- o(this, "applying", {});
- o(this, "getTime", Date.now);
- o(this, "ticker", new I());
- o(this, "value", {});
- o(this, "listener", {});
- this.timing = (i) => i;
- }
- async all() {
- if (Object.values(this.applying).every((i) => i === !0))
- throw new ReferenceError("There is no animates to be waited.");
- await new Promise((i) => {
- const t = () => {
- Object.values(this.applying).every((e) => e === !1) &&
- (this.unlisten("end", t), i("all animated."));
- };
- this.listen("end", t);
- });
- }
- async n(i) {
- const t = Object.values(this.applying).filter((s) => s === !0).length;
- if (t < i)
- throw new ReferenceError(
- `You are trying to wait ${i} animate, but there are only ${t} animate animating.`
- );
- let e = 0;
- await new Promise((s) => {
- const r = () => {
- e++, e === i && (this.unlisten("end", r), s(`${i} animated.`));
- };
- this.listen("end", r);
- });
- }
- async w(i) {
- if (this.applying[i] === !1)
- throw new ReferenceError(`The ${i} animate is not animating.`);
- await new Promise((t) => {
- const e = () => {
- this.applying[i] === !1 &&
- (this.unlisten("end", e), t(`${i} animated.`));
- };
- this.listen("end", e);
- });
- }
- listen(i, t) {
- var e, s;
- (s = (e = this.listener)[i]) != null || (e[i] = []),
- this.listener[i].push(t);
- }
- unlisten(i, t) {
- const e = this.listener[i].findIndex((s) => s === t);
- if (e === -1)
- throw new ReferenceError(
- "You are trying to remove a nonexistent listener."
- );
- this.listener[i].splice(e, 1);
- }
- hook(...i) {
- const t = Object.entries(this.listener).filter((e) => i.includes(e[0]));
- for (const [e, s] of t) for (const r of s) r(this, e);
- }
- }
-
- function y(n) {
- return n != null;
- }
- async function R(n) {
- return new Promise((i) => setTimeout(i, n));
- }
- class j extends F {
- constructor() {
- super();
- o(this, "shakeTiming");
- o(this, "path");
- o(this, "multiTiming");
- o(this, "value", {});
- o(this, "size", 1);
- o(this, "angle", 0);
- o(this, "targetValue", {
- system: {
- move: [0, 0],
- moveAs: [0, 0],
- resize: 0,
- rotate: 0,
- shake: 0,
- "@@bind": [],
- },
- custom: {},
- });
- o(this, "animateFn", {
- system: {
- move: [() => 0, () => 0],
- moveAs: () => 0,
- resize: () => 0,
- rotate: () => 0,
- shake: () => 0,
- "@@bind": () => 0,
- },
- custom: {},
- });
- o(this, "ox", 0);
- o(this, "oy", 0);
- o(this, "sx", 0);
- o(this, "sy", 0);
- o(this, "bindInfo", []);
- (this.timing = (t) => t),
- (this.shakeTiming = (t) => t),
- (this.multiTiming = (t) => [t, t]),
- (this.path = (t) => [t, t]),
- (this.applying = {
- move: !1,
- scale: !1,
- rotate: !1,
- shake: !1,
- }),
- this.ticker.add(() => {
- const { running: t } = this.listener;
- if (y(t)) for (const e of t) e(this, "running");
- });
- }
- get x() {
- return this.ox + this.sx;
- }
- get y() {
- return this.oy + this.sy;
- }
- mode(t, e = !1) {
- return (
- typeof t(0) == "number"
- ? e
- ? (this.shakeTiming = t)
- : (this.timing = t)
- : (this.multiTiming = t),
- this
- );
- }
- time(t) {
- return (this.easeTime = t), this;
- }
- relative() {
- return (this.relation = "relative"), this;
- }
- absolute() {
- return (this.relation = "absolute"), this;
- }
- bind(...t) {
- return (
- this.applying["@@bind"] === !0 && this.end(!1, "@@bind"),
- (this.bindInfo = t),
- this
- );
- }
- unbind() {
- return (
- this.applying["@@bind"] === !0 && this.end(!1, "@@bind"),
- (this.bindInfo = []),
- this
- );
- }
- move(t, e) {
- return (
- this.applying.move && this.end(!0, "move"),
- this.applySys("ox", t, "move"),
- this.applySys("oy", e, "move"),
- this
- );
- }
- rotate(t) {
- return this.applySys("angle", t, "rotate"), this;
- }
- scale(t) {
- return this.applySys("size", t, "resize"), this;
- }
- shake(t, e) {
- this.applying.shake === !0 && this.end(!0, "shake"),
- (this.applying.shake = !0);
- const { easeTime: s, shakeTiming: r } = this,
- l = this.getTime();
- if ((this.hook("start", "shakestart"), s <= 0))
- return this.end(!1, "shake"), this;
- const a = () => {
- const c = this.getTime() - l;
- if (c > s) {
- this.ticker.remove(a),
- (this.applying.shake = !1),
- (this.sx = 0),
- (this.sy = 0),
- this.hook("end", "shakeend");
- return;
- }
- const h = c / s,
- m = r(h);
- (this.sx = m * t), (this.sy = m * e);
- };
- return this.ticker.add(a), (this.animateFn.system.shake = a), this;
- }
- moveAs(t) {
- this.applying.moveAs && this.end(!0, "moveAs"),
- (this.applying.moveAs = !0),
- (this.path = t);
- const { easeTime: e, relation: s, timing: r } = this,
- l = this.getTime(),
- [a, u] = [this.x, this.y],
- [c, h] = (() => {
- if (s === "absolute") return t(1);
- {
- const [d, f] = t(1);
- return [a + d, u + f];
- }
- })();
- if ((this.hook("start", "movestart"), e <= 0))
- return this.end(!1, "moveAs"), this;
- const m = () => {
- const f = this.getTime() - l;
- if (f > e) {
- this.end(!0, "moveAs");
- return;
- }
- const g = f / e,
- [v, x] = t(r(g));
- s === "absolute"
- ? ((this.ox = v), (this.oy = x))
- : ((this.ox = a + v), (this.oy = u + x));
- };
- return (
- this.ticker.add(m),
- (this.animateFn.system.moveAs = m),
- (this.targetValue.system.moveAs = [c, h]),
- this
- );
- }
- register(t, e) {
- if (typeof this.value[t] == "number")
- return this.error(
- `Property ${t} has been regietered twice.`,
- "reregister"
- );
- (this.value[t] = e), (this.applying[t] = !1);
- }
- apply(t, e) {
- this.applying[t] === !0 && this.end(!1, t),
- t in this.value ||
- this.error(`You are trying to execute nonexistent property ${t}.`),
- (this.applying[t] = !0);
- const s = this.value[t],
- r = this.getTime(),
- { timing: l, relation: a, easeTime: u } = this,
- c = a === "absolute" ? e - s : e;
- if ((this.hook("start"), u <= 0)) return this.end(!1, t), this;
- const h = () => {
- const d = this.getTime() - r;
- if (d > u) {
- this.end(!1, t);
- return;
- }
- const f = d / u,
- g = l(f);
- this.value[t] = s + g * c;
- };
- return (
- this.ticker.add(h),
- (this.animateFn.custom[t] = h),
- (this.targetValue.custom[t] = c + s),
- this
- );
- }
- applyMulti() {
- this.applying["@@bind"] === !0 && this.end(!1, "@@bind"),
- (this.applying["@@bind"] = !0);
- const t = this.bindInfo,
- e = t.map((h) => this.value[h]),
- s = this.getTime(),
- { multiTiming: r, relation: l, easeTime: a } = this,
- u = r(1);
- if (u.length !== e.length)
- throw new TypeError(
- `The number of binded animate attributes and timing function returns's length does not match. binded: ${t.length}, timing: ${u.length}`
- );
- if ((this.hook("start"), a <= 0)) return this.end(!1, "@@bind"), this;
- const c = () => {
- const m = this.getTime() - s;
- if (m > a) {
- this.end(!1, "@@bind");
- return;
- }
- const d = m / a,
- f = r(d);
- t.forEach((g, v) => {
- l === "absolute"
- ? (this.value[g] = f[v])
- : (this.value[g] = e[v] + f[v]);
- });
- };
- return (
- this.ticker.add(c),
- (this.animateFn.custom["@@bind"] = c),
- (this.targetValue.system["@@bind"] = u),
- this
- );
- }
- applySys(t, e, s) {
- s !== "move" && this.applying[s] === !0 && this.end(!0, s),
- (this.applying[s] = !0);
- const r = this[t],
- l = this.getTime(),
- a = this.timing,
- u = this.relation,
- c = this.easeTime,
- h = u === "absolute" ? e - r : e;
- if ((this.hook("start", `${s}start`), c <= 0)) return this.end(!0, s);
- const m = () => {
- const f = this.getTime() - l;
- if (f > c) {
- this.end(!0, s);
- return;
- }
- const g = f / c,
- v = a(g);
- (this[t] = r + h * v), t !== "oy" && this.hook(s);
- };
- this.ticker.add(m),
- t === "ox"
- ? (this.animateFn.system.move[0] = m)
- : t === "oy"
- ? (this.animateFn.system.move[1] = m)
- : (this.animateFn.system[s] = m),
- s === "move"
- ? (t === "ox" && (this.targetValue.system.move[0] = h + r),
- t === "oy" && (this.targetValue.system.move[1] = h + r))
- : s !== "shake" && (this.targetValue.system[s] = h + r);
- }
- error(t, e) {
- throw e === "repeat"
- ? new Error(`Cannot execute the same animation twice. Info: ${t}`)
- : e === "reregister"
- ? new Error(`Cannot register an animated property twice. Info: ${t}`)
- : new Error(t);
- }
- end(t, e) {
- if (t === !0)
- if (
- ((this.applying[e] = !1),
- e === "move"
- ? (this.ticker.remove(this.animateFn.system.move[0]),
- this.ticker.remove(this.animateFn.system.move[1]))
- : e === "moveAs"
- ? this.ticker.remove(this.animateFn.system.moveAs)
- : e === "@@bind"
- ? this.ticker.remove(this.animateFn.system["@@bind"])
- : this.ticker.remove(this.animateFn.system[e]),
- e === "move")
- ) {
- const [s, r] = this.targetValue.system.move;
- (this.ox = s), (this.oy = r), this.hook("moveend", "end");
- } else if (e === "moveAs") {
- const [s, r] = this.targetValue.system.moveAs;
- (this.ox = s), (this.oy = r), this.hook("moveend", "end");
- } else
- e === "rotate"
- ? ((this.angle = this.targetValue.system.rotate),
- this.hook("rotateend", "end"))
- : e === "resize"
- ? ((this.size = this.targetValue.system.resize),
- this.hook("resizeend", "end"))
- : e === "@@bind"
- ? this.bindInfo.forEach((r, l) => {
- this.value[r] = this.targetValue.system["@@bind"][l];
- })
- : ((this.sx = 0), (this.sy = 0), this.hook("shakeend", "end"));
- else
- (this.applying[e] = !1),
- this.ticker.remove(this.animateFn.custom[e]),
- (this.value[e] = this.targetValue.custom[e]),
- this.hook("end");
- }
- }
- class O extends F {
- constructor() {
- super();
- o(this, "now", {});
- o(this, "target", {});
- o(this, "transitionFn", {});
- o(this, "value");
- o(this, "handleSet", (t, e, s) => (this.transition(e, s), !0));
- o(this, "handleGet", (t, e) => this.now[e]);
- (this.timing = (t) => t),
- (this.value = new Proxy(this.target, {
- set: this.handleSet,
- get: this.handleGet,
- }));
- }
- mode(t) {
- return (this.timing = t), this;
- }
- time(t) {
- return (this.easeTime = t), this;
- }
- relative() {
- return (this.relation = "relative"), this;
- }
- absolute() {
- return (this.relation = "absolute"), this;
- }
- transition(t, e) {
- if (e === this.target[t]) return this;
- if (!y(this.now[t])) return (this.now[t] = e), this;
- this.applying[t] && this.end(t, !0),
- (this.applying[t] = !0),
- this.hook("start");
- const s = this.getTime(),
- r = this.easeTime,
- l = this.timing,
- a = this.now[t],
- u = e + (this.relation === "absolute" ? 0 : a),
- c = u - a;
- this.target[t] = u;
- const h = () => {
- const d = this.getTime() - s;
- if (d >= r) {
- this.end(t);
- return;
- }
- const f = d / r;
- (this.now[t] = l(f) * c + a), this.hook("running");
- };
- return (
- (this.transitionFn[t] = h),
- this.ticker.add(h),
- r <= 0 ? (this.end(t), this) : this
- );
- }
- end(t, e = !1) {
- const s = this.transitionFn[t];
- if (!y(s))
- throw new ReferenceError(
- `You are trying to end an ended transition: ${t}`
- );
- this.ticker.remove(this.transitionFn[t]),
- delete this.transitionFn[t],
- (this.applying[t] = !1),
- this.hook("end"),
- e || (this.now[t] = this.target[t]);
- }
- }
- const T = (...n) => n.reduce((i, t) => i + t, 0),
- b = (n) => {
- if (n === 0) return 1;
- let i = n;
- for (; n > 1; ) n--, (i *= n);
- return i;
- },
- A = (n, i) => Math.round(b(i) / (b(n) * b(i - n))),
- p = (n, i, t = (e) => 1 - i(1 - e)) =>
- n === "in"
- ? i
- : n === "out"
- ? t
- : n === "in-out"
- ? (e) => (e < 0.5 ? i(e * 2) / 2 : 0.5 + t((e - 0.5) * 2) / 2)
- : (e) => (e < 0.5 ? t(e * 2) / 2 : 0.5 + i((e - 0.5) * 2) / 2),
- $ = Math.cosh(2),
- z = Math.acosh(2),
- V = Math.tanh(3),
- P = Math.atan(5);
-
- function Y() {
- return (n) => n;
- }
-
- function q(...n) {
- const i = [0].concat(n);
- i.push(1);
- const t = i.length,
- e = Array(t)
- .fill(0)
- .map((s, r) => A(r, t - 1));
- return (s) => {
- const r = e.map((l, a) => l * i[a] * (1 - s) ** (t - a - 1) * s ** a);
- return T(...r);
- };
- }
-
- function U(n, i) {
- if (n === "sin") {
- const t = (s) => Math.sin((s * Math.PI) / 2);
- return p(i, (s) => 1 - t(1 - s), t);
- }
- if (n === "sec") {
- const t = (s) => 1 / Math.cos(s);
- return p(i, (s) => t((s * Math.PI) / 3) - 1);
- }
- throw new TypeError(
- "Unexpected parameters are delivered in trigo timing function."
- );
- }
-
- function C(n, i) {
- if (!Number.isInteger(n))
- throw new TypeError(
- "The first parameter of power timing function only allow integer."
- );
- return p(i, (e) => e ** n);
- }
-
- function G(n, i) {
- if (n === "sin") return p(i, (e) => (Math.cosh(e * 2) - 1) / ($ - 1));
- if (n === "tan") {
- const t = (s) => (Math.tanh(s * 3) * 1) / V;
- return p(i, (s) => 1 - t(1 - s), t);
- }
- if (n === "sec") {
- const t = (s) => 1 / Math.cosh(s);
- return p(i, (s) => 1 - (t(s * z) - 0.5) * 2);
- }
- throw new TypeError(
- "Unexpected parameters are delivered in hyper timing function."
- );
- }
-
- function N(n, i) {
- if (n === "sin") {
- const t = (s) => (Math.asin(s) / Math.PI) * 2;
- return p(i, (s) => 1 - t(1 - s), t);
- }
- if (n === "tan") {
- const t = (s) => Math.atan(s * 5) / P;
- return p(i, (s) => 1 - t(1 - s), t);
- }
- throw new TypeError(
- "Unexpected parameters are delivered in inverse trigo timing function."
- );
- }
-
- function B(n, i = () => 1) {
- let t = -1;
- return (e) => (
- (t *= -1), e < 0.5 ? n * i(e * 2) * t : n * i((1 - e) * 2) * t
- );
- }
-
- function D(n, i = 1, t = [0, 0], e = 0, s = (l) => 1, r = !1) {
- return (l) => {
- const a = i * l * Math.PI * 2 + (e * Math.PI) / 180,
- u = Math.cos(a),
- c = Math.sin(a),
- h = n * s(s(r ? 1 - l : l));
- return [h * u + t[0], h * c + t[1]];
- };
- }
-
- function H(n, i, ...t) {
- const e = [n].concat(t);
- e.push(i);
- const s = e.length,
- r = Array(s)
- .fill(0)
- .map((l, a) => A(a, s - 1));
- return (l) => {
- const a = r.map(
- (c, h) => c * e[h][0] * (1 - l) ** (s - h - 1) * l ** h
- ),
- u = r.map((c, h) => c * e[h][1] * (1 - l) ** (s - h - 1) * l ** h);
- return [T(...a), T(...u)];
- };
- }
- if ("animate" in core.plugin)
- throw new ReferenceError(`插件中已存在名为animate的属性!`);
-
- core.plugin.animate = {
- Animation: j,
- AnimationBase: F,
- Ticker: I,
- Transition: O,
- bezier: q,
- bezierPath: H,
- circle: D,
- hyper: G,
- linear: Y,
- power: C,
- shake: B,
- sleep: R,
- trigo: U,
- inverseTrigo: N,
- };
- },
+ // 还记得刚开始定义的async function 吗,直接调用它就能执行动画了!
+ // 示例:ani(); // 执行刚刚写的所有动画
+
+ // 8. 自定义速率曲线和路径
+
+ // 该插件中,速率曲线和路径均可自定义
+
+ // 对于速率曲线,其类型为 (input: number) => number
+ // 它接受一个范围在 0-1 的值,输出一个 0-1 的值,表示了动画的完成度,1表示动画已完成,0表示动画刚开始(当前大于1小于0也不会报错,也会执行相应的动画)
+
+ // 对于路径,其类型为 (input: number) => [number, number]
+ // 它与速率曲线类似,接收一个 0-1 的值,输出一个坐标数组
+
+ // 9. 多个属性绑定
+
+ // 该插件中,你可以绑定多个动画属性,你可以使用ani.bind(...attr)来绑定。
+ // 绑定之后,这三个动画属性可以被一个返回了长度为3的数组的渐变函数执行。
+ // 绑定使用ani.bind,设置渐变函数仍然使用ani.mode,注意它与单个动画属性是分开的,也就是它不会影响正常的渐变函数。
+ // 然后使用ani.applyMulti即可执行动画
+
+ // 例如:
+ // // 自定义的一个三属性渐变函数
+ // function b(input) {
+ // return [input * 100, input ** 2 * 100, input ** 3 * 100];
+ // }
+ // ani.bind('a', 'b', 'c') // 这样会绑定abc这三个动画属性
+ // .mode(b) // 自定义的一个返回了长度为3的数组的函数
+ // .time(5000)
+ // .absolute()
+ // .applyMulti(); // 执行这个动画
+
+ // 9. 监听 动画的生命周期钩子
+
+ // 这个插件还允许你去监听动画的状态,可以监听动画的开始、结束、运行
+ // 你可以使用 animate.listen(type, fn)来监听,fn的类型是 (a: Animation, type: string) => void
+ // 当然,一般情况下你不会用到这个功能,插件中已经帮你包装了三个等待函数,他们就是以这些监听为基础的
+
+ // 10. 自定义时间获取函数
+
+ // 你可以修改ani.getTime来修改动画的时间获取函数,例如想让动画速度变成一半可以写ani.getTime = () => Date.now() / 2
+ // 这样可以允许你随意控制动画的运行速度,暂停,甚至是倒退。该值默认为`Date.now`
+
+ // -------------------- 渐变使用教程 -------------------- //
+
+ // 相比于动画,渐变属于一种较为简便的动画,它可以让你在设置一个属性后使属性缓慢变化值目标值而不是突变至目标值
+ // 现在假设你已经了解了动画的使用,下面我们来了解渐变。
+
+ // 1. 创建一个渐变实例
+ // 与动画类似,你需要使用new来实例化一个渐变,当然别忘了引入
+ // const { Transition } = core.plugin.animate;
+ // const tran = new Transition();
+
+ // 2. 绘制
+ // const ctx = core.createCanvas('transition', 0, 0, 416, 416, 100);
+ // ctx.save();
+ // const fn = () => {
+ // ctx.restore();
+ // ctx.save();
+ // ctx.clearRect(0, 0, 800, 800);
+ // ctx.beginPath();
+ // ctx.arc(tran.value.x, tran.value.y, 50, 0, Math.PI * 2); // 使用tran.value.xxx获取当前的属性
+ // ctx.fill();
+ // // 当然也可以用样板的api,例如core.fillCircle();等
+ // }
+ // animate.ticker.add(fn);
+
+ // 3. 设置渐变
+ // 同样,与动画类似,你可以使用tran.time()设置渐变时间,使用tran.mode()设置渐变函数,使用tran.absolute()和tran.relative()设置相对模式
+ // 例如:
+ // tran.time(1000)
+ // .mode(hyper('sin', 'out'))
+ // .absolute();
+
+ // 4. 初始化渐变属性
+ // 与动画不同的是,动画在执行一个自定义属性前都需要register,而渐变不需要。
+ // 你可以通过tran.value.xxx = yyy来设置动画属性或使用tran.transition('xxx', yyy)来设置
+ // 你的首次赋值即是初始化了渐变属性,这时是不会执行渐变的,例如:
+ // tran.value.x = 200;
+ // tran.transition('y', 200);
+ // 上述例子便是将 x 和 y 初始化成了200
+
+ // 5. 执行渐变
+ // 初始化完成后,便可以直接执行渐变了,有两种方法
+ // tran.value.x = 400; // 将 x 缓慢移动至400
+ // tran.transition('y', 400); // 将 y 缓慢移动至400
+
+ // 6. 自定义时间获取函数
+ // 与动画类似,你依然可以通过修改tran.getTime来修改时间获取函数
+
+ if (main.replayChecking) return (core.plugin.animate = {});
+
+ var M = Object.defineProperty;
+ var E = (n, i, t) =>
+ i in n ?
+ M(n, i, { enumerable: !0, configurable: !0, writable: !0, value: t }) :
+ (n[i] = t);
+ var o = (n, i, t) => (E(n, typeof i != "symbol" ? i + "" : i, t), t);
+ let w = [];
+ const k = (n) => {
+ for (const i of w)
+ if (i.status === "running")
+ try {
+ for (const t of i.funcs) t(n - i.startTime);
+ } catch (t) {
+ i.destroy(), console.error(t);
+ }
+ requestAnimationFrame(k);
+ };
+ requestAnimationFrame(k);
+ class I {
+ constructor() {
+ o(this, "funcs", /* @__PURE__ */ new Set());
+ o(this, "status", "stop");
+ o(this, "startTime", 0);
+ (this.status = "running"),
+ w.push(this),
+ requestAnimationFrame((i) => (this.startTime = i));
+ }
+ add(i) {
+ return this.funcs.add(i), this;
+ }
+ remove(i) {
+ return this.funcs.delete(i), this;
+ }
+ clear() {
+ this.funcs.clear();
+ }
+ destroy() {
+ this.clear(), this.stop();
+ }
+ stop() {
+ (this.status = "stop"), (w = w.filter((i) => i !== this));
+ }
+ }
+ class F {
+ constructor() {
+ o(this, "timing");
+ o(this, "relation", "absolute");
+ o(this, "easeTime", 0);
+ o(this, "applying", {});
+ o(this, "getTime", Date.now);
+ o(this, "ticker", new I());
+ o(this, "value", {});
+ o(this, "listener", {});
+ this.timing = (i) => i;
+ }
+ async all() {
+ if (Object.values(this.applying).every((i) => i === !0))
+ throw new ReferenceError("There is no animates to be waited.");
+ await new Promise((i) => {
+ const t = () => {
+ Object.values(this.applying).every((e) => e === !1) &&
+ (this.unlisten("end", t), i("all animated."));
+ };
+ this.listen("end", t);
+ });
+ }
+ async n(i) {
+ const t = Object.values(this.applying).filter((s) => s === !0).length;
+ if (t < i)
+ throw new ReferenceError(
+ `You are trying to wait ${i} animate, but there are only ${t} animate animating.`
+ );
+ let e = 0;
+ await new Promise((s) => {
+ const r = () => {
+ e++, e === i && (this.unlisten("end", r), s(`${i} animated.`));
+ };
+ this.listen("end", r);
+ });
+ }
+ async w(i) {
+ if (this.applying[i] === !1)
+ throw new ReferenceError(`The ${i} animate is not animating.`);
+ await new Promise((t) => {
+ const e = () => {
+ this.applying[i] === !1 &&
+ (this.unlisten("end", e), t(`${i} animated.`));
+ };
+ this.listen("end", e);
+ });
+ }
+ listen(i, t) {
+ var e, s;
+ (s = (e = this.listener)[i]) != null || (e[i] = []),
+ this.listener[i].push(t);
+ }
+ unlisten(i, t) {
+ const e = this.listener[i].findIndex((s) => s === t);
+ if (e === -1)
+ throw new ReferenceError(
+ "You are trying to remove a nonexistent listener."
+ );
+ this.listener[i].splice(e, 1);
+ }
+ hook(...i) {
+ const t = Object.entries(this.listener).filter((e) => i.includes(e[0]));
+ for (const [e, s] of t)
+ for (const r of s) r(this, e);
+ }
+ }
+
+ function y(n) {
+ return n != null;
+ }
+ async function R(n) {
+ return new Promise((i) => setTimeout(i, n));
+ }
+ class j extends F {
+ constructor() {
+ super();
+ o(this, "shakeTiming");
+ o(this, "path");
+ o(this, "multiTiming");
+ o(this, "value", {});
+ o(this, "size", 1);
+ o(this, "angle", 0);
+ o(this, "targetValue", {
+ system: {
+ move: [0, 0],
+ moveAs: [0, 0],
+ resize: 0,
+ rotate: 0,
+ shake: 0,
+ "@@bind": [],
+ },
+ custom: {},
+ });
+ o(this, "animateFn", {
+ system: {
+ move: [() => 0, () => 0],
+ moveAs: () => 0,
+ resize: () => 0,
+ rotate: () => 0,
+ shake: () => 0,
+ "@@bind": () => 0,
+ },
+ custom: {},
+ });
+ o(this, "ox", 0);
+ o(this, "oy", 0);
+ o(this, "sx", 0);
+ o(this, "sy", 0);
+ o(this, "bindInfo", []);
+ (this.timing = (t) => t),
+ (this.shakeTiming = (t) => t),
+ (this.multiTiming = (t) => [t, t]),
+ (this.path = (t) => [t, t]),
+ (this.applying = {
+ move: !1,
+ scale: !1,
+ rotate: !1,
+ shake: !1,
+ }),
+ this.ticker.add(() => {
+ const { running: t } = this.listener;
+ if (y(t))
+ for (const e of t) e(this, "running");
+ });
+ }
+ get x() {
+ return this.ox + this.sx;
+ }
+ get y() {
+ return this.oy + this.sy;
+ }
+ mode(t, e = !1) {
+ return (
+ typeof t(0) == "number" ?
+ e ?
+ (this.shakeTiming = t) :
+ (this.timing = t) :
+ (this.multiTiming = t),
+ this
+ );
+ }
+ time(t) {
+ return (this.easeTime = t), this;
+ }
+ relative() {
+ return (this.relation = "relative"), this;
+ }
+ absolute() {
+ return (this.relation = "absolute"), this;
+ }
+ bind(...t) {
+ return (
+ this.applying["@@bind"] === !0 && this.end(!1, "@@bind"),
+ (this.bindInfo = t),
+ this
+ );
+ }
+ unbind() {
+ return (
+ this.applying["@@bind"] === !0 && this.end(!1, "@@bind"),
+ (this.bindInfo = []),
+ this
+ );
+ }
+ move(t, e) {
+ return (
+ this.applying.move && this.end(!0, "move"),
+ this.applySys("ox", t, "move"),
+ this.applySys("oy", e, "move"),
+ this
+ );
+ }
+ rotate(t) {
+ return this.applySys("angle", t, "rotate"), this;
+ }
+ scale(t) {
+ return this.applySys("size", t, "resize"), this;
+ }
+ shake(t, e) {
+ this.applying.shake === !0 && this.end(!0, "shake"),
+ (this.applying.shake = !0);
+ const { easeTime: s, shakeTiming: r } = this,
+ l = this.getTime();
+ if ((this.hook("start", "shakestart"), s <= 0))
+ return this.end(!1, "shake"), this;
+ const a = () => {
+ const c = this.getTime() - l;
+ if (c > s) {
+ this.ticker.remove(a),
+ (this.applying.shake = !1),
+ (this.sx = 0),
+ (this.sy = 0),
+ this.hook("end", "shakeend");
+ return;
+ }
+ const h = c / s,
+ m = r(h);
+ (this.sx = m * t), (this.sy = m * e);
+ };
+ return this.ticker.add(a), (this.animateFn.system.shake = a), this;
+ }
+ moveAs(t) {
+ this.applying.moveAs && this.end(!0, "moveAs"),
+ (this.applying.moveAs = !0),
+ (this.path = t);
+ const { easeTime: e, relation: s, timing: r } = this,
+ l = this.getTime(),
+ [a, u] = [this.x, this.y],
+ [c, h] = (() => {
+ if (s === "absolute") return t(1); {
+ const [d, f] = t(1);
+ return [a + d, u + f];
+ }
+ })();
+ if ((this.hook("start", "movestart"), e <= 0))
+ return this.end(!1, "moveAs"), this;
+ const m = () => {
+ const f = this.getTime() - l;
+ if (f > e) {
+ this.end(!0, "moveAs");
+ return;
+ }
+ const g = f / e,
+ [v, x] = t(r(g));
+ s === "absolute" ?
+ ((this.ox = v), (this.oy = x)) :
+ ((this.ox = a + v), (this.oy = u + x));
+ };
+ return (
+ this.ticker.add(m),
+ (this.animateFn.system.moveAs = m),
+ (this.targetValue.system.moveAs = [c, h]),
+ this
+ );
+ }
+ register(t, e) {
+ if (typeof this.value[t] == "number")
+ return this.error(
+ `Property ${t} has been regietered twice.`,
+ "reregister"
+ );
+ (this.value[t] = e), (this.applying[t] = !1);
+ }
+ apply(t, e) {
+ this.applying[t] === !0 && this.end(!1, t),
+ t in this.value ||
+ this.error(`You are trying to execute nonexistent property ${t}.`),
+ (this.applying[t] = !0);
+ const s = this.value[t],
+ r = this.getTime(),
+ { timing: l, relation: a, easeTime: u } = this,
+ c = a === "absolute" ? e - s : e;
+ if ((this.hook("start"), u <= 0)) return this.end(!1, t), this;
+ const h = () => {
+ const d = this.getTime() - r;
+ if (d > u) {
+ this.end(!1, t);
+ return;
+ }
+ const f = d / u,
+ g = l(f);
+ this.value[t] = s + g * c;
+ };
+ return (
+ this.ticker.add(h),
+ (this.animateFn.custom[t] = h),
+ (this.targetValue.custom[t] = c + s),
+ this
+ );
+ }
+ applyMulti() {
+ this.applying["@@bind"] === !0 && this.end(!1, "@@bind"),
+ (this.applying["@@bind"] = !0);
+ const t = this.bindInfo,
+ e = t.map((h) => this.value[h]),
+ s = this.getTime(),
+ { multiTiming: r, relation: l, easeTime: a } = this,
+ u = r(1);
+ if (u.length !== e.length)
+ throw new TypeError(
+ `The number of binded animate attributes and timing function returns's length does not match. binded: ${t.length}, timing: ${u.length}`
+ );
+ if ((this.hook("start"), a <= 0)) return this.end(!1, "@@bind"), this;
+ const c = () => {
+ const m = this.getTime() - s;
+ if (m > a) {
+ this.end(!1, "@@bind");
+ return;
+ }
+ const d = m / a,
+ f = r(d);
+ t.forEach((g, v) => {
+ l === "absolute" ?
+ (this.value[g] = f[v]) :
+ (this.value[g] = e[v] + f[v]);
+ });
+ };
+ return (
+ this.ticker.add(c),
+ (this.animateFn.custom["@@bind"] = c),
+ (this.targetValue.system["@@bind"] = u),
+ this
+ );
+ }
+ applySys(t, e, s) {
+ s !== "move" && this.applying[s] === !0 && this.end(!0, s),
+ (this.applying[s] = !0);
+ const r = this[t],
+ l = this.getTime(),
+ a = this.timing,
+ u = this.relation,
+ c = this.easeTime,
+ h = u === "absolute" ? e - r : e;
+ if ((this.hook("start", `${s}start`), c <= 0)) return this.end(!0, s);
+ const m = () => {
+ const f = this.getTime() - l;
+ if (f > c) {
+ this.end(!0, s);
+ return;
+ }
+ const g = f / c,
+ v = a(g);
+ (this[t] = r + h * v), t !== "oy" && this.hook(s);
+ };
+ this.ticker.add(m),
+ t === "ox" ?
+ (this.animateFn.system.move[0] = m) :
+ t === "oy" ?
+ (this.animateFn.system.move[1] = m) :
+ (this.animateFn.system[s] = m),
+ s === "move" ?
+ (t === "ox" && (this.targetValue.system.move[0] = h + r),
+ t === "oy" && (this.targetValue.system.move[1] = h + r)) :
+ s !== "shake" && (this.targetValue.system[s] = h + r);
+ }
+ error(t, e) {
+ throw e === "repeat" ?
+ new Error(`Cannot execute the same animation twice. Info: ${t}`) :
+ e === "reregister" ?
+ new Error(`Cannot register an animated property twice. Info: ${t}`) :
+ new Error(t);
+ }
+ end(t, e) {
+ if (t === !0)
+ if (
+ ((this.applying[e] = !1),
+ e === "move" ?
+ (this.ticker.remove(this.animateFn.system.move[0]),
+ this.ticker.remove(this.animateFn.system.move[1])) :
+ e === "moveAs" ?
+ this.ticker.remove(this.animateFn.system.moveAs) :
+ e === "@@bind" ?
+ this.ticker.remove(this.animateFn.system["@@bind"]) :
+ this.ticker.remove(this.animateFn.system[e]),
+ e === "move")
+ ) {
+ const [s, r] = this.targetValue.system.move;
+ (this.ox = s), (this.oy = r), this.hook("moveend", "end");
+ } else if (e === "moveAs") {
+ const [s, r] = this.targetValue.system.moveAs;
+ (this.ox = s), (this.oy = r), this.hook("moveend", "end");
+ } else
+ e === "rotate" ?
+ ((this.angle = this.targetValue.system.rotate),
+ this.hook("rotateend", "end")) :
+ e === "resize" ?
+ ((this.size = this.targetValue.system.resize),
+ this.hook("resizeend", "end")) :
+ e === "@@bind" ?
+ this.bindInfo.forEach((r, l) => {
+ this.value[r] = this.targetValue.system["@@bind"][l];
+ }) :
+ ((this.sx = 0), (this.sy = 0), this.hook("shakeend", "end"));
+ else
+ (this.applying[e] = !1),
+ this.ticker.remove(this.animateFn.custom[e]),
+ (this.value[e] = this.targetValue.custom[e]),
+ this.hook("end");
+ }
+ }
+ class O extends F {
+ constructor() {
+ super();
+ o(this, "now", {});
+ o(this, "target", {});
+ o(this, "transitionFn", {});
+ o(this, "value");
+ o(this, "handleSet", (t, e, s) => (this.transition(e, s), !0));
+ o(this, "handleGet", (t, e) => this.now[e]);
+ (this.timing = (t) => t),
+ (this.value = new Proxy(this.target, {
+ set: this.handleSet,
+ get: this.handleGet,
+ }));
+ }
+ mode(t) {
+ return (this.timing = t), this;
+ }
+ time(t) {
+ return (this.easeTime = t), this;
+ }
+ relative() {
+ return (this.relation = "relative"), this;
+ }
+ absolute() {
+ return (this.relation = "absolute"), this;
+ }
+ transition(t, e) {
+ if (e === this.target[t]) return this;
+ if (!y(this.now[t])) return (this.now[t] = e), this;
+ this.applying[t] && this.end(t, !0),
+ (this.applying[t] = !0),
+ this.hook("start");
+ const s = this.getTime(),
+ r = this.easeTime,
+ l = this.timing,
+ a = this.now[t],
+ u = e + (this.relation === "absolute" ? 0 : a),
+ c = u - a;
+ this.target[t] = u;
+ const h = () => {
+ const d = this.getTime() - s;
+ if (d >= r) {
+ this.end(t);
+ return;
+ }
+ const f = d / r;
+ (this.now[t] = l(f) * c + a), this.hook("running");
+ };
+ return (
+ (this.transitionFn[t] = h),
+ this.ticker.add(h),
+ r <= 0 ? (this.end(t), this) : this
+ );
+ }
+ end(t, e = !1) {
+ const s = this.transitionFn[t];
+ if (!y(s))
+ throw new ReferenceError(
+ `You are trying to end an ended transition: ${t}`
+ );
+ this.ticker.remove(this.transitionFn[t]),
+ delete this.transitionFn[t],
+ (this.applying[t] = !1),
+ this.hook("end"),
+ e || (this.now[t] = this.target[t]);
+ }
+ }
+ const T = (...n) => n.reduce((i, t) => i + t, 0),
+ b = (n) => {
+ if (n === 0) return 1;
+ let i = n;
+ for (; n > 1;) n--, (i *= n);
+ return i;
+ },
+ A = (n, i) => Math.round(b(i) / (b(n) * b(i - n))),
+ p = (n, i, t = (e) => 1 - i(1 - e)) =>
+ n === "in" ?
+ i :
+ n === "out" ?
+ t :
+ n === "in-out" ?
+ (e) => (e < 0.5 ? i(e * 2) / 2 : 0.5 + t((e - 0.5) * 2) / 2) :
+ (e) => (e < 0.5 ? t(e * 2) / 2 : 0.5 + i((e - 0.5) * 2) / 2),
+ $ = Math.cosh(2),
+ z = Math.acosh(2),
+ V = Math.tanh(3),
+ P = Math.atan(5);
+
+ function Y() {
+ return (n) => n;
+ }
+
+ function q(...n) {
+ const i = [0].concat(n);
+ i.push(1);
+ const t = i.length,
+ e = Array(t)
+ .fill(0)
+ .map((s, r) => A(r, t - 1));
+ return (s) => {
+ const r = e.map((l, a) => l * i[a] * (1 - s) ** (t - a - 1) * s ** a);
+ return T(...r);
+ };
+ }
+
+ function U(n, i) {
+ if (n === "sin") {
+ const t = (s) => Math.sin((s * Math.PI) / 2);
+ return p(i, (s) => 1 - t(1 - s), t);
+ }
+ if (n === "sec") {
+ const t = (s) => 1 / Math.cos(s);
+ return p(i, (s) => t((s * Math.PI) / 3) - 1);
+ }
+ throw new TypeError(
+ "Unexpected parameters are delivered in trigo timing function."
+ );
+ }
+
+ function C(n, i) {
+ if (!Number.isInteger(n))
+ throw new TypeError(
+ "The first parameter of power timing function only allow integer."
+ );
+ return p(i, (e) => e ** n);
+ }
+
+ function G(n, i) {
+ if (n === "sin") return p(i, (e) => (Math.cosh(e * 2) - 1) / ($ - 1));
+ if (n === "tan") {
+ const t = (s) => (Math.tanh(s * 3) * 1) / V;
+ return p(i, (s) => 1 - t(1 - s), t);
+ }
+ if (n === "sec") {
+ const t = (s) => 1 / Math.cosh(s);
+ return p(i, (s) => 1 - (t(s * z) - 0.5) * 2);
+ }
+ throw new TypeError(
+ "Unexpected parameters are delivered in hyper timing function."
+ );
+ }
+
+ function N(n, i) {
+ if (n === "sin") {
+ const t = (s) => (Math.asin(s) / Math.PI) * 2;
+ return p(i, (s) => 1 - t(1 - s), t);
+ }
+ if (n === "tan") {
+ const t = (s) => Math.atan(s * 5) / P;
+ return p(i, (s) => 1 - t(1 - s), t);
+ }
+ throw new TypeError(
+ "Unexpected parameters are delivered in inverse trigo timing function."
+ );
+ }
+
+ function B(n, i = () => 1) {
+ let t = -1;
+ return (e) => (
+ (t *= -1), e < 0.5 ? n * i(e * 2) * t : n * i((1 - e) * 2) * t
+ );
+ }
+
+ function D(n, i = 1, t = [0, 0], e = 0, s = (l) => 1, r = !1) {
+ return (l) => {
+ const a = i * l * Math.PI * 2 + (e * Math.PI) / 180,
+ u = Math.cos(a),
+ c = Math.sin(a),
+ h = n * s(s(r ? 1 - l : l));
+ return [h * u + t[0], h * c + t[1]];
+ };
+ }
+
+ function H(n, i, ...t) {
+ const e = [n].concat(t);
+ e.push(i);
+ const s = e.length,
+ r = Array(s)
+ .fill(0)
+ .map((l, a) => A(a, s - 1));
+ return (l) => {
+ const a = r.map(
+ (c, h) => c * e[h][0] * (1 - l) ** (s - h - 1) * l ** h
+ ),
+ u = r.map((c, h) => c * e[h][1] * (1 - l) ** (s - h - 1) * l ** h);
+ return [T(...a), T(...u)];
+ };
+ }
+ if ("animate" in core.plugin)
+ throw new ReferenceError(`插件中已存在名为animate的属性!`);
+
+ core.plugin.animate = {
+ Animation: j,
+ AnimationBase: F,
+ Ticker: I,
+ Transition: O,
+ bezier: q,
+ bezierPath: H,
+ circle: D,
+ hyper: G,
+ linear: Y,
+ power: C,
+ shake: B,
+ sleep: R,
+ trigo: U,
+ inverseTrigo: N,
+ };
+},
"func": function () {
// 功能函数集,具体有哪些函数看每个函数前的注释即可
// 安装方式:直接复制到插件里面,注意新建插件自带的 function () { } 不能删
@@ -9551,8 +9344,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
},
"音频系统": function () {
- // 在此增加新插件
- /*首先,在造塔群下载所需的库文件,然后放置在塔目录下的 libs/thirdparty 或其他目录下,之后在 index.html 的最后加上下面这几行:
+ // 在此增加新插件
+ /*首先,在造塔群下载所需的库文件,然后放置在塔目录下的 libs/thirdparty 或其他目录下,之后在 index.html 的最后加上下面这几行:
@@ -9560,2083 +9353,2101 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
*/
- // 将__enable置为false将关闭插件
- let __enable = true;
- if (!__enable || main.mode === "editor") return;
- const { OggOpusDecoderWebWorker } = window["ogg-opus-decoder"];
- const { OggVorbisDecoderWebWorker } = window["ogg-vorbis-decoder"];
- const { CodecParser } = window.CodecParser;
- const { Transition, linear } = core.plugin.animate;
-
- const audio = new Audio();
- const AudioStatus = {
- Playing: 0,
- Pausing: 1,
- Paused: 2,
- Stoping: 3,
- Stoped: 4,
- };
- const supportMap = new Map();
- const AudioType = {
- Mp3: "audio/mpeg",
- Wav: 'audio/wav; codecs="1"',
- Flac: "audio/flac",
- Opus: 'audio/ogg; codecs="opus"',
- Ogg: 'audio/ogg; codecs="vorbis"',
- Aac: "audio/aac",
- };
- /**
- * 检查一种音频类型是否能被播放
- * @param type 音频类型 AudioType
- */
- function isAudioSupport(type) {
- if (supportMap.has(type)) return supportMap.get(type);
- else {
- const support = audio.canPlayType(type);
- const canPlay = support === "maybe" || support === "probably";
- supportMap.set(type, canPlay);
- return canPlay;
- }
- }
-
- const typeMap = new Map([
- ["ogg", AudioType.Ogg],
- ["mp3", AudioType.Mp3],
- ["wav", AudioType.Wav],
- ["flac", AudioType.Flac],
- ["opus", AudioType.Opus],
- ["aac", AudioType.Aac],
- ]);
-
- /**
- * 根据文件名拓展猜测其类型
- * @param file 文件名 string
- */
- function guessTypeByExt(file) {
- const ext = /\.[a-zA-Z\d]+$/.exec(file);
- if (!ext?.[0]) return "";
- const type = ext[0].slice(1);
- return typeMap.get(type.toLocaleLowerCase()) ?? "";
- }
-
- isAudioSupport(AudioType.Ogg);
- isAudioSupport(AudioType.Mp3);
- isAudioSupport(AudioType.Wav);
- isAudioSupport(AudioType.Flac);
- isAudioSupport(AudioType.Opus);
- isAudioSupport(AudioType.Aac);
-
- function isNil(value) {
- return value === void 0 || value === null;
- }
-
- function sleep(time) {
- return new Promise((res) => setTimeout(res, time));
- }
- class AudioEffect {
- constructor(ac) {}
- /**
- * 连接至其他效果器
- * @param target 目标输入 IAudioInput
- * @param output 当前效果器输出通道 Number
- * @param input 目标效果器的输入通道 Number
- */
- connect(target, output, input) {
- this.output.connect(target.input, output, input);
- }
-
- /**
- * 与其他效果器取消连接
- * @param target 目标输入 IAudioInput
- * @param output 当前效果器输出通道 Number
- * @param input 目标效果器的输入通道 Number
- */
- disconnect(target, output, input) {
- if (!target) {
- if (!isNil(output)) {
- this.output.disconnect(output);
- } else {
- this.output.disconnect();
- }
- } else {
- if (!isNil(output)) {
- if (!isNil(input)) {
- this.output.disconnect(target.input, output, input);
- } else {
- this.output.disconnect(target.input, output);
- }
- } else {
- this.output.disconnect(target.input);
- }
- }
- }
- }
-
- class StereoEffect extends AudioEffect {
- constructor(ac) {
- super(ac);
- const panner = ac.createPanner();
- this.input = panner;
- this.output = panner;
- }
-
- /**
- * 设置音频朝向,x正方形水平向右,y正方形垂直于地面向上,z正方向垂直屏幕远离用户
- * @param x 朝向x坐标 Number
- * @param y 朝向y坐标 Number
- * @param z 朝向z坐标 Number
- */
- setOrientation(x, y, z) {
- this.output.orientationX.value = x;
- this.output.orientationY.value = y;
- this.output.orientationZ.value = z;
- }
- /**
- * 设置音频位置,x正方形水平向右,y正方形垂直于地面向上,z正方向垂直屏幕远离用户
- * @param x 位置x坐标 Number
- * @param y 位置y坐标 Number
- * @param z 位置z坐标 Number
- */
- setPosition(x, y, z) {
- this.output.positionX.value = x;
- this.output.positionY.value = y;
- this.output.positionZ.value = z;
- }
- end() {}
-
- start() {}
- }
- class VolumeEffect extends AudioEffect {
- constructor(ac) {
- super(ac);
- const gain = ac.createGain();
- this.input = gain;
- this.output = gain;
- }
-
- /**
- * 设置音量大小
- * @param volume 音量大小 Number
- */
- setVolume(volume) {
- this.output.gain.value = volume;
- }
-
- /**
- * 获取音量大小 Number
- */
- getVolume() {
- return this.output.gain.value;
- }
-
- end() {}
-
- start() {}
- }
- class ChannelVolumeEffect extends AudioEffect {
- /** 所有的音量控制节点 */
-
- constructor(ac) {
- super(ac);
- /** 所有的音量控制节点 */
- this.gain = [];
- const splitter = ac.createChannelSplitter();
- const merger = ac.createChannelMerger();
- this.output = merger;
- this.input = splitter;
- for (let i = 0; i < 6; i++) {
- const gain = ac.createGain();
- splitter.connect(gain, i);
- gain.connect(merger, 0, i);
- this.gain.push(gain);
- }
- }
-
- /**
- * 设置某个声道的音量大小
- * @param channel 要设置的声道,可填0-5 Number
- * @param volume 这个声道的音量大小 Number
- */
- setVolume(channel, volume) {
- if (!this.gain[channel]) return;
- this.gain[channel].gain.value = volume;
- }
-
- /**
- * 获取某个声道的音量大小,可填0-5
- * @param channel 要获取的声道 Number
- */
- getVolume(channel) {
- if (!this.gain[channel]) return 0;
- return this.gain[channel].gain.value;
- }
-
- end() {}
-
- start() {}
- }
- class DelayEffect extends AudioEffect {
- constructor(ac) {
- super(ac);
-
- const delay = ac.createDelay();
- this.input = delay;
- this.output = delay;
- }
-
- /**
- * 设置延迟时长
- * @param delay 延迟时长,单位秒 Number
- */
- setDelay(delay) {
- this.output.delayTime.value = delay;
- }
-
- /**
- * 获取延迟时长
- */
- getDelay() {
- return this.output.delayTime.value;
- }
-
- end() {}
-
- start() {}
- }
- class EchoEffect extends AudioEffect {
- constructor(ac) {
- super(ac);
- /** 当前增益 */
- this.gain = 0.5;
- /** 是否正在播放 */
- this.playing = false;
- const delay = ac.createDelay();
- const gain = ac.createGain();
- gain.gain.value = 0.5;
- delay.delayTime.value = 0.05;
- delay.connect(gain);
- gain.connect(delay);
- /** 延迟节点 */
- this.delay = delay;
- /** 反馈增益节点 */
- this.gainNode = gain;
-
- this.input = gain;
- this.output = gain;
- }
-
- /**
- * 设置回声反馈增益大小
- * @param gain 增益大小,范围 0-1,大于等于1的视为0.5,小于0的视为0 Number
- */
- setFeedbackGain(gain) {
- const resolved = gain >= 1 ? 0.5 : gain < 0 ? 0 : gain;
- this.gain = resolved;
- if (this.playing) this.gainNode.gain.value = resolved;
- }
-
- /**
- * 设置回声间隔时长
- * @param delay 回声时长,范围 0.01-Infinity,小于0.01的视为0.01 Number
- */
- setEchoDelay(delay) {
- const resolved = delay < 0.01 ? 0.01 : delay;
- this.delay.delayTime.value = resolved;
- }
-
- /**
- * 获取反馈节点增益
- */
- getFeedbackGain() {
- return this.gain;
- }
-
- /**
- * 获取回声间隔时长
- */
- getEchoDelay() {
- return this.delay.delayTime.value;
- }
-
- end() {
- this.playing = false;
- const echoTime = Math.ceil(Math.log(0.001) / Math.log(this.gain)) + 10;
- sleep(this.delay.delayTime.value * echoTime).then(() => {
- if (!this.playing) this.gainNode.gain.value = 0;
- });
- }
-
- start() {
- this.playing = true;
- this.gainNode.gain.value = this.gain;
- }
- }
-
- class StreamLoader {
- constructor(url) {
- /** 传输目标 Set*/
- this.target = new Set();
- this.loading = false;
- }
-
- /**
- * 将加载流传递给字节流读取对象
- * @param reader 字节流读取对象 IStreamReader
- */
- pipe(reader) {
- if (this.loading) {
- console.warn(
- "Cannot pipe new StreamReader object when stream is loading."
- );
- return;
- }
- this.target.add(reader);
- reader.piped(this);
- return this;
- }
-
- async start() {
- if (this.loading) return;
- this.loading = true;
- const response = await window.fetch(this.url);
- const stream = response.body;
- if (!stream) {
- console.error("Cannot get reader when fetching '" + this.url + "'.");
- return;
- }
- // 获取读取器
- this.stream = stream;
- const reader = response.body?.getReader();
- const targets = [...this.target];
-
- await Promise.all(targets.map((v) => v.start(stream, this, response)));
- if (reader && reader.read) {
- // 开始流传输
- while (true) {
- const { value, done } = await reader.read();
- await Promise.all(
- targets.map((v) => v.pump(value, done, response))
- );
- if (done) break;
- }
- } else {
- // 如果不支持流传输
- const buffer = await response.arrayBuffer();
- const data = new Uint8Array(buffer);
- await Promise.all(targets.map((v) => v.pump(data, true, response)));
- }
-
- this.loading = false;
- targets.forEach((v) => v.end(true));
-
- //
- }
-
- cancel(reason) {
- if (!this.stream) return;
- this.stream.cancel(reason);
- this.loading = false;
- this.target.forEach((v) => v.end(false, reason));
- }
- }
- const fileSignatures = [
- [AudioType.Mp3, [0x49, 0x44, 0x33]],
- [AudioType.Ogg, [0x4f, 0x67, 0x67, 0x53]],
- [AudioType.Wav, [0x52, 0x49, 0x46, 0x46]],
- [AudioType.Flac, [0x66, 0x4c, 0x61, 0x43]],
- [AudioType.Aac, [0xff, 0xf1]],
- [AudioType.Aac, [0xff, 0xf9]],
- ];
- const oggHeaders = [
- [AudioType.Opus, [0x4f, 0x70, 0x75, 0x73, 0x48, 0x65, 0x61, 0x64]],
- ];
-
- function checkAudioType(data) {
- let audioType = "";
- // 检查头文件获取音频类型,仅检查前256个字节
- const toCheck = data.slice(0, 256);
- for (const [type, value] of fileSignatures) {
- if (value.every((v, i) => toCheck[i] === v)) {
- audioType = type;
- break;
- }
- }
- if (audioType === AudioType.Ogg) {
- // 如果是ogg的话,进一步判断是不是opus
- for (const [key, value] of oggHeaders) {
- const has = toCheck.some((_, i) => {
- return value.every((v, ii) => toCheck[i + ii] === v);
- });
- if (has) {
- audioType = key;
- break;
- }
- }
- }
-
- return audioType;
- }
- class AudioDecoder {
- /**
- * 注册一个解码器
- * @param type 要注册的解码器允许解码的类型
- * @param decoder 解码器对象
- */
- static registerDecoder(type, decoder) {
- if (!this.decoderMap) this.decoderMap = new Map();
- if (this.decoderMap.has(type)) {
- console.warn(
- "Audio stream decoder for audio type '" +
- type +
- "' has already existed."
- );
- return;
- }
-
- this.decoderMap.set(type, decoder);
- }
-
- /**
- * 解码音频数据
- * @param data 音频文件数据
- * @param player AudioPlayer实例
- */
- static async decodeAudioData(data, player) {
- // 检查头文件获取音频类型,仅检查前256个字节
- const toCheck = data.slice(0, 256);
- const type = checkAudioType(data);
- if (type === "") {
- console.error(
- "Unknown audio type. Header: '" +
- [...toCheck]
- .map((v) => v.toString().padStart(2, "0"))
- .join(" ")
- .toUpperCase() +
- "'"
- );
- return null;
- }
- if (isAudioSupport(type)) {
- if (data.buffer instanceof ArrayBuffer) {
- return player.ac.decodeAudioData(data.buffer);
- } else {
- return null;
- }
- } else {
- const Decoder = this.decoderMap.get(type);
- if (!Decoder) {
- return null;
- } else {
- const decoder = new Decoder();
- await decoder.create();
- const decodedData = await decoder.decode(data);
- if (!decodedData) return null;
- const buffer = player.ac.createBuffer(
- decodedData.channelData.length,
- decodedData.channelData[0].length,
- decodedData.sampleRate
- );
- decodedData.channelData.forEach((v, i) => {
- buffer.copyToChannel(v, i);
- });
- decoder.destroy();
- return buffer;
- }
- }
- }
- }
-
- class VorbisDecoder {
- /**
- * 创建音频解码器
- */
- async create() {
- this.decoder = new OggVorbisDecoderWebWorker();
- await this.decoder.ready;
- }
- /**
- * 摧毁这个解码器
- */
- destroy() {
- this.decoder?.free();
- }
- /**
- * 解码流数据
- * @param data 流数据
- */
-
- async decode(data) {
- return this.decoder?.decode(data);
- }
- /**
- * 解码整个文件
- * @param data 文件数据
- */
- async decodeAll(data) {
- return this.decoder?.decodeFile(data);
- }
- /**
- * 当音频解码完成后,会调用此函数,需要返回之前还未解析或未返回的音频数据。调用后,该解码器将不会被再次使用
- */
- async flush() {
- return this.decoder?.flush();
- }
- }
-
- class OpusDecoder {
- /**
- * 创建音频解码器
- */
- async create() {
- this.decoder = new OggOpusDecoderWebWorker();
- await this.decoder.ready;
- }
- /**
- * 摧毁这个解码器
- */
- destroy() {
- this.decoder?.free();
- }
- /**
- * 解码流数据
- * @param data 流数据
- */
- async decode(data) {
- return this.decoder?.decode(data);
- }
- /**
- * 解码整个文件
- * @param data 文件数据
- */
- async decodeAll(data) {
- return this.decoder?.decodeFile(data);
- }
- /**
- * 当音频解码完成后,会调用此函数,需要返回之前还未解析或未返回的音频数据。调用后,该解码器将不会被再次使用
- */
- async flush() {
- return await this.decoder?.flush();
- }
- }
- const mimeTypeMap = {
- [AudioType.Aac]: "audio/aac",
- [AudioType.Flac]: "audio/flac",
- [AudioType.Mp3]: "audio/mpeg",
- [AudioType.Ogg]: "application/ogg",
- [AudioType.Opus]: "application/ogg",
- [AudioType.Wav]: "application/ogg",
- };
-
- function isOggPage(data) {
- return !isNil(data.isFirstPage);
- }
- class AudioStreamSource {
- constructor(context) {
- this.output = context.createBufferSource();
- /** 是否已经完全加载完毕 */
- this.loaded = false;
- /** 是否正在播放 */
- this.playing = false;
- /** 已经缓冲了多长时间,如果缓冲完那么跟歌曲时长一致 */
- this.buffered = 0;
- /** 已经缓冲的采样点数量 */
- this.bufferedSamples = 0;
- /** 歌曲时长,加载完毕之前保持为 0 */
- this.duration = 0;
- /** 在流传输阶段,至少缓冲多长时间的音频之后才开始播放,单位秒 */
- this.bufferPlayDuration = 1;
- /** 音频的采样率,未成功解析出之前保持为 0 */
- this.sampleRate = 0;
- //是否循环播放
- this.loop = false;
- /** 上一次播放是从何时开始的 */
- this.lastStartWhen = 0;
- /** 开始播放时刻 */
- this.lastStartTime = 0;
- /** 上一次播放的缓存长度 */
- this.lastBufferSamples = 0;
-
- /** 是否已经获取到头文件 */
- this.headerRecieved = false;
- /** 音频类型 */
- this.audioType = "";
- /** 每多长时间组成一个缓存 Float32Array */
- this.bufferChunkSize = 10;
- /** 缓存音频数据,每 bufferChunkSize 秒钟组成一个 Float32Array,用于流式解码 */
- this.audioData = [];
-
- this.errored = false;
- this.ac = context;
- }
- /** 当前已经播放了多长时间 */
- get currentTime() {
- return this.ac.currentTime - this.lastStartTime + this.lastStartWhen;
- }
- /**
- * 设置每个缓存数据的大小,默认为10秒钟一个缓存数据
- * @param size 每个缓存数据的时长,单位秒
- */
- setChunkSize(size) {
- if (this.controller?.loading || this.loaded) return;
- this.bufferChunkSize = size;
- }
-
- piped(controller) {
- this.controller = controller;
- }
-
- async pump(data, done) {
- if (!data || this.errored) return;
- if (!this.headerRecieved) {
- // 检查头文件获取音频类型,仅检查前256个字节
- const toCheck = data.slice(0, 256);
- this.audioType = checkAudioType(data);
- if (!this.audioType) {
- console.error(
- "Unknown audio type. Header: '" +
- [...toCheck]
- .map((v) => v.toString(16).padStart(2, "0"))
- .join(" ")
- .toUpperCase() +
- "'"
- );
- return;
- }
- // 创建解码器
- const Decoder = AudioDecoder.decoderMap.get(this.audioType);
- if (!Decoder) {
- this.errored = true;
- console.error(
- "Cannot decode stream source type of '" +
- this.audioType +
- "', since there is no registered decoder for that type."
- );
- return Promise.reject(
- `Cannot decode stream source type of '${this.audioType}', since there is no registered decoder for that type.`
- );
- }
- this.decoder = new Decoder();
- // 创建数据解析器
- const mime = mimeTypeMap[this.audioType];
- const parser = new CodecParser(mime);
- this.parser = parser;
- await this.decoder.create();
- this.headerRecieved = true;
- }
-
- const decoder = this.decoder;
- const parser = this.parser;
- if (!decoder || !parser) {
- this.errored = true;
- return Promise.reject(
- "No parser or decoder attached in this AudioStreamSource"
- );
- }
-
- await this.decodeData(data, decoder, parser);
- if (done) await this.decodeFlushData(decoder, parser);
- this.checkBufferedPlay();
- }
-
- /**
- * 检查采样率,如果还未解析出采样率,那么将设置采样率,如果当前采样率与之前不同,那么发出警告
- */
- checkSampleRate(info) {
- for (const one of info) {
- const frame = isOggPage(one) ? one.codecFrames[0] : one;
- if (frame) {
- const rate = frame.header.sampleRate;
- if (this.sampleRate === 0) {
- this.sampleRate = rate;
- break;
- } else {
- if (rate !== this.sampleRate) {
- console.warn("Sample rate in stream audio must be constant.");
- }
- }
- }
- }
- }
-
- /**
- * 解析音频数据
- */
- async decodeData(data, decoder, parser) {
- // 解析音频数据
- const audioData = await decoder.decode(data);
- if (!audioData) return;
- // @ts-expect-error 库类型声明错误
- const audioInfo = [...parser.parseChunk(data)];
-
- // 检查采样率
- this.checkSampleRate(audioInfo);
- // 追加音频数据
- this.appendDecodedData(audioData, audioInfo);
- }
-
- /**
- * 解码剩余数据
- */
- async decodeFlushData(decoder, parser) {
- const audioData = await decoder.flush();
- if (!audioData) return;
- // @ts-expect-error 库类型声明错误
- const audioInfo = [...parser.flush()];
-
- this.checkSampleRate(audioInfo);
- this.appendDecodedData(audioData, audioInfo);
- }
-
- /**
- * 追加音频数据
- */
- appendDecodedData(data, info) {
- const channels = data.channelData.length;
- if (channels === 0) return;
- if (this.audioData.length !== channels) {
- this.audioData = [];
- for (let i = 0; i < channels; i++) {
- this.audioData.push([]);
- }
- }
- // 计算出应该放在哪
- const chunk = this.sampleRate * this.bufferChunkSize;
- const sampled = this.bufferedSamples;
- const pushIndex = Math.floor(sampled / chunk);
- const bufferIndex = sampled % chunk;
- const dataLength = data.channelData[0].length;
- let buffered = 0;
- let nowIndex = pushIndex;
- let toBuffer = bufferIndex;
- while (buffered < dataLength) {
- const rest = toBuffer !== 0 ? chunk - bufferIndex : chunk;
-
- for (let i = 0; i < channels; i++) {
- const audioData = this.audioData[i];
- if (!audioData[nowIndex]) {
- audioData.push(new Float32Array(chunk));
- }
- const toPush = data.channelData[i].slice(buffered, buffered + rest);
-
- audioData[nowIndex].set(toPush, toBuffer);
- }
- buffered += rest;
- nowIndex++;
- toBuffer = 0;
- }
-
- this.buffered +=
- info.reduce((prev, curr) => prev + curr.duration, 0) / 1000;
- this.bufferedSamples += info.reduce(
- (prev, curr) => prev + curr.samples,
- 0
- );
- }
-
- /**
- * 检查已缓冲内容,并在未开始播放时播放
- */
- checkBufferedPlay() {
- if (this.playing || this.sampleRate === 0) return;
- const played = this.lastBufferSamples / this.sampleRate;
- const dt = this.buffered - played;
- if (this.loaded) {
- this.playAudio(played);
- return;
- }
- if (dt < this.bufferPlayDuration) return;
-
- this.lastBufferSamples = this.bufferedSamples;
- // 需要播放
- this.mergeBuffers();
- if (!this.buffer) return;
- if (this.playing) this.output.stop();
- this.createSourceNode(this.buffer);
- this.output.loop = false;
- this.output.start(0, played);
- this.lastStartTime = this.ac.currentTime;
- this.playing = true;
- this.output.addEventListener("ended", () => {
- this.playing = false;
- this.checkBufferedPlay();
- });
- }
-
- mergeBuffers() {
- const buffer = this.ac.createBuffer(
- this.audioData.length,
- this.bufferedSamples,
- this.sampleRate
- );
- const chunk = this.sampleRate * this.bufferChunkSize;
- const bufferedChunks = Math.floor(this.bufferedSamples / chunk);
- const restLength = this.bufferedSamples % chunk;
- for (let i = 0; i < this.audioData.length; i++) {
- const audio = this.audioData[i];
- const data = new Float32Array(this.bufferedSamples);
- for (let j = 0; j < bufferedChunks; j++) {
- data.set(audio[j], chunk * j);
- }
- if (restLength !== 0) {
- data.set(
- audio[bufferedChunks].slice(0, restLength),
- chunk * bufferedChunks
- );
- }
-
- buffer.copyToChannel(data, i, 0);
- }
- this.buffer = buffer;
- }
-
- async start() {
- delete this.buffer;
- this.headerRecieved = false;
- this.audioType = "";
- this.errored = false;
- this.buffered = 0;
- this.sampleRate = 0;
- this.bufferedSamples = 0;
- this.duration = 0;
- this.loaded = false;
- if (this.playing) this.output.stop();
- this.playing = false;
- this.lastStartTime = this.ac.currentTime;
- }
-
- end(done, reason) {
- if (done && this.buffer) {
- this.loaded = true;
- delete this.controller;
- this.mergeBuffers();
-
- this.duration = this.buffered;
- this.audioData = [];
- this.decoder?.destroy();
- delete this.decoder;
- delete this.parser;
- } else {
- console.warn(
- "Unexpected end when loading stream audio, reason: '" +
- (reason ?? "") +
- "'"
- );
- }
- }
-
- playAudio(when) {
- if (!this.buffer) return;
- this.lastStartTime = this.ac.currentTime;
- if (this.playing) this.output.stop();
- if (this.route.status !== AudioStatus.Playing) {
- this.route.status = AudioStatus.Playing;
- }
- this.createSourceNode(this.buffer);
- this.output.start(0, when);
- this.playing = true;
-
- this.output.addEventListener("ended", () => {
- this.playing = false;
- if (this.route.status === AudioStatus.Playing) {
- this.route.status = AudioStatus.Stoped;
- }
- if (this.loop && !this.output.loop) this.play(0);
- });
- }
- /**
- * 开始播放这个音频源
- */
- play(when) {
- if (this.playing || this.errored) return;
- if (this.loaded && this.buffer) {
- this.playing = true;
- this.playAudio(when);
- } else {
- this.controller?.start();
- }
- }
-
- createSourceNode(buffer) {
- if (!this.target) return;
- const node = this.ac.createBufferSource();
- node.buffer = buffer;
- if (this.playing) this.output.stop();
- this.playing = false;
- this.output = node;
- node.connect(this.target.input);
- node.loop = this.loop;
- }
- /**
- * 停止播放这个音频源
- * @returns 音频暂停的时刻 number
- */
- stop() {
- if (this.playing) this.output.stop();
- this.playing = false;
- return this.ac.currentTime - this.lastStartTime;
- }
- /**
- * 连接到音频路由图上,每次调用播放的时候都会执行一次
- * @param target 连接至的目标 IAudioInput
- */
- connect(target) {
- this.target = target;
- }
- /**
- * 设置是否循环播放
- * @param loop 是否循环 boolean)
- */
- setLoop(loop) {
- this.loop = loop;
- }
- }
- class AudioElementSource {
- constructor(context) {
- const audio = new Audio();
- audio.preload = "none";
- this.output = context.createMediaElementSource(audio);
- this.audio = audio;
- this.ac = context;
- audio.addEventListener("play", () => {
- this.playing = true;
- if (this.route.status !== AudioStatus.Playing) {
- this.route.status = AudioStatus.Playing;
- }
- });
- audio.addEventListener("ended", () => {
- this.playing = false;
- if (this.route.status === AudioStatus.Playing) {
- this.route.status = AudioStatus.Stoped;
- }
- });
- }
- get duration() {
- return this.audio.duration;
- }
- get currentTime() {
- return this.audio.currentTime;
- }
- /**
- * 设置音频源的路径
- * @param url 音频路径
- */
- setSource(url) {
- this.audio.src = url;
- }
-
- play(when = 0) {
- if (this.playing) return;
- this.audio.currentTime = when;
- this.audio.play();
- }
-
- stop() {
- this.audio.pause();
- this.playing = false;
- if (this.route.status === AudioStatus.Playing) {
- this.route.status = AudioStatus.Stoped;
- }
- return this.audio.currentTime;
- }
-
- connect(target) {
- this.output.connect(target.input);
- }
-
- setLoop(loop) {
- this.audio.loop = loop;
- }
- }
- class AudioBufferSource {
- constructor(context) {
- this.output = context.createBufferSource();
- /** 是否循环 */
- this.loop = false;
- /** 上一次播放是从何时开始的 */
- this.lastStartWhen = 0;
- /** 播放开始时刻 */
- this.lastStartTime = 0;
- this.duration = 0;
- this.ac = context;
- }
- get currentTime() {
- return this.ac.currentTime - this.lastStartTime + this.lastStartWhen;
- }
-
- /**
- * 设置音频源数据
- * @param buffer 音频源,可以是未解析的 ArrayBuffer,也可以是已解析的 AudioBuffer
- */
- async setBuffer(buffer) {
- if (buffer instanceof ArrayBuffer) {
- this.buffer = await this.ac.decodeAudioData(buffer);
- } else {
- this.buffer = buffer;
- }
- this.duration = this.buffer.duration;
- }
-
- play(when) {
- if (this.playing || !this.buffer) return;
- this.playing = true;
- this.lastStartTime = this.ac.currentTime;
- if (this.route.status !== AudioStatus.Playing) {
- this.route.status = AudioStatus.Playing;
- }
- this.createSourceNode(this.buffer);
- this.output.start(0, when);
- this.output.addEventListener("ended", () => {
- this.playing = false;
- if (this.route.status === AudioStatus.Playing) {
- this.route.status = AudioStatus.Stoped;
- }
- if (this.loop && !this.output.loop) this.play(0);
- });
- }
-
- createSourceNode(buffer) {
- if (!this.target) return;
- const node = this.ac.createBufferSource();
- node.buffer = buffer;
- this.output = node;
- node.connect(this.target.input);
- node.loop = this.loop;
- }
-
- stop() {
- this.output.stop();
- return this.ac.currentTime - this.lastStartTime;
- }
-
- connect(target) {
- this.target = target;
- }
-
- setLoop(loop) {
- this.loop = loop;
- }
- }
- class AudioPlayer {
- constructor() {
- /** 音频播放上下文 */
- this.ac = new AudioContext();
- /** 音量节点 */
- this.gain = this.ac.createGain();
- this.gain.connect(this.ac.destination);
- this.audioRoutes = new Map();
- }
- /**
- * 解码音频数据
- * @param data 音频数据
- */
- decodeAudioData(data) {
- return AudioDecoder.decodeAudioData(data, this);
- }
- /**
- * 设置音量
- * @param volume 音量
- */
- setVolume(volume) {
- this.gain.gain.value = volume;
- }
-
- /**
- * 获取音量
- */
- getVolume() {
- return this.gain.gain.value;
- }
-
- /**
- * 创建一个音频源
- * @param Source 音频源类
- */
- createSource(Source) {
- return new Source(this.ac);
- }
-
- /**
- * 创建一个兼容流式音频源,可以与流式加载相结合,主要用于处理 opus ogg 不兼容的情况
- */
- createStreamSource() {
- return new AudioStreamSource(this.ac);
- }
-
- /**
- * 创建一个通过 audio 元素播放的音频源
- */
- createElementSource() {
- return new AudioElementSource(this.ac);
- }
-
- /**
- * 创建一个通过 AudioBuffer 播放的音频源
- */
- createBufferSource() {
- return new AudioBufferSource(this.ac);
- }
-
- /**
- * 获取音频目的地
- */
- getDestination() {
- return this.gain;
- }
-
- /**
- * 创建一个音频效果器
- * @param Effect 效果器类
- */
- createEffect(Effect) {
- return new Effect(this.ac);
- }
-
- /**
- * 创建一个修改音量的效果器
- * ```txt
- * |----------|
- * Input ----> | GainNode | ----> Output
- * |----------|
- * ```
- */
- createVolumeEffect() {
- return new VolumeEffect(this.ac);
- }
-
- /**
- * 创建一个立体声效果器
- * ```txt
- * |------------|
- * Input ----> | PannerNode | ----> Output
- * |------------|
- * ```
- */
- createStereoEffect() {
- return new StereoEffect(this.ac);
- }
-
- /**
- * 创建一个修改单个声道音量的效果器
- * ```txt
- * |----------|
- * -> | GainNode | \
- * |--------------| / |----------| -> |------------|
- * Input ----> | SplitterNode | ...... | MergerNode | ----> Output
- * |--------------| \ |----------| -> |------------|
- * -> | GainNode | /
- * |----------|
- * ```
- */
- createChannelVolumeEffect() {
- return new ChannelVolumeEffect(this.ac);
- }
-
- /**
- * 创建一个延迟效果器
- * |-----------|
- * Input ----> | DelayNode | ----> Output
- * |-----------|
- */
- createDelay() {
- return new DelayEffect(this.ac);
- }
-
- /**
- * 创建一个回声效果器
- * ```txt
- * |----------|
- * Input ----> | GainNode | ----> Output
- * ^ |----------| |
- * | |
- * | |------------| ↓
- * |-- | Delay Node | <--
- * |------------|
- * ```
- */
- createEchoEffect() {
- return new EchoEffect(this.ac);
- }
-
- /**
- * 创建一个音频播放路由
- * @param source 音频源
- */
- createRoute(source) {
- return new AudioRoute(source, this);
- }
-
- /**
- * 添加一个音频播放路由,可以直接被播放
- * @param id 这个音频播放路由的名称
- * @param route 音频播放路由对象
- */
- addRoute(id, route) {
- if (!this.audioRoutes) this.audioRoutes = new Map();
- if (this.audioRoutes.has(id)) {
- console.warn(
- "Audio route with id of '" +
- id +
- "' has already existed. New route will override old route."
- );
- }
- this.audioRoutes.set(id, route);
- }
-
- /**
- * 根据名称获取音频播放路由对象
- * @param id 音频播放路由的名称
- */
- getRoute(id) {
- return this.audioRoutes.get(id);
- }
- /**
- * 移除一个音频播放路由
- * @param id 要移除的播放路由的名称
- */
- removeRoute(id) {
- this.audioRoutes.delete(id);
- }
- /**
- * 播放音频
- * @param id 音频名称
- * @param when 从音频的哪个位置开始播放,单位秒
- */
- play(id, when) {
- const route = this.getRoute(id);
- if (!route) {
- console.warn(
- "Cannot play audio route '" +
- id +
- "', since there is not added route named it."
- );
- return;
- }
-
- route.play(when);
- }
-
- /**
- * 暂停音频播放
- * @param id 音频名称
- * @returns 当音乐真正停止时兑现
- */
- pause(id) {
- const route = this.getRoute(id);
- if (!route) {
- console.warn(
- "Cannot pause audio route '" +
- id +
- "', since there is not added route named it."
- );
- return;
- }
- return route.pause();
- }
-
- /**
- * 停止音频播放
- * @param id 音频名称
- * @returns 当音乐真正停止时兑现
- */
- stop(id) {
- const route = this.getRoute(id);
- if (!route) {
- console.warn(
- "Cannot stop audio route '" +
- id +
- "', since there is not added route named it."
- );
- return;
- }
- return route.stop();
- }
-
- /**
- * 继续音频播放
- * @param id 音频名称
- */
- resume(id) {
- const route = this.getRoute(id);
- if (!route) {
- console.warn(
- "Cannot pause audio route '" +
- id +
- "', since there is not added route named it."
- );
- return;
- }
- route.resume();
- }
-
- /**
- * 设置听者位置,x正方向水平向右,y正方向垂直于地面向上,z正方向垂直屏幕远离用户
- * @param x 位置x坐标
- * @param y 位置y坐标
- * @param z 位置z坐标
- */
- setListenerPosition(x, y, z) {
- const listener = this.ac.listener;
- listener.positionX.value = x;
- listener.positionY.value = y;
- listener.positionZ.value = z;
- }
-
- /**
- * 设置听者朝向,x正方向水平向右,y正方向垂直于地面向上,z正方向垂直屏幕远离用户
- * @param x 朝向x坐标
- * @param y 朝向y坐标
- * @param z 朝向z坐标
- */
- setListenerOrientation(x, y, z) {
- const listener = this.ac.listener;
- listener.forwardX.value = x;
- listener.forwardY.value = y;
- listener.forwardZ.value = z;
- }
-
- /**
- * 设置听者头顶朝向,x正方向水平向右,y正方向垂直于地面向上,z正方向垂直屏幕远离用户
- * @param x 头顶朝向x坐标
- * @param y 头顶朝向y坐标
- * @param z 头顶朝向z坐标
- */
- setListenerUp(x, y, z) {
- const listener = this.ac.listener;
- listener.upX.value = x;
- listener.upY.value = y;
- listener.upZ.value = z;
- }
- }
- class AudioRoute {
- constructor(source, player) {
- source.route = this;
- this.output = source.output;
-
- /** 效果器路由图 */
- this.effectRoute = [];
-
- /** 结束时长,当音频暂停或停止时,会经过这么长时间之后才真正终止播放,期间可以做音频淡入淡出等效果 */
- this.endTime = 0;
- /** 暂停时播放了多长时间 */
- this.pauseCurrentTime = 0;
- /** 当前播放状态 */
- this.player = player;
- this.status = AudioStatus.Stoped;
-
- this.shouldStop = false;
- /**
- * 每次暂停或停止时自增,用于判断当前正在处理的情况。
- * 假如暂停后很快播放,然后很快暂停,那么需要根据这个来判断实际是否应该执行暂停后操作
- */
- this.stopIdentifier = 0;
- /** 暂停时刻 */
- this.pauseTime = 0;
- this.source = source;
- this.source.player = player;
- }
- /** 音频时长,单位秒 */
- get duration() {
- return this.source.duration;
- }
- /** 当前播放了多长时间,单位秒 */
- get currentTime() {
- if (this.status === AudioStatus.Paused) {
- return this.pauseCurrentTime;
- } else {
- return this.source.currentTime;
- }
- }
- set currentTime(time) {
- this.source.stop();
- this.source.play(time);
- }
- /**
- * 设置结束时间,暂停或停止时,会经过这么长时间才终止音频的播放,这期间可以做一下音频淡出的效果。
- * @param time 暂停或停止时,经过多长时间之后才会结束音频的播放
- */
- setEndTime(time) {
- this.endTime = time;
- }
-
- /**
- * 当音频播放时执行的函数,可以用于音频淡入效果
- * @param fn 音频开始播放时执行的函数
- */
- onStart(fn) {
- this.audioStartHook = fn;
- }
-
- /**
- * 当音频暂停或停止时执行的函数,可以用于音频淡出效果
- * @param fn 音频在暂停或停止时执行的函数,不填时表示取消这个钩子。
- * 包含两个参数,第一个参数是结束时长,第二个参数是当前音频播放路由对象
- */
- onEnd(fn) {
- this.audioEndHook = fn;
- }
-
- /**
- * 开始播放这个音频
- * @param when 从音频的什么时候开始播放,单位秒
- */
- async play(when = 0) {
- if (this.status === AudioStatus.Playing) return;
- this.link();
- await this.player.ac.resume();
- if (this.effectRoute.length > 0) {
- const first = this.effectRoute[0];
- this.source.connect(first);
- const last = this.effectRoute.at(-1);
- last.connect({ input: this.player.getDestination() });
- } else {
- this.source.connect({ input: this.player.getDestination() });
- }
- this.source.play(when);
- this.status = AudioStatus.Playing;
- this.pauseTime = 0;
- this.audioStartHook?.(this);
- this.startAllEffect();
- if (this.status !== AudioStatus.Playing) {
- this.status = AudioStatus.Playing;
- }
- }
-
- /**
- * 暂停音频播放
- */
- async pause() {
- if (this.status !== AudioStatus.Playing) return;
- this.status = AudioStatus.Pausing;
- this.stopIdentifier++;
- const identifier = this.stopIdentifier;
- if (this.audioEndHook) {
- this.audioEndHook(this.endTime, this);
- await sleep(this.endTime);
- }
- if (
- this.status !== AudioStatus.Pausing ||
- this.stopIdentifier !== identifier
- ) {
- return;
- }
- this.pauseCurrentTime = this.source.currentTime;
- const time = this.source.stop();
- this.pauseTime = time;
- if (this.shouldStop) {
- this.status = AudioStatus.Stoped;
- this.endAllEffect();
-
- this.shouldStop = false;
- } else {
- this.status = AudioStatus.Paused;
- this.endAllEffect();
- }
- this.endAllEffect();
- }
-
- /**
- * 继续音频播放
- */
- resume() {
- if (this.status === AudioStatus.Playing) return;
- if (
- this.status === AudioStatus.Pausing ||
- this.status === AudioStatus.Stoping
- ) {
- this.audioStartHook?.(this);
-
- return;
- }
- if (this.status === AudioStatus.Paused) {
- this.play(this.pauseTime);
- } else {
- this.play(0);
- }
- this.status = AudioStatus.Playing;
- this.pauseTime = 0;
- this.audioStartHook?.(this);
- this.startAllEffect();
- }
-
- /**
- * 停止音频播放
- */
- async stop() {
- if (this.status !== AudioStatus.Playing) {
- if (this.status === AudioStatus.Pausing) {
- this.shouldStop = true;
- }
- return;
- }
- this.status = AudioStatus.Stoping;
- this.stopIdentifier++;
- const identifier = this.stopIdentifier;
- if (this.audioEndHook) {
- this.audioEndHook(this.endTime, this);
- await sleep(this.endTime);
- }
- if (
- this.status !== AudioStatus.Stoping ||
- this.stopIdentifier !== identifier
- ) {
- return;
- }
- this.source.stop();
- this.status = AudioStatus.Stoped;
- this.pauseTime = 0;
- this.endAllEffect();
- }
-
- /**
- * 添加效果器
- * @param effect 要添加的效果,可以是数组,表示一次添加多个
- * @param index 从哪个位置开始添加,如果大于数组长度,那么加到末尾,如果小于0,那么将会从后面往前数。默认添加到末尾
- */
- addEffect(effect, index) {
- if (isNil(index)) {
- if (effect instanceof Array) {
- this.effectRoute.push(...effect);
- } else {
- this.effectRoute.push(effect);
- }
- } else {
- if (effect instanceof Array) {
- this.effectRoute.splice(index, 0, ...effect);
- } else {
- this.effectRoute.splice(index, 0, effect);
- }
- }
- this.setOutput();
- if (this.source.playing) this.link();
- }
-
- /**
- * 移除一个效果器
- * @param effect 要移除的效果
- */
- removeEffect(effect) {
- const index = this.effectRoute.indexOf(effect);
- if (index === -1) return;
- this.effectRoute.splice(index, 1);
- effect.disconnect();
- this.setOutput();
- if (this.source.playing) this.link();
- }
-
- setOutput() {
- const effect = this.effectRoute.at(-1);
- if (!effect) this.output = this.source.output;
- else this.output = effect.output;
- }
-
- /**
- * 连接音频路由图
- */
- link() {
- this.effectRoute.forEach((v) => v.disconnect());
- this.effectRoute.forEach((v, i) => {
- const next = this.effectRoute[i + 1];
- if (next) {
- v.connect(next);
- }
- });
- }
-
- startAllEffect() {
- this.effectRoute.forEach((v) => v.start());
- }
-
- endAllEffect() {
- this.effectRoute.forEach((v) => v.end());
- }
- }
-
- const audioPlayer = new AudioPlayer();
-
- class BgmController {
- constructor(player) {
- this.mainGain = player.createVolumeEffect();
- this.player = player;
- /** bgm音频名称的前缀 */
- this.prefix = "bgms.";
- /** 每个 bgm 的音量控制器 */
- this.gain = new Map();
-
- /** 正在播放的 bgm */
- this.playingBgm = "";
- /** 是否正在播放 */
- this.playing = false;
-
- /** 是否已经启用 */
- this.enabled = true;
- /** 是否屏蔽所有的音乐切换 */
- this.blocking = false;
- /** 渐变时长 */
- this.transitionTime = 2000;
- }
-
- /**
- * 设置音频渐变时长
- * @param time 渐变时长
- */
- setTransitionTime(time) {
- this.transitionTime = time;
- for (const [, value] of this.gain) {
- value.transition.time(time);
- }
- }
-
- /**
- * 屏蔽音乐切换
- */
- blockChange() {
- this.blocking = true;
- }
-
- /**
- * 取消屏蔽音乐切换
- */
- unblockChange() {
- this.blocking = false;
- }
-
- /**
- * 设置总音量大小
- * @param volume 音量大小
- */
- setVolume(volume) {
- this.mainGain.setVolume(volume);
- this._volume = volume;
- }
- /**
- * 获取总音量大小
- */
- getVolume() {
- return this.mainGain.getVolume();
- }
- /**
- * 设置是否启用
- * @param enabled 是否启用
- */
- setEnabled(enabled) {
- if (enabled) this.resume();
- else this.stop();
- this.enabled = enabled;
- }
-
- /**
- * 设置 bgm 音频名称的前缀
- */
- setPrefix(prefix) {
- this.prefix = prefix;
- }
-
- getId(name) {
- return `${this.prefix}${name}`;
- }
-
- /**
- * 根据 bgm 名称获取其 AudioRoute 实例
- * @param id 音频名称
- */
- get(id) {
- return this.player.getRoute(this.getId(id));
- }
-
- /**
- * 添加一个 bgm
- * @param id 要添加的 bgm 的名称
- * @param url 指定 bgm 的加载地址
- */
- addBgm(id, url = `project/bgms/${id}`) {
- const type = guessTypeByExt(id);
- if (!type) {
- console.warn(
- "Unknown audio extension name: '" +
- id.split(".").slice(0, -1).join(".") +
- "'"
- );
- return;
- }
- const gain = this.player.createVolumeEffect();
- if (isAudioSupport(type)) {
- const source = audioPlayer.createElementSource();
- source.setSource(url);
- source.setLoop(true);
- const route = new AudioRoute(source, audioPlayer);
- route.addEffect([gain, this.mainGain]);
- audioPlayer.addRoute(this.getId(id), route);
- this.setTransition(id, route, gain);
- } else {
- const source = audioPlayer.createStreamSource();
- const stream = new StreamLoader(url);
- stream.pipe(source);
- source.setLoop(true);
- const route = new AudioRoute(source, audioPlayer);
- route.addEffect([gain, this.mainGain]);
- audioPlayer.addRoute(this.getId(id), route);
- this.setTransition(id, route, gain);
- }
- }
-
- /**
- * 移除一个 bgm
- * @param id 要移除的 bgm 的名称
- */
- removeBgm(id) {
- this.player.removeRoute(this.getId(id));
- const gain = this.gain.get(id);
- gain?.transition.ticker.destroy();
- this.gain.delete(id);
- }
-
- setTransition(id, route, gain) {
- const transition = new Transition();
- transition
- .time(this.transitionTime)
- .mode(linear())
- .transition("volume", 0);
-
- const tick = () => {
- gain.setVolume(transition.value.volume);
- };
-
- /**
- * @param expect 在结束时应该是正在播放还是停止
- */
- const setTick = async (expect) => {
- transition.ticker.remove(tick);
- transition.ticker.add(tick);
- const identifier = route.stopIdentifier;
- await sleep(this.transitionTime + 500);
- if (route.status === expect && identifier === route.stopIdentifier) {
- transition.ticker.remove(tick);
- if (route.status === AudioStatus.Playing) {
- gain.setVolume(1);
- } else {
- gain.setVolume(0);
- }
- }
- };
-
- route.onStart(async () => {
- transition.transition("volume", 1);
- setTick(AudioStatus.Playing);
- });
- route.onEnd(() => {
- transition.transition("volume", 0);
- setTick(AudioStatus.Paused);
- });
- route.setEndTime(this.transitionTime);
-
- this.gain.set(id, { effect: gain, transition });
- }
-
- /**
- * 播放一个 bgm
- * @param id 要播放的 bgm 名称
- */
- play(id, when) {
- if (this.blocking) return;
- if (id !== this.playingBgm && this.playingBgm) {
- this.player.pause(this.getId(this.playingBgm));
- }
- this.playingBgm = id;
- if (!this.enabled) return;
- this.player.play(this.getId(id), when);
- this.playing = true;
- }
-
- /**
- * 继续当前的 bgm
- */
- resume() {
- if (this.blocking || !this.enabled || this.playing) return;
- if (this.playingBgm) {
- this.player.resume(this.getId(this.playingBgm));
- }
- this.playing = true;
- }
-
- /**
- * 暂停当前的 bgm
- */
- pause() {
- if (this.blocking || !this.enabled) return;
- if (this.playingBgm) {
- this.player.pause(this.getId(this.playingBgm));
- }
- this.playing = false;
- }
-
- /**
- * 停止当前的 bgm
- */
- stop() {
- if (this.blocking || !this.enabled) return;
- if (this.playingBgm) {
- this.player.stop(this.getId(this.playingBgm));
- }
- this.playing = false;
- }
- }
- const bgmController = new BgmController(audioPlayer);
-
- class SoundPlayer {
- constructor(player) {
- /** 每个音效的唯一标识符 */
- this.num = 0;
- this.enabled = true;
- this.gain = player.createVolumeEffect();
- /** 每个音效的数据 */
- this.buffer = new Map();
- /** 所有正在播放的音乐 */
- this.playing = new Set();
- this.player = player;
- }
- /**
- * 设置是否启用音效
- * @param enabled 是否启用音效
- */
- setEnabled(enabled) {
- if (!enabled) this.stopAllSounds();
- this.enabled = enabled;
- }
-
- /**
- * 设置音量大小
- * @param volume 音量大小
- */
- setVolume(volume) {
- this.gain.setVolume(volume);
- }
- /**
- * 获取音量大小
- */
- getVolume() {
- return this.gain.getVolume();
- }
- /**
- * 添加一个音效
- * @param id 音效名称
- * @param data 音效的Uint8Array数据
- */
- async add(id, data) {
- const buffer = await this.player.decodeAudioData(data);
- if (!buffer) {
- console.warn(
- "Cannot decode sound '" +
- id +
- "', since audio file may not supported by 2.b."
- );
- return;
- }
- this.buffer.set(id, buffer);
- }
-
- /**
- * 播放一个音效
- * @param id 音效名称
- * @param position 音频位置,[0, 0, 0]表示正中心,x轴指向水平向右,y轴指向水平向上,z轴指向竖直向上
- * @param orientation 音频朝向,[0, 1, 0]表示朝向前方
- */
- play(id, position = [0, 0, 0], orientation = [1, 0, 0]) {
- if (!this.enabled || !id) return -1;
- const buffer = this.buffer.get(id);
- if (!buffer) {
- console.warn(
- "Cannot play sound '" +
- id +
- "', since there is no added data named it."
- );
- return -1;
- }
- const soundNum = this.num++;
-
- const source = this.player.createBufferSource();
- source.setBuffer(buffer);
- const route = this.player.createRoute(source);
- const stereo = this.player.createStereoEffect();
- stereo.setPosition(position[0], position[1], position[2]);
- stereo.setOrientation(orientation[0], orientation[1], orientation[2]);
- route.addEffect([stereo, this.gain]);
- this.player.addRoute(`sounds.${soundNum}`, route);
- route.play();
- source.output.addEventListener("ended", () => {
- this.playing.delete(soundNum);
- });
- this.playing.add(soundNum);
- return soundNum;
- }
-
- /**
- * 停止一个音效
- * @param num 音效的唯一 id
- */
- stop(num) {
- const id = `sounds.${num}`;
- const route = this.player.getRoute(id);
- if (route) {
- route.stop();
- this.player.removeRoute(id);
- this.playing.delete(num);
- }
- }
-
- /**
- * 停止播放所有音效
- */
- stopAllSounds() {
- this.playing.forEach((v) => {
- const id = `sounds.${v}`;
- const route = this.player.getRoute(id);
- if (route) {
- route.stop();
- this.player.removeRoute(id);
- }
- });
- this.playing.clear();
- }
- }
- const soundPlayer = new SoundPlayer(audioPlayer);
-
- function loadAllBgm() {
- const data = data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d;
- for (const bgm of data.main.bgms) {
- bgmController.addBgm(bgm);
- }
- }
- loadAllBgm();
- AudioDecoder.registerDecoder(AudioType.Ogg, VorbisDecoder);
- AudioDecoder.registerDecoder(AudioType.Opus, OpusDecoder);
-
- core.plugin.audioSystem = {
- AudioType,
- AudioDecoder,
- AudioStatus,
- checkAudioType,
- isAudioSupport,
- audioPlayer,
- soundPlayer,
- bgmController,
- guessTypeByExt,
- BgmController,
- SoundPlayer,
- EchoEffect,
- DelayEffect,
- ChannelVolumeEffect,
- VolumeEffect,
- StereoEffect,
- AudioEffect,
- AudioPlayer,
- AudioRoute,
- AudioStreamSource,
- AudioElementSource,
- AudioBufferSource,
- loadAllBgm,
- StreamLoader,
- };
- //bgm相关复写
- control.prototype.playBgm = (bgm, when) => {
- bgm = core.getMappedName(bgm);
- bgmController.play(bgm, when);
- core.setMusicBtn();
- };
- control.prototype.pauseBgm = () => {
- bgmController.pause();
- core.setMusicBtn();
- };
-
- control.prototype.resumeBgm = function () {
- bgmController.resume();
- core.setMusicBtn();
- };
- control.prototype.checkBgm = function () {
- core.playBgm(bgmController.playingBgm || main.startBgm);
- };
- control.prototype.triggerBgm = function () {
- core.musicStatus.bgmStatus = !core.musicStatus.bgmStatus;
- if (bgmController.playing) bgmController.pause();
- else bgmController.resume();
- core.setMusicBtn();
- core.setLocalStorage("bgmStatus", core.musicStatus.bgmStatus);
- };
- //sound相关复写
- control.prototype.playSound = function (
- sound,
- _pitch,
- callback,
- position,
- orientation
- ) {
- if (main.mode != "play" || !core.musicStatus.soundStatus) return;
- const name = core.getMappedName(sound);
- const num = soundPlayer.play(name, position, orientation);
- const route = audioPlayer.getRoute(`sounds.${num}`);
- if (!route) {
- callback?.();
- return -1;
- } else {
- sleep(route.duration * 1000).then(() => callback?.());
- return num;
- }
- };
- control.prototype.stopSound = function (id) {
- if (isNil(id)) {
- soundPlayer.stopAllSounds();
- } else {
- soundPlayer.stop(id);
- }
- };
- control.prototype.getPlayingSounds = function () {
- return [...soundPlayer.playing];
- };
- //sound加载复写
- loader.prototype._loadOneSound_decodeData = function (name, data) {
- if (data instanceof Blob) {
- var blobReader = new zip.BlobReader(data);
- blobReader.init(function () {
- blobReader.readUint8Array(0, blobReader.size, function (uint8) {
- //core.loader._loadOneSound_decodeData(name, uint8.buffer);
- soundPlayer.add(name, uint8);
- });
- });
- return;
- }
- if (data instanceof ArrayBuffer) {
- const uint8 = new Uint8Array(data);
- soundPlayer.add(name, uint8);
- }
- };
- //音量控制复写
- soundPlayer.setVolume(
- core.musicStatus.userVolume * core.musicStatus.designVolume
- );
- bgmController.setVolume(
- core.musicStatus.userVolume * core.musicStatus.designVolume
- );
- actions.prototype._clickSwitchs_sounds_userVolume = function (delta) {
- var value = Math.round(Math.sqrt(100 * core.musicStatus.userVolume));
- if (value == 0 && delta < 0) return;
- core.musicStatus.userVolume = core.clamp(
- Math.pow(value + delta, 2) / 100,
- 0,
- 1
- );
- //audioContext 音效 不受designVolume 影响
- if (core.musicStatus.gainNode != null)
- core.musicStatus.gainNode.gain.value = core.musicStatus.userVolume;
- soundPlayer.setVolume(
- core.musicStatus.userVolume * core.musicStatus.designVolume
- );
- bgmController.setVolume(
- core.musicStatus.userVolume * core.musicStatus.designVolume
- );
- core.setLocalStorage("userVolume", core.musicStatus.userVolume);
- core.playSound("确定");
- core.ui._drawSwitchs_sounds();
- };
- },
+ // 将__enable置为false将关闭插件
+ let __enable = true;
+ if (!__enable || main.mode === "editor") return;
+ const { OggOpusDecoderWebWorker } = window["ogg-opus-decoder"];
+ const { OggVorbisDecoderWebWorker } = window["ogg-vorbis-decoder"];
+ const { CodecParser } = window.CodecParser;
+ const { Transition, linear } = core.plugin.animate;
+
+ const audio = new Audio();
+ const AudioStatus = {
+ Playing: 0,
+ Pausing: 1,
+ Paused: 2,
+ Stoping: 3,
+ Stoped: 4,
+ };
+ const supportMap = new Map();
+ const AudioType = {
+ Mp3: "audio/mpeg",
+ Wav: 'audio/wav; codecs="1"',
+ Flac: "audio/flac",
+ Opus: 'audio/ogg; codecs="opus"',
+ Ogg: 'audio/ogg; codecs="vorbis"',
+ Aac: "audio/aac",
+ };
+ /**
+ * 检查一种音频类型是否能被播放
+ * @param type 音频类型 AudioType
+ */
+ function isAudioSupport(type) {
+ if (supportMap.has(type)) return supportMap.get(type);
+ else {
+ const support = audio.canPlayType(type);
+ const canPlay = support === "maybe" || support === "probably";
+ supportMap.set(type, canPlay);
+ return canPlay;
+ }
+ }
+
+ const typeMap = new Map([
+ ["ogg", AudioType.Ogg],
+ ["mp3", AudioType.Mp3],
+ ["wav", AudioType.Wav],
+ ["flac", AudioType.Flac],
+ ["opus", AudioType.Opus],
+ ["aac", AudioType.Aac],
+ ]);
+
+ /**
+ * 根据文件名拓展猜测其类型
+ * @param file 文件名 string
+ */
+ function guessTypeByExt(file) {
+ const ext = /\.[a-zA-Z\d]+$/.exec(file);
+ if (!ext?.[0]) return "";
+ const type = ext[0].slice(1);
+ return typeMap.get(type.toLocaleLowerCase()) ?? "";
+ }
+
+ isAudioSupport(AudioType.Ogg);
+ isAudioSupport(AudioType.Mp3);
+ isAudioSupport(AudioType.Wav);
+ isAudioSupport(AudioType.Flac);
+ isAudioSupport(AudioType.Opus);
+ isAudioSupport(AudioType.Aac);
+
+ function isNil(value) {
+ return value === void 0 || value === null;
+ }
+
+ function sleep(time) {
+ return new Promise((res) => setTimeout(res, time));
+ }
+ class AudioEffect {
+ constructor(ac) {}
+ /**
+ * 连接至其他效果器
+ * @param target 目标输入 IAudioInput
+ * @param output 当前效果器输出通道 Number
+ * @param input 目标效果器的输入通道 Number
+ */
+ connect(target, output, input) {
+ this.output.connect(target.input, output, input);
+ }
+
+ /**
+ * 与其他效果器取消连接
+ * @param target 目标输入 IAudioInput
+ * @param output 当前效果器输出通道 Number
+ * @param input 目标效果器的输入通道 Number
+ */
+ disconnect(target, output, input) {
+ if (!target) {
+ if (!isNil(output)) {
+ this.output.disconnect(output);
+ } else {
+ this.output.disconnect();
+ }
+ } else {
+ if (!isNil(output)) {
+ if (!isNil(input)) {
+ this.output.disconnect(target.input, output, input);
+ } else {
+ this.output.disconnect(target.input, output);
+ }
+ } else {
+ this.output.disconnect(target.input);
+ }
+ }
+ }
+ }
+
+ class StereoEffect extends AudioEffect {
+ constructor(ac) {
+ super(ac);
+ const panner = ac.createPanner();
+ this.input = panner;
+ this.output = panner;
+ }
+
+ /**
+ * 设置音频朝向,x正方形水平向右,y正方形垂直于地面向上,z正方向垂直屏幕远离用户
+ * @param x 朝向x坐标 Number
+ * @param y 朝向y坐标 Number
+ * @param z 朝向z坐标 Number
+ */
+ setOrientation(x, y, z) {
+ this.output.orientationX.value = x;
+ this.output.orientationY.value = y;
+ this.output.orientationZ.value = z;
+ }
+ /**
+ * 设置音频位置,x正方形水平向右,y正方形垂直于地面向上,z正方向垂直屏幕远离用户
+ * @param x 位置x坐标 Number
+ * @param y 位置y坐标 Number
+ * @param z 位置z坐标 Number
+ */
+ setPosition(x, y, z) {
+ this.output.positionX.value = x;
+ this.output.positionY.value = y;
+ this.output.positionZ.value = z;
+ }
+ end() {}
+
+ start() {}
+ }
+ class VolumeEffect extends AudioEffect {
+ constructor(ac) {
+ super(ac);
+ const gain = ac.createGain();
+ this.input = gain;
+ this.output = gain;
+ }
+
+ /**
+ * 设置音量大小
+ * @param volume 音量大小 Number
+ */
+ setVolume(volume) {
+ this.output.gain.value = volume;
+ }
+
+ /**
+ * 获取音量大小 Number
+ */
+ getVolume() {
+ return this.output.gain.value;
+ }
+
+ end() {}
+
+ start() {}
+ }
+ class ChannelVolumeEffect extends AudioEffect {
+ /** 所有的音量控制节点 */
+
+ constructor(ac) {
+ super(ac);
+ /** 所有的音量控制节点 */
+ this.gain = [];
+ const splitter = ac.createChannelSplitter();
+ const merger = ac.createChannelMerger();
+ this.output = merger;
+ this.input = splitter;
+ for (let i = 0; i < 6; i++) {
+ const gain = ac.createGain();
+ splitter.connect(gain, i);
+ gain.connect(merger, 0, i);
+ this.gain.push(gain);
+ }
+ }
+
+ /**
+ * 设置某个声道的音量大小
+ * @param channel 要设置的声道,可填0-5 Number
+ * @param volume 这个声道的音量大小 Number
+ */
+ setVolume(channel, volume) {
+ if (!this.gain[channel]) return;
+ this.gain[channel].gain.value = volume;
+ }
+
+ /**
+ * 获取某个声道的音量大小,可填0-5
+ * @param channel 要获取的声道 Number
+ */
+ getVolume(channel) {
+ if (!this.gain[channel]) return 0;
+ return this.gain[channel].gain.value;
+ }
+
+ end() {}
+
+ start() {}
+ }
+ class DelayEffect extends AudioEffect {
+ constructor(ac) {
+ super(ac);
+
+ const delay = ac.createDelay();
+ this.input = delay;
+ this.output = delay;
+ }
+
+ /**
+ * 设置延迟时长
+ * @param delay 延迟时长,单位秒 Number
+ */
+ setDelay(delay) {
+ this.output.delayTime.value = delay;
+ }
+
+ /**
+ * 获取延迟时长
+ */
+ getDelay() {
+ return this.output.delayTime.value;
+ }
+
+ end() {}
+
+ start() {}
+ }
+ class EchoEffect extends AudioEffect {
+ constructor(ac) {
+ super(ac);
+ /** 当前增益 */
+ this.gain = 0.5;
+ /** 是否正在播放 */
+ this.playing = false;
+ const delay = ac.createDelay();
+ const gain = ac.createGain();
+ gain.gain.value = 0.5;
+ delay.delayTime.value = 0.05;
+ delay.connect(gain);
+ gain.connect(delay);
+ /** 延迟节点 */
+ this.delay = delay;
+ /** 反馈增益节点 */
+ this.gainNode = gain;
+
+ this.input = gain;
+ this.output = gain;
+ }
+
+ /**
+ * 设置回声反馈增益大小
+ * @param gain 增益大小,范围 0-1,大于等于1的视为0.5,小于0的视为0 Number
+ */
+ setFeedbackGain(gain) {
+ const resolved = gain >= 1 ? 0.5 : gain < 0 ? 0 : gain;
+ this.gain = resolved;
+ if (this.playing) this.gainNode.gain.value = resolved;
+ }
+
+ /**
+ * 设置回声间隔时长
+ * @param delay 回声时长,范围 0.01-Infinity,小于0.01的视为0.01 Number
+ */
+ setEchoDelay(delay) {
+ const resolved = delay < 0.01 ? 0.01 : delay;
+ this.delay.delayTime.value = resolved;
+ }
+
+ /**
+ * 获取反馈节点增益
+ */
+ getFeedbackGain() {
+ return this.gain;
+ }
+
+ /**
+ * 获取回声间隔时长
+ */
+ getEchoDelay() {
+ return this.delay.delayTime.value;
+ }
+
+ end() {
+ this.playing = false;
+ const echoTime = Math.ceil(Math.log(0.001) / Math.log(this.gain)) + 10;
+ sleep(this.delay.delayTime.value * echoTime).then(() => {
+ if (!this.playing) this.gainNode.gain.value = 0;
+ });
+ }
+
+ start() {
+ this.playing = true;
+ this.gainNode.gain.value = this.gain;
+ }
+ }
+
+ class StreamLoader {
+ constructor(url) {
+ /** 传输目标 Set*/
+ this.target = new Set();
+ this.loading = false;
+ }
+
+ /**
+ * 将加载流传递给字节流读取对象
+ * @param reader 字节流读取对象 IStreamReader
+ */
+ pipe(reader) {
+ if (this.loading) {
+ console.warn(
+ "Cannot pipe new StreamReader object when stream is loading."
+ );
+ return;
+ }
+ this.target.add(reader);
+ reader.piped(this);
+ return this;
+ }
+
+ async start() {
+ if (this.loading) return;
+ this.loading = true;
+ const response = await window.fetch(this.url);
+ const stream = response.body;
+ if (!stream) {
+ console.error("Cannot get reader when fetching '" + this.url + "'.");
+ return;
+ }
+ // 获取读取器
+ this.stream = stream;
+ const reader = response.body?.getReader();
+ const targets = [...this.target];
+
+ await Promise.all(targets.map((v) => v.start(stream, this, response)));
+ if (reader && reader.read) {
+ // 开始流传输
+ while (true) {
+ const { value, done } = await reader.read();
+ await Promise.all(
+ targets.map((v) => v.pump(value, done, response))
+ );
+ if (done) break;
+ }
+ } else {
+ // 如果不支持流传输
+ const buffer = await response.arrayBuffer();
+ const data = new Uint8Array(buffer);
+ await Promise.all(targets.map((v) => v.pump(data, true, response)));
+ }
+
+ this.loading = false;
+ targets.forEach((v) => v.end(true));
+
+ //
+ }
+
+ cancel(reason) {
+ if (!this.stream) return;
+ this.stream.cancel(reason);
+ this.loading = false;
+ this.target.forEach((v) => v.end(false, reason));
+ }
+ }
+ const fileSignatures = [
+ [AudioType.Mp3, [0x49, 0x44, 0x33]],
+ [AudioType.Ogg, [0x4f, 0x67, 0x67, 0x53]],
+ [AudioType.Wav, [0x52, 0x49, 0x46, 0x46]],
+ [AudioType.Flac, [0x66, 0x4c, 0x61, 0x43]],
+ [AudioType.Aac, [0xff, 0xf1]],
+ [AudioType.Aac, [0xff, 0xf9]],
+ ];
+ const oggHeaders = [
+ [AudioType.Opus, [0x4f, 0x70, 0x75, 0x73, 0x48, 0x65, 0x61, 0x64]],
+ ];
+
+ function checkAudioType(data) {
+ let audioType = "";
+ // 检查头文件获取音频类型,仅检查前256个字节
+ const toCheck = data.slice(0, 256);
+ for (const [type, value] of fileSignatures) {
+ if (value.every((v, i) => toCheck[i] === v)) {
+ audioType = type;
+ break;
+ }
+ }
+ if (audioType === AudioType.Ogg) {
+ // 如果是ogg的话,进一步判断是不是opus
+ for (const [key, value] of oggHeaders) {
+ const has = toCheck.some((_, i) => {
+ return value.every((v, ii) => toCheck[i + ii] === v);
+ });
+ if (has) {
+ audioType = key;
+ break;
+ }
+ }
+ }
+
+ return audioType;
+ }
+ class AudioDecoder {
+ /**
+ * 注册一个解码器
+ * @param type 要注册的解码器允许解码的类型
+ * @param decoder 解码器对象
+ */
+ static registerDecoder(type, decoder) {
+ if (!this.decoderMap) this.decoderMap = new Map();
+ if (this.decoderMap.has(type)) {
+ console.warn(
+ "Audio stream decoder for audio type '" +
+ type +
+ "' has already existed."
+ );
+ return;
+ }
+
+ this.decoderMap.set(type, decoder);
+ }
+
+ /**
+ * 解码音频数据
+ * @param data 音频文件数据
+ * @param player AudioPlayer实例
+ */
+ static async decodeAudioData(data, player) {
+ // 检查头文件获取音频类型,仅检查前256个字节
+ const toCheck = data.slice(0, 256);
+ const type = checkAudioType(data);
+ if (type === "") {
+ console.error(
+ "Unknown audio type. Header: '" + [...toCheck]
+ .map((v) => v.toString().padStart(2, "0"))
+ .join(" ")
+ .toUpperCase() +
+ "'"
+ );
+ return null;
+ }
+ if (isAudioSupport(type)) {
+ if (data.buffer instanceof ArrayBuffer) {
+ return player.ac.decodeAudioData(data.buffer);
+ } else {
+ return null;
+ }
+ } else {
+ const Decoder = this.decoderMap.get(type);
+ if (!Decoder) {
+ return null;
+ } else {
+ const decoder = new Decoder();
+ await decoder.create();
+ const decodedData = await decoder.decode(data);
+ if (!decodedData) return null;
+ const buffer = player.ac.createBuffer(
+ decodedData.channelData.length,
+ decodedData.channelData[0].length,
+ decodedData.sampleRate
+ );
+ decodedData.channelData.forEach((v, i) => {
+ buffer.copyToChannel(v, i);
+ });
+ decoder.destroy();
+ return buffer;
+ }
+ }
+ }
+ }
+
+ class VorbisDecoder {
+ /**
+ * 创建音频解码器
+ */
+ async create() {
+ this.decoder = new OggVorbisDecoderWebWorker();
+ await this.decoder.ready;
+ }
+ /**
+ * 摧毁这个解码器
+ */
+ destroy() {
+ this.decoder?.free();
+ }
+ /**
+ * 解码流数据
+ * @param data 流数据
+ */
+
+ async decode(data) {
+ return this.decoder?.decode(data);
+ }
+ /**
+ * 解码整个文件
+ * @param data 文件数据
+ */
+ async decodeAll(data) {
+ return this.decoder?.decodeFile(data);
+ }
+ /**
+ * 当音频解码完成后,会调用此函数,需要返回之前还未解析或未返回的音频数据。调用后,该解码器将不会被再次使用
+ */
+ async flush() {
+ return this.decoder?.flush();
+ }
+ }
+
+ class OpusDecoder {
+ /**
+ * 创建音频解码器
+ */
+ async create() {
+ this.decoder = new OggOpusDecoderWebWorker();
+ await this.decoder.ready;
+ }
+ /**
+ * 摧毁这个解码器
+ */
+ destroy() {
+ this.decoder?.free();
+ }
+ /**
+ * 解码流数据
+ * @param data 流数据
+ */
+ async decode(data) {
+ return this.decoder?.decode(data);
+ }
+ /**
+ * 解码整个文件
+ * @param data 文件数据
+ */
+ async decodeAll(data) {
+ return this.decoder?.decodeFile(data);
+ }
+ /**
+ * 当音频解码完成后,会调用此函数,需要返回之前还未解析或未返回的音频数据。调用后,该解码器将不会被再次使用
+ */
+ async flush() {
+ return await this.decoder?.flush();
+ }
+ }
+ const mimeTypeMap = {
+ [AudioType.Aac]: "audio/aac",
+ [AudioType.Flac]: "audio/flac",
+ [AudioType.Mp3]: "audio/mpeg",
+ [AudioType.Ogg]: "application/ogg",
+ [AudioType.Opus]: "application/ogg",
+ [AudioType.Wav]: "application/ogg",
+ };
+
+ function isOggPage(data) {
+ return !isNil(data.isFirstPage);
+ }
+ class AudioStreamSource {
+ constructor(context) {
+ this.output = context.createBufferSource();
+ /** 是否已经完全加载完毕 */
+ this.loaded = false;
+ /** 是否正在播放 */
+ this.playing = false;
+ /** 已经缓冲了多长时间,如果缓冲完那么跟歌曲时长一致 */
+ this.buffered = 0;
+ /** 已经缓冲的采样点数量 */
+ this.bufferedSamples = 0;
+ /** 歌曲时长,加载完毕之前保持为 0 */
+ this.duration = 0;
+ /** 在流传输阶段,至少缓冲多长时间的音频之后才开始播放,单位秒 */
+ this.bufferPlayDuration = 1;
+ /** 音频的采样率,未成功解析出之前保持为 0 */
+ this.sampleRate = 0;
+ //是否循环播放
+ this.loop = false;
+ /** 上一次播放是从何时开始的 */
+ this.lastStartWhen = 0;
+ /** 开始播放时刻 */
+ this.lastStartTime = 0;
+ /** 上一次播放的缓存长度 */
+ this.lastBufferSamples = 0;
+
+ /** 是否已经获取到头文件 */
+ this.headerRecieved = false;
+ /** 音频类型 */
+ this.audioType = "";
+ /** 每多长时间组成一个缓存 Float32Array */
+ this.bufferChunkSize = 10;
+ /** 缓存音频数据,每 bufferChunkSize 秒钟组成一个 Float32Array,用于流式解码 */
+ this.audioData = [];
+
+ this.errored = false;
+ this.ac = context;
+ }
+ /** 当前已经播放了多长时间 */
+ get currentTime() {
+ return this.ac.currentTime - this.lastStartTime + this.lastStartWhen;
+ }
+ /**
+ * 设置每个缓存数据的大小,默认为10秒钟一个缓存数据
+ * @param size 每个缓存数据的时长,单位秒
+ */
+ setChunkSize(size) {
+ if (this.controller?.loading || this.loaded) return;
+ this.bufferChunkSize = size;
+ }
+
+ piped(controller) {
+ this.controller = controller;
+ }
+
+ async pump(data, done) {
+ if (!data || this.errored) return;
+ if (!this.headerRecieved) {
+ // 检查头文件获取音频类型,仅检查前256个字节
+ const toCheck = data.slice(0, 256);
+ this.audioType = checkAudioType(data);
+ if (!this.audioType) {
+ console.error(
+ "Unknown audio type. Header: '" + [...toCheck]
+ .map((v) => v.toString(16).padStart(2, "0"))
+ .join(" ")
+ .toUpperCase() +
+ "'"
+ );
+ return;
+ }
+ // 创建解码器
+ const Decoder = AudioDecoder.decoderMap.get(this.audioType);
+ if (!Decoder) {
+ this.errored = true;
+ console.error(
+ "Cannot decode stream source type of '" +
+ this.audioType +
+ "', since there is no registered decoder for that type."
+ );
+ return Promise.reject(
+ `Cannot decode stream source type of '${this.audioType}', since there is no registered decoder for that type.`
+ );
+ }
+ this.decoder = new Decoder();
+ // 创建数据解析器
+ const mime = mimeTypeMap[this.audioType];
+ const parser = new CodecParser(mime);
+ this.parser = parser;
+ await this.decoder.create();
+ this.headerRecieved = true;
+ }
+
+ const decoder = this.decoder;
+ const parser = this.parser;
+ if (!decoder || !parser) {
+ this.errored = true;
+ return Promise.reject(
+ "No parser or decoder attached in this AudioStreamSource"
+ );
+ }
+
+ await this.decodeData(data, decoder, parser);
+ if (done) await this.decodeFlushData(decoder, parser);
+ this.checkBufferedPlay();
+ }
+
+ /**
+ * 检查采样率,如果还未解析出采样率,那么将设置采样率,如果当前采样率与之前不同,那么发出警告
+ */
+ checkSampleRate(info) {
+ for (const one of info) {
+ const frame = isOggPage(one) ? one.codecFrames[0] : one;
+ if (frame) {
+ const rate = frame.header.sampleRate;
+ if (this.sampleRate === 0) {
+ this.sampleRate = rate;
+ break;
+ } else {
+ if (rate !== this.sampleRate) {
+ console.warn("Sample rate in stream audio must be constant.");
+ }
+ }
+ }
+ }
+ }
+
+ /**
+ * 解析音频数据
+ */
+ async decodeData(data, decoder, parser) {
+ // 解析音频数据
+ const audioData = await decoder.decode(data);
+ if (!audioData) return;
+ // @ts-expect-error 库类型声明错误
+ const audioInfo = [...parser.parseChunk(data)];
+
+ // 检查采样率
+ this.checkSampleRate(audioInfo);
+ // 追加音频数据
+ this.appendDecodedData(audioData, audioInfo);
+ }
+
+ /**
+ * 解码剩余数据
+ */
+ async decodeFlushData(decoder, parser) {
+ const audioData = await decoder.flush();
+ if (!audioData) return;
+ // @ts-expect-error 库类型声明错误
+ const audioInfo = [...parser.flush()];
+
+ this.checkSampleRate(audioInfo);
+ this.appendDecodedData(audioData, audioInfo);
+ }
+
+ /**
+ * 追加音频数据
+ */
+ appendDecodedData(data, info) {
+ const channels = data.channelData.length;
+ if (channels === 0) return;
+ if (this.audioData.length !== channels) {
+ this.audioData = [];
+ for (let i = 0; i < channels; i++) {
+ this.audioData.push([]);
+ }
+ }
+ // 计算出应该放在哪
+ const chunk = this.sampleRate * this.bufferChunkSize;
+ const sampled = this.bufferedSamples;
+ const pushIndex = Math.floor(sampled / chunk);
+ const bufferIndex = sampled % chunk;
+ const dataLength = data.channelData[0].length;
+ let buffered = 0;
+ let nowIndex = pushIndex;
+ let toBuffer = bufferIndex;
+ while (buffered < dataLength) {
+ const rest = toBuffer !== 0 ? chunk - bufferIndex : chunk;
+
+ for (let i = 0; i < channels; i++) {
+ const audioData = this.audioData[i];
+ if (!audioData[nowIndex]) {
+ audioData.push(new Float32Array(chunk));
+ }
+ const toPush = data.channelData[i].slice(buffered, buffered + rest);
+
+ audioData[nowIndex].set(toPush, toBuffer);
+ }
+ buffered += rest;
+ nowIndex++;
+ toBuffer = 0;
+ }
+
+ this.buffered +=
+ info.reduce((prev, curr) => prev + curr.duration, 0) / 1000;
+ this.bufferedSamples += info.reduce(
+ (prev, curr) => prev + curr.samples,
+ 0
+ );
+ }
+
+ /**
+ * 检查已缓冲内容,并在未开始播放时播放
+ */
+ checkBufferedPlay() {
+ if (this.playing || this.sampleRate === 0) return;
+ const played = this.lastBufferSamples / this.sampleRate;
+ const dt = this.buffered - played;
+ if (this.loaded) {
+ this.playAudio(played);
+ return;
+ }
+ if (dt < this.bufferPlayDuration) return;
+
+ this.lastBufferSamples = this.bufferedSamples;
+ // 需要播放
+ this.mergeBuffers();
+ if (!this.buffer) return;
+ if (this.playing) this.output.stop();
+ this.createSourceNode(this.buffer);
+ this.output.loop = false;
+ this.output.start(0, played);
+ this.lastStartTime = this.ac.currentTime;
+ this.playing = true;
+ this.output.addEventListener("ended", () => {
+ this.playing = false;
+ this.checkBufferedPlay();
+ });
+ }
+
+ mergeBuffers() {
+ const buffer = this.ac.createBuffer(
+ this.audioData.length,
+ this.bufferedSamples,
+ this.sampleRate
+ );
+ const chunk = this.sampleRate * this.bufferChunkSize;
+ const bufferedChunks = Math.floor(this.bufferedSamples / chunk);
+ const restLength = this.bufferedSamples % chunk;
+ for (let i = 0; i < this.audioData.length; i++) {
+ const audio = this.audioData[i];
+ const data = new Float32Array(this.bufferedSamples);
+ for (let j = 0; j < bufferedChunks; j++) {
+ data.set(audio[j], chunk * j);
+ }
+ if (restLength !== 0) {
+ data.set(
+ audio[bufferedChunks].slice(0, restLength),
+ chunk * bufferedChunks
+ );
+ }
+
+ buffer.copyToChannel(data, i, 0);
+ }
+ this.buffer = buffer;
+ }
+
+ async start() {
+ delete this.buffer;
+ this.headerRecieved = false;
+ this.audioType = "";
+ this.errored = false;
+ this.buffered = 0;
+ this.sampleRate = 0;
+ this.bufferedSamples = 0;
+ this.duration = 0;
+ this.loaded = false;
+ if (this.playing) this.output.stop();
+ this.playing = false;
+ this.lastStartTime = this.ac.currentTime;
+ }
+
+ end(done, reason) {
+ if (done && this.buffer) {
+ this.loaded = true;
+ delete this.controller;
+ this.mergeBuffers();
+
+ this.duration = this.buffered;
+ this.audioData = [];
+ this.decoder?.destroy();
+ delete this.decoder;
+ delete this.parser;
+ } else {
+ console.warn(
+ "Unexpected end when loading stream audio, reason: '" +
+ (reason ?? "") +
+ "'"
+ );
+ }
+ }
+
+ playAudio(when) {
+ if (!this.buffer) return;
+ this.lastStartTime = this.ac.currentTime;
+ if (this.playing) this.output.stop();
+ if (this.route.status !== AudioStatus.Playing) {
+ this.route.status = AudioStatus.Playing;
+ }
+ this.createSourceNode(this.buffer);
+ this.output.start(0, when);
+ this.playing = true;
+
+ this.output.addEventListener("ended", () => {
+ this.playing = false;
+ if (this.route.status === AudioStatus.Playing) {
+ this.route.status = AudioStatus.Stoped;
+ }
+ if (this.loop && !this.output.loop) this.play(0);
+ });
+ }
+ /**
+ * 开始播放这个音频源
+ */
+ play(when) {
+ if (this.playing || this.errored) return;
+ if (this.loaded && this.buffer) {
+ this.playing = true;
+ this.playAudio(when);
+ } else {
+ this.controller?.start();
+ }
+ }
+
+ createSourceNode(buffer) {
+ if (!this.target) return;
+ const node = this.ac.createBufferSource();
+ node.buffer = buffer;
+ if (this.playing) this.output.stop();
+ this.playing = false;
+ this.output = node;
+ node.connect(this.target.input);
+ node.loop = this.loop;
+ }
+ /**
+ * 停止播放这个音频源
+ * @returns 音频暂停的时刻 number
+ */
+ stop() {
+ if (this.playing) this.output.stop();
+ this.playing = false;
+ return this.ac.currentTime - this.lastStartTime;
+ }
+ /**
+ * 连接到音频路由图上,每次调用播放的时候都会执行一次
+ * @param target 连接至的目标 IAudioInput
+ */
+ connect(target) {
+ this.target = target;
+ }
+ /**
+ * 设置是否循环播放
+ * @param loop 是否循环 boolean)
+ */
+ setLoop(loop) {
+ this.loop = loop;
+ }
+ }
+ class AudioElementSource {
+ constructor(context) {
+ const audio = new Audio();
+ audio.preload = "none";
+ this.output = context.createMediaElementSource(audio);
+ this.audio = audio;
+ this.ac = context;
+ audio.addEventListener("play", () => {
+ this.playing = true;
+ if (this.route.status !== AudioStatus.Playing) {
+ this.route.status = AudioStatus.Playing;
+ }
+ });
+ audio.addEventListener("ended", () => {
+ this.playing = false;
+ if (this.route.status === AudioStatus.Playing) {
+ this.route.status = AudioStatus.Stoped;
+ }
+ });
+ }
+ get duration() {
+ return this.audio.duration;
+ }
+ get currentTime() {
+ return this.audio.currentTime;
+ }
+ /**
+ * 设置音频源的路径
+ * @param url 音频路径
+ */
+ setSource(url) {
+ this.audio.src = url;
+ }
+
+ play(when = 0) {
+ if (this.playing) return;
+ this.audio.currentTime = when;
+ this.audio.play();
+ }
+
+ stop() {
+ this.audio.pause();
+ this.playing = false;
+ if (this.route.status === AudioStatus.Playing) {
+ this.route.status = AudioStatus.Stoped;
+ }
+ return this.audio.currentTime;
+ }
+
+ connect(target) {
+ this.output.connect(target.input);
+ }
+
+ setLoop(loop) {
+ this.audio.loop = loop;
+ }
+ }
+ class AudioBufferSource {
+ constructor(context) {
+ this.output = context.createBufferSource();
+ /** 是否循环 */
+ this.loop = false;
+ /** 上一次播放是从何时开始的 */
+ this.lastStartWhen = 0;
+ /** 播放开始时刻 */
+ this.lastStartTime = 0;
+ this.duration = 0;
+ this.ac = context;
+ }
+ get currentTime() {
+ return this.ac.currentTime - this.lastStartTime + this.lastStartWhen;
+ }
+
+ /**
+ * 设置音频源数据
+ * @param buffer 音频源,可以是未解析的 ArrayBuffer,也可以是已解析的 AudioBuffer
+ */
+ async setBuffer(buffer) {
+ if (buffer instanceof ArrayBuffer) {
+ this.buffer = await this.ac.decodeAudioData(buffer);
+ } else {
+ this.buffer = buffer;
+ }
+ this.duration = this.buffer.duration;
+ }
+
+ play(when) {
+ if (this.playing || !this.buffer) return;
+ this.playing = true;
+ this.lastStartTime = this.ac.currentTime;
+ if (this.route.status !== AudioStatus.Playing) {
+ this.route.status = AudioStatus.Playing;
+ }
+ this.createSourceNode(this.buffer);
+ this.output.start(0, when);
+ this.output.addEventListener("ended", () => {
+ this.playing = false;
+ if (this.route.status === AudioStatus.Playing) {
+ this.route.status = AudioStatus.Stoped;
+ }
+ if (this.loop && !this.output.loop) this.play(0);
+ });
+ }
+
+ createSourceNode(buffer) {
+ if (!this.target) return;
+ const node = this.ac.createBufferSource();
+ node.buffer = buffer;
+ this.output = node;
+ node.connect(this.target.input);
+ node.loop = this.loop;
+ }
+
+ stop() {
+ this.output.stop();
+ return this.ac.currentTime - this.lastStartTime;
+ }
+
+ connect(target) {
+ this.target = target;
+ }
+
+ setLoop(loop) {
+ this.loop = loop;
+ }
+ }
+ class AudioPlayer {
+ constructor() {
+ /** 音频播放上下文 */
+ this.ac = new AudioContext();
+ /** 音量节点 */
+ this.gain = this.ac.createGain();
+ this.gain.connect(this.ac.destination);
+ this.audioRoutes = new Map();
+ }
+ /**
+ * 解码音频数据
+ * @param data 音频数据
+ */
+ decodeAudioData(data) {
+ return AudioDecoder.decodeAudioData(data, this);
+ }
+ /**
+ * 设置音量
+ * @param volume 音量
+ */
+ setVolume(volume) {
+ this.gain.gain.value = volume;
+ }
+
+ /**
+ * 获取音量
+ */
+ getVolume() {
+ return this.gain.gain.value;
+ }
+
+ /**
+ * 创建一个音频源
+ * @param Source 音频源类
+ */
+ createSource(Source) {
+ return new Source(this.ac);
+ }
+
+ /**
+ * 创建一个兼容流式音频源,可以与流式加载相结合,主要用于处理 opus ogg 不兼容的情况
+ */
+ createStreamSource() {
+ return new AudioStreamSource(this.ac);
+ }
+
+ /**
+ * 创建一个通过 audio 元素播放的音频源
+ */
+ createElementSource() {
+ return new AudioElementSource(this.ac);
+ }
+
+ /**
+ * 创建一个通过 AudioBuffer 播放的音频源
+ */
+ createBufferSource() {
+ return new AudioBufferSource(this.ac);
+ }
+
+ /**
+ * 获取音频目的地
+ */
+ getDestination() {
+ return this.gain;
+ }
+
+ /**
+ * 创建一个音频效果器
+ * @param Effect 效果器类
+ */
+ createEffect(Effect) {
+ return new Effect(this.ac);
+ }
+
+ /**
+ * 创建一个修改音量的效果器
+ * ```txt
+ * |----------|
+ * Input ----> | GainNode | ----> Output
+ * |----------|
+ * ```
+ */
+ createVolumeEffect() {
+ return new VolumeEffect(this.ac);
+ }
+
+ /**
+ * 创建一个立体声效果器
+ * ```txt
+ * |------------|
+ * Input ----> | PannerNode | ----> Output
+ * |------------|
+ * ```
+ */
+ createStereoEffect() {
+ return new StereoEffect(this.ac);
+ }
+
+ /**
+ * 创建一个修改单个声道音量的效果器
+ * ```txt
+ * |----------|
+ * -> | GainNode | \
+ * |--------------| / |----------| -> |------------|
+ * Input ----> | SplitterNode | ...... | MergerNode | ----> Output
+ * |--------------| \ |----------| -> |------------|
+ * -> | GainNode | /
+ * |----------|
+ * ```
+ */
+ createChannelVolumeEffect() {
+ return new ChannelVolumeEffect(this.ac);
+ }
+
+ /**
+ * 创建一个延迟效果器
+ * |-----------|
+ * Input ----> | DelayNode | ----> Output
+ * |-----------|
+ */
+ createDelay() {
+ return new DelayEffect(this.ac);
+ }
+
+ /**
+ * 创建一个回声效果器
+ * ```txt
+ * |----------|
+ * Input ----> | GainNode | ----> Output
+ * ^ |----------| |
+ * | |
+ * | |------------| ↓
+ * |-- | Delay Node | <--
+ * |------------|
+ * ```
+ */
+ createEchoEffect() {
+ return new EchoEffect(this.ac);
+ }
+
+ /**
+ * 创建一个音频播放路由
+ * @param source 音频源
+ */
+ createRoute(source) {
+ return new AudioRoute(source, this);
+ }
+
+ /**
+ * 添加一个音频播放路由,可以直接被播放
+ * @param id 这个音频播放路由的名称
+ * @param route 音频播放路由对象
+ */
+ addRoute(id, route) {
+ if (!this.audioRoutes) this.audioRoutes = new Map();
+ if (this.audioRoutes.has(id)) {
+ console.warn(
+ "Audio route with id of '" +
+ id +
+ "' has already existed. New route will override old route."
+ );
+ }
+ this.audioRoutes.set(id, route);
+ }
+
+ /**
+ * 根据名称获取音频播放路由对象
+ * @param id 音频播放路由的名称
+ */
+ getRoute(id) {
+ return this.audioRoutes.get(id);
+ }
+ /**
+ * 移除一个音频播放路由
+ * @param id 要移除的播放路由的名称
+ */
+ removeRoute(id) {
+ this.audioRoutes.delete(id);
+ }
+ /**
+ * 播放音频
+ * @param id 音频名称
+ * @param when 从音频的哪个位置开始播放,单位秒
+ */
+ play(id, when) {
+ const route = this.getRoute(id);
+ if (!route) {
+ console.warn(
+ "Cannot play audio route '" +
+ id +
+ "', since there is not added route named it."
+ );
+ return;
+ }
+
+ route.play(when);
+ }
+
+ /**
+ * 暂停音频播放
+ * @param id 音频名称
+ * @returns 当音乐真正停止时兑现
+ */
+ pause(id) {
+ const route = this.getRoute(id);
+ if (!route) {
+ console.warn(
+ "Cannot pause audio route '" +
+ id +
+ "', since there is not added route named it."
+ );
+ return;
+ }
+ return route.pause();
+ }
+
+ /**
+ * 停止音频播放
+ * @param id 音频名称
+ * @returns 当音乐真正停止时兑现
+ */
+ stop(id) {
+ const route = this.getRoute(id);
+ if (!route) {
+ console.warn(
+ "Cannot stop audio route '" +
+ id +
+ "', since there is not added route named it."
+ );
+ return;
+ }
+ return route.stop();
+ }
+
+ /**
+ * 继续音频播放
+ * @param id 音频名称
+ */
+ resume(id) {
+ const route = this.getRoute(id);
+ if (!route) {
+ console.warn(
+ "Cannot pause audio route '" +
+ id +
+ "', since there is not added route named it."
+ );
+ return;
+ }
+ route.resume();
+ }
+
+ /**
+ * 设置听者位置,x正方向水平向右,y正方向垂直于地面向上,z正方向垂直屏幕远离用户
+ * @param x 位置x坐标
+ * @param y 位置y坐标
+ * @param z 位置z坐标
+ */
+ setListenerPosition(x, y, z) {
+ const listener = this.ac.listener;
+ listener.positionX.value = x;
+ listener.positionY.value = y;
+ listener.positionZ.value = z;
+ }
+
+ /**
+ * 设置听者朝向,x正方向水平向右,y正方向垂直于地面向上,z正方向垂直屏幕远离用户
+ * @param x 朝向x坐标
+ * @param y 朝向y坐标
+ * @param z 朝向z坐标
+ */
+ setListenerOrientation(x, y, z) {
+ const listener = this.ac.listener;
+ listener.forwardX.value = x;
+ listener.forwardY.value = y;
+ listener.forwardZ.value = z;
+ }
+
+ /**
+ * 设置听者头顶朝向,x正方向水平向右,y正方向垂直于地面向上,z正方向垂直屏幕远离用户
+ * @param x 头顶朝向x坐标
+ * @param y 头顶朝向y坐标
+ * @param z 头顶朝向z坐标
+ */
+ setListenerUp(x, y, z) {
+ const listener = this.ac.listener;
+ listener.upX.value = x;
+ listener.upY.value = y;
+ listener.upZ.value = z;
+ }
+ }
+ class AudioRoute {
+ constructor(source, player) {
+ source.route = this;
+ this.output = source.output;
+
+ /** 效果器路由图 */
+ this.effectRoute = [];
+
+ /** 结束时长,当音频暂停或停止时,会经过这么长时间之后才真正终止播放,期间可以做音频淡入淡出等效果 */
+ this.endTime = 0;
+ /** 暂停时播放了多长时间 */
+ this.pauseCurrentTime = 0;
+ /** 当前播放状态 */
+ this.player = player;
+ this.status = AudioStatus.Stoped;
+
+ this.shouldStop = false;
+ /**
+ * 每次暂停或停止时自增,用于判断当前正在处理的情况。
+ * 假如暂停后很快播放,然后很快暂停,那么需要根据这个来判断实际是否应该执行暂停后操作
+ */
+ this.stopIdentifier = 0;
+ /** 暂停时刻 */
+ this.pauseTime = 0;
+ this.source = source;
+ this.source.player = player;
+ }
+ /** 音频时长,单位秒 */
+ get duration() {
+ return this.source.duration;
+ }
+ /** 当前播放了多长时间,单位秒 */
+ get currentTime() {
+ if (this.status === AudioStatus.Paused) {
+ return this.pauseCurrentTime;
+ } else {
+ return this.source.currentTime;
+ }
+ }
+ set currentTime(time) {
+ this.source.stop();
+ this.source.play(time);
+ }
+ /**
+ * 设置结束时间,暂停或停止时,会经过这么长时间才终止音频的播放,这期间可以做一下音频淡出的效果。
+ * @param time 暂停或停止时,经过多长时间之后才会结束音频的播放
+ */
+ setEndTime(time) {
+ this.endTime = time;
+ }
+
+ /**
+ * 当音频播放时执行的函数,可以用于音频淡入效果
+ * @param fn 音频开始播放时执行的函数
+ */
+ onStart(fn) {
+ this.audioStartHook = fn;
+ }
+
+ /**
+ * 当音频暂停或停止时执行的函数,可以用于音频淡出效果
+ * @param fn 音频在暂停或停止时执行的函数,不填时表示取消这个钩子。
+ * 包含两个参数,第一个参数是结束时长,第二个参数是当前音频播放路由对象
+ */
+ onEnd(fn) {
+ this.audioEndHook = fn;
+ }
+
+ /**
+ * 开始播放这个音频
+ * @param when 从音频的什么时候开始播放,单位秒
+ */
+ async play(when = 0) {
+ if (this.status === AudioStatus.Playing) return;
+ this.link();
+ await this.player.ac.resume();
+ if (this.effectRoute.length > 0) {
+ const first = this.effectRoute[0];
+ this.source.connect(first);
+ const last = this.effectRoute.at(-1);
+ last.connect({ input: this.player.getDestination() });
+ } else {
+ this.source.connect({ input: this.player.getDestination() });
+ }
+ this.source.play(when);
+ this.status = AudioStatus.Playing;
+ this.pauseTime = 0;
+ this.audioStartHook?.(this);
+ this.startAllEffect();
+ if (this.status !== AudioStatus.Playing) {
+ this.status = AudioStatus.Playing;
+ }
+ }
+
+ /**
+ * 暂停音频播放
+ */
+ async pause() {
+ if (this.status !== AudioStatus.Playing) return;
+ this.status = AudioStatus.Pausing;
+ this.stopIdentifier++;
+ const identifier = this.stopIdentifier;
+ if (this.audioEndHook) {
+ this.audioEndHook(this.endTime, this);
+ await sleep(this.endTime);
+ }
+ if (
+ this.status !== AudioStatus.Pausing ||
+ this.stopIdentifier !== identifier
+ ) {
+ return;
+ }
+ this.pauseCurrentTime = this.source.currentTime;
+ const time = this.source.stop();
+ this.pauseTime = time;
+ if (this.shouldStop) {
+ this.status = AudioStatus.Stoped;
+ this.endAllEffect();
+
+ this.shouldStop = false;
+ } else {
+ this.status = AudioStatus.Paused;
+ this.endAllEffect();
+ }
+ this.endAllEffect();
+ }
+
+ /**
+ * 继续音频播放
+ */
+ resume() {
+ if (this.status === AudioStatus.Playing) return;
+ if (
+ this.status === AudioStatus.Pausing ||
+ this.status === AudioStatus.Stoping
+ ) {
+ this.audioStartHook?.(this);
+
+ return;
+ }
+ if (this.status === AudioStatus.Paused) {
+ this.play(this.pauseTime);
+ } else {
+ this.play(0);
+ }
+ this.status = AudioStatus.Playing;
+ this.pauseTime = 0;
+ this.audioStartHook?.(this);
+ this.startAllEffect();
+ }
+
+ /**
+ * 停止音频播放
+ */
+ async stop() {
+ if (this.status !== AudioStatus.Playing) {
+ if (this.status === AudioStatus.Pausing) {
+ this.shouldStop = true;
+ }
+ return;
+ }
+ this.status = AudioStatus.Stoping;
+ this.stopIdentifier++;
+ const identifier = this.stopIdentifier;
+ if (this.audioEndHook) {
+ this.audioEndHook(this.endTime, this);
+ await sleep(this.endTime);
+ }
+ if (
+ this.status !== AudioStatus.Stoping ||
+ this.stopIdentifier !== identifier
+ ) {
+ return;
+ }
+ this.source.stop();
+ this.status = AudioStatus.Stoped;
+ this.pauseTime = 0;
+ this.endAllEffect();
+ }
+
+ /**
+ * 添加效果器
+ * @param effect 要添加的效果,可以是数组,表示一次添加多个
+ * @param index 从哪个位置开始添加,如果大于数组长度,那么加到末尾,如果小于0,那么将会从后面往前数。默认添加到末尾
+ */
+ addEffect(effect, index) {
+ if (isNil(index)) {
+ if (effect instanceof Array) {
+ this.effectRoute.push(...effect);
+ } else {
+ this.effectRoute.push(effect);
+ }
+ } else {
+ if (effect instanceof Array) {
+ this.effectRoute.splice(index, 0, ...effect);
+ } else {
+ this.effectRoute.splice(index, 0, effect);
+ }
+ }
+ this.setOutput();
+ if (this.source.playing) this.link();
+ }
+
+ /**
+ * 移除一个效果器
+ * @param effect 要移除的效果
+ */
+ removeEffect(effect) {
+ const index = this.effectRoute.indexOf(effect);
+ if (index === -1) return;
+ this.effectRoute.splice(index, 1);
+ effect.disconnect();
+ this.setOutput();
+ if (this.source.playing) this.link();
+ }
+
+ setOutput() {
+ const effect = this.effectRoute.at(-1);
+ if (!effect) this.output = this.source.output;
+ else this.output = effect.output;
+ }
+
+ /**
+ * 连接音频路由图
+ */
+ link() {
+ this.effectRoute.forEach((v) => v.disconnect());
+ this.effectRoute.forEach((v, i) => {
+ const next = this.effectRoute[i + 1];
+ if (next) {
+ v.connect(next);
+ }
+ });
+ }
+
+ startAllEffect() {
+ this.effectRoute.forEach((v) => v.start());
+ }
+
+ endAllEffect() {
+ this.effectRoute.forEach((v) => v.end());
+ }
+ }
+
+ const audioPlayer = new AudioPlayer();
+
+ class BgmController {
+ constructor(player) {
+ this.mainGain = player.createVolumeEffect();
+ this.player = player;
+ /** bgm音频名称的前缀 */
+ this.prefix = "bgms.";
+ /** 每个 bgm 的音量控制器 */
+ this.gain = new Map();
+
+ /** 正在播放的 bgm */
+ this.playingBgm = "";
+ /** 是否正在播放 */
+ this.playing = false;
+
+ /** 是否已经启用 */
+ this.enabled = true;
+ /** 是否屏蔽所有的音乐切换 */
+ this.blocking = false;
+ /** 渐变时长 */
+ this.transitionTime = 2000;
+ }
+
+ /**
+ * 设置音频渐变时长
+ * @param time 渐变时长
+ */
+ setTransitionTime(time) {
+ this.transitionTime = time;
+ for (const [, value] of this.gain) {
+ value.transition.time(time);
+ }
+ }
+
+ /**
+ * 屏蔽音乐切换
+ */
+ blockChange() {
+ this.blocking = true;
+ }
+
+ /**
+ * 取消屏蔽音乐切换
+ */
+ unblockChange() {
+ this.blocking = false;
+ }
+
+ /**
+ * 设置总音量大小
+ * @param volume 音量大小
+ */
+ setVolume(volume) {
+ this.mainGain.setVolume(volume);
+ this._volume = volume;
+ }
+ /**
+ * 获取总音量大小
+ */
+ getVolume() {
+ return this.mainGain.getVolume();
+ }
+ /**
+ * 设置是否启用
+ * @param enabled 是否启用
+ */
+ setEnabled(enabled) {
+ if (enabled) this.resume();
+ else this.stop();
+ this.enabled = enabled;
+ }
+
+ /**
+ * 设置 bgm 音频名称的前缀
+ */
+ setPrefix(prefix) {
+ this.prefix = prefix;
+ }
+
+ getId(name) {
+ return `${this.prefix}${name}`;
+ }
+
+ /**
+ * 根据 bgm 名称获取其 AudioRoute 实例
+ * @param id 音频名称
+ */
+ get(id) {
+ return this.player.getRoute(this.getId(id));
+ }
+
+ /**
+ * 添加一个 bgm
+ * @param id 要添加的 bgm 的名称
+ * @param url 指定 bgm 的加载地址
+ */
+ addBgm(id, url = `project/bgms/${id}`) {
+ const type = guessTypeByExt(id);
+ if (!type) {
+ console.warn(
+ "Unknown audio extension name: '" +
+ id.split(".").slice(0, -1).join(".") +
+ "'"
+ );
+ return;
+ }
+ const gain = this.player.createVolumeEffect();
+ if (isAudioSupport(type)) {
+ const source = audioPlayer.createElementSource();
+ source.setSource(url);
+ source.setLoop(true);
+ const route = new AudioRoute(source, audioPlayer);
+ route.addEffect([gain, this.mainGain]);
+ audioPlayer.addRoute(this.getId(id), route);
+ this.setTransition(id, route, gain);
+ } else {
+ const source = audioPlayer.createStreamSource();
+ const stream = new StreamLoader(url);
+ stream.pipe(source);
+ source.setLoop(true);
+ const route = new AudioRoute(source, audioPlayer);
+ route.addEffect([gain, this.mainGain]);
+ audioPlayer.addRoute(this.getId(id), route);
+ this.setTransition(id, route, gain);
+ }
+ }
+
+ /**
+ * 移除一个 bgm
+ * @param id 要移除的 bgm 的名称
+ */
+ removeBgm(id) {
+ this.player.removeRoute(this.getId(id));
+ const gain = this.gain.get(id);
+ gain?.transition.ticker.destroy();
+ this.gain.delete(id);
+ }
+
+ setTransition(id, route, gain) {
+ const transition = new Transition();
+ transition
+ .time(this.transitionTime)
+ .mode(linear())
+ .transition("volume", 0);
+
+ const tick = () => {
+ gain.setVolume(transition.value.volume);
+ };
+
+ /**
+ * @param expect 在结束时应该是正在播放还是停止
+ */
+ const setTick = async (expect) => {
+ transition.ticker.remove(tick);
+ transition.ticker.add(tick);
+ const identifier = route.stopIdentifier;
+ await sleep(this.transitionTime + 500);
+ if (route.status === expect && identifier === route.stopIdentifier) {
+ transition.ticker.remove(tick);
+ if (route.status === AudioStatus.Playing) {
+ gain.setVolume(1);
+ } else {
+ gain.setVolume(0);
+ }
+ }
+ };
+
+ route.onStart(async () => {
+ transition.transition("volume", 1);
+ setTick(AudioStatus.Playing);
+ });
+ route.onEnd(() => {
+ transition.transition("volume", 0);
+ setTick(AudioStatus.Paused);
+ });
+ route.setEndTime(this.transitionTime);
+
+ this.gain.set(id, { effect: gain, transition });
+ }
+
+ /**
+ * 播放一个 bgm
+ * @param id 要播放的 bgm 名称
+ */
+ play(id, when) {
+ if (this.blocking) return;
+ if (id !== this.playingBgm && this.playingBgm) {
+ this.player.pause(this.getId(this.playingBgm));
+ }
+ this.playingBgm = id;
+ if (!this.enabled) return;
+ this.player.play(this.getId(id), when);
+ this.playing = true;
+ }
+
+ /**
+ * 继续当前的 bgm
+ */
+ resume() {
+ if (this.blocking || !this.enabled || this.playing) return;
+ if (this.playingBgm) {
+ this.player.resume(this.getId(this.playingBgm));
+ }
+ this.playing = true;
+ }
+
+ /**
+ * 暂停当前的 bgm
+ */
+ pause() {
+ if (this.blocking || !this.enabled) return;
+ if (this.playingBgm) {
+ this.player.pause(this.getId(this.playingBgm));
+ }
+ this.playing = false;
+ }
+
+ /**
+ * 停止当前的 bgm
+ */
+ stop() {
+ if (this.blocking || !this.enabled) return;
+ if (this.playingBgm) {
+ this.player.stop(this.getId(this.playingBgm));
+ }
+ this.playing = false;
+ }
+ }
+ const bgmController = new BgmController(audioPlayer);
+
+ class SoundPlayer {
+ constructor(player) {
+ /** 每个音效的唯一标识符 */
+ this.num = 0;
+ this.enabled = true;
+ this.gain = player.createVolumeEffect();
+ /** 每个音效的数据 */
+ this.buffer = new Map();
+ /** 所有正在播放的音乐 */
+ this.playing = new Set();
+ this.player = player;
+ }
+ /**
+ * 设置是否启用音效
+ * @param enabled 是否启用音效
+ */
+ setEnabled(enabled) {
+ if (!enabled) this.stopAllSounds();
+ this.enabled = enabled;
+ }
+
+ /**
+ * 设置音量大小
+ * @param volume 音量大小
+ */
+ setVolume(volume) {
+ this.gain.setVolume(volume);
+ }
+ /**
+ * 获取音量大小
+ */
+ getVolume() {
+ return this.gain.getVolume();
+ }
+ /**
+ * 添加一个音效
+ * @param id 音效名称
+ * @param data 音效的Uint8Array数据
+ */
+ async add(id, data) {
+ const buffer = await this.player.decodeAudioData(data);
+ if (!buffer) {
+ console.warn(
+ "Cannot decode sound '" +
+ id +
+ "', since audio file may not supported by 2.b."
+ );
+ return;
+ }
+ this.buffer.set(id, buffer);
+ }
+
+ /**
+ * 播放一个音效
+ * @param id 音效名称
+ * @param position 音频位置,[0, 0, 0]表示正中心,x轴指向水平向右,y轴指向水平向上,z轴指向竖直向上
+ * @param orientation 音频朝向,[0, 1, 0]表示朝向前方
+ */
+ play(id, position = [0, 0, 0], orientation = [1, 0, 0]) {
+ if (!this.enabled || !id) return -1;
+ const buffer = this.buffer.get(id);
+ if (!buffer) {
+ console.warn(
+ "Cannot play sound '" +
+ id +
+ "', since there is no added data named it."
+ );
+ return -1;
+ }
+ const soundNum = this.num++;
+
+ const source = this.player.createBufferSource();
+ source.setBuffer(buffer);
+ const route = this.player.createRoute(source);
+ const stereo = this.player.createStereoEffect();
+ stereo.setPosition(position[0], position[1], position[2]);
+ stereo.setOrientation(orientation[0], orientation[1], orientation[2]);
+ route.addEffect([stereo, this.gain]);
+ this.player.addRoute(`sounds.${soundNum}`, route);
+ route.play();
+ source.output.addEventListener("ended", () => {
+ this.playing.delete(soundNum);
+ });
+ this.playing.add(soundNum);
+ return soundNum;
+ }
+
+ /**
+ * 停止一个音效
+ * @param num 音效的唯一 id
+ */
+ stop(num) {
+ const id = `sounds.${num}`;
+ const route = this.player.getRoute(id);
+ if (route) {
+ route.stop();
+ this.player.removeRoute(id);
+ this.playing.delete(num);
+ }
+ }
+
+ /**
+ * 停止播放所有音效
+ */
+ stopAllSounds() {
+ this.playing.forEach((v) => {
+ const id = `sounds.${v}`;
+ const route = this.player.getRoute(id);
+ if (route) {
+ route.stop();
+ this.player.removeRoute(id);
+ }
+ });
+ this.playing.clear();
+ }
+ }
+ const soundPlayer = new SoundPlayer(audioPlayer);
+
+ function loadAllBgm() {
+ const data = data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d;
+ for (const bgm of data.main.bgms) {
+ bgmController.addBgm(bgm);
+ }
+ }
+ loadAllBgm();
+ AudioDecoder.registerDecoder(AudioType.Ogg, VorbisDecoder);
+ AudioDecoder.registerDecoder(AudioType.Opus, OpusDecoder);
+
+ core.plugin.audioSystem = {
+ AudioType,
+ AudioDecoder,
+ AudioStatus,
+ checkAudioType,
+ isAudioSupport,
+ audioPlayer,
+ soundPlayer,
+ bgmController,
+ guessTypeByExt,
+ BgmController,
+ SoundPlayer,
+ EchoEffect,
+ DelayEffect,
+ ChannelVolumeEffect,
+ VolumeEffect,
+ StereoEffect,
+ AudioEffect,
+ AudioPlayer,
+ AudioRoute,
+ AudioStreamSource,
+ AudioElementSource,
+ AudioBufferSource,
+ loadAllBgm,
+ StreamLoader,
+ };
+ //bgm相关复写
+ control.prototype.playBgm = (bgm, when) => {
+ bgm = core.getMappedName(bgm);
+ if (main.mode != "play" || !core.material.bgms[bgm]) return;
+ // 如果不允许播放
+ if (!core.musicStatus.bgmStatus) {
+ try {
+ core.musicStatus.playingBgm = bgm;
+ core.musicStatus.lastBgm = bgm;
+ core.material.bgms[bgm].pause();
+ } catch (e) {
+ console.error(e);
+ }
+ return;
+ }
+ core.setMusicBtn();
+
+ try {
+ bgmController.play(bgm, when);
+ } catch (e) {
+ console.log("无法播放BGM " + bgm);
+ console.error(e);
+ core.musicStatus.playingBgm = null;
+ }
+
+ };
+ control.prototype.pauseBgm = () => {
+ bgmController.pause();
+ core.setMusicBtn();
+ };
+
+ control.prototype.resumeBgm = function () {
+ bgmController.resume();
+ core.setMusicBtn();
+ };
+ control.prototype.checkBgm = function () {
+ core.playBgm(bgmController.playingBgm || main.startBgm);
+ };
+ control.prototype.triggerBgm = function () {
+ core.musicStatus.bgmStatus = !core.musicStatus.bgmStatus;
+ if (bgmController.playing) bgmController.pause();
+ else bgmController.resume();
+ core.setMusicBtn();
+ core.setLocalStorage("bgmStatus", core.musicStatus.bgmStatus);
+ };
+ //sound相关复写
+ control.prototype.playSound = function (
+ sound,
+ _pitch,
+ callback,
+ position,
+ orientation
+ ) {
+ if (main.mode != "play" || !core.musicStatus.soundStatus) return callback?.();
+ const name = core.getMappedName(sound);
+ const num = soundPlayer.play(name, position, orientation);
+ const route = audioPlayer.getRoute(`sounds.${num}`);
+ if (!route) {
+ callback?.();
+ return -1;
+ } else {
+ sleep(route.duration * 1000).then(() => callback?.());
+ return num;
+ }
+ };
+ control.prototype.stopSound = function (id) {
+ if (isNil(id)) {
+ soundPlayer.stopAllSounds();
+ } else {
+ soundPlayer.stop(id);
+ }
+ };
+ control.prototype.getPlayingSounds = function () {
+ return [...soundPlayer.playing];
+ };
+ //sound加载复写
+ loader.prototype._loadOneSound_decodeData = function (name, data) {
+ if (data instanceof Blob) {
+ var blobReader = new zip.BlobReader(data);
+ blobReader.init(function () {
+ blobReader.readUint8Array(0, blobReader.size, function (uint8) {
+ //core.loader._loadOneSound_decodeData(name, uint8.buffer);
+ soundPlayer.add(name, uint8);
+ });
+ });
+ return;
+ }
+ if (data instanceof ArrayBuffer) {
+ const uint8 = new Uint8Array(data);
+ soundPlayer.add(name, uint8);
+ }
+ };
+ //音量控制复写
+ soundPlayer.setVolume(
+ core.musicStatus.userVolume * core.musicStatus.designVolume
+ );
+ bgmController.setVolume(
+ core.musicStatus.userVolume * core.musicStatus.designVolume
+ );
+ actions.prototype._clickSwitchs_sounds_userVolume = function (delta) {
+ var value = Math.round(Math.sqrt(100 * core.musicStatus.userVolume));
+ if (value == 0 && delta < 0) return;
+ core.musicStatus.userVolume = core.clamp(
+ Math.pow(value + delta, 2) / 100,
+ 0,
+ 1
+ );
+ //audioContext 音效 不受designVolume 影响
+ if (core.musicStatus.gainNode != null)
+ core.musicStatus.gainNode.gain.value = core.musicStatus.userVolume;
+ soundPlayer.setVolume(
+ core.musicStatus.userVolume * core.musicStatus.designVolume
+ );
+ bgmController.setVolume(
+ core.musicStatus.userVolume * core.musicStatus.designVolume
+ );
+ core.setLocalStorage("userVolume", core.musicStatus.userVolume);
+ core.playSound("确定");
+ core.ui._drawSwitchs_sounds();
+ };
+},
"自定义常用事件": function () {
// editorBlocklyconfigPlus.js
// 自訂常見事件模板插件
@@ -12009,30 +11820,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
//定義表格操作行為
- editor_mode.OriginDoActionList = editor_mode.doActionList;
- editor_mode.doActionList = function (mode, actionList, callback) {
- if (editor_mode.mode == "CommonEventTemplate") {
- if (actionList.length == 0) return;
- printf("修改中...");
- var cb = function (objs_) {
- if (objs_.slice(-1)[0] != null) {
- printe(objs_.slice(-1)[0]);
- throw objs_.slice(-1)[0];
- }
- var str = "修改成功!";
- if (
- data_a1e2fb4a_e986_4524_b0da_9b7ba7c0874d.firstData.name ==
- "template"
- )
- str += "
请注意:全塔属性的name尚未修改,请及时予以设置。";
- printf(str);
- if (callback) callback();
- };
- editor.file.editCommonEventTemplate(actionList, cb);
- } else {
- editor_mode.OriginDoActionList(mode, actionList, callback);
- }
- };
+
//添加表格列
editor.table.CommonEventTemplateAddFunc = function () {
let obj = events_c12a15a8_c380_4b28_8144_256cba95f760;
@@ -12121,6 +11909,35 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
],
"event"
),
+ MotaActionFunctions.actionParser.parse({
+ "type": "taskEvent",
+ "text": "任务描述",
+ "n": 1,
+ "info": [
+ { "type": "checkItem", "checkItem": "yellowKey", "operator": ">=", "count": 0 },
+ { "type": "checkStatus", "checkStatus": "atk", "operator": ">=", "count": 10 },
+ { "type": "checkFlag", "checkFlag": "flag1", "operator": "=", "count": "\"value\"" },
+ { "type": "checkBlock", "checkBlock": "bat", "floorId": ["MT1", "MT2"], "operator": "<=", "count": 0 },
+ { "type": "kill", "operator": ">=", "count": 0 },
+ {
+ "type": "killLocs",
+ "loc": [
+ [1, 1]
+ ],
+ "floorId": "MT1",
+ "operator": ">=",
+ "count": 1
+ },
+ { "type": "killSpecial", "killSpecial": "61", "floorId": ["61"], "operator": ">=", "count": 1 },
+ { "type": "killAll", "floorId": ["MT1"] },
+ { "type": "specialBlock", "floorId": ["MT1"], "specialBlock": "血网伤害", "operator": "<", "count": 1 },
+ { "type": "gosthFloor", "floorId": ["MT1"], "operator": "<", "count": 1 },
+ { "type": "arrival", "floorId": "MT1" },
+ ],
+ "action": []
+ },
+ "taskEvent"
+ ),
MotaActionFunctions.actionParser.parse({
condition: "flag:__door__===2",
currentFloor: true,
@@ -12355,6 +12172,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
地图处理: [
MotaActionBlocks["battle_1_s"].xmlText(),
MotaActionBlocks["openDoor_s"].xmlText(),
+ MotaActionBlocks["specialDoor_s"].xmlText(),
MotaActionBlocks["closeDoor_s"].xmlText(),
MotaActionBlocks["show_s"].xmlText(),
MotaActionBlocks["hide_s"].xmlText(),
@@ -12521,6 +12339,40 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
MotaActionBlocks["setVolume_s"].xmlText(),
MotaActionBlocks["setBgmSpeed_s"].xmlText(),
],
+ 任务相关: [
+ MotaActionFunctions.actionParser.parseList({
+ "type": "menu",
+ "text": "流浪者",
+ "choices": [{
+ "type": "context",
+ "text": "对话",
+ "action": [
+ "\t[流浪者]你好啊",
+ ]
+ },
+ {
+ "type": "taskContext",
+ "text": "任务",
+ "text1": "新手任务",
+ "text2": "task1,task2",
+ "condition": "'新手任务'.split(',').some(v=>core.plugin.可接取任务.includes(v))||'task1,task2,'.split(',').some(v=>core.taskSystem.tasksInfo.findIndex(a => a.name ===v.name))",
+ "action": [
+
+ ]
+ },
+
+ ]
+ }),
+ MotaActionBlocks['setTask_s'].xmlText(),
+ MotaActionBlocks['removeTask_s'].xmlText(),
+ MotaActionBlocks['removeTaskByName_s'].xmlText(),
+ MotaActionBlocks['successTask_s'].xmlText(),
+ MotaActionBlocks['successTaskByName_s'].xmlText(),
+ MotaActionBlocks['trymitTask_s'].xmlText(),
+ MotaActionBlocks['trymitTaskByName_s'].xmlText(),
+ MotaActionBlocks['submitTask_s'].xmlText(),
+ MotaActionBlocks['clearTask_s'].xmlText(),
+ ],
UI绘制: [
MotaActionBlocks["previewUI_s"].xmlText(),
MotaActionBlocks["clearMap_s"].xmlText(),
@@ -12667,7 +12519,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"firstArrive",
"eachArrive",
"commonEvent",
- "item",
+ "item"
];
return commonEntries.indexOf(editor_blockly.entryType) >= 0;
};
@@ -13126,152 +12978,151 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
},
"瞬移轨迹": function () {
- // 在此增加新插件
- function popMove() {
- var ctx = core.getContextByName("popMove");
- if (!ctx)
- ctx = core.createCanvas(
- "popMove",
- 0,
- 0,
- core.__PIXELS__,
- core.__PIXELS__,
- 71
- );
- ctx.canvas.classList.add("gameCanvas", "anti-aliasing");
- core.clearMap(ctx);
- if (core.status.replay.speed <= 3 && !flags.stopPop) {
- var list = core.status.popMove || [];
- var count = 0;
- list.forEach(function (one) {
- // 由frame计算出dy
+ // 在此增加新插件
+ function popMove() {
+ var ctx = core.getContextByName("popMove");
+ if (!ctx)
+ ctx = core.createCanvas(
+ "popMove",
+ 0,
+ 0,
+ core.__PIXELS__,
+ core.__PIXELS__,
+ 71
+ );
+ ctx.canvas.classList.add("gameCanvas", "anti-aliasing");
+ core.clearMap(ctx);
+ if (core.status.replay.speed <= 3 && !flags.stopPop) {
+ var list = core.status.popMove || [];
+ var count = 0;
+ list.forEach(function (one) {
+ // 由frame计算出dy
- one.frame++;
- // 绘制
+ one.frame++;
+ // 绘制
- if (one.frame >= 0) core.setAlpha(ctx, 1 - one.frame / 30);
- else core.setAlpha(ctx, 1);
+ if (one.frame >= 0) core.setAlpha(ctx, 1 - one.frame / 30);
+ else core.setAlpha(ctx, 1);
- var length = Math.sqrt(
- Math.pow(one.px2 - one.px, 2) + Math.pow(one.py2 - one.py, 2)
- );
- //console.log(length)
- var li = length / 16;
- var lx = (one.px2 - one.px) / li;
- var ly = (one.py2 - one.py) / li;
- for (var i = 0; i < li; i += 1) {
- core.setAlpha(ctx, (1 - one.frame / 30) * ((i / li) * 0.8 + 0.2));
- core.drawLine(
- "popMove",
- one.px + i * lx,
- one.py + i * ly,
- one.px + (i + 0.5) * lx,
- one.py + (i + 0.5) * ly,
- "#E1E1E1",
- 6
- );
- if (i == 0)
- core.strokeCircle("popMove", one.px, one.py, 6, "#E1E1E1", 3);
- }
- core.strokeCircle("popMove", one.px2, one.py2, 6, "#E1E1E1", 3);
- core.strokeCircle(
- "popMove",
- one.px2,
- one.py2,
- 6 + (16 * one.frame) / 30,
- "#E1E1E1",
- 6 * (1 - one.frame / 30)
- );
- //core.drawLine('popMove', one.px, one.py, one.px2, one.py2, '#E1E1E1', 6);
+ var length = Math.sqrt(
+ Math.pow(one.px2 - one.px, 2) + Math.pow(one.py2 - one.py, 2)
+ );
+ //console.log(length)
+ var li = length / 16;
+ var lx = (one.px2 - one.px) / li;
+ var ly = (one.py2 - one.py) / li;
+ for (var i = 0; i < li; i += 1) {
+ core.setAlpha(ctx, (1 - one.frame / 30) * ((i / li) * 0.8 + 0.2));
+ core.drawLine(
+ "popMove",
+ one.px + i * lx,
+ one.py + i * ly,
+ one.px + (i + 0.5) * lx,
+ one.py + (i + 0.5) * ly,
+ "#E1E1E1",
+ 6
+ );
+ if (i == 0)
+ core.strokeCircle("popMove", one.px, one.py, 6, "#E1E1E1", 3);
+ }
+ core.strokeCircle("popMove", one.px2, one.py2, 6, "#E1E1E1", 3);
+ core.strokeCircle(
+ "popMove",
+ one.px2,
+ one.py2,
+ 6 + (16 * one.frame) / 30,
+ "#E1E1E1",
+ 6 * (1 - one.frame / 30)
+ );
+ //core.drawLine('popMove', one.px, one.py, one.px2, one.py2, '#E1E1E1', 6);
- if (one.frame >= 30) count++;
- });
- if (count > 0) list.splice(0, count);
- }
- }
+ if (one.frame >= 30) count++;
+ });
+ if (count > 0) list.splice(0, count);
+ }
+ }
- if (!main.replayChecking) {
- core.registerAnimationFrame("popMove", true, popMove);
- }
- this.addPopMove = function (px, py, px2, py2, frame) {
- var data = { px: px, py: py, px2: px2, py2: py2, frame: frame || 0 };
- if (core.status.replay.speed <= 3) {
- if (!core.status.popMove) core.status.popMove = [data];
- else core.status.popMove.push(data);
- }
- };
- },
+ if (!main.replayChecking) {
+ core.registerAnimationFrame("popMove", true, popMove);
+ }
+ this.addPopMove = function (px, py, px2, py2, frame) {
+ var data = { px: px, py: py, px2: px2, py2: py2, frame: frame || 0 };
+ if (core.status.replay.speed <= 3) {
+ if (!core.status.popMove) core.status.popMove = [data];
+ else core.status.popMove.push(data);
+ }
+ };
+},
"墓碑(编辑器)": function () {
- // 在此增加新插件
- if (main.mode != "editor") return; // 编辑器模式下使用
- var mapData = null;
- var drawMap = core.maps._drawMap_drawAll;
- core.maps._drawMap_drawAll = function (floorId) {
- floorId = floorId || core.status.floorId;
- if (!main.useCompress) {
- core.getLocalForage(
- "autoSave",
- { maps: [] },
- function (v) {
- mapData = v.maps[floorId]?.map;
- drawMap.call(core.maps, floorId);
- },
- function (e) {
- console.log(e);
- }
- );
- }
- };
+ // 在此增加新插件
+ if (main.mode != "editor") return; // 编辑器模式下使用
+ var mapData = null;
+ var drawMap = core.maps._drawMap_drawAll;
+ core.maps._drawMap_drawAll = function (floorId) {
+ floorId = floorId || core.status.floorId;
+ if (!main.useCompress) {
+ core.getLocalForage(
+ "autoSave", { maps: [] },
+ function (v) {
+ mapData = v.maps[floorId]?.map;
+ drawMap.call(core.maps, floorId);
+ },
+ function (e) {
+ console.log(e);
+ }
+ );
+ }
+ };
- maps.prototype._drawBlockInfo = function (blockInfo, x, y) {
- var alpha = 1.0;
- if (mapData && !!mapData[y] && mapData[y][x] == 0) {
- core.setAlpha("event", 0.5);
- core.setAlpha("event2", 0.5);
- }
- var image = blockInfo.image,
- posX = blockInfo.posX,
- posY = blockInfo.posY,
- height = blockInfo.height;
+ maps.prototype._drawBlockInfo = function (blockInfo, x, y) {
+ var alpha = 1.0;
+ if (mapData && !!mapData[y] && mapData[y][x] == 0) {
+ core.setAlpha("event", 0.5);
+ core.setAlpha("event2", 0.5);
+ }
+ var image = blockInfo.image,
+ posX = blockInfo.posX,
+ posY = blockInfo.posY,
+ height = blockInfo.height;
- core.clearMap("event", x * 32, y * 32, 32, 32);
- if (blockInfo.bigImage) {
- this._drawBlockInfo_bigImage(blockInfo, x, y, "event");
- core.setAlpha("event", alpha);
- core.setAlpha("event2", alpha);
- return;
- }
- core.drawImage(
- "event",
- image,
- posX * 32,
- posY * height + height - 32,
- 32,
- 32,
- x * 32,
- y * 32,
- 32,
- 32
- );
- if (height > 32) {
- core.clearMap("event2", x * 32, y * 32 + 32 - height, 32, height - 32);
- core.drawImage(
- "event2",
- image,
- posX * 32,
- posY * height,
- 32,
- height - 32,
- x * 32,
- y * 32 + 32 - height,
- 32,
- height - 32
- );
- }
- core.setAlpha("event", alpha);
- core.setAlpha("event2", alpha);
- };
- },
+ core.clearMap("event", x * 32, y * 32, 32, 32);
+ if (blockInfo.bigImage) {
+ this._drawBlockInfo_bigImage(blockInfo, x, y, "event");
+ core.setAlpha("event", alpha);
+ core.setAlpha("event2", alpha);
+ return;
+ }
+ core.drawImage(
+ "event",
+ image,
+ posX * 32,
+ posY * height + height - 32,
+ 32,
+ 32,
+ x * 32,
+ y * 32,
+ 32,
+ 32
+ );
+ if (height > 32) {
+ core.clearMap("event2", x * 32, y * 32 + 32 - height, 32, height - 32);
+ core.drawImage(
+ "event2",
+ image,
+ posX * 32,
+ posY * height,
+ 32,
+ height - 32,
+ x * 32,
+ y * 32 + 32 - height,
+ 32,
+ height - 32
+ );
+ }
+ core.setAlpha("event", alpha);
+ core.setAlpha("event2", alpha);
+ };
+},
"小地图": function () {
// 在此增加新插件
// ----- 不可自定义 杂七杂八的变量
@@ -13316,7 +13167,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
// ---- 可自定义,默认数值
const defaultValue = {
font: "Verdana", // 默认字体
- scale: 60, // 默认地图缩放比例
+ scale: 20, // 默认地图缩放比例
depth: Infinity, // 默认的遍历深度
};
@@ -13610,26 +13461,26 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
sh,
scale = defaultValue.scale
) {
- core.clearMap(ctx, sx, sy, sw + 40, sh + 60);
+ core.clearMap(ctx, sx, sy, sw + 13, sh + 20);
if (core.domStyle.isVertical) {
- sy += 50;
- sx += 15;
+ sy += 17;
+ sx += 5;
} else {
- sy += 60;
- sx += 30;
+ sy += 20;
+ sx += 10;
}
- core.fillRect(ctx, sx - 10, sy - 10, sw + 20, sh + 20, "#000");
- core.strokeRect(ctx, sx - 10, sy - 10, sw + 20, sh + 20, "#fff", 5);
+ core.fillRect(ctx, sx - 3, sy - 3, sw + 7, sh + 7, "#000");
+ core.strokeRect(ctx, sx - 3, sy - 3, sw + 7, sh + 7, "#fff", 2);
core.setTextAlign("outerUI", "center");
core.fillBoldText1(
ctx,
core.status.maps[center].areas,
sx + sw / 2,
- sy - 20,
+ sy - 7,
"#FFFFFF",
"#000000",
- 6,
- "bold 42px Verdana"
+ 2,
+ "bold 14px Verdana"
);
const locs = info.locs;
for (const id in locs) {
@@ -13676,8 +13527,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
19,
fx + min / 4,
fy + (min * 5) / 16,
- 32,
- 19
+ 11,
+ 6
);
// 显示漏怪数量
if (core.getFlag("showEnemy")) {
@@ -13697,7 +13548,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
fx + (w * 3) / 10,
fy + (h * 7) / 10,
color,
- 22 + "px normal"
+ 7 + "px normal"
);
ctx.shadowBlur = 0;
}
@@ -13709,1136 +13560,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
fx + min / 2,
fy + (min * 3) / 4,
"#FFFFFF",
- "bold 42px Verdana"
+ "bold 14px Verdana"
);
}
}
};
-},
- "楼传": function () {
- // 在此增加新插件
-
- core.canMoveFloor = function () {
- let canmove = false;
- core.status.thisMap.blocks.forEach((block) => {
- if (
- !block.disable &&
- (block.event.id == "upFloor" || block.event.id == "downFloor")
- ) {
- let automaticRoute = core.automaticRoute(block.x, block.y);
- if (!core.flags.flyNearStair || automaticRoute.length > 0) {
- let loc = automaticRoute.pop();
- loc = automaticRoute.pop();
- if (core.canMoveDirectly(loc?.x, loc?.y) >= 0 || !loc) {
- canmove = true;
- }
- }
- }
- });
- return canmove;
- };
- ui.prototype._drawViewMaps_drawHint = function () {
- core.playSound("打开界面");
- };
-
- ////// 绘制浏览地图界面 //////
- ui.prototype._drawViewMaps = function (index, x, y) {
- core.lockControl();
-
- core.clearMap("data");
- core.status.event.id = "viewMaps";
- this.clearUI();
- //console.log(index)
- if (index == null) index = core.floorIds.indexOf(core.status.floorId);
- core.animateFrame.tip = null;
- core.status.checkBlock.cache = {};
- let data = this._drawViewMaps_buildData(index, x, y);
- core.drawWindowSkin("winskin1.webp", "ui", 0, 0, 416, 416);
- let page = core.status.event.data.index;
- let floorId = core.status.event.data.floorId;
- core.ui.statusBar._update_map(floorId);
- const bfs = core.plugin.bfsSearch(floorId, 1, true);
- const mapdir = bfs.mapdir[floorId];
- core.setTextAlign("ui", "center");
- let size = (core.__PIXELS__ * 3) / 4; //312
- const areas = core.getFlag("areas");
-
- let i = areas.findIndex((v) => v.maps.includes(floorId));
- core.fillRoundRect("ui", 15 - 2, 15 - 2, 35 + 4, 35 + 4, 4, "#444444");
- core.strokeRoundRect(
- "ui",
- 15 - 4,
- 15 - 4,
- 35 + 8,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- core.fillBoldText1(
- "ui",
- "当前",
- 13 + 20,
- 17 + 20,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
-
- core.fillRoundRect(
- "ui",
- 15 - 2,
- 15 - 2 + 35 + 8 + size + 8 - 54,
- 35 + 4,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4,
- 15 - 4 + 35 + 8 + size + 8 - 54,
- 35 + 8,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- if (
- !core.status.maps[core.floorIds[page]].canFlyTo ||
- !core.hasVisitedFloor(core.floorIds[page])
- ) {
- core.fillBoldText1(
- "ui",
- "预览",
- 13 + 20,
- 17 + 20 + 35 + 8 + size + 8 - 54,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "传送",
- 13 + 20,
- 17 + 20 + 35 + 8 + size + 8 - 54,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
- core.fillRoundRect(
- "ui",
- 15 - 4 + size - 2 + 45,
- 15 - 2 + size - 4 + 45,
- 35 + 4,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4 + size - 4 + 45,
- 15 - 4 + size - 4 + 45,
- 35 + 8,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- core.fillBoldText1(
- "ui",
- "离开",
- 15 - 4 + size - 4 + 45 + 22,
- 15 - 4 + size - 4 + 45 + 26,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
-
- core.fillRoundRect(
- "ui",
- 15 + 44 - 2,
- 15 - 2,
- size + 4 - 58,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 + 44 - 4,
- 15 - 4,
- size + 8 - 58,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- if (mapdir.includes("up")) {
- core.fillBoldText1(
- "ui",
- "北▲",
- 30 + 145 + 10,
- 17 + 20,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "北▲",
- 30 + 145 + 10,
- 17 + 20,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
-
- core.fillRoundRect(
- "ui",
- 15 - 2,
- 59 - 2,
- 35 + 4,
- size + 4 - 58,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4,
- 59 - 4,
- 35 + 8,
- size + 8 - 58,
- 4,
- "#444444",
- 1
- );
- if (mapdir.includes("left")) {
- core.fillBoldText1(
- "ui",
- "西",
- 15 + 17,
- 25 + 150,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- core.fillBoldText1(
- "ui",
- "◀",
- 15 + 17,
- 45 + 150,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "西",
- 15 + 17,
- 25 + 150,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- core.fillBoldText1(
- "ui",
- "◀",
- 15 + 17,
- 45 + 150,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
- core.fillRoundRect(
- "ui",
- 15 + 44 - 2,
- 15 - 2 + size - 4,
- size + 4 - 58,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 + 44 - 4,
- 15 - 4 + size - 4,
- size + 8 - 58,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- if (mapdir.includes("down")) {
- core.fillBoldText1(
- "ui",
- "南▼",
- 30 + 145 + 10,
- 17 + 20 + size - 4,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "南▼",
- 30 + 145 + 10,
- 17 + 20 + size - 4,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
-
- core.fillRoundRect(
- "ui",
- 15 - 2 + size - 4,
- 59 - 2,
- 35 + 4,
- size + 4 - 58,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4 + size - 4,
- 59 - 4,
- 35 + 8,
- size + 8 - 58,
- 4,
- "#444444",
- 1
- );
- if (mapdir.includes("right")) {
- core.fillBoldText1(
- "ui",
- "东",
- 15 + 17 + size - 4,
- 25 + 150,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- core.fillBoldText1(
- "ui",
- "▶",
- 15 + 17 + size - 4,
- 45 + 150,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "东",
- 15 + 17 + size - 4,
- 25 + 150,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- core.fillBoldText1(
- "ui",
- "▶",
- 15 + 17 + size - 4,
- 45 + 150,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
- core.fillRoundRect(
- "ui",
- 60 - 2,
- 60 - 2,
- size - 58 + 4,
- size - 58 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 60 - 4,
- 60 - 4,
- size - 58 + 8,
- size - 58 + 8,
- 4,
- "#444444",
- 1
- );
- core.drawThumbnail(floorId, null, {
- damage: data.damage,
- ctx: "ui",
- x: 58,
- y: 58,
- size: 0.62,
- all: data.all,
- });
- if (
- !core.status.maps[core.floorIds[page]].canFlyTo ||
- !core.hasVisitedFloor(core.floorIds[page])
- ) {
- /*core.fillRect("ui", 58,
- 58,
- size - 50,
- size - 50, "rgba(0,0,0,0.5)")*/
- core.getContextByName("ui").globalAlpha = 0.7;
-
- core.drawImage(
- "ui",
- "miwu.webp",
- 0,
- 0,
- size,
- size,
- 58,
- 58,
- size - 50,
- size - 50
- );
- core.getContextByName("ui").globalAlpha = 1;
- /*core.fillText("ui", '?', 188,
- 278,
- "rgba(255,255,255,0.2)", this._buildFont(250, true))*/
- }
- core.fillRoundRect(
- "ui",
- 15 + 44 - 2,
- 60 - 2 + size - 4,
- size + 4 - 58,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 + 44 - 4,
- 60 - 4 + size - 4,
- size + 8 - 58,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- core.fillBoldText1(
- "ui",
- core.status.maps[floorId].areas,
- 30 + 145 + 10,
- 17 + 65 + size - 4,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- core.fillRoundRect(
- "ui",
- 15 - 2,
- 60 - 2 + size - 4,
- 35 + 4,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4,
- 60 - 4 + size - 4,
- 35 + 8,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- if (i === 0) {
- core.fillBoldText1(
- "ui",
- "◀",
- 30,
- 17 + 65 + size - 4,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "◀",
- 30,
- 17 + 65 + size - 4,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
- core.fillRoundRect(
- "ui",
- 15 - 2 + size - 4,
- 60 - 2 + size - 4,
- 35 + 4,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4 + size - 4,
- 60 - 4 + size - 4,
- 35 + 8,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- if (i === areas.length - 1) {
- core.fillBoldText1(
- "ui",
- "▶",
- 30 + 300 + 10,
- 17 + 65 + size - 4,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "▶",
- 30 + 300 + 10,
- 17 + 65 + size - 4,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
-
- core.fillRoundRect(
- "ui",
- 15 - 2 + size - 4,
- 15 - 2,
- 80 + 4,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4 + size - 4,
- 15 - 4,
- 80 + 8,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- if (mapdir.includes("upFloor")) {
- core.fillBoldText1(
- "ui",
- "上楼",
- 30 + 320 + 10,
- 17 + 20,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "上楼",
- 30 + 320 + 10,
- 17 + 20,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
- core.fillRoundRect(
- "ui",
- 15 - 2 + size - 4,
- 15 - 2 + size - 4,
- 80 + 4,
- 35 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4 + size - 4,
- 15 - 4 + size - 4,
- 80 + 8,
- 35 + 8,
- 4,
- "#444444",
- 1
- );
- if (mapdir.includes("downFloor")) {
- core.fillBoldText1(
- "ui",
- "下楼",
- 30 + 320 + 10,
- 17 + 20 + size - 4,
- "#FFFFFF",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- } else {
- core.fillBoldText1(
- "ui",
- "下楼",
- 30 + 320 + 10,
- 17 + 20 + size - 4,
- "#909090",
- "#000000",
- 2,
- this._buildFont(18, true)
- );
- }
-
- core.fillRoundRect(
- "ui",
- 15 - 2 + size - 4 + 35 + 8,
- 59 - 2,
- 37 + 4,
- (size - 58) / 2 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4 + size - 4 + 35 + 8,
- 59 - 4,
- 37 + 8,
- (size - 58) / 2 + 8,
- 4,
- "#444444",
- 1
- );
- const title = core.status.maps[floorId].title;
- //const length = title.length
- fillTextVertical(
- "ui",
- title,
- 15 - 4 + size - 4 + 45,
- 85,
- core.hasVisitedFloor(floorId) ? "#FFFFFF" : "#444444",
- "#000000",
- 18
- );
- //const uictx = main.dom.gameCanvas.ui.getContext('2d')
- core.fillRoundRect(
- "ui",
- 15 - 2 + size - 4 + 35 + 8,
- 59 - 2 + (size - 58) / 2 + 8,
- 37 + 4,
- 119 + 4,
- 4,
- "#444444"
- );
- core.strokeRoundRect(
- "ui",
- 15 - 4 + size - 4 + 35 + 8,
- 59 - 4 + (size - 58) / 2 + 8,
- 37 + 8,
- 119 + 8,
- 4,
- "#444444",
- 1
- );
- if (core.getFlag("showEnemy")) {
- fillTextVertical(
- "ui",
- "关闭漏怪检测",
- 15 - 4 + size - 4 + 45,
- 220,
- "#FFFFFF",
- "#000000",
- 18
- );
- } else {
- fillTextVertical(
- "ui",
- "开启漏怪检测",
- 15 - 4 + size - 4 + 45,
- 220,
- "#FFFFFF",
- "#000000",
- 18
- );
- }
-
- //uictx.fillTextVertical(title, 15 - 4 + size - 4 + 35 + 29, 25 + 150)
- //fillTextVertical('ui', title, 15 - 4 + size - 4 + 35 + 29, 25 + 150, '#FFFFFF', this._buildFont(18, true))
- };
-
- function fillTextVertical(name, text, x, y, style, boldstyle, fontsize) {
- //竖向文字绘制
-
- const ctx = core.ui.getContextByName(name);
- if (!ctx) return;
- const canvas = document.createElement("canvas");
- const context = canvas.getContext("2d");
- fontsize *= 3;
- const length = text.length;
- canvas.width = fontsize * 2;
- canvas.height = fontsize * length * 2;
- if (style) context.fillStyle = core.arrayToRGBA(style);
- if (boldstyle) context.strokeStyle = core.arrayToRGBA(boldstyle);
- context.lineWidth = 2;
- if (fontsize) context.font = core.ui._buildFont(fontsize, true);
- let arrText = text.split("");
-
- let arrWidth = arrText.map(function (letter) {
- return context.measureText(letter).width;
- });
-
- let align = context.textAlign;
-
- let baseline = context.textBaseline;
- let sx = fontsize,
- sy = fontsize * length;
- if (align == "left") {
- sx = sx + Math.max.apply(null, arrWidth) / 2;
- } else if (align == "right") {
- sx = sx - Math.max.apply(null, arrWidth) / 2;
- }
-
- if (
- baseline == "bottom" ||
- baseline == "alphabetic" ||
- baseline == "ideographic"
- ) {
- sy = sy - arrWidth[0] / 2;
- } else if (baseline == "top" || baseline == "hanging") {
- sy = sy + arrWidth[0] / 2;
- }
-
- context.textAlign = "center";
-
- context.textBaseline = "middle";
- context.lineWidth = 6;
-
- // 开始逐字绘制
-
- arrText.forEach(function (letter, index) {
- // 确定下一个字符的纵坐标位置
-
- context.strokeText(letter, sx, sy);
- context.fillText(letter, sx, sy);
- // 旋转坐标系还原成初始态
-
- context.setTransform(1, 0, 0, 1, 0, 0);
-
- // 确定下一个字符的纵坐标位置
-
- var letterWidth = 54;
-
- sy = sy + letterWidth;
- });
-
- // 水平垂直对齐方式还原
-
- context.textAlign = align;
-
- context.textBaseline = baseline;
-
- //绘制到目标位置
- ctx.drawImage(
- canvas,
- x,
- y - (fontsize / 3) * length,
- canvas.width / 3,
- canvas.height / 3
- );
- }
-
- ////// 点击楼层传送器时的打开操作 //////
- events.prototype.useFly = function (fromUserAction) {
- if (!core.isPlaying()) return;
- if (!core.status.maps[core.status.floorId].canFlyFrom) {
- core.drawTip(core.material.items["fly"].name + "好像失效了", "fly");
- return;
- }
- // 从“浏览地图”页面:尝试直接传送到该层
- if (core.status.event.id == "viewMaps") {
- if (!core.hasItem("fly")) {
- core.playSound("操作失败");
- core.drawTip("你没有" + core.material.items["fly"].name, "fly");
- } else if (
- core.flags.flyNearStair &&
- !core.nearStair() &&
- !flags.canMoveFloor
- ) {
- core.playSound("操作失败");
- core.drawTip(
- "无法到达楼梯边使用" + core.material.items["fly"].name,
- "fly"
- );
- } else {
- core.flyTo(core.status.event.data.floorId);
- core.updateStatusBar();
- }
- return;
- }
-
- if (!this._checkStatus("fly", fromUserAction, true)) return;
- //if (core.flags.flyNearStair && !core.nearStair())
-
- if (
- (core.flags.flyNearStair && !core.nearStair()) ||
- !flags.canMoveFloor
- ) {
- core.playSound("操作失败");
- core.drawTip(
- "无法到达楼梯边使用" + core.material.items["fly"].name,
- "fly"
- );
- core.unlockControl();
- core.status.event.data = null;
- core.status.event.id = null;
- return;
- }
- if (!core.canUseItem("fly")) {
- core.playSound("操作失败");
- core.drawTip(core.material.items["fly"].name + "好像失效了", "fly");
- core.unlockControl();
- core.status.event.data = null;
- core.status.event.id = null;
- return;
- }
- core.playSound("打开界面");
- core.useItem("fly", true);
- core.updateStatusBar();
- return;
- };
- ////// 系统菜单栏界面时的点击操作 //////
- actions.prototype._clickSettings = function (x, y) {
- if (this._out(x)) return;
- var choices = core.status.event.ui.choices;
- var topIndex = this._getChoicesTopIndex(choices.length);
- if (y >= topIndex && y < topIndex + choices.length) {
- var selection = y - topIndex;
- core.status.event.selection = selection;
- switch (selection) {
- case 0:
- core.status.event.selection = 0;
- core.playSound("确定");
- core.ui._drawSwitchs();
- break;
- case 1:
- // core.playSound('确定');
- core.ui._drawKeyBoard();
- break;
- case 2:
- // core.playSound('确定');
- core.clearUI();
- core.useItem("fly");
- break;
- case 3:
- core.status.event.selection = 0;
- core.playSound("确定");
- core.ui._drawNotes();
- break;
- case 4:
- core.status.event.selection = 0;
- core.playSound("确定");
- core.ui._drawSyncSave();
- break;
- case 5:
- core.status.event.selection = 0;
- core.playSound("确定");
- core.ui._drawGameInfo();
- break;
- case 6:
- return core.confirmRestart();
- case 7:
- core.playSound("取消");
- core.ui.closePanel();
- break;
- }
- }
- return;
- };
- ////// 查看地图界面时的点击操作 //////
- actions.prototype._clickViewMaps = function (x, y, px, py) {
- if (core.status.event.data == null) {
- core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));
- return;
- }
- let now = core.floorIds.indexOf(core.status.floorId);
- let index = core.status.event.data.index;
- let cx = core.status.event.data.x,
- cy = core.status.event.data.y;
- let floorId = core.floorIds[index],
- mw = core.floors[floorId].width,
- mh = core.floors[floorId].height;
- let perpx = core.__PIXELS__ / 5,
- cornerpx = (perpx * 3) / 4;
- const bfs = core.plugin.bfsSearch(floorId, 1, true);
- const mapdir = bfs.mapdir[floorId];
- const res = bfs.res;
- const formto = {};
- for (let from in res) {
- const to = res[from];
- const [fromfloorId, fromsx, fromsy, dir] = from.split("_");
- const [tofloorId, tosx, tosy] = to.split("_");
- if (!formto[fromfloorId]) formto[fromfloorId] = {};
- if (!formto[fromfloorId][dir]) formto[fromfloorId][dir] = tofloorId;
- }
- const areas = core.getFlag("areas");
- let i = areas.findIndex((v) => v.maps.includes(floorId));
-
- if (px >= 11 && px <= 54 && py >= 11 && py <= 54) {
- core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));
- } else if (px >= 362 && px <= 407 && py >= 191 && py <= 318) {
- flags.showEnemy = !flags.showEnemy;
- core.ui._drawViewMaps(index);
- } else if (px >= 364 && px <= 407 && py >= 364 && py <= 407) {
- core.clearMap("data");
- core.playSound("取消");
- core.ui.closePanel();
- core.getItemDetail();
- core.redrawMap();
- core.updateStatusBar();
- core.ui.statusBar._update_map();
- return;
- } else if (px >= 55 && px <= 317 && py >= 11 && py <= 54) {
- if (mapdir.includes("up"))
- core.ui._drawViewMaps(core.floorIds.indexOf(formto[floorId].up));
- } else if (px >= 55 && px <= 317 && py >= 319 && py <= 362) {
- if (mapdir.includes("down"))
- core.ui._drawViewMaps(core.floorIds.indexOf(formto[floorId].down));
- } else if (px >= 11 && px <= 54 && py >= 55 && py <= 317) {
- if (mapdir.includes("left"))
- core.ui._drawViewMaps(core.floorIds.indexOf(formto[floorId].left));
- } else if (px >= 319 && px <= 362 && py >= 55 && py <= 317) {
- if (mapdir.includes("right"))
- core.ui._drawViewMaps(core.floorIds.indexOf(formto[floorId].right));
- } else if (px >= 319 && px <= 407 && py >= 11 && py <= 54) {
- if (mapdir.includes("upFloor"))
- core.ui._drawViewMaps(core.floorIds.indexOf(formto[floorId].upFloor));
- } else if (px >= 319 && px <= 407 && py >= 319 && py <= 362) {
- if (mapdir.includes("downFloor"))
- core.ui._drawViewMaps(
- core.floorIds.indexOf(formto[floorId].downFloor)
- );
- } else if (
- px >= 55 &&
- px <= 317 &&
- py >= 55 &&
- py <= 317 &&
- core.isPlaying()
- ) {
- core.useFly(false);
- return;
- } else if (px >= 11 && px <= 54 && py >= 364 && py <= 407) {
- if (i > 0) {
- i -= 1;
- core.ui._drawViewMaps(core.floorIds.indexOf(areas[i].maps[0]));
- }
- } else if (px >= 319 && px <= 362 && py >= 364 && py <= 407) {
- if (i < areas.length - 1) {
- i += 1;
- core.ui._drawViewMaps(core.floorIds.indexOf(areas[i].maps[0]));
- }
- }
- };
- const replayAction_fly = function (action) {
- //楼层传送的录像操作
- if (action.indexOf("fly:") != 0) return false;
- var floorId = action.substring(4);
- var toIndex = core.floorIds.indexOf(floorId);
- if (
- !core.canUseItem("fly") ||
- (core.flags.flyNearStair && !core.nearStair() && !flags.canMoveFloor)
- )
- return false;
- core.ui._drawViewMaps(toIndex);
- if (core.status.replay.speed == 24) {
- if (!core.flyTo(floorId, core.replay))
- core.control._replay_error(action);
- return true;
- }
- setTimeout(function () {
- if (!core.flyTo(floorId, core.replay))
- core.control._replay_error(action);
- }, core.control.__replay_getTimeout());
- return true;
- };
- core.registerReplayAction("fly", replayAction_fly);
- ////// 查看地图界面时,放开某个键的操作 //////
-
- actions.prototype._keyUpViewMaps = function (keycode) {
- if (core.status.event.data == null) {
- core.ui._drawViewMaps(core.floorIds.indexOf(core.status.floorId));
- return;
- }
- var floorId = core.floorIds[core.status.event.data.index];
-
- if (keycode == 27 || keycode == 71) {
- core.clearMap("data");
- core.playSound("取消");
- core.ui.closePanel();
- core.getItemDetail();
- core.redrawMap();
- core.ui.statusBar._update_map();
- core.updateStatusBar();
- return;
- }
-
- if (keycode == 86) {
- core.status.event.data.damage = !core.status.event.data.damage;
- core.playSound("光标移动");
- core.ui._drawViewMaps(core.status.event.data);
- return;
- }
- if (keycode == 66 || keycode == 88) {
- if (core.isReplaying()) {
- core.control._replay_book();
- } else {
- core.openBook(false);
- }
- return;
- }
- if (
- (keycode == 13 || keycode == 32 || keycode == 67) &&
- !core.isReplaying()
- ) {
- core.useFly(false);
- return;
- }
- return;
- };
- actions.prototype._keyDownViewMaps = function (keycode) {
- if (core.status.event.data == null) return;
-
- var floorId = core.floorIds[core.status.event.data.index],
- mh = core.floors[floorId].height;
-
- if (keycode == 39) this._clickViewMaps(9, 1, 330, 250);
- if (keycode == 37) this._clickViewMaps(9, 8, 25, 200);
- if (keycode == 40) this._clickViewMaps(9, 6, 250, 330);
- if (keycode == 38) this._clickViewMaps(9, 3, 200, 25);
- if (keycode == 34) this._clickViewMaps(9, 3, 350, 330);
- if (keycode == 33) this._clickViewMaps(9, 3, 350, 25);
- return;
- };
-
- actions.prototype._sys_onmousewheel = function (direct) {
- // 向下滚动是 -1 ,向上是 1
-
- if (this._checkReplaying()) {
- // 滚轮控制速度
- if (direct == 1) core.speedUpReplay();
- if (direct == -1) core.speedDownReplay();
- return;
- }
-
- // 楼层飞行器
- if (core.status.lockControl && core.status.event.id == "fly") {
- if (direct == 1) core.ui.drawFly(this._getNextFlyFloor(1));
- if (direct == -1) core.ui.drawFly(this._getNextFlyFloor(-1));
- return;
- }
-
- // 怪物手册
- if (core.status.lockControl && core.status.event.id == "book") {
- var pageinfo = core.ui._drawBook_pageinfo();
- if (direct == 1)
- core.ui.drawBook(core.status.event.data - pageinfo.per_page);
- if (direct == -1)
- core.ui.drawBook(core.status.event.data + pageinfo.per_page);
- return;
- }
-
- // 存读档
- if (
- core.status.lockControl &&
- (core.status.event.id == "save" || core.status.event.id == "load")
- ) {
- var index =
- core.status.event.data.page * 10 + core.status.event.data.offset;
- if (direct == 1) core.ui._drawSLPanel(index - 10);
- if (direct == -1) core.ui._drawSLPanel(index + 10);
- return;
- }
-
- // 浏览地图
- if (core.status.lockControl && core.status.event.id == "viewMaps") {
- let floorId = core.floorIds[core.status.event.data.index];
- if (!flags.__visited__[floorId]) floorId = core.status.floorId;
- const visit = Object.keys(flags.__visited__);
- let index = visit.indexOf(floorId);
- if (direct == 1) {
- if (index > 0)
- core.ui._drawViewMaps(core.floorIds.indexOf(visit[index - 1]));
- }
- if (direct == -1) {
- if (index < visit.length - 1)
- core.ui._drawViewMaps(core.floorIds.indexOf(visit[index + 1]));
- }
- return;
- }
-
- // wait事件
- if (
- core.status.lockControl &&
- core.status.event.id == "action" &&
- core.status.event.data.type == "wait"
- ) {
- var timeout =
- Math.max(0, core.status.event.timeout - new Date().getTime()) || 0;
- core.setFlag("type", 0);
- var keycode = direct == 1 ? 33 : 34;
- core.setFlag("keycode", keycode);
- core.setFlag("timeout", timeout);
- var executed = core.events.__action_wait_afterGet(
- core.status.event.data.current
- );
- if (executed || !core.status.event.data.current.forceChild) {
- core.status.route.push("input:" + (1e8 * timeout + keycode));
- clearTimeout(core.status.event.interval);
- delete core.status.event.timeout;
- core.doAction();
- }
- return;
- }
- };
- core.registerAction(
- "onmousewheel",
- "_sys_onmousewheel",
- actions.prototype._sys_onmousewheel,
- 0
- );
},
"CG回廊": function () {
// 在此增加新插件
@@ -14847,10 +13573,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
CGUI.style.zIndex = 300;
CGUI.style.display = "none";
CGUI.id = "CGUI";
- main.dom.gameGroup.insertAdjacentElement("afterend", CGUI);
- CGUI.style.top = "50%";
- CGUI.style.left = "50%";
- CGUI.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", CGUI)
const ctx = CGUI.getContext("2d");
main.dom.CGUI = CGUI;
let page = 0; //初始页面
@@ -14863,7 +13586,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const top = core.dom.gameGroup.offsetTop;
const px = Math.floor((e.clientX - left) / core.domStyle.scale),
py = Math.floor((e.clientY - top) / core.domStyle.scale);
- core.ui.CG.onclick(px * 3, py * 3);
+ core.ui.CG.onclick(px, py);
} catch (ee) {
main.log(ee);
}
@@ -14922,11 +13645,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
background() {
//画布大小设置
if (core.domStyle.isVertical) {
- CGUI.width = 1248;
- CGUI.height = 2028;
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+
} else {
- CGUI.width = 2028;
- CGUI.height = 1248;
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+
}
core.setTextAlign(ctx, "center");
}
@@ -14952,7 +13675,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
return sx <= x && x <= dx && sy <= y && y <= dy;
};
const pos = [px, py];
- const backbox = makeBox([15, 35], [210, 90]);
+ const backbox = makeBox([5, 12], [70, 30]);
if (inRect(pos, backbox)) {
//离开按钮是一致的,其余的记区分横竖屏
CGUI.style.display = "none";
@@ -14962,16 +13685,16 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
if (core.domStyle.isVertical) {
//竖屏
- const pageupbox = makeBox([200, 1830], [200, 100]);
- const pagedownbox = makeBox([900, 1830], [200, 100]);
+ const pageupbox = makeBox([67, 610], [67, 33]);
+ const pagedownbox = makeBox([300, 610], [67, 33]);
- const imagebox0 = makeBox([50, 200], [560, 420]);
- const imagebox1 = makeBox([50, 750], [560, 420]);
- const imagebox2 = makeBox([50, 1300], [560, 420]);
+ const imagebox0 = makeBox([17, 67], [187, 140]);
+ const imagebox1 = makeBox([17, 250], [187, 140]);
+ const imagebox2 = makeBox([17, 433], [187, 140]);
- const imagebox3 = makeBox([650, 200], [560, 420]);
- const imagebox4 = makeBox([650, 750], [560, 420]);
- const imagebox5 = makeBox([650, 1300], [560, 420]);
+ const imagebox3 = makeBox([217, 67], [187, 140]);
+ const imagebox4 = makeBox([217, 250], [187, 140]);
+ const imagebox5 = makeBox([217, 433], [187, 140]);
if (inRect(pos, pagedownbox)) {
//2代表当前最大页数-1
if (page < this.UIMx.length - 1) {
@@ -14990,9 +13713,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const img = core.material.images.images[this.UIMx[page][0][0]];
if (img) {
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
ctx.restore(); //重置画布设置
show = !show;
}
@@ -15002,9 +13725,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const img = core.material.images.images[this.UIMx[page][0][1]];
if (img) {
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
ctx.restore(); //重置画布设置
show = !show;
}
@@ -15014,9 +13737,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const img = core.material.images.images[this.UIMx[page][0][2]];
if (img) {
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
ctx.restore(); //重置画布设置
show = !show;
}
@@ -15026,9 +13749,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const img = core.material.images.images[this.UIMx[page][1][0]];
if (img) {
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
ctx.restore(); //重置画布设置
show = !show;
}
@@ -15038,9 +13761,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const img = core.material.images.images[this.UIMx[page][1][1]];
if (img) {
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
ctx.restore(); //重置画布设置
show = !show;
}
@@ -15052,21 +13775,21 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
ctx.save(); //保存设置
ctx.translate(1248, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
ctx.restore(); //重置画布设置
show = !show;
}
}
}
} else {
- const pageupbox = makeBox([200, 1110], [200, 100]);
- const pagedownbox = makeBox([1600, 1110], [200, 100]);
- const imagebox0 = makeBox([75, 150], [600, 450]);
- const imagebox1 = makeBox([725, 150], [600, 450]);
- const imagebox2 = makeBox([1300, 150], [600, 450]);
- const imagebox3 = makeBox([75, 650], [600, 450]);
- const imagebox4 = makeBox([725, 650], [600, 450]);
- const imagebox5 = makeBox([1375, 650], [600, 450]);
+ const pageupbox = makeBox([67, 370], [67, 33]);
+ const pagedownbox = makeBox([533, 370], [67, 33]);
+ const imagebox0 = makeBox([25, 50], [200, 150]);
+ const imagebox1 = makeBox([242, 50], [200, 150]);
+ const imagebox2 = makeBox([433, 50], [200, 150]);
+ const imagebox3 = makeBox([25, 217], [200, 150]);
+ const imagebox4 = makeBox([242, 217], [200, 150]);
+ const imagebox5 = makeBox([433, 217], [200, 150]);
if (inRect(pos, pagedownbox)) {
if (page < this.UIMx.length - 1) {
page++;
@@ -15083,7 +13806,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (this.cgs.includes(this.UIMx[page][0][0])) {
const img = core.material.images.images[this.UIMx[page][0][0]];
if (img) {
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
show = !show;
}
}
@@ -15091,7 +13814,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (this.cgs.includes(this.UIMx[page][0][1])) {
const img = core.material.images.images[this.UIMx[page][0][1]];
if (img) {
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
show = !show;
}
}
@@ -15099,7 +13822,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (this.cgs.includes(this.UIMx[page][0][2])) {
const img = core.material.images.images[this.UIMx[page][0][2]];
if (img) {
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
show = !show;
}
}
@@ -15107,7 +13830,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (this.cgs.includes(this.UIMx[page][1][0])) {
const img = core.material.images.images[this.UIMx[page][1][0]];
if (img) {
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
show = !show;
}
}
@@ -15115,7 +13838,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (this.cgs.includes(this.UIMx[page][1][1])) {
const img = core.material.images.images[this.UIMx[page][1][1]];
if (img) {
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
show = !show;
}
}
@@ -15123,7 +13846,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (this.cgs.includes(this.UIMx[page][1][2])) {
const img = core.material.images.images[this.UIMx[page][1][2]];
if (img) {
- ctx.drawImage(img, 0, 0, 2028, 1248);
+ ctx.drawImage(img, 0, 0, 676, 416);
show = !show;
}
}
@@ -15139,54 +13862,54 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (core.domStyle.isVertical) {
//竖屏
- core.fillRect(ctx, 0, 0, 1248, 2028, "#000000"); //黑色背景
+ core.fillRect(ctx, 0, 0, 416, 676, "#000000"); //黑色背景
ctx.globalAlpha = 0.5; //透明度
if (bgVertical)
- ctx.drawImage(bgVertical, 0, 0, 1280, 1500, 0, 0, 1248, 2028); //绘制半透明背景图片
+ ctx.drawImage(bgVertical, 0, 0, 1280, 1500, 0, 0, 416, 676); //绘制半透明背景图片
ctx.globalAlpha = 1; //恢复为不透明
core.setTextAlign(ctx, "center");
core.fillBoldText1(
ctx,
"◀离开",
- 100,
- 110,
+ 33,
+ 37,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
core.fillBoldText1(
ctx,
"上一页",
- 300,
- 1900,
+ 100,
+ 633,
page === 0 ? "#444444" : "#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
core.fillBoldText1(
ctx,
page + 1 + "/" + this.UIMx.length,
- 650,
- 1900,
+ 217,
+ 633,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
core.fillBoldText1(
ctx,
"下一页",
- 1000,
- 1900,
+ 333,
+ 633,
page === this.UIMx.length - 1 ? "#444444" : "#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
// 添加向上翻页和向下翻页的按钮
@@ -15196,92 +13919,92 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const img = core.material.images.images[this.UIMx[page][j][i]];
core.strokeRect(
ctx,
- 50 + j * 600,
- 200 + i * 550,
- 560,
- 420,
+ 17 + j * 200,
+ 67 + i * 183,
+ 187,
+ 140,
"#444444",
- 5
+ 2
);
if (this.cgs.includes(this.UIMx[page][j][i])) {
if (img)
ctx.drawImage(
img,
- 50 + j * 600 + 15,
- 200 + i * 550 + 15,
- 560 - 30,
- 420 - 30
+ 17 + j * 200 + 5,
+ 67 + i * 183 + 5,
+ 187 - 10,
+ 140 - 10
);
} else {
ctx.fillStyle = "#000000";
ctx.fillRect(
- 50 + j * 600 + 15,
- 200 + i * 550 + 15,
- 560 - 30,
- 420 - 30
+ 17 + j * 200 + 5,
+ 67 + i * 183 + 5,
+ 187 - 10,
+ 140 - 10
);
const img = core.material.images.images["LOGO.webp"];
if (img)
ctx.drawImage(
img,
- 50 + j * 600 + 15,
- 200 + i * 550 + 15,
- 560 - 30,
- 420 - 30
+ 17 + j * 200 + 5,
+ 67 + i * 183 + 15,
+ 187 - 10,
+ 140 - 10
);
}
}
}
} else {
//横屏
- core.fillRect(ctx, 0, 0, 2028, 1248, "#000000"); //黑色背景
+ core.fillRect(ctx, 0, 0, 676, 416, "#000000"); //黑色背景
ctx.globalAlpha = 0.5; //透明度
- if (bg) ctx.drawImage(bg, 0, 0, 1280, 720, 0, 0, 2028, 1248); //绘制半透明背景图片
+ if (bg) ctx.drawImage(bg, 0, 0, 1280, 720, 0, 0, 676, 416); //绘制半透明背景图片
ctx.globalAlpha = 1; //恢复为不透明
core.setTextAlign(ctx, "center");
core.fillBoldText1(
ctx,
"◀离开",
- 110,
- 100,
+ 37,
+ 33,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
// 添加向上翻页和向下翻页的按钮
core.fillBoldText1(
ctx,
"上一页",
- 300,
- 1180,
+ 100,
+ 393,
page === 0 ? "#444444" : "#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
core.fillBoldText1(
ctx,
page + 1 + "/" + this.UIMx.length,
- 1000,
- 1180,
+ 333,
+ 393,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
core.fillBoldText1(
ctx,
"下一页",
- 1700,
- 1180,
+ 567,
+ 393,
page === this.UIMx.length - 1 ? "#444444" : "#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
// 添加3*2个4:3的画框
@@ -15289,39 +14012,39 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
for (let j = 0; j < 3; j++) {
core.strokeRect(
ctx,
- 75 + j * 650,
- 150 + i * 500,
- 600,
- 450,
+ 25 + j * 217,
+ 50 + i * 167,
+ 200,
+ 150,
"#444444",
- 2
+ 1
);
if (this.cgs.includes(this.UIMx[page][i][j])) {
const img = core.material.images.images[this.UIMx[page][i][j]];
if (img)
ctx.drawImage(
img,
- 75 + j * 650 + 15,
- 150 + i * 500 + 15,
- 600 - 30,
- 450 - 30
+ 25 + j * 217 + 5,
+ 50 + i * 167 + 5,
+ 200 - 10,
+ 150 - 10
);
} else {
ctx.fillStyle = "#000000";
ctx.fillRect(
- 75 + j * 650 + 15,
- 150 + i * 500 + 15,
- 600 - 30,
- 450 - 30
+ 25 + j * 217 + 5,
+ 50 + i * 167 + 5,
+ 200 - 10,
+ 150 - 10
);
const img = core.material.images.images["LOGO.webp"];
if (img)
ctx.drawImage(
img,
- 75 + j * 650 + 15,
- 150 + i * 500 + 15,
- 600 - 30,
- 450 - 30
+ 25 + j * 217 + 5,
+ 50 + i * 167 + 5,
+ 200 - 10,
+ 150 - 10
);
}
}
@@ -15347,42 +14070,42 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
},
"光标设置": function () {
- // 在此增加新插件
- this.changeMouse = function (
- icon,
- div = "gameGroup",
- translateX = 0,
- translateY = 0,
- scaleX = 1,
- scaleY = 1,
- degree = 0,
- px = 0,
- py = 0
- ) {
- const canvas = document.createElement("canvas");
- canvas.width = 64;
- canvas.height = 64;
+ // 在此增加新插件
+ this.changeMouse = function (
+ icon,
+ div = "gameGroup",
+ translateX = 0,
+ translateY = 0,
+ scaleX = 1,
+ scaleY = 1,
+ degree = 0,
+ px = 0,
+ py = 0
+ ) {
+ const canvas = document.createElement("canvas");
+ canvas.width = 64;
+ canvas.height = 64;
- const ctx = canvas.getContext("2d");
- ctx.translate(translateX, translateY); //偏移画布(x,y)
- ctx.scale(scaleX, scaleY); //(x,y轴缩放倍率,-1为沿X,Y轴翻转)
- const angle = (degree * Math.PI) / 180; //根据角度计算参数
- ctx.rotate(angle); //顺时针旋转(以画布原点为中心,可通过偏移画布影响中心点)
- let info = {
- image: core.statusBar.icons[icon],
- posX: 0,
- posY: 0,
- height: 32,
- };
+ const ctx = canvas.getContext("2d");
+ ctx.translate(translateX, translateY); //偏移画布(x,y)
+ ctx.scale(scaleX, scaleY); //(x,y轴缩放倍率,-1为沿X,Y轴翻转)
+ const angle = (degree * Math.PI) / 180; //根据角度计算参数
+ ctx.rotate(angle); //顺时针旋转(以画布原点为中心,可通过偏移画布影响中心点)
+ let info = {
+ image: core.statusBar.icons[icon],
+ posX: 0,
+ posY: 0,
+ height: 32,
+ };
- core.drawIcon(ctx, icon, 0, 0, 32, 32);
- const data = canvas.toDataURL("image/png");
- core.dom[div].style.cursor = `url(${data}) ${px} ${py},url(${data}),auto`; //div为你要改变光标的元素,默认为包含状态栏的整个游戏画面,px/py为点击点偏移像素
- };
- this.removeMouse = function (div = "gameGroup") {
- core.dom[div].style.cursor = "auto";
- };
- },
+ core.drawIcon(ctx, icon, 0, 0, 32, 32);
+ const data = canvas.toDataURL("image/png");
+ core.dom[div].style.cursor = `url(${data}) ${px} ${py},url(${data}),auto`; //div为你要改变光标的元素,默认为包含状态栏的整个游戏画面,px/py为点击点偏移像素
+ };
+ this.removeMouse = function (div = "gameGroup") {
+ core.dom[div].style.cursor = "auto";
+ };
+},
"信息弹出": function () {
// 在此增加新插件
/* 弹出显示某个内容
@@ -15605,6 +14328,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
},
"滑动转场": function () {
// 在此增加新插件
+
const defaultChange = {
left: "leftPortal", // 左箭头
up: "upPortal", // 上箭头
@@ -15624,14 +14348,13 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
let allChangeEntries = Object.entries(defaultChange);
const move = document.createElement("canvas");
- const speed = 12;
- let modedata = 0;
+ const move2 = document.createElement("canvas");
- move.width = 1248;
- move.height = 1248;
const ctx = move.getContext("2d");
-
+ const ctx2 = move2.getContext("2d");
+ core.maps._setHDCanvasSize(ctx, 416, 416)
+ core.maps._setHDCanvasSize(ctx2, 416, 416)
events.prototype.changeFloor = function (
floorId,
stair,
@@ -15660,6 +14383,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
this._changeFloor_beforeChange(info, block, callback);
};
+ const { Animation, linear, bezier, circle, hyper, trigo, power, inverseTrigo, shake, sleep } = core.plugin.animate
+
events.prototype._changeFloor_beforeChange = function (
info,
block,
@@ -15688,95 +14413,98 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
);
const v = dirData[dir][1], // 水平数值
h = dirData[dir][0]; //竖直数值
- ctx.clearRect(0, 0, 1248, 1248);
+ ctx.clearRect(0, 0, 208, 208);
+ ctx2.clearRect(0, 0, 208, 208);
core.drawThumbnail(core.status.floorId, null, {
- damage: data.damage,
+ damage: false,
ctx: ctx,
- x: 416,
- y: 416,
+ x: 0,
+ y: 0,
size: 1,
all: data.all,
});
if (dir !== "upFloor" && dir !== "downFloor") {
core.drawThumbnail(toFloorId, null, {
- damage: dataTo.damage,
- ctx: ctx,
- x: 416 + 416 * v,
- y: 416 + 416 * h,
+ damage: false,
+ ctx: ctx2,
+ x: 0,
+ y: 0,
size: 1,
all: dataTo.all,
});
- var _run = function () {
- var cb = function () {
- modedata = 0;
- core.clearUI();
- core.clearMap("data");
+ const changefloor = async function () {
+ const animate = new Animation()
+ const change = core.createCanvas("change", 0, 0, 416, 416, 100)
+ change.canvas.style.width = core.__PIXELS__ * core.domStyle.scale + "px"
+ change.canvas.style.height = core.__PIXELS__ * core.domStyle.scale + "px"
+
+ const fn = () => {
+
+
+ const x1 = -animate.x * v;
+ const y1 = -animate.x * h
+ const x2 = (416 - animate.x) * v;
+ const y2 = (416 - animate.x) * h;
+
+
+ let status = animate.x > 208 ? "rightFoot" : "leftFoot";
+
+
+ const img = core.material.images.hero;
+ const heroIconArr = core.material.icons.hero;
+ const width = core.material.icons.hero.width || 32;
+ const height = core.material.icons.hero.height;
+ const heroIcon = heroIconArr[dir];
+ const imgx = (heroIcon[status] % 4) * width,
+ imgy = heroIcon.loc * height,
+ x = core.status.hero.loc.x * 32 -
+ core.bigmap.offsetX -
+ (animate.x - (animate.x * 32) / 416) * v,
+ y = core.status.hero.loc.y * 32 -
+ 16 -
+ (animate.x - (animate.x * 32) / 416) * h;
+ const ctx3 = core.dymCanvas.change
+ core.clearMap(ctx3)
+ core.fillRect(ctx3, x1,
+ y1, 416, 416)
+ ctx3.drawImage(
+ move,
+ x1,
+ y1, 416, 416
+
+ );
+
+ ctx3.drawImage(
+ move2,
+ x2,
+ y2,
+ 416, 416
+ );
+ ctx3.drawImage(
+ img,
+ imgx, imgy,
+ width,
+ height,
+ x, y,
+ width,
+ height
+ );
+ }
+ animate.ticker.add(fn)
+
+ animate.mode(linear()).time(core.values.floorChangeTime).move(416, 0)
+ await animate.all();
+ animate.ticker.destroy()
+
+ window.setTimeout(function () {
core.events._changeFloor_changing(info, callback);
- };
+ core.clearMap(change)
+ }, 25)
- var animate = window.setInterval(
- function () {
- if (modedata >= 416) {
- delete core.animateFrame.asyncId[animate];
- clearInterval(animate);
- cb();
- } else {
- core.clearUI();
- core.clearMap("data");
+ }
+ changefloor()
- core.canvas.data.drawImage(
- move,
- 416 + modedata * v,
- 416 + modedata * h,
- 416,
- 416,
- 0,
- 0,
- 416,
- 416
- );
- let status = "leftFoot";
-
- if (modedata > 208) {
- status = "rightFoot";
- }
- const img = core.material.images.hero;
- const heroIconArr = core.material.icons.hero;
- const width = core.material.icons.hero.width || 32;
- const height = core.material.icons.hero.height;
- const heroIcon = heroIconArr[dir];
-
- core.canvas.data.drawImage(
- img,
- (heroIcon[status] % 4) * width,
- heroIcon.loc * height,
- width,
- height,
- core.status.hero.loc.x * 32 -
- core.bigmap.offsetX -
- (modedata - (modedata * 32) / 416) * v,
- core.status.hero.loc.y * 32 -
- 16 -
- (modedata - (modedata * 32) / 416) * h,
- width,
- height
- );
- modedata += speed;
- clearInterval(animate);
- delete core.animateFrame.asyncId[animate];
- _run();
- }
- },
- core.status.replay.speed == 24 ?
- 1 :
- 10 / core.status.replay.speed
- );
-
- core.animateFrame.lastAsyncId = animate;
- core.animateFrame.asyncId[animate] = cb;
- };
- _run();
return;
}
}
@@ -15802,22 +14530,16 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
cg.style.position = "absolute";
cg.style.zIndex = 320;
cg.style.display = "none";
- cg.id = "cgText";
- main.dom.gameGroup.insertAdjacentElement("afterend", cg);
- cg.style.top = "50%";
- cg.style.left = "50%";
- cg.style.transform = "translate(-50%,-50%)";
+ cg.id = "cg";
+ main.dom.startPanel.insertAdjacentElement("afterend", cg)
const ctx = cg.getContext("2d");
- main.dom.cgText = cg;
+ main.dom.cg = cg;
const logcanvas = document.createElement("canvas"); //cg画布设置
logcanvas.style.position = "absolute";
logcanvas.style.zIndex = 321;
logcanvas.style.display = "none";
- logcanvas.id = "cgText";
- main.dom.gameGroup.insertAdjacentElement("afterend", logcanvas);
- logcanvas.style.top = "50%";
- logcanvas.style.left = "50%";
- logcanvas.style.transform = "translate(-50%,-50%)";
+ logcanvas.id = "logcanvas";
+ main.dom.startPanel.insertAdjacentElement("afterend", logcanvas)
const logctx = logcanvas.getContext("2d");
main.dom.logcanvas = logcanvas;
logcanvas.onmouseup = function (e) {
@@ -15846,7 +14568,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const top = core.dom.gameGroup.offsetTop;
const px = Math.floor((e.clientX - left) / core.domStyle.scale),
py = Math.floor((e.clientY - top) / core.domStyle.scale);
- core.ui.cgText.click(px * 3, py * 3);
+ core.ui.cgText.click(px, py);
} catch (ee) {
main.log(ee);
}
@@ -15880,7 +14602,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
py = Math.floor(
(e.targetTouches[0].clientY - top) / core.domStyle.scale
);
- core.ui.cgText.click(px * 3, py * 3);
+ core.ui.cgText.click(px, py);
} catch (ee) {
main.log(ee);
}
@@ -15911,7 +14633,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const top = core.dom.gameGroup.offsetTop;
const px = Math.floor((e.clientX - left) / core.domStyle.scale),
py = Math.floor((e.clientY - top) / core.domStyle.scale);
- core.ui.cgText.click(px * 3, py * 3);
+ core.ui.cgText.click(px, py);
} catch (ee) {
main.log(ee);
}
@@ -15947,7 +14669,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
py = Math.floor(
(e.targetTouches[0].clientY - top) / core.domStyle.scale
);
- core.ui.cgText.click(px * 3, py * 3);
+ core.ui.cgText.click(px, py);
} catch (ee) {
main.log(ee);
}
@@ -15959,10 +14681,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
this.nobg = false;
//绘制需要的变量
this.image = "";
- this.head = { name: "face_050445.webp", px: -300 };
+ this.head = { name: "face_050445.webp", px: -100 };
this.bodyList = [
- { name: "tati_050145a.webp", px: 100, filter: false },
- { name: "tati_120124.webp", px: 1100, filter: true },
+ { name: "tati_050145a.webp", px: 33, filter: false },
+ { name: "tati_120124.webp", px: 367, filter: true },
];
this.name = "";
this.text = "";
@@ -15994,22 +14716,22 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
return sx <= x && x <= dx && sy <= y && y <= dy;
};
const pos = [px, py];
- const savebox = makeBox([1700, 1100], [192, 96]);
- const saveboxVertical = makeBox([52, 1700], [96, 192]);
- const skipbox = makeBox([1700, 1000], [192, 96]);
- const skipboxVertical = makeBox([152, 1700], [96, 192]);
- const autobox = makeBox([1700, 900], [192, 96]);
- const autoboxVertical = makeBox([252, 1700], [96, 192]);
- const textbox = makeBox([1700, 800], [192, 96]);
- const textboxVertical = makeBox([352, 1700], [96, 192]);
- const backbox = makeBox([15, 35], [210, 90]);
- const backboxVertical = makeBox([1123, 15], [90, 210]);
- const pageupbox = makeBox([300, 1130], [200, 100]);
- const pageupboxVertical = makeBox([18, 300], [100, 200]);
- const pagedownbox = makeBox([1500, 1130], [200, 100]);
- const pagedownboxVertical = makeBox([18, 1500], [100, 200]);
- const soundbox = makeBox([550, 150], [100, 900]);
- const soundboxVertical = makeBox([198, 550], [900, 100]);
+ const savebox = makeBox([567, 367], [64, 32]);
+ const saveboxVertical = makeBox([17, 567], [32, 64]);
+ const skipbox = makeBox([567, 333], [64, 32]);
+ const skipboxVertical = makeBox([51, 567], [32, 64]);
+ const autobox = makeBox([567, 300], [64, 32]);
+ const autoboxVertical = makeBox([84, 567], [32, 64]);
+ const textbox = makeBox([567, 267], [64, 32]);
+ const textboxVertical = makeBox([117, 567], [32, 64]);
+ const backbox = makeBox([5, 12], [70, 30]);
+ const backboxVertical = makeBox([372, 5], [30, 70]);
+ const pageupbox = makeBox([100, 377], [67, 33]);
+ const pageupboxVertical = makeBox([18, 100], [33, 67]);
+ const pagedownbox = makeBox([500, 377], [67, 33]);
+ const pagedownboxVertical = makeBox([6, 500], [33, 67]);
+ const soundbox = makeBox([150, 50], [33, 300]);
+ const soundboxVertical = makeBox([66, 150], [300, 33]);
if (this.log) {
if (
(core.domStyle.isVertical && inRect(pos, backboxVertical)) ||
@@ -16041,7 +14763,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const sound =
core.plugin[this.textList][
(this.page - 1) * 6 +
- Math.min(Math.floor((px - 198) / 150), 5)
+ Math.min(Math.floor((px - 66) / 50), 5)
][2];
core.stopSound();
core.playSound(sound);
@@ -16049,7 +14771,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const sound =
core.plugin[this.textList][
(this.page - 1) * 6 +
- Math.min(Math.floor((py - 150) / 150), 5)
+ Math.min(Math.floor((py - 50) / 50), 5)
][2];
core.stopSound();
core.playSound(sound);
@@ -16068,16 +14790,15 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let time = 0;
core.stopSound(this.beforeSound);
core.registerAnimationFrame("skip", true, (timestamp) => {
- if (timestamp > time + 50) {
- time = timestamp;
- if (
- core.status.event.id == "action" &&
- core.status.event.data.type == "cgtext"
- ) {
- core.setFlag("skip", true);
- main.dom.cgText.style.display = "none";
- core.doAction();
- }
+ if (timestamp - time < 50) return
+ time = timestamp;
+ if (
+ core.status.event.id == "action" &&
+ core.status.event.data.type == "cgtext"
+ ) {
+ core.setFlag("skip", true);
+ main.dom.cg.style.display = "none";
+ core.doAction();
}
});
} else if (
@@ -16258,7 +14979,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
ctx.restore();
ctx.save(); //保存设置
if (core.domStyle.isVertical) {
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
}
ctx.drawImage(
@@ -16325,35 +15046,33 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
logdraw(page) {
if (core.domStyle.isVertical) {
- logctx.canvas.width = 1248;
- logctx.canvas.height = 2028;
+ core.maps._setHDCanvasSize(logctx, 416, 676)
logctx.save(); //保存设置
- logctx.translate(1248, 0); //重新定位右上角为基准
+ logctx.translate(416, 0); //重新定位右上角为基准
logctx.rotate(Math.PI / 2); //旋转90度
} else {
- logctx.canvas.width = 2028;
- logctx.canvas.height = 1248;
+ core.maps._setHDCanvasSize(logctx, 676, 416)
}
- core.fillRect(logctx, 0, 0, 2028, 1248, "rgba(0,0,0,0.5)");
+ core.fillRect(logctx, 0, 0, 676, 416, "rgba(0,0,0,0.5)");
core.setTextAlign(logctx, "center");
core.fillBoldText1(
logctx,
"◀离开",
- 110,
- 100,
+ 37,
+ 33,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
logctx.strokeStyle = "#FFFFFF";
- logctx.lineWidth = 3;
+ logctx.lineWidth = 1;
logctx.beginPath();
- logctx.moveTo(100, 150);
- logctx.lineTo(1928, 150);
+ logctx.moveTo(33, 50);
+ logctx.lineTo(643, 50);
logctx.stroke();
- let posy = 150;
+ let posy = 50;
const indexList = this.textList;
core.setTextAlign(logctx, "left");
for (
@@ -16371,37 +15090,37 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillBoldText1(
logctx,
name,
- 150,
- posy + 50,
+ 50,
+ posy + 17,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(42, true)
+ 2,
+ core.ui._buildFont(14, true)
);
}
- if (sound) core.drawImage(logctx, "sound.webp", 550, posy + 30);
+ if (sound) core.drawImage(logctx, "sound.webp", 183, posy + 10);
if (text.length < 30) {
core.fillBoldText1(
logctx,
text,
- 650,
- posy + 50,
+ 217,
+ posy + 17,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(42, true)
+ 2,
+ core.ui._buildFont(14, true)
);
} else {
let text1 = text.slice(0, 30);
core.fillBoldText1(
logctx,
text1,
- 650,
- posy + 50,
+ 217,
+ posy + 17,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(42, true)
+ 2,
+ core.ui._buildFont(14, true)
);
if (text.length > 60) {
let text2 = text.slice(30, 60);
@@ -16409,96 +15128,94 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillBoldText1(
logctx,
text2,
- 650,
- posy + 100,
+ 217,
+ posy + 33,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(42, true)
+ 2,
+ core.ui._buildFont(14, true)
);
core.fillBoldText1(
logctx,
text3,
- 650,
- posy + 150,
+ 217,
+ posy + 50,
"#FFFFFF",
"#000000",
6,
- core.ui._buildFont(42, true)
+ core.ui._buildFont(14, true)
);
} else {
let text2 = text.slice(30);
core.fillBoldText1(
logctx,
text2,
- 650,
- posy + 100,
+ 217,
+ posy + 33,
"#FFFFFF",
"#000000",
6,
- core.ui._buildFont(42, true)
+ core.ui._buildFont(14, true)
);
}
}
logctx.strokeStyle = "#FFFFFF";
- logctx.lineWidth = 3;
+ logctx.lineWidth = 1;
logctx.beginPath();
- logctx.moveTo(100, posy);
- logctx.lineTo(1928, posy);
+ logctx.moveTo(33, posy);
+ logctx.lineTo(643, posy);
logctx.stroke();
- posy += 160;
+ posy += 53;
}
logctx.beginPath();
- logctx.moveTo(100, 1120);
- logctx.lineTo(1928, 1120);
- logctx.moveTo(100, 1110);
- logctx.lineTo(1928, 1110);
+ logctx.moveTo(33, 373);
+ logctx.lineTo(643, 373);
+ logctx.moveTo(33, 370);
+ logctx.lineTo(643, 370);
logctx.stroke();
core.fillBoldText1(
logctx,
"上一页",
- 300,
- 1200,
+ 100,
+ 400,
page === 1 ? "#444444" : "#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
core.fillBoldText1(
logctx,
page + "/" + this.overpage,
- 1000,
- 1200,
+ 333,
+ 400,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
core.fillBoldText1(
logctx,
"下一页",
- 1500,
- 1200,
+ 500,
+ 400,
page === this.overpage ? "#444444" : "#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(66, true)
+ 2,
+ core.ui._buildFont(22, true)
);
}
background() {
if (core.domStyle.isVertical) {
- ctx.canvas.width = 1248;
- ctx.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx, 416, 676)
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
} else {
- ctx.canvas.width = 2028;
- ctx.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx, 676, 416)
}
this.bodyList.forEach((v) => {
@@ -16506,7 +15223,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const body = core.material.images.images?.[v.name];
if (v.filter) ctx.filter = "brightness(50%)";
if (body) {
- if (!v.w && !v.h && !v.scale) v.scale = 1.7;
+ if (!v.w && !v.h && !v.scale) v.scale = 0.6;
if (!v.w && !v.h) {
ctx.drawImage(
body,
@@ -16515,7 +15232,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
body.width,
body.height,
v.px,
- 1248 - body.height * v.scale,
+ 416 - body.height * v.scale,
body.width * v.scale,
body.height * v.scale
);
@@ -16527,7 +15244,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
body.width,
body.height,
v.px,
- 1248 - (v.h ?? body.height),
+ 416 - (v.h ?? body.height),
v.w ?? body.width,
v.h ?? body.height
);
@@ -16539,14 +15256,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawWindowSkin(
"winskin.webp",
ctx,
- 30,
- 780,
- 1968,
- 436,
- null,
- null,
- null,
- 3
+ 10,
+ 260,
+ 656,
+ 145,
+
); //绘制对话框
const head = core.material.images.images?.[this.head.name];
if (head) {
@@ -16558,113 +15272,100 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
head.width,
head.height,
this.head.px,
- 1248 - head.height * 2.2,
- head.width * 2.2,
- head.height * 2.2
+ 416 - head.height * 0.7,
+ head.width * 0.7,
+ head.height * 0.7
);
}
if (core.isPlaying() && !this.WindowSkin) {
core.drawWindowSkin(
"winskin.webp",
ctx,
- 1700,
- 800,
- 192,
- 96,
- null,
- null,
- null,
- 3
+ 567,
+ 267,
+ 64,
+ 32
+
);
core.fillBoldText1(
ctx,
"记 录",
- 1736,
- 866,
+ 579,
+ 289,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
core.drawWindowSkin(
"winskin.webp",
ctx,
- 1700,
- 1100,
- 192,
- 96,
- null,
- null,
- null,
- 3
+ 567,
+ 367,
+ 64,
+ 32
+
);
core.fillBoldText1(
ctx,
"存 档",
- 1736,
- 1166,
+ 579,
+ 389,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
core.drawWindowSkin(
"winskin.webp",
ctx,
- 1700,
- 1000,
- 192,
- 96,
- null,
- null,
- null,
- 3
+ 567,
+ 333,
+ 64,
+ 32
+
);
core.fillBoldText1(
ctx,
"▶▶",
- 1756,
- 1066,
+ 585,
+ 355,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
core.drawWindowSkin(
"winskin.webp",
ctx,
- 1700,
- 900,
- 192,
- 96,
- null,
- null,
- null,
- 3
+ 567,
+ 300,
+ 64,
+ 32
);
let autoText = "AUTO";
if (auto) autoText = "STOP";
core.fillBoldText1(
ctx,
autoText,
- 1722,
- 966,
+ 574,
+ 322,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
}
if (this.name)
core.fillBoldText1(
ctx,
`【${this.name}】`,
- 550,
- 880,
+ 183,
+ 293,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
); //绘制名字
if (
@@ -16694,15 +15395,15 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (this.text && !core.getFlag("skip", false)) {
//绘制对话
this.drawTextContent(ctx, this.text, {
- left: 550,
- top: 950,
+ left: 180,
+ top: 317,
bold: true,
color: "#FFFFFF",
align: "left",
- fontSize: 48,
+ fontSize: 16,
time: this.time || 0,
font: "Verdana",
- maxWidth: 1000,
+ maxWidth: 333,
});
}
@@ -16718,44 +15419,39 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
over.style.zIndex = 310;
over.style.display = "none";
over.id = "over";
- main.dom.gameGroup.insertAdjacentElement("afterend", over);
- over.style.top = "50%";
- over.style.left = "50%";
- over.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", over)
const ctx1 = over.getContext("2d");
main.dom.over = over;
const temp = document.createElement("canvas")
- temp.width = 676 * 3;
- temp.height = 416 * 3;
+
+
const ctx = temp.getContext("2d");
-
+ core.maps._setHDCanvasSize(ctx, 676, 416)
this.overupdate = function () {
if (core.domStyle.isVertical) {
- ctx1.canvas.width = 416 * 3;
- ctx1.canvas.height = 676 * 3;
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
ctx1.save(); //保存设置
- ctx1.translate(416 * 3, 0); //重新定位右上角为基准
+ ctx1.translate(416, 0); //重新定位右上角为基准
ctx1.rotate(Math.PI / 2); //旋转90度
} else {
- ctx1.canvas.width = 676 * 3;
- ctx1.canvas.height = 416 * 3;
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
}
core.clearMap(ctx1)
- ctx1.drawImage(temp, 0, 0, 676 * 3, 416 * 3)
+ ctx1.drawImage(temp, 0, 0, 676, 416)
ctx1.restore();
}
this.over = function (
image,
memory,
- time = 100,
- hidetime = 30,
+ time = 30,
+ hidetime = 10,
sound = "",
textColor = "#FFFFFF",
boldColor = "#000000",
- font = "bold 48px Verdana",
+ font = "bold 16px Verdana",
text = ""
) {
if (!core.isPlaying()) {
@@ -16766,9 +15462,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let sod = 0;
let start = 0;
+ let frame = 0
core.registerAnimationFrame("over", true, (timestamp) => {
-
- if (start === 0) start = timestamp;
+ if (timestamp - start < 50) return
+ start = timestamp;
core.clearMap(ctx);
@@ -16777,15 +15474,15 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
//绘制背景
if (memory) ctx.filter = "sepia(50%)";
- ctx.drawImage(img, 0, 0, 676 * 3, 416 * 3);
+ ctx.drawImage(img, 0, 0, 676, 416);
ctx.filter = "none";
} else {
ctx.fillStyle = "#000000"
- core.fillRect(ctx, 0, 0, 676 * 3, 416 * 3);
+ core.fillRect(ctx, 0, 0, 676, 416);
}
- let frame = Math.floor((timestamp - start) / (1000 / 60))
+
// 绘制
if (frame <= hidetime)
core.setAlpha(ctx, 1 - (hidetime - frame) / hidetime);
@@ -16810,25 +15507,26 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillBoldText1(
ctx,
text,
- 1014,
- 624,
+ 338,
+ 208,
textColor,
boldColor,
- 6,
+ 2,
font
);
+
+ frame++
if (core.domStyle.isVertical) {
- ctx1.canvas.width = 416 * 3;
- ctx1.canvas.height = 676 * 3;
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
ctx1.save(); //保存设置
- ctx1.translate(416 * 3, 0); //重新定位右上角为基准
+ ctx1.translate(416, 0); //重新定位右上角为基准
ctx1.rotate(Math.PI / 2); //旋转90度
} else {
- ctx1.canvas.width = 676 * 3;
- ctx1.canvas.height = 416 * 3;
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
}
+
core.clearMap(ctx1)
- ctx1.drawImage(temp, 0, 0, 676 * 3, 416 * 3)
+ ctx1.drawImage(temp, 0, 0, 676, 416)
ctx1.restore();
});
@@ -16837,14 +15535,14 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
this.overlist = function (
image,
memory,
- hidetime = 30,
+ hidetime = 10,
list = [{
text: "",
sound: "",
- time: 50,
+ time: 20,
textColor: "#FFFFFF",
boldColor: "#000000",
- font: "bold 48px Verdana",
+ font: "bold 16px Verdana",
frame: 0,
}, ]
) {
@@ -16857,249 +15555,247 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let i = 0;
let now = 0;
core.registerAnimationFrame("overlist", true, (timestamp) => {
- if (timestamp - now > 1000 / 60) {
- now = timestamp;
- core.clearMap(ctx);
+ if (timestamp - now < 50) return
+ now = timestamp;
+ core.clearMap(ctx);
- ctx.globalAlpha = 1;
- if (img) {
- //绘制背景
- if (memory) ctx.filter = "sepia(50%)";
+ ctx.globalAlpha = 1;
+ if (img) {
+ //绘制背景
+ if (memory) ctx.filter = "sepia(50%)";
- core.drawImage(ctx, img, 0, 0, 676 * 3, 416 * 3);
- ctx.filter = "none";
- } else {
- ctx.fillStyle = "#000000"
- core.fillRect(ctx, 0, 0, 676 * 3, 416 * 3);
- }
- const a = list[i];
- const b = list[i - 1];
- const c = list[i - 2];
- const d = list[i - 3];
- let ay = 624,
- by = 624,
- cy = 624,
- dy = 624;
- if (i === 0 && !list[1]) {
- core.over(
- image,
- memory,
- a.time,
- hidetime,
- a.sound,
- a.textColor,
- a.boldColor,
- a.font,
- a.text
- );
- } else {
- const numa =
- parseInt(a?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
- 48;
- const numb =
- parseInt(b?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
- 48;
- const numc =
- parseInt(c?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
- 48;
- const numd =
- parseInt(d?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
- 48;
+ core.drawImage(ctx, img, 0, 0, 676, 416);
+ ctx.filter = "none";
+ } else {
+ ctx.fillStyle = "#000000"
+ core.fillRect(ctx, 0, 0, 676, 416);
+ }
+ const a = list[i];
+ const b = list[i - 1];
+ const c = list[i - 2];
+ const d = list[i - 3];
+ let ay = 208,
+ by = 208,
+ cy = 208,
+ dy = 208;
+ if (i === 0 && !list[1]) {
+ core.over(
+ image,
+ memory,
+ a.time,
+ hidetime,
+ a.sound,
+ a.textColor,
+ a.boldColor,
+ a.font,
+ a.text
+ );
+ } else {
+ const numa =
+ parseInt(a?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
+ 16;
+ const numb =
+ parseInt(b?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
+ 16;
+ const numc =
+ parseInt(c?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
+ 16;
+ const numd =
+ parseInt(d?.font?.match(/\s*[\d.-]+[a-zA-Z%]*\s*/)?.[0].trim()) ||
+ 16;
- // 绘制
- if (a) {
- if (a.frame < hidetime / 2) {
- a.frame++;
- core.setAlpha(ctx, 1 - (hidetime - a.frame) / hidetime);
- ay += ((numa * (hidetime - a.frame)) / hidetime) * 3;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- a.text,
- 1014,
- ay,
- a.textColor,
- a.boldColor,
- 6,
- a.font
- );
- }
- if (a.frame === hidetime / 2) {
- core.setAlpha(ctx, 1 - (hidetime - a.frame) / hidetime);
- ay = 624 + ((numa * (hidetime - a.frame)) / hidetime) * 3;
- core.setTextAlign(ctx, "center");
-
- core.fillBoldText1(
- ctx,
- a.text,
- 1014,
- ay,
- a.textColor,
- a.boldColor,
- 6,
- a.font
- );
- if (!b) {
- a.frame++;
- i++;
- }
- }
+ // 绘制
+ if (a) {
+ if (a.frame < hidetime / 2) {
+ a.frame++;
+ core.setAlpha(ctx, 1 - (hidetime - a.frame) / hidetime);
+ ay += ((numa * (hidetime - a.frame)) / hidetime) * 3;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ a.text,
+ 338,
+ ay,
+ a.textColor,
+ a.boldColor,
+ 2,
+ a.font
+ );
}
- if (b) {
- if (b.frame > hidetime / 2 && b.frame <= hidetime) {
- b.frame++;
- core.setAlpha(ctx, 1 - (hidetime - b.frame) / hidetime);
- by += ((numb * (hidetime - b.frame)) / hidetime) * 3;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- b.text,
- 1014,
- by,
- b.textColor,
- b.boldColor,
- 6,
- b.font
- );
+ if (a.frame === hidetime / 2) {
+ core.setAlpha(ctx, 1 - (hidetime - a.frame) / hidetime);
+ ay = 208 + ((numa * (hidetime - a.frame)) / hidetime) * 3;
+ core.setTextAlign(ctx, "center");
- core.stopSound(sod);
- }
- const lisenb =
- b.sound && core.sounds[b.sound] && core.musicStatus.soundStatus;
- if (b.frame && lisenb) {
- sod = core.playSound(sound);
- }
- if (b.frame > hidetime && b.frame < hidetime + b.time) {
- b.frame++;
- ctx.globalAlpha = 1;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- b.text,
- 1014,
- by,
- b.textColor,
- b.boldColor,
- 6,
- b.font
- );
- }
-
- if (b.frame == hidetime + b.time) {
- ctx.globalAlpha = 1;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- b.text,
- 1014,
- by,
- b.textColor,
- b.boldColor,
- 6,
- b.font
- );
- if (a) a.frame++;
- if (b) b.frame++;
- if (c) c.frame++;
+ core.fillBoldText1(
+ ctx,
+ a.text,
+ 338,
+ ay,
+ a.textColor,
+ a.boldColor,
+ 2,
+ a.font
+ );
+ if (!b) {
+ a.frame++;
i++;
}
}
- if (c) {
- if (
- c.frame > hidetime + c.time &&
- c.frame < (hidetime * 3) / 2 + c.time
- ) {
- c.frame++;
- core.setAlpha(
- ctx,
- 1 - (c.frame - hidetime - c.time) / hidetime
- );
- cy -= ((numc * (c.frame - hidetime - c.time)) / hidetime) * 3;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- c.text,
- 1014,
- cy,
- c.textColor,
- c.boldColor,
- 6,
- c.font
- );
- }
- if (c.frame === (hidetime * 3) / 2 + c.time) {
- core.setAlpha(
- ctx,
- 1 - (c.frame - hidetime - c.time) / hidetime
- );
- cy =
- 624 - ((numc * (c.frame - hidetime - c.time)) / hidetime) * 3;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- c.text,
- 1014,
- cy,
- c.textColor,
- c.boldColor,
- 6,
- c.font
- );
- if (!b) {
- c.frame++;
- i++;
- }
- }
- }
- if (d) {
- if (
- d.frame > (hidetime * 3) / 2 + d.time &&
- d.frame < hidetime * 2 + d.time
- ) {
- d.frame++;
- core.setAlpha(
- ctx,
- 1 - (d.frame - hidetime - d.time) / hidetime
- );
- dy -= ((numd * (d.frame - hidetime - d.time)) / hidetime) * 3;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- d.text,
- 1014,
- dy,
- d.textColor,
- d.boldColor,
- 6,
- d.font
- );
- }
- if (d.frame == hidetime * 2 + d.time && !c) {
- core.unregisterAnimationFrame("overlist");
- core.clearMap(ctx)
- core.clearMap(ctx1)
+ }
+ if (b) {
+ if (b.frame > hidetime / 2 && b.frame <= hidetime) {
+ b.frame++;
+ core.setAlpha(ctx, 1 - (hidetime - b.frame) / hidetime);
+ by += ((numb * (hidetime - b.frame)) / hidetime) * 3;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ b.text,
+ 338,
+ by,
+ b.textColor,
+ b.boldColor,
+ 2,
+ b.font
+ );
- over.style.display = "none";
- core.stopSound(sod);
- core.doAction();
- return;
+ core.stopSound(sod);
+ }
+ const lisenb =
+ b.sound && core.sounds[b.sound] && core.musicStatus.soundStatus;
+ if (b.frame && lisenb) {
+ sod = core.playSound(sound);
+ }
+ if (b.frame > hidetime && b.frame < hidetime + b.time) {
+ b.frame++;
+ ctx.globalAlpha = 1;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ b.text,
+ 338,
+ by,
+ b.textColor,
+ b.boldColor,
+ 2,
+ b.font
+ );
+ }
+
+ if (b.frame == hidetime + b.time) {
+ ctx.globalAlpha = 1;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ b.text,
+ 338,
+ by,
+ b.textColor,
+ b.boldColor,
+ 2,
+ b.font
+ );
+ if (a) a.frame++;
+ if (b) b.frame++;
+ if (c) c.frame++;
+ i++;
+ }
+ }
+ if (c) {
+ if (
+ c.frame > hidetime + c.time &&
+ c.frame < (hidetime * 3) / 2 + c.time
+ ) {
+ c.frame++;
+ core.setAlpha(
+ ctx,
+ 1 - (c.frame - hidetime - c.time) / hidetime
+ );
+ cy -= ((numc * (c.frame - hidetime - c.time)) / hidetime) * 3;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ c.text,
+ 338,
+ cy,
+ c.textColor,
+ c.boldColor,
+ 2,
+ c.font
+ );
+ }
+ if (c.frame === (hidetime * 3) / 2 + c.time) {
+ core.setAlpha(
+ ctx,
+ 1 - (c.frame - hidetime - c.time) / hidetime
+ );
+ cy =
+ 208 - ((numc * (c.frame - hidetime - c.time)) / hidetime) * 3;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ c.text,
+ 338,
+ cy,
+ c.textColor,
+ c.boldColor,
+ 2,
+ c.font
+ );
+ if (!b) {
+ c.frame++;
+ i++;
}
}
}
- if (core.domStyle.isVertical) {
- ctx1.canvas.width = 416 * 3;
- ctx1.canvas.height = 676 * 3;
- ctx1.save(); //保存设置
- ctx1.translate(416 * 3, 0); //重新定位右上角为基准
- ctx1.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx1.canvas.width = 676 * 3;
- ctx1.canvas.height = 416 * 3;
+ if (d) {
+ if (
+ d.frame > (hidetime * 3) / 2 + d.time &&
+ d.frame < hidetime * 2 + d.time
+ ) {
+ d.frame++;
+ core.setAlpha(
+ ctx,
+ 1 - (d.frame - hidetime - d.time) / hidetime
+ );
+ dy -= ((numd * (d.frame - hidetime - d.time)) / hidetime) * 3;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ d.text,
+ 338,
+ dy,
+ d.textColor,
+ d.boldColor,
+ 2,
+ d.font
+ );
+ }
+ if (d.frame == hidetime * 2 + d.time && !c) {
+ core.unregisterAnimationFrame("overlist");
+ core.clearMap(ctx)
+ core.clearMap(ctx1)
+
+ over.style.display = "none";
+ core.stopSound(sod);
+ core.doAction();
+ return;
+ }
}
- core.clearMap(ctx1)
- ctx1.drawImage(temp, 0, 0, 676 * 3, 416 * 3)
- ctx1.restore();
}
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
+ ctx1.save(); //保存设置
+ ctx1.translate(416, 0); //重新定位右上角为基准
+ ctx1.rotate(Math.PI / 2); //旋转90度
+ } else {
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
+ }
+ core.clearMap(ctx1)
+ ctx1.drawImage(temp, 0, 0, 676, 416)
+ ctx1.restore();
+
});
};
@@ -17112,34 +15808,33 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
switch (style) {
case "引入":
core.registerAnimationFrame("bgin", true, (timestamp) => {
+ if (timestamp - start < 50) return
+ start = timestamp;
- if (start === 0) start = timestamp;
- let frame = Math.floor((timestamp - start) / (1000 / 60))
core.clearMap(ctx);
ctx.globalAlpha = frame / time;
if (img2) {
//绘制背景
if (memory2) ctx.filter = "sepia(50%)";
- core.drawImage(ctx, img2, 0, 0, 676 * 3, 1248);
+ core.drawImage(ctx, img2, 0, 0, 676, 416);
ctx.filter = "none";
} else {
ctx.fillStyle = "#000000"
- core.fillRect(ctx, 0, 0, 676 * 3, 1248);
+ core.fillRect(ctx, 0, 0, 676, 416);
}
if (core.domStyle.isVertical) {
- ctx1.canvas.width = 416 * 3;
- ctx1.canvas.height = 676 * 3;
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
ctx1.save(); //保存设置
- ctx1.translate(416 * 3, 0); //重新定位右上角为基准
+ ctx1.translate(416, 0); //重新定位右上角为基准
ctx1.rotate(Math.PI / 2); //旋转90度
} else {
- ctx1.canvas.width = 676 * 3;
- ctx1.canvas.height = 416 * 3;
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
}
core.clearMap(ctx1)
- ctx1.drawImage(temp, 0, 0, 676 * 3, 416 * 3)
+ ctx1.drawImage(temp, 0, 0, 676, 416)
+ frame++
ctx1.restore();
if (frame > time) {
core.unregisterAnimationFrame("bgin");
@@ -17153,34 +15848,34 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
break;
case "引出":
core.registerAnimationFrame("bgout", true, (timestamp) => {
- if (start === 0) start = timestamp;
- let frame = Math.floor((timestamp - start) / (1000 / 60))
+ if (timestamp - start < 50) return
+ start = timestamp;
+
core.clearMap(ctx);
ctx.globalAlpha = 1 - frame / time;
if (img1) {
//绘制背景
if (memory1) ctx.filter = "sepia(50%)";
- core.drawImage(ctx, img1, 0, 0, 676 * 3, 1248);
+ core.drawImage(ctx, img1, 0, 0, 676, 416);
ctx.filter = "none";
} else {
ctx.fillStyle = "#000000"
- core.fillRect(ctx, 0, 0, 676 * 3, 1248);
+ core.fillRect(ctx, 0, 0, 676, 416);
}
if (core.domStyle.isVertical) {
- ctx1.canvas.width = 416 * 3;
- ctx1.canvas.height = 676 * 3;
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
ctx1.save(); //保存设置
- ctx1.translate(416 * 3, 0); //重新定位右上角为基准
+ ctx1.translate(416, 0); //重新定位右上角为基准
ctx1.rotate(Math.PI / 2); //旋转90度
} else {
- ctx1.canvas.width = 676 * 3;
- ctx1.canvas.height = 416 * 3;
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
}
core.clearMap(ctx1)
- ctx1.drawImage(temp, 0, 0, 676 * 3, 416 * 3)
+ ctx1.drawImage(temp, 0, 0, 676, 416)
ctx1.restore();
+ frame++
if (frame > time) {
core.unregisterAnimationFrame("bgout");
over.style.display = "none";
@@ -17192,47 +15887,47 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
break;
case "场景切换":
core.registerAnimationFrame("changebg", true, (timestamp) => {
- if (start === 0) start = timestamp;
- let frame = Math.floor((timestamp - start) / (1000 / 60))
+ if (timestamp - start < 50) return
+ start = timestamp;
+
core.clearMap(ctx);
ctx.globalAlpha = 1;
ctx.fillStyle = "#000000"
- core.fillRect(ctx, 0, 0, 676 * 3, 1248);
+ core.fillRect(ctx, 0, 0, 676, 416);
ctx.globalAlpha = 1 - frame / time;
if (img1) {
//绘制背景
if (memory1) ctx.filter = "sepia(50%)";
- core.drawImage(ctx, img1, 0, 0, 676 * 3, 1248);
+ core.drawImage(ctx, img1, 0, 0, 676, 416);
ctx.filter = "none";
} else {
ctx.fillStyle = "#000000"
- core.fillRect(ctx, 0, 0, 676 * 3, 1248);
+ core.fillRect(ctx, 0, 0, 676, 416);
}
ctx.globalAlpha = frame / time;
if (img2) {
//绘制背景
if (memory2) ctx.filter = "sepia(50%)";
- core.drawImage(ctx, img2, 0, 0, 676 * 3, 1248);
+ core.drawImage(ctx, img2, 0, 0, 676, 416);
ctx.filter = "none";
} else {
ctx.fillStyle = "#000000"
- core.fillRect(ctx, 0, 0, 676 * 3, 1248);
+ core.fillRect(ctx, 0, 0, 676, 416);
}
if (core.domStyle.isVertical) {
- ctx1.canvas.width = 416 * 3;
- ctx1.canvas.height = 676 * 3;
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
ctx1.save(); //保存设置
- ctx1.translate(416 * 3, 0); //重新定位右上角为基准
+ ctx1.translate(416, 0); //重新定位右上角为基准
ctx1.rotate(Math.PI / 2); //旋转90度
} else {
- ctx1.canvas.width = 676 * 3;
- ctx1.canvas.height = 416 * 3;
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
}
core.clearMap(ctx1)
- ctx1.drawImage(temp, 0, 0, 676 * 3, 416 * 3)
+ ctx1.drawImage(temp, 0, 0, 676, 416)
ctx1.restore();
+ frame++
if (frame > time) {
core.unregisterAnimationFrame("changebg");
@@ -17252,20 +15947,18 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
//绘制背景
if (memory) ctx.filter = "sepia(70%)";
- core.drawImage(ctx, image, 0, 0, 2028, 1248);
+ core.drawImage(ctx, image, 0, 0, 676, 416);
ctx.filter = "none";
if (core.domStyle.isVertical) {
- ctx1.canvas.width = 416 * 3;
- ctx1.canvas.height = 676 * 3;
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
ctx1.save(); //保存设置
- ctx1.translate(416 * 3, 0); //重新定位右上角为基准
+ ctx1.translate(416, 0); //重新定位右上角为基准
ctx1.rotate(Math.PI / 2); //旋转90度
} else {
- ctx1.canvas.width = 676 * 3;
- ctx1.canvas.height = 416 * 3;
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
}
core.clearMap(ctx1)
- ctx1.drawImage(temp, 0, 0, 676 * 3, 416 * 3)
+ ctx1.drawImage(temp, 0, 0, 676, 416)
ctx1.restore();
}
@@ -17282,10 +15975,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss.style.zIndex = 310;
boss.style.display = "none";
boss.id = "boss";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss);
- boss.style.top = "50%";
- boss.style.left = "50%";
- boss.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss)
const ctx = boss.getContext("2d");
main.dom.boss = boss;
const boss1 = document.createElement("canvas"); //boss战画布设置
@@ -17293,10 +15983,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss1.style.zIndex = 300;
boss1.style.display = "none";
boss1.id = "boss1";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss1);
- boss1.style.top = "50%";
- boss1.style.left = "50%";
- boss1.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss1)
const ctx1 = boss1.getContext("2d");
main.dom.boss1 = boss1;
const boss2 = document.createElement("canvas"); //boss战画布设置
@@ -17304,10 +15991,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss2.style.zIndex = 301;
boss2.style.display = "none";
boss2.id = "boss2";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss2);
- boss2.style.top = "50%";
- boss2.style.left = "50%";
- boss2.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss2)
main.dom.boss2 = boss2;
const ctx2 = boss2.getContext("2d");
const boss3 = document.createElement("canvas"); //boss战画布设置
@@ -17315,10 +15999,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss3.style.zIndex = 302;
boss3.style.display = "none";
boss3.id = "boss3";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss3);
- boss3.style.top = "50%";
- boss3.style.left = "50%";
- boss3.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss3)
main.dom.boss3 = boss3;
const ctx3 = boss3.getContext("2d");
const boss4 = document.createElement("canvas"); //boss战画布设置
@@ -17326,10 +16007,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss4.style.zIndex = 303;
boss4.style.display = "none";
boss4.id = "boss4";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss4);
- boss4.style.top = "50%";
- boss4.style.left = "50%";
- boss4.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss4)
const ctx4 = boss4.getContext("2d");
main.dom.boss4 = boss4;
const boss5 = document.createElement("canvas"); //boss战画布设置
@@ -17337,10 +16015,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss5.style.zIndex = 304;
boss5.style.display = "none";
boss5.id = "boss5";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss5);
- boss5.style.top = "50%";
- boss5.style.left = "50%";
- boss5.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss5)
const ctx5 = boss5.getContext("2d");
main.dom.boss5 = boss5;
@@ -17349,10 +16024,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss6.style.zIndex = 305;
boss6.style.display = "none";
boss6.id = "boss6";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss6);
- boss6.style.top = "50%";
- boss6.style.left = "50%";
- boss6.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss6)
const ctx6 = boss6.getContext("2d");
main.dom.boss6 = boss6;
const boss7 = document.createElement("canvas"); //boss战画布设置
@@ -17360,10 +16032,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss7.style.zIndex = 306;
boss7.style.display = "none";
boss7.id = "boss7";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss7);
- boss7.style.top = "50%";
- boss7.style.left = "50%";
- boss7.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss7)
const ctx7 = boss7.getContext("2d");
main.dom.boss7 = boss7;
const boss8 = document.createElement("canvas"); //boss战画布设置
@@ -17371,10 +16040,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss8.style.zIndex = 307;
boss8.style.display = "none";
boss8.id = "boss8";
- main.dom.gameGroup.insertAdjacentElement("afterend", boss8);
- boss8.style.top = "50%";
- boss8.style.left = "50%";
- boss8.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", boss8)
const ctx8 = boss8.getContext("2d");
main.dom.boss8 = boss8;
const { imagelighter } = core.plugin.utils;
@@ -17388,14 +16054,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.playSound((animate.se || {})[index % animate.frame + 1], (animate.pitch || {})[index % animate.frame + 1]);
var ratio = animate.ratio * 6;
if (core.domStyle.isVertical) {
- a.canvas.width = 1248;
- a.canvas.height = 2028;
+ core.maps._setHDCanvasSize(a, 416, 676)
a.save(); //保存设置
- a.translate(1248, 0); //重新定位右上角为基准
+ a.translate(416, 0); //重新定位右上角为基准
a.rotate(Math.PI / 2); //旋转90度
} else {
- a.canvas.width = 2028;
- a.canvas.height = 1248;
+ core.maps._setHDCanvasSize(a, 676, 416)
}
frame.forEach(function (t) {
var image = animate.images[t.index];
@@ -17422,7 +16086,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let ani = []
function drawanimate(timestamp) {
- let frametime = timestamp - core.ui.boss.time
+ if (timestamp - core.ui.boss.time < 50) return
core.ui.boss.time = timestamp;
if (!ani || ani.length == 0) return;
@@ -17430,8 +16094,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
// 更新帧
for (var i = 0; i < ani.length; i++) {
var obj = ani[i];
- if (obj.start === 0) obj.start = core.ui.boss.time
- obj.index = Math.floor((core.ui.boss.time - obj.start) / (1000 / 60))
if (obj.index >= obj.animate.frames.length) {
@@ -17443,12 +16105,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
}
ani = ani.filter(function (obj) {
- return obj.index < obj.animate.frames.length;
+ return obj.index <= obj.animate.frames.length;
});
ani.forEach(function (obj) {
- animateFarme(ctx6, obj.animate, obj.centerX, obj.centerY, obj.index);
+ animateFarme(ctx6, obj.animate, obj.centerX, obj.centerY, obj.index++);
});
}
@@ -17468,19 +16130,19 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let x, y;
if (core.domStyle.isVertical) {
- x = py * 3;
- y = 1248 - px * 3;
+ x = py;
+ y = 416 - px;
} else {
- x = px * 3;
- y = py * 3;
+ x = px;
+ y = py;
}
core.ui.boss.click(x, y);
if (
- x > 1050 &&
- x < 1450 &&
- y > 250 &&
- y < 390 &&
+ x > 350 &&
+ x < 483 &&
+ y > 83 &&
+ y < 130 &&
!core.ui.boss.show &&
core.ui.boss.hasEnemy()
) {
@@ -17490,10 +16152,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
return; // 退出函数
}
if (
- x > 850 &&
- x < 1250 &&
- y > 250 &&
- y < 390 &&
+ x > 283 &&
+ x < 417 &&
+ y > 83 &&
+ y < 130 &&
!core.ui.boss.show &&
!core.ui.boss.hasEnemy()
) {
@@ -17672,42 +16334,38 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
);
core.clearMap(ctx2);
if (core.domStyle.isVertical) {
- ctx2.canvas.width = 1248;
- ctx2.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx2, 416, 676)
ctx2.save(); //保存设置
- ctx2.translate(1248, 0); //重新定位右上角为基准
+ ctx2.translate(416, 0); //重新定位右上角为基准
ctx2.rotate(Math.PI / 2); //旋转90度
} else {
- ctx2.canvas.width = 2028;
- ctx2.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx2, 676, 416)
}
- core.drawImage(ctx2, img, animate.x, 168, 750, 1080);
+ core.drawImage(ctx2, img, animate.x, 56, 250, 360);
ctx2.restore();
} else {
core.clearMap(ctx3);
if (core.domStyle.isVertical) {
- ctx3.canvas.width = 1248;
- ctx3.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx3, 416, 676)
ctx3.save(); //保存设置
ctx3.translate(1248, 0); //重新定位右上角为基准
ctx3.rotate(Math.PI / 2); //旋转90度
} else {
- ctx3.canvas.width = 2028;
- ctx3.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx3, 676, 416)
}
if (this.selection === "boss" || this.selection === "") {
const img = imagelighter(
core.material.images.images[this.boss.image]
);
- core.drawImage(ctx3, img, 1400 + animate.x, 168, 750, 1080);
+ core.drawImage(ctx3, img, 467 + animate.x, 56, 250, 360);
} else {
const img = imagelighter(
core.material.images.images[
this.enemy[this.selection].image
]
);
- core.drawImage(ctx3, img, 1400 + animate.x, 168, 750, 1080);
+ core.drawImage(ctx3, img, 467 + animate.x, 56, 250, 360);
}
ctx3.restore();
@@ -17715,7 +16373,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
animate.ticker.add(fn)
animate.getTime = () => Date.now() / 100
- animate.mode(shake(30, linear()), true).time(5).shake(1, 0)
+ animate.mode(shake(10, linear()), true).time(5).shake(1, 0)
await animate.all();
animate.ticker.destroy()
this.drawhero();
@@ -17728,24 +16386,23 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (typeof damage === "number") {
color = damage < 0 ? "#22FF44" : "lightcoral";
}
- let posx = onhero ? 300 : 1800;
+ let posx = onhero ? 100 : 600;
let start = 0
- const speed = 9;
+ const speed = 3;
return new Promise((resolve) => {
+ let farme = 0
core.registerAnimationFrame("popDamageonboss", true, (temptime) => {
+ if (temptime - start < 50) return
+ start = temptime
- if (start === 0) start = temptime
- let farme = Math.floor((temptime - start) / (1000 / 60))
if (core.domStyle.isVertical) {
- ctx.canvas.width = 1248;
- ctx.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx, 416, 676)
ctx.save(); //保存设置
ctx.translate(1248, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
} else {
- ctx.canvas.width = 2028;
- ctx.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx, 676, 416)
}
core.clearMap(ctx);
core.setTextAlign(ctx, "center");
@@ -17753,14 +16410,15 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
ctx,
damage,
posx,
- 800 - speed * farme,
+ 267 - speed * farme,
color,
"#000000",
- 6,
- "bold 72px Arial"
+ 2,
+ "bold 24px Arial"
);
ctx.restore();
+ farme++
if (farme > 30) {
core.unregisterAnimationFrame("popDamageonboss");
@@ -17791,44 +16449,44 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
case "hero":
this.popDamage(damage, false);
if (damage > 0 && typeof damage !== "string") this.shake(false);
- await this.playanimate("jianji2", 1750, 770); //播放动画jianji2
+ await this.playanimate("jianji2", 583, 257); //播放动画jianji2
break;
case "angel":
this.popDamage(damage, true);
if (damage > 0 && typeof damage !== "string") this.shake(true);
- await this.playanimate("sword", 300, 770); //播放动画sword
+ await this.playanimate("sword", 100, 257); //播放动画sword
break;
case "bat":
this.popDamage(damage, true);
if (damage > 0 && typeof damage !== "string") this.shake(true);
- await this.playanimate("sword", 300, 770); //播放动画sword
+ await this.playanimate("sword", 100, 257); //播放动画sword
break;
case "redBat":
this.popDamage(damage, true);
if (damage > 0 && typeof damage !== "string") this.shake(true);
- await this.playanimate("hand", 300, 770); //播放动画hand
+ await this.playanimate("hand", 100, 257); //播放动画hand
break;
case "bigBat":
this.popDamage(damage, true);
if (damage > 0 && typeof damage !== "string") this.shake(true);
- await this.playanimate("jianji", 300, 770); //播放动画jianji
+ await this.playanimate("jianji", 100, 257); //播放动画jianji
break;
case "greenSlime":
this.popDamage(damage, true);
if (damage > 0 && typeof damage !== "string") this.shake(true);
- await this.playanimate("thunder", 300, 770); //播放动画thunder
+ await this.playanimate("thunder", 100, 257); //播放动画thunder
break;
case "redSlime":
this.popDamage(damage, true);
if (damage > 0 && typeof damage !== "string") this.shake(true);
- await this.playanimate("yongchang", 300, 770); //播放动画yongchang
+ await this.playanimate("yongchang", 100, 257); //播放动画yongchang
break;
case "blackSlime":
this.popDamage(damage, true);
if (damage > 0 && typeof damage !== "string") this.shake(true);
- await this.playanimate("zone", 300, 770); //播放动画zone
+ await this.playanimate("zone", 100, 257); //播放动画zone
break;
}
break; //下面写其余技能
@@ -17852,11 +16510,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
const pos = [px, py];
if (main.replayChecking || core.isReplaying()) return;
- const enemyStatusBox = makeBox([50, 50], [1900, 200]),
- heroStatusBox = makeBox([600, 920], [900, 300]),
- bossBox = makeBox([800, 300], [100, 150]),
- enemyBox = makeBox([700, 500], [300, 300]),
- imageBox = makeBox([1500, 250], [550, 1000]);
+ const enemyStatusBox = makeBox([17, 17], [633, 67]),
+ heroStatusBox = makeBox([200, 307], [300, 100]),
+ bossBox = makeBox([267, 100], [33, 50]),
+ enemyBox = makeBox([233, 167], [100, 100]),
+ imageBox = makeBox([500, 83], [183, 333]);
if (this.show) {
//清除展示画面
this.show = !this.show;
@@ -17889,7 +16547,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
} else if (inRect(pos, enemyBox) && this.hasEnemy()) {
//切换selection为enemy
const symbol =
- Math.floor((px - 700) / 100) + Math.floor((py - 500) / 150) * 3;
+ Math.floor((px - 233) / 33) + Math.floor((py - 167) / 50) * 3;
if (this.enemy[symbol] && this.enemy[symbol].hp > 0) {
this.selection = symbol;
@@ -17901,14 +16559,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
drawchoose() {
boss7.style.display = "block";
if (core.domStyle.isVertical) {
- ctx7.canvas.width = 1248;
- ctx7.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx7, 416, 676)
ctx7.save(); //保存设置
- ctx7.translate(1248, 0); //重新定位右上角为基准
+ ctx7.translate(416, 0); //重新定位右上角为基准
ctx7.rotate(Math.PI / 2); //旋转90度
} else {
- ctx7.canvas.width = 2028;
- ctx7.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx7, 676, 416)
}
core.clearMap(ctx7);
@@ -17916,143 +16572,129 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawWindowSkin(
"winskin.webp",
ctx7,
- 1050,
- 250,
- 400,
- 660,
- null,
- null,
- null,
- 3
+ 350,
+ 83,
+ 133,
+ 220
);
core.fillBoldText1(
ctx7,
"普通攻击",
- 1120,
- 350,
+ 373,
+ 117,
"#FFFFFF",
"#000000",
- 6,
- "bold 64px Verdana"
+ 2,
+ "bold 31px Verdana"
);
- core.drawLine(ctx7, 1070, 390, 1430, 390, "#FFFFFF", 6);
+ core.drawLine(ctx7, 357, 130, 477, 130, "#FFFFFF", 2);
} else {
core.drawWindowSkin(
"winskin.webp",
ctx7,
- 850,
- 250,
- 400,
- 660,
- null,
- null,
- null,
- 3
+ 283,
+ 83,
+ 133,
+ 220
);
core.fillBoldText1(
ctx7,
"普通攻击",
- 920,
- 350,
+ 307,
+ 117,
"#FFFFFF",
"#000000",
- 6,
- "bold 64px Verdana"
+ 2,
+ "bold 21px Verdana"
);
- core.drawLine(ctx7, 850, 390, 1250, 390, "#FFFFFF", 6);
+ core.drawLine(ctx7, 283, 130, 417, 130, "#FFFFFF", 2);
}
ctx7.restore();
}
moreShow(select) {
if (core.domStyle.isVertical) {
- ctx8.canvas.width = 1248;
- ctx8.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx8, 416, 676)
ctx8.save(); //保存设置
- ctx8.translate(1248, 0); //重新定位右上角为基准
+ ctx8.translate(416, 0); //重新定位右上角为基准
ctx8.rotate(Math.PI / 2); //旋转90度
} else {
- ctx8.canvas.width = 2028;
- ctx8.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx8, 676, 416)
}
core.clearMap(ctx8);
- core.fillRect(ctx8, 100, 100, 1800, 1000, "rgba(0,0,0,0.7)");
+ core.fillRect(ctx8, 33, 33, 600, 333, "rgba(0,0,0,0.7)");
core.drawWindowSkin(
"winskin.webp",
ctx8,
- 100,
- 100,
- 1800,
- 1000,
- null,
- null,
- null,
- 3
+ 33,
+ 33,
+ 600,
+ 333
);
- let posy = 200;
+ let posy = 67;
switch (select) {
case "hero":
//勇士技能/buff
core.fillBoldText1(
ctx8,
this.hero.name,
- 1000,
+ 333,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
if (this.herobuff.length === 0) {
core.fillBoldText1(
ctx8,
"当前无特殊状态",
- 200,
+ 67,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
} else {
this.herobuff.forEach((v) => {
core.drawTextContent(ctx8, this.buffshow(v), {
- left: 200,
+ left: 67,
top: posy,
bold: true,
color: "#FFFFFF",
align: "left",
- fontSize: 48,
+ fontSize: 16,
time: 0,
font: "Verdana",
- maxWidth: 1600,
+ maxWidth: 533,
});
- posy += 100;
+ posy += 33;
});
}
- posy += 50;
+ posy += 17;
core.setTextAlign(ctx8, "center")
core.fillBoldText1(
ctx8,
"主角所造成的伤害将提升主角速度与怪物敌人速度值之比",
- 1000,
+ 333,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
core.fillBoldText1(
ctx8,
"技能说明",
- 1000,
+ 333,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
posy += 100;
core.fillBoldText1(
@@ -18062,73 +16704,73 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
break;
case "boss":
core.fillBoldText1(
ctx8,
this.boss.name,
- 1000,
+ 333,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
//boss技能/buff
if (this.bossbuff.length === 0) {
core.fillBoldText1(
ctx8,
"当前无特殊状态",
- 200,
+ 67,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
} else {
this.bossbuff.forEach((v) => {
core.drawTextContent(ctx8, this.buffshow(v), {
- left: 200,
+ left: 67,
top: posy,
bold: true,
color: "#FFFFFF",
align: "left",
- fontSize: 48,
+ fontSize: 16,
time: 0,
font: "Verdana",
- maxWidth: 1600,
+ maxWidth: 533,
});
- posy += 100;
+ posy += 33;
});
}
- posy += 50;
+ posy += 17;
core.fillBoldText1(
ctx8,
"当前技能",
- 1000,
+ 333,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
core.fillBoldText1(
ctx8,
this.boss.skill[this.boss.index] +
this.skillShow[this.boss.skill[this.boss.index]],
- 200,
+ 67,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
break;
default:
@@ -18137,64 +16779,64 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillBoldText1(
ctx8,
enemy.name,
- 1000,
+ 333,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
if (enemybuff.length === 0) {
core.fillBoldText1(
ctx8,
"当前无特殊状态",
- 200,
+ 67,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 67;
} else {
enemybuff.forEach((v) => {
core.drawTextContent(ctx8, this.buffshow(v), {
- left: 200,
+ left: 67,
top: posy,
bold: true,
color: "#FFFFFF",
align: "left",
- fontSize: 48,
+ fontSize: 16,
time: 0,
font: "Verdana",
- maxWidth: 1600,
+ maxWidth: 533,
});
- posy += 100;
+ posy += 33;
});
}
- posy += 50;
+ posy += 17;
core.fillBoldText1(
ctx8,
"当前技能",
- 1000,
+ 333,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
- posy += 100;
+ posy += 33;
core.fillBoldText1(
ctx8,
enemy.skill[enemy.index] +
this.skillShow[enemy.skill[enemy.index]],
- 200,
+ 67,
posy,
"#FFFFFF",
"#000000",
- 6,
- "bold 48px Verdana"
+ 2,
+ "bold 16px Verdana"
);
break;
}
@@ -18317,20 +16959,18 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const fn = () => {
core.clearMap(ctx);
if (core.domStyle.isVertical) {
- ctx.canvas.width = 1248;
- ctx.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx, 416, 676)
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
} else {
- ctx.canvas.width = 2028;
- ctx.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx, 676, 416)
}
core.fillRect(
ctx,
0,
- 624 - animate.y,
- 2028,
+ 208 - animate.y,
+ 676,
animate.y * 2,
"rgba(0,0,0,0.7)"
);
@@ -18339,21 +16979,21 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.fillBoldText1(
ctx,
"回合 " + this.turn,
- animate.x - 300,
- 644,
+ animate.x - 100,
+ 215,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(96, true)
+ 2,
+ core.ui._buildFont(32, true)
);
ctx.restore()
}
animate.ticker.add(fn)
- animate.mode(hyper('sin', 'out')).time(1000).move(1314, 200)
+ animate.mode(hyper('sin', 'out')).time(1000).move(438, 67)
await animate.all()
await sleep(500)
- animate.mode(hyper('sin', 'in')).time(1000).move(2800, 0)
+ animate.mode(hyper('sin', 'in')).time(1000).move(933, 0)
await animate.all()
core.clearMap(ctx);
animate.ticker.destroy()
@@ -18367,133 +17007,125 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss5.style.display = "block";
core.registerAnimationFrame("enemyanimate", true, (temptime) => {
- if (temptime - time > 1000 / 60) {
- time = temptime;
- this.enemyfarme += 1;
- let animate = Math.floor(this.enemyfarme / 10),
- posx = 700,
- posy = 500;
- core.clearMap(ctx5);
- if (core.domStyle.isVertical) {
- ctx5.canvas.width = 1248;
- ctx5.canvas.height = 2028;
- ctx5.save(); //保存设置
- ctx5.translate(1248, 0); //重新定位右上角为基准
- ctx5.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx5.canvas.width = 2028;
- ctx5.canvas.height = 1248;
- }
+ if (temptime - time < 50) return
+ time = temptime;
+ this.enemyfarme += 1;
+ let animate = Math.floor(this.enemyfarme / 10),
+ posx = 233,
+ posy = 167;
+ core.clearMap(ctx5);
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx5, 416, 676)
+ ctx5.save(); //保存设置
+ ctx5.translate(416, 0); //重新定位右上角为基准
+ ctx5.rotate(Math.PI / 2); //旋转90度
+ } else {
+ core.maps._setHDCanvasSize(ctx5, 676, 416)
+ }
- if (this.hasEnemy()) {
- core.drawWindowSkin(
- "winskin.webp",
- ctx5,
- 650,
- 250,
- 400,
- 660,
- null,
- null,
- null,
- 3
- );
- if (this.selection === "boss")
- core.strokeRect(ctx5, 800, 300, 100, 150, "yellow", 6);
- const bossBlock = core.getBlockInfo(this.boss.id);
- core.drawImage(
- ctx5,
- bossBlock.image,
- 32 * (animate % 4),
- bossBlock.posY * 48,
- 32,
- 48,
- 800,
- 300,
- 96,
- 144
- );
- core.drawImage(
- ctx5,
- "hero.webp",
- 32 * (animate % 4),
- 144,
- 32,
- 48,
- 800,
- 750,
- 96,
- 144
- );
- for (let i = 0; i < this.enemy.length; i++) {
- if (this.enemy[i].id && this.enemy[i].hp > 0) {
- block = core.getBlockInfo(this.enemy[i].id);
- } else {
- posx += 100;
- if (i === 2) {
- posx = 700;
- posy += 150;
- }
- continue;
- }
-
- if (block.cls === "enemys") {
- core.drawImage(
- ctx5,
- block.image,
- 32 * (animate % 2),
- block.posY * 32,
- 32,
- 32,
- posx,
- posy,
- 96,
- 96
- );
- if (this.selection === i)
- core.strokeRect(ctx5, posx, posy, 100, 100, "yellow", 6);
- } else {
- core.drawImage(
- ctx5,
- block.image,
- 32 * (animate % 4),
- block.posY * 48,
- 32,
- 48,
- posx,
- posy,
- 96,
- 144
- );
- if (this.selection === i)
- core.strokeRect(ctx5, posx, posy, 100, 150, "yellow", 6);
- }
-
- posx += 100;
+ if (this.hasEnemy()) {
+ core.drawWindowSkin(
+ "winskin.webp",
+ ctx5,
+ 217,
+ 83,
+ 133,
+ 220
+ );
+ if (this.selection === "boss")
+ core.strokeRect(ctx5, 267, 100, 33, 50, "yellow", 2);
+ const bossBlock = core.getBlockInfo(this.boss.id);
+ core.drawImage(
+ ctx5,
+ bossBlock.image,
+ 32 * (animate % 4),
+ bossBlock.posY * 48,
+ 32,
+ 48,
+ 267,
+ 100,
+ 32,
+ 48
+ );
+ core.drawImage(
+ ctx5,
+ "hero.webp",
+ 32 * (animate % 4),
+ 144,
+ 32,
+ 48,
+ 267,
+ 250,
+ 32,
+ 48
+ );
+ for (let i = 0; i < this.enemy.length; i++) {
+ if (this.enemy[i].id && this.enemy[i].hp > 0) {
+ block = core.getBlockInfo(this.enemy[i].id);
+ } else {
+ posx += 33;
if (i === 2) {
- posx = 700;
- posy += 150;
+ posx = 233;
+ posy += 50;
}
+ continue;
+ }
+
+ if (block.cls === "enemys") {
+ core.drawImage(
+ ctx5,
+ block.image,
+ 32 * (animate % 2),
+ block.posY * 32,
+ 32,
+ 32,
+ posx,
+ posy,
+ 32,
+ 32
+ );
+ if (this.selection === i)
+ core.strokeRect(ctx5, posx, posy, 33, 33, "yellow", 2);
+ } else {
+ core.drawImage(
+ ctx5,
+ block.image,
+ 32 * (animate % 4),
+ block.posY * 48,
+ 32,
+ 48,
+ posx,
+ posy,
+ 32,
+ 48
+ );
+ if (this.selection === i)
+ core.strokeRect(ctx5, posx, posy, 33, 50, "yellow", 3);
+ }
+
+ posx += 33;
+ if (i === 2) {
+ posx = 233;
+ posy += 50;
}
}
-
- ctx5.restore();
}
+
+ ctx5.restore();
+
});
}
drawhero() {
core.clearMap(ctx2);
if (core.domStyle.isVertical) {
- ctx2.canvas.width = 1248;
- ctx2.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx2, 416, 676)
ctx2.save(); //保存设置
- ctx2.translate(1248, 0); //重新定位右上角为基准
+ ctx2.translate(416, 0); //重新定位右上角为基准
ctx2.rotate(Math.PI / 2); //旋转90度
} else {
- ctx2.canvas.width = 2028;
- ctx2.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx, 676, 416)
}
- core.drawImage(ctx2, this.heroImage, 0, 168, 750, 1080);
+ core.drawImage(ctx2, this.heroImage, 0, 56, 250, 360);
ctx2.restore();
}
async movehero() {
@@ -18502,21 +17134,19 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const fn = () => {
core.clearMap(ctx2);
if (core.domStyle.isVertical) {
- ctx2.canvas.width = 1248;
- ctx2.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx2, 416, 676)
ctx2.save(); //保存设置
- ctx2.translate(1248, 0); //重新定位右上角为基准
+ ctx2.translate(416, 0); //重新定位右上角为基准
ctx2.rotate(Math.PI / 2); //旋转90度
} else {
- ctx2.canvas.width = 2028;
- ctx2.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx2, 676, 416)
}
- core.drawImage(ctx2, this.heroImage, animate.x - 200, 168, 750, 1080);
+ core.drawImage(ctx2, this.heroImage, animate.x - 67, 56, 250, 360);
ctx2.restore();
}
animate.ticker.add(fn)
- animate.mode(hyper('sin', 'out')).time(1000).move(200, 0)
+ animate.mode(hyper('sin', 'out')).time(1000).move(67, 0)
await animate.all()
core.clearMap(ctx2);
@@ -18525,7 +17155,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
update() {
- core.drawImage(ctx1, this.bg, 0, 0, 2028, 1248);
+ core.drawImage(ctx1, this.bg, 0, 0, 676, 416);
this.drawboss();
this.drawhero();
this.drawStatus();
@@ -18579,25 +17209,23 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
drawboss() {
core.clearMap(ctx3);
if (core.domStyle.isVertical) {
- ctx3.canvas.width = 1248;
- ctx3.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx3, 416, 676)
ctx3.save(); //保存设置
- ctx3.translate(1248, 0); //重新定位右上角为基准
+ ctx3.translate(416, 0); //重新定位右上角为基准
ctx3.rotate(Math.PI / 2); //旋转90度
} else {
- ctx3.canvas.width = 2028;
- ctx3.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx3, 676, 416)
}
if (this.selection === "boss" || this.selection === "") {
- core.drawImage(ctx3, this.boss.image, 1400, 168, 750, 1080);
+ core.drawImage(ctx3, this.boss.image, 467, 56, 250, 360);
} else {
core.drawImage(
ctx3,
this.enemy[this.selection].image,
- 1400,
- 168,
- 750,
- 1080
+ 467,
+ 56,
+ 250,
+ 360
);
}
@@ -18609,22 +17237,20 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const fn = () => {
core.clearMap(ctx3);
if (core.domStyle.isVertical) {
- ctx3.canvas.width = 1248;
- ctx3.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx3, 416, 676)
ctx3.save(); //保存设置
- ctx3.translate(1248, 0); //重新定位右上角为基准
+ ctx3.translate(416, 0); //重新定位右上角为基准
ctx3.rotate(Math.PI / 2); //旋转90度
} else {
- ctx3.canvas.width = 2028;
- ctx3.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx3, 676, 416)
}
- core.drawImage(ctx3, this.boss.image, 1600 - animate.x, 168, 750, 1080);
+ core.drawImage(ctx3, this.boss.image, 533 - animate.x, 56, 250, 360);
ctx3.restore();
}
animate.ticker.add(fn)
- animate.mode(hyper('sin', 'out')).time(1000).move(200, 0)
+ animate.mode(hyper('sin', 'out')).time(1000).move(67, 0)
await animate.all()
core.clearMap(ctx3);
@@ -18635,124 +17261,118 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
drawStatus() {
core.clearMap(ctx4);
if (core.domStyle.isVertical) {
- ctx4.canvas.width = 1248;
- ctx4.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx4, 416, 676)
ctx4.save(); //保存设置
- ctx4.translate(1248, 0); //重新定位右上角为基准
+ ctx4.translate(416, 0); //重新定位右上角为基准
ctx4.rotate(Math.PI / 2); //旋转90度
} else {
- ctx4.canvas.width = 2028;
- ctx4.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx4, 676, 416)
}
core.drawWindowSkin(
"winskin.webp",
ctx4,
- 600,
- 920,
- 900,
+ 200,
+ 307,
300,
- null,
- null,
- null,
- 3
+ 100
);
core.fillBoldText1(
ctx4,
hero.name,
- 630,
- 1000,
+ 210,
+ 333,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"状态",
- 880,
- 1000,
+ 293,
+ 333,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"生命 " + this.hero.hp,
- 630,
- 1070,
+ 210,
+ 357,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"攻击 " + this.hero.atk,
- 630,
- 1120,
+ 210,
+ 373,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"防御 " + this.hero.def,
- 630,
- 1170,
+ 210,
+ 390,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法强 " + this.hero.spell,
- 1080,
- 1070,
+ 360,
+ 357,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法抗 " + this.hero.mdef + "%",
- 1080,
- 1120,
+ 360,
+ 373,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"速度 " + this.hero.speed,
- 1080,
- 1170,
+ 360,
+ 390,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
- let posx = 980;
+ let posx = 327;
this.herobuff.forEach((v) => {
if (v) {
- core.drawIcon(ctx4, v.id, posx, 950, 64, 64);
+ core.drawIcon(ctx4, v.id, posx, 317, 21, 21);
core.setTextAlign(ctx4, "right");
core.fillBoldText1(
ctx4,
v.count,
- posx + 50,
- 1000,
+ posx + 27,
+ 333,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(24, true)
+ 2,
+ core.ui._buildFont(8, true)
);
core.setTextAlign(ctx4, "left");
- posx += 80;
+ posx += 27;
}
});
@@ -18760,247 +17380,239 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawWindowSkin(
"winskin.webp",
ctx4,
- 50,
- 50,
- 1900,
- 200,
- null,
- null,
- null,
- 3
+ 17,
+ 17,
+ 633,
+ 67
);
core.fillBoldText1(
ctx4,
this.boss.name,
- 100,
- 120,
+ 33,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"状态",
- 500,
- 120,
+ 167,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"当前技能",
- 1400,
- 120,
+ 467,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
const bosstext = this.boss.skill[this.boss.index];
core.fillBoldText1(
ctx4,
bosstext,
- 1600,
- 120,
+ 533,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"生命 " + this.boss.hp,
- 100,
- 220,
+ 33,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"攻击 " + this.boss.atk,
- 500,
- 220,
+ 133,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"防御 " + this.boss.def,
- 900,
- 220,
+ 300,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法抗 " + this.boss.mdef + "%",
- 1300,
- 220,
+ 433,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"速度 " + this.boss.speed,
- 1700,
- 220,
+ 567,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
- let posx = 600;
+ let posx = 200;
this.bossbuff.forEach((v) => {
if (v) {
- core.drawIcon(ctx4, v.id, posx, 80, 64, 64);
+ core.drawIcon(ctx4, v.id, posx, 27, 21, 21);
core.setTextAlign(ctx4, "right");
core.fillBoldText1(
ctx4,
v.count,
- posx + 50,
- 130,
+ posx + 17,
+ 43,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(24, true)
+ 2,
+ core.ui._buildFont(8, true)
);
core.setTextAlign(ctx4, "left");
- posx += 80;
+ posx += 27;
}
});
} else if (this.selection === "") {} else {
core.drawWindowSkin(
"winskin.webp",
ctx4,
- 50,
- 50,
- 1900,
- 200,
- null,
- null,
- null,
- 3
+ 17,
+ 17,
+ 633,
+ 67
);
core.fillBoldText1(
ctx4,
this.enemy[this.selection].name,
- 100,
- 120,
+ 33,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"状态",
- 500,
- 120,
+ 233,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"当前技能",
- 1400,
- 120,
+ 467,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
const enemytext =
this.enemy[this.selection].skill[this.enemy[this.selection].index];
core.fillBoldText1(
ctx4,
enemytext,
- 1600,
- 120,
+ 533,
+ 40,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"生命 " + this.enemy[this.selection].hp,
- 100,
- 220,
+ 33,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"攻击 " + this.enemy[this.selection].atk,
- 500,
- 220,
+ 167,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"防御 " + this.enemy[this.selection].def,
- 900,
- 220,
+ 300,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法抗 " + this.enemy[this.selection].mdef + "%",
- 1300,
- 220,
+ 433,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"速度 " + this.enemy[this.selection].speed,
- 1700,
- 220,
+ 567,
+ 73,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
let posx = 600;
this.enemybuff[this.selection].forEach((v) => {
if (v) {
- core.drawIcon(ctx4, v.id, posx, 80, 64, 64);
+ core.drawIcon(ctx4, v.id, posx, 27, 21, 21);
core.setTextAlign(ctx4, "right");
core.fillBoldText1(
ctx4,
v.count,
- posx + 50,
- 130,
+ posx + 17,
+ 43,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(24, true)
+ 2,
+ core.ui._buildFont(8, true)
);
core.setTextAlign(ctx4, "left");
- posx += 80;
+ posx += 27;
}
});
}
@@ -19012,328 +17624,314 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
const fn = () => {
core.clearMap(ctx4);
if (core.domStyle.isVertical) {
- ctx4.canvas.width = 1248;
- ctx4.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx4, 416, 676)
ctx4.save(); //保存设置
- ctx4.translate(1248, 0); //重新定位右上角为基准
+ ctx4.translate(416, 0); //重新定位右上角为基准
ctx4.rotate(Math.PI / 2); //旋转90度
} else {
- ctx4.canvas.width = 2028;
- ctx4.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx4, 676, 416)
}
core.drawWindowSkin(
"winskin.webp",
ctx4,
- 600,
- 1320 - animate.y,
- 900,
+ 200,
+ 440 - animate.y,
300,
- null,
- null,
- null,
- 3
+ 100
);
core.fillBoldText1(
ctx4,
hero.name,
- 630,
- 1400 - animate.y,
+ 210,
+ 467 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"状态",
- 880,
- 1400 - animate.y,
+ 293,
+ 467 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"生命 " + this.hero.hp,
- 630,
- 1470 - animate.y,
+ 210,
+ 490 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"攻击 " + this.hero.atk,
- 630,
- 1520 - animate.y,
+ 210,
+ 57 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"防御 " + this.hero.def,
- 630,
- 1570 - animate.y,
+ 210,
+ 523 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法强 " + this.hero.spell,
- 1080,
- 1470 - animate.y,
+ 360,
+ 490 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法抗 " + this.hero.mdef + "%",
- 1080,
- 1520 - animate.y,
+ 360,
+ 507 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"速度 " + this.hero.speed,
- 1080,
- 1570 - animate.y,
+ 360,
+ 523 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
- let posx = 980;
+ let posx = 327;
this.herobuff.forEach((v) => {
if (v) {
- core.drawIcon(ctx4, v.id, posx, 1350 - animate.y, 64, 64);
+ core.drawIcon(ctx4, v.id, posx, 450 - animate.y, 21, 21);
core.setTextAlign(ctx4, "right");
core.fillBoldText1(
ctx4,
v.count,
- posx + 50,
- 1400 - animate.y,
+ posx + 17,
+ 467 - animate.y,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(24, true)
+ 2,
+ core.ui._buildFont(8, true)
);
core.setTextAlign(ctx4, "left");
- posx += 80;
+ posx += 27;
}
});
if (this.selection === "boss") {
core.drawWindowSkin(
"winskin.webp",
ctx4,
- 50,
- -150 + animate.y / 2,
- 1900,
- 200,
- null,
- null,
- null,
- 3
+ 17,
+ -50 + animate.y / 2,
+ 633,
+ 67
);
core.fillBoldText1(
ctx4,
this.boss.name,
- 100,
- -80 + animate.y / 2,
+ 33,
+ -27 + animate.y / 2,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"状态",
- 500,
- animate.y / 2 - 80,
+ 167,
+ animate.y / 2 - 27,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"生命 " + this.boss.hp,
- 100,
- animate.y / 2 + 20,
+ 33,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
6,
- core.ui._buildFont(44, true)
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"攻击 " + this.boss.atk,
- 500,
- animate.y / 2 + 20,
+ 167,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"防御 " + this.boss.def,
- 900,
- animate.y / 2 + 20,
+ 300,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法抗 " + this.boss.mdef + "%",
- 1300,
- animate.y / 2 + 20,
+ 433,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"速度 " + this.boss.speed,
- 1700,
- animate.y / 2 + 20,
+ 567,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
- let posx = 600;
+ let posx = 200;
this.bossbuff.forEach((v) => {
if (v) {
- core.drawIcon(ctx4, v.id, posx, animate.y / 2 - 120, 64, 64);
+ core.drawIcon(ctx4, v.id, posx, animate.y / 2 - 40, 21, 21);
core.setTextAlign(ctx4, "right");
core.fillBoldText1(
ctx4,
v.count,
- posx + 50,
- animate.y / 2 - 70,
+ posx + 17,
+ animate.y / 2 - 23,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(24, true)
+ 2,
+ core.ui._buildFont(8, true)
);
core.setTextAlign(ctx4, "left");
- posx += 80;
+ posx += 27;
}
});
} else if (this.selection === "") {} else {
core.drawWindowSkin(
"winskin.webp",
ctx4,
- 50,
+ 17,
animate.y / 2 - 150,
- 1900,
- 200,
- null,
- null,
- null,
- 3
+ 633,
+ 67
);
core.fillBoldText1(
ctx4,
this.enemy[this.selection].name,
- 100,
- animate.y / 2 - 80,
+ 33,
+ animate.y / 2 - 27,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(16, true)
);
core.fillBoldText1(
ctx4,
"状态",
- 500,
- animate.y / 2 - 80,
+ 167,
+ animate.y / 2 - 27,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"生命 " + this.enemy[this.selection].hp,
- 100,
- animate.y / 2 + 20,
+ 33,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"攻击 " + this.enemy[this.selection].atk,
- 500,
- animate.y / 2 + 20,
+ 167,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"防御 " + this.enemy[this.selection].def,
- 900,
- animate.y / 2 + 20,
+ 300,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"法抗 " + this.enemy[this.selection].mdef + "%",
- 1300,
- animate.y / 2 + 20,
+ 433,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
core.fillBoldText1(
ctx4,
"速度 " + this.enemy[this.selection].speed,
- 1700,
- animate.y / 2 + 20,
+ 567,
+ animate.y / 2 + 7,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(44, true)
+ 2,
+ core.ui._buildFont(15, true)
);
- let posx = 600;
+ let posx = 200;
this.enemybuff[this.selection].forEach((v) => {
if (v) {
- core.drawIcon(ctx4, v.id, posx, animate.y / 2 - 120, 64, 64);
+ core.drawIcon(ctx4, v.id, posx, animate.y / 2 - 40, 21, 21);
core.setTextAlign(ctx4, "right");
core.fillBoldText1(
ctx4,
v.count,
- posx + 50,
- animate.y / 2 - 70,
+ posx + 17,
+ animate.y / 2 - 23,
"#FFFFFF",
"#000000",
- 6,
- core.ui._buildFont(24, true)
+ 2,
+ core.ui._buildFont(8, true)
);
core.setTextAlign(ctx4, "left");
- posx += 80;
+ posx += 27;
}
});
}
@@ -19341,7 +17939,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
animate.ticker.add(fn)
- animate.mode(hyper('sin', 'out')).time(1000).move(0, 400)
+ animate.mode(hyper('sin', 'out')).time(1000).move(0, 133)
await animate.all()
core.clearMap(ctx3);
@@ -19354,68 +17952,64 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
time = 0;
return new Promise((resolve) => {
core.registerAnimationFrame("closeblack", true, (temptime) => {
- if (temptime - time > 1000 / 60) {
- time = temptime;
- core.clearMap(ctx);
- if (core.domStyle.isVertical) {
- ctx.canvas.width = 1248;
- ctx.canvas.height = 2028;
- ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
- ctx.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx.canvas.width = 2028;
- ctx.canvas.height = 1248;
- }
-
- ctx.globalAlpha = globalAlpha;
-
- core.fillRect(ctx, 0, 0, 2028, 1248);
- globalAlpha += 1 / 30;
- ctx.restore();
- if (globalAlpha > 1) {
- time = 0;
- globalAlpha = 1;
- core.unregisterAnimationFrame("closeblack");
- core.unregisterAnimationFrame("enemyanimate");
- boss1.style.display = "none";
- boss2.style.display = "none";
- boss3.style.display = "none";
- boss4.style.display = "none";
- boss5.style.display = "none";
- boss6.style.display = "none";
- boss7.style.display = "none";
- boss8.style.display = "none";
-
- core.registerAnimationFrame("closeblack2", true, (temptime) => {
- if (temptime - time > 1000 / 60) {
- time = temptime;
- core.clearMap(ctx);
- if (core.domStyle.isVertical) {
- ctx.canvas.width = 1248;
- ctx.canvas.height = 2028;
- ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
- ctx.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx.canvas.width = 2028;
- ctx.canvas.height = 1248;
- }
- ctx.globalAlpha = globalAlpha;
- core.fillRect(ctx, 0, 0, 2028, 1248, "#000000");
- ctx.restore();
- globalAlpha -= 1 / 30;
- if (globalAlpha < 0) {
- core.unregisterAnimationFrame("closeblack2");
-
- boss.style.display = "none";
-
- resolve();
- }
- }
- });
- }
+ if (temptime - time < 50) return
+ time = temptime;
+ core.clearMap(ctx);
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+ ctx.save(); //保存设置
+ ctx.translate(416, 0); //重新定位右上角为基准
+ ctx.rotate(Math.PI / 2); //旋转90度
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
}
+
+ ctx.globalAlpha = globalAlpha;
+
+ core.fillRect(ctx, 0, 0, 676, 416);
+ globalAlpha += 1 / 10;
+ ctx.restore();
+ if (globalAlpha > 1) {
+ time = 0;
+ globalAlpha = 1;
+ core.unregisterAnimationFrame("closeblack");
+ core.unregisterAnimationFrame("enemyanimate");
+ boss1.style.display = "none";
+ boss2.style.display = "none";
+ boss3.style.display = "none";
+ boss4.style.display = "none";
+ boss5.style.display = "none";
+ boss6.style.display = "none";
+ boss7.style.display = "none";
+ boss8.style.display = "none";
+
+ core.registerAnimationFrame("closeblack2", true, (temptime) => {
+ if (temptime - time < 50)
+ time = temptime;
+ core.clearMap(ctx);
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+ ctx.save(); //保存设置
+ ctx.translate(416, 0); //重新定位右上角为基准
+ ctx.rotate(Math.PI / 2); //旋转90度
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+ }
+ ctx.globalAlpha = globalAlpha;
+ core.fillRect(ctx, 0, 0, 676, 416, "#000000");
+ ctx.restore();
+ globalAlpha -= 1 / 10;
+ if (globalAlpha < 0) {
+ core.unregisterAnimationFrame("closeblack2");
+
+ boss.style.display = "none";
+
+ resolve();
+ }
+
+ });
+ }
+
});
});
}
@@ -19427,58 +18021,54 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
boss1.style.display = "block";
return new Promise((resolve) => {
core.registerAnimationFrame("bossblack", true, (temptime) => {
- if (temptime - time > 1000 / 60) {
- time = temptime;
- core.clearMap(ctx1);
- if (core.domStyle.isVertical) {
- ctx1.canvas.width = 1248;
- ctx1.canvas.height = 2028;
- ctx1.save(); //保存设置
- ctx1.translate(1248, 0); //重新定位右上角为基准
- ctx1.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx1.canvas.width = 2028;
- ctx1.canvas.height = 1248;
- }
-
- ctx1.globalAlpha = globalAlpha;
-
- core.fillRect(ctx1, 0, 0, 2028, 1248);
- globalAlpha += 1 / 30;
- ctx1.restore();
- if (globalAlpha > 1) {
- time = 0;
- globalAlpha = 0;
- core.unregisterAnimationFrame("bossblack");
- core.registerAnimationFrame("bossBg", true, (temptime) => {
- if (temptime - time > 1000 / 60) {
- time = temptime;
- core.clearMap(ctx1);
- if (core.domStyle.isVertical) {
- ctx1.canvas.width = 1248;
- ctx1.canvas.height = 2028;
- ctx1.save(); //保存设置
- ctx1.translate(1248, 0); //重新定位右上角为基准
- ctx1.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx1.canvas.width = 2028;
- ctx1.canvas.height = 1248;
- }
-
- ctx1.globalAlpha = 1;
- core.fillRect(ctx1, 0, 0, 2028, 1248);
- ctx1.globalAlpha = globalAlpha;
- if (img) ctx1.drawImage(img, 0, 0, 2028, 1248);
- ctx1.restore();
- globalAlpha += 1 / 30;
- if (globalAlpha > 1) {
- core.unregisterAnimationFrame("bossBg");
- resolve();
- }
- }
- });
- }
+ if (temptime - time < 50) return
+ time = temptime;
+ core.clearMap(ctx1);
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
+ ctx1.save(); //保存设置
+ ctx1.translate(416, 0); //重新定位右上角为基准
+ ctx1.rotate(Math.PI / 2); //旋转90度
+ } else {
+ core.maps._setHDCanvasSize(ctx1, 676, 416)
}
+
+ ctx1.globalAlpha = globalAlpha;
+
+ core.fillRect(ctx1, 0, 0, 676, 416);
+ globalAlpha += 1 / 10;
+ ctx1.restore();
+ if (globalAlpha > 1) {
+ time = 0;
+ globalAlpha = 0;
+ core.unregisterAnimationFrame("bossblack");
+ core.registerAnimationFrame("bossBg", true, (temptime) => {
+ if (temptime - time < 50) return
+ time = temptime;
+ core.clearMap(ctx1);
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx1, 416, 676)
+ ctx1.save(); //保存设置
+ ctx1.translate(416, 0); //重新定位右上角为基准
+ ctx1.rotate(Math.PI / 2); //旋转90度
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+ }
+
+ ctx1.globalAlpha = 1;
+ core.fillRect(ctx1, 0, 0, 676, 416);
+ ctx1.globalAlpha = globalAlpha;
+ if (img) ctx1.drawImage(img, 0, 0, 676, 416);
+ ctx1.restore();
+ globalAlpha += 1 / 10;
+ if (globalAlpha > 1) {
+ core.unregisterAnimationFrame("bossBg");
+ resolve();
+ }
+
+ });
+ }
+
});
});
}
@@ -19486,188 +18076,182 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.ui.boss = new Boss();
},
"剧情视频引用": function () {
- // 在此增加新插件
- let a;
- let bgm;
+ // 在此增加新插件
+ let a;
+ let bgm;
- function gtouchstart() {
- timeOutEvent = setTimeout(() => {
- video.remove();
- video1.remove();
- core.doAction();
- clearTimeout(a);
- core.playBgm(bgm);
- }, 2000); //这里设置定时器,定义长按500毫秒触发长按事件,时间可以自己改,个人感觉500毫秒非常合适
- return false;
- }
+ function gtouchstart() {
+ timeOutEvent = setTimeout(() => {
+ video.remove();
+ video1.remove();
+ core.doAction();
+ clearTimeout(a);
+ core.playBgm(bgm);
+ }, 2000); //这里设置定时器,定义长按500毫秒触发长按事件,时间可以自己改,个人感觉500毫秒非常合适
+ return false;
+ }
- //手释放,如果在500毫秒内就释放,则取消长按事件,此时可以执行onclick应该执行的事件
- function gtouchend() {
- if (timeOutEvent != 0) {
- //这里写要执行的内容(尤如onclick事件)
- console.log("你这是点击,不是长按");
- }
- clearTimeout(timeOutEvent); //清除定时器
- return false;
- }
+ //手释放,如果在500毫秒内就释放,则取消长按事件,此时可以执行onclick应该执行的事件
+ function gtouchend() {
+ if (timeOutEvent != 0) {
+ //这里写要执行的内容(尤如onclick事件)
+ console.log("你这是点击,不是长按");
+ }
+ clearTimeout(timeOutEvent); //清除定时器
+ return false;
+ }
- this.openvideo = function () {
- if (!core.isPlaying()) return;
- const video = document.createElement("iframe"); //iframe设置
- video.style.position = "absolute";
- video.style.zIndex = 320;
- video.style.display = "block";
- video.id = "video";
- main.dom.gameGroup.insertAdjacentElement("afterend", video);
- video.style.top = "50%";
- video.style.left = "50%";
- video.style.transform = "translate(-50%,-50%)";
- main.dom.video = video;
- const video1 = document.createElement("canvas"); //video1画布设置
- video1.style.position = "absolute";
- video1.style.zIndex = 330;
- video1.style.display = "block";
- video1.id = "video1";
- main.dom.gameGroup.insertAdjacentElement("afterend", video1);
- video1.style.top = "50%";
- video1.style.left = "50%";
- video1.style.transform = "translate(-50%,-50%)";
- const ctx = video1.getContext("2d");
- main.dom.video1 = video1;
- if (core.domStyle.isVertical) {
- video.width = 416 * 3;
- video.height = 676 * 3;
- video.style.transform = "translate(-50%,-50%) rotate(90deg)"; //重新定位右上角为基准
- } else {
- video.width = 676 * 3;
- video.height = 416 * 3;
- video.style.transform = "translate(-50%,-50%)";
- }
- video1.ontouchstart = function (e) {
- try {
- e.preventDefault();
- if (!core.isPlaying()) return false;
- gtouchstart();
- } catch (ee) {
- main.log(ee);
- }
- };
- video1.ontouchend = function (e) {
- try {
- e.preventDefault();
- if (!core.isPlaying()) return false;
- gtouchend();
- } catch (ee) {
- main.log(ee);
- }
- };
+ this.openvideo = function () {
+ if (!core.isPlaying()) return;
+ const video = document.createElement("iframe"); //iframe设置
+ video.style.position = "absolute";
+ video.style.zIndex = 320;
+ video.style.display = "block";
+ video.id = "video";
+ main.dom.startPanel.insertAdjacentElement("afterend", video)
+ main.dom.video = video;
+ const ctx2 = video.getContext('2d')
+ const video1 = document.createElement("canvas"); //video1画布设置
+ video1.style.position = "absolute";
+ video1.style.zIndex = 330;
+ video1.style.display = "block";
+ video1.id = "video1";
+ main.dom.startPanel.insertAdjacentElement("afterend", video1)
+ const ctx = video1.getContext("2d");
+ main.dom.video1 = video1;
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx2, 416, 676)
- video1.onmouseup = function (e) {
- //鼠标抬起
- try {
- e.stopPropagation();
- if (!core.isPlaying()) return false;
- gtouchend();
- } catch (ee) {
- console.error(ee);
- }
- };
- video1.onmousedown = function (e) {
- //鼠标按下
- try {
- e.stopPropagation();
- if (!core.isPlaying()) return false;
- gtouchstart();
- } catch (ee) {
- main.log(ee);
- }
- };
- let globalAlpha = 0;
- let frame = 1;
- let al = 0;
- core.registerAnimationFrame("beforeop", true, function () {
- al++;
- core.clearMap(ctx);
- ctx.globalAlpha = al / 30;
- core.fillRect(ctx, 0, 0, video1.width, video1.height, "#000000");
- ctx.globalAlpha = 1;
- core.fillBoldText1(
- ctx,
- "Loading...",
- 1014,
- 624,
- "#FFFFFF",
- "#000000",
- 6,
- "bold 72px Verdana"
- );
- });
- core.control.resize();
+ video.style.transform = "translate(-50%,-50%) rotate(90deg)"; //重新定位右上角为基准
+ } else {
+ core.maps._setHDCanvasSize(ctx2, 416, 676)
+ video.style.transform = "translate(-50%,-50%)";
+ }
+ video1.ontouchstart = function (e) {
+ try {
+ e.preventDefault();
+ if (!core.isPlaying()) return false;
+ gtouchstart();
+ } catch (ee) {
+ main.log(ee);
+ }
+ };
+ video1.ontouchend = function (e) {
+ try {
+ e.preventDefault();
+ if (!core.isPlaying()) return false;
+ gtouchend();
+ } catch (ee) {
+ main.log(ee);
+ }
+ };
- //player.bilibili.com/player.html
- //www.bilibili.com/blackboard/html5mobileplayer.html
- //
- video.src =
- "///www.bilibili.com/blackboard/html5mobileplayer.html?isOutside=true&aid=6484104&bvid=BV1cs411b7cH&cid=10546155&p=1&poster=0&autoplay=1&high_quality=1&muted=0&danmaku=0";
- video.scrolling = "no";
- video.border = "0";
- video.crossorigin = true;
- video.frameborder = "no";
- video.framespacing = "0";
- video.allowfullscreen = false;
+ video1.onmouseup = function (e) {
+ //鼠标抬起
+ try {
+ e.stopPropagation();
+ if (!core.isPlaying()) return false;
+ gtouchend();
+ } catch (ee) {
+ console.error(ee);
+ }
+ };
+ video1.onmousedown = function (e) {
+ //鼠标按下
+ try {
+ e.stopPropagation();
+ if (!core.isPlaying()) return false;
+ gtouchstart();
+ } catch (ee) {
+ main.log(ee);
+ }
+ };
+ let globalAlpha = 0;
+ let frame = 1;
+ let al = 0;
+ let time = 0
+ core.registerAnimationFrame("beforeop", true, function (tamptime) {
+ if (tamptimetime < 50) return
+ al++;
+ core.clearMap(ctx);
+ ctx.globalAlpha = al / 10;
+ core2.fillRect(ctx, 0, 0, video1.width, video1.height, "#000000");
+ ctx.globalAlpha = 1;
+ core.fillBoldText1(
+ ctx,
+ "Loading...",
+ 338,
+ 208,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ "bold 24px Verdana"
+ );
+ });
+ core.control.resize();
- video.sandbox =
- "allow-top-navigation allow-same-origin allow-forms allow-scripts";
- //gsl_play_mask
+ //player.bilibili.com/player.html
+ //www.bilibili.com/blackboard/html5mobileplayer.html
+ //
+ video.src =
+ "///www.bilibili.com/blackboard/html5mobileplayer.html?isOutside=true&aid=6484104&bvid=BV1cs411b7cH&cid=10546155&p=1&poster=0&autoplay=1&high_quality=1&muted=0&danmaku=0";
+ video.scrolling = "no";
+ video.border = "0";
+ video.crossorigin = true;
+ video.frameborder = "no";
+ video.framespacing = "0";
+ video.allowfullscreen = false;
- video.addEventListener("load", function () {
- core.unregisterAnimationFrame("beforeop");
- core.registerAnimationFrame("op", true, function () {
- core.clearMap(ctx);
- if (core.domStyle.isVertical) {
- ctx.canvas.width = 416 * 3;
- ctx.canvas.height = 676 * 3;
- ctx.save(); //保存设置
- ctx.translate(416 * 3, 0); //重新定位右上角为基准
- ctx.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx.canvas.width = 676 * 3;
- ctx.canvas.height = 416 * 3;
- }
- ctx.globalAlpha = 1;
- core.fillRect(ctx, 0, 0, video1.width, video1.height, "#000000");
+ video.sandbox =
+ "allow-top-navigation allow-same-origin allow-forms allow-scripts";
+ //gsl_play_mask
- ctx.globalAlpha = globalAlpha / 30;
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- "长按2秒后跳过op",
- 1014,
- 624,
- "#FFFFFF",
- "#000000",
- 6,
- "bold 48px Verdana"
- );
- globalAlpha += frame;
- if (globalAlpha > 29) frame = -1;
- ctx.restore();
- if (frame === -1 && globalAlpha < 0) {
- core.clearMap(ctx);
- core.unregisterAnimationFrame("op");
- }
- });
- bgm = core.musicStatus.playingBgm;
- core.playBgm("op.opus");
- a = setTimeout(() => {
- video.remove();
- video1.remove();
- core.playBgm(bgm);
- core.doAction();
- }, 127500);
- });
- };
- },
+ video.addEventListener("load", function () {
+ core.unregisterAnimationFrame("beforeop");
+ core.registerAnimationFrame("op", true, function () {
+ core.clearMap(ctx);
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+ ctx.save(); //保存设置
+ ctx.translate(416, 0); //重新定位右上角为基准
+ ctx.rotate(Math.PI / 2); //旋转90度
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+ }
+ ctx.globalAlpha = 1;
+ core.fillRect(ctx, 0, 0, video1.width, video1.height, "#000000");
+
+ ctx.globalAlpha = globalAlpha / 30;
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ "长按2秒后跳过op",
+ 338,
+ 208,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ "bold16px Verdana"
+ );
+ globalAlpha += frame;
+ if (globalAlpha > 29) frame = -1;
+ ctx.restore();
+ if (frame === -1 && globalAlpha < 0) {
+ core.clearMap(ctx);
+ core.unregisterAnimationFrame("op");
+ }
+ });
+ bgm = core.musicStatus.playingBgm;
+ core.playBgm("op.opus");
+ a = setTimeout(() => {
+ video.remove();
+ video1.remove();
+ core.playBgm(bgm);
+ core.doAction();
+ }, 127500);
+ });
+ };
+},
"帧动画/图片叠拼": function () {
// 在此增加新插件
this.animationDrawable = function (
@@ -19686,38 +18270,36 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let now = 0;
- let start = 0
+ let farme = 0
core.registerAnimationFrame(
"animationDrawable",
true,
function (timestamp) {
+ if (timestamp - now < 50) return
+
- let frametime = timestamp - now
- now = timestamp;
if (!imageList || imageList.length == 0) return;
- if (start === 0) start = now
+
now = timestamp;
- let farme = Math.floor((now - start) / (1000 / 60))
+
if (farme > allFarme) {
core.unregisterAnimationFrame("animationDrawable");
core.doAction();
return
}
if (core.domStyle.isVertical) {
- over.width = 1248;
- over.height = 2028;
+ core.maps._setHDCanvasSize(ctx, 416, 676)
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
} else {
- over.width = 2028;
- over.height = 1248;
+ core.maps._setHDCanvasSize(ctx, 676, 416)
}
core.clearMap(ctx)
ctx.globalAlpha = (globalAlpha ?? 100) / 100;
- core.fillRect(ctx, 0, 0, 2028, 1248, color);
+ core.fillRect(ctx, 0, 0, 676, 416, color);
imageList.forEach(function (one) {
if (
@@ -19766,13 +18348,13 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
(((one.ay ?? 0) - (one.y ?? 0)) * (farme - beforefarme)) /
(afterfarme - beforefarme || 1),
w =
- (one.w ?? 2028) +
- (((one.aw ?? 2028) - (one.w ?? 2028)) *
+ (one.w ?? 676) +
+ (((one.aw ?? 676) - (one.w ?? 676)) *
(farme - beforefarme)) /
(afterfarme - beforefarme || 1),
h =
- (one.h ?? 1248) +
- (((one.ah ?? 1248) - (one.h ?? 1248)) *
+ (one.h ?? 416) +
+ (((one.ah ?? 416) - (one.h ?? 416)) *
(farme - beforefarme)) /
(afterfarme - beforefarme || 1),
angle =
@@ -19789,1166 +18371,1165 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
one.sound &&
core.sounds[one.sound] &&
core.musicStatus.soundStatus;
- if (farme >= one.startfarme && lisen && !one.start) {
- one.start = true
+ if (farme >= one.startfarme && lisen) {
if (one.stopbefore) core.stopSound();
core.playSound(one.sound);
+
}
});
ctx.globalAlpha = 1;
ctx.restore();
-
+ farme++
}
);
};
},
"musicMode": function () {
- // 在此增加新插件
- const music = document.createElement("canvas");
- music.style.position = "absolute";
- music.style.zIndex = 300;
- music.style.display = "none";
- music.id = "music";
- main.dom.gameGroup.insertAdjacentElement("afterend", music);
- music.style.top = "50%";
- music.style.left = "50%";
- music.style.transform = "translate(-50%,-50%)";
- const ctx = music.getContext("2d");
- main.dom.music = music;
-
- const audio = core.plugin.audioSystem.bgmController;
-
- let page = 0; //初始页面
-
- let isvolume = false;
-
- function shuffle(arr) {
- let n = arr.length,
- random;
- while (n) {
- random = (Math.random() * n--) >>> 0;
- [arr[n], arr[random]] = [arr[random], arr[n]];
- }
- return arr;
- }
- music.addEventListener("mousedown", function (e) {
- e.stopPropagation();
- const left = core.dom.gameGroup.offsetLeft;
- const top = core.dom.gameGroup.offsetTop;
- const px = Math.floor((e.clientX - left) / core.domStyle.scale),
- py = Math.floor((e.clientY - top) / core.domStyle.scale);
- core.ui.music.mousedown(px * 3, py * 3);
- });
- music.addEventListener("mousemove", function (e) {
- e.stopPropagation();
- const left = core.dom.gameGroup.offsetLeft;
- const top = core.dom.gameGroup.offsetTop;
- const px = Math.floor((e.clientX - left) / core.domStyle.scale),
- py = Math.floor((e.clientY - top) / core.domStyle.scale);
- core.ui.music.mousemove(px * 3, py * 3);
- });
- music.addEventListener("mouseup", function (e) {
- e.stopPropagation();
-
- isvolume = false;
- });
- music.addEventListener("mouseleave", function (e) {
- e.stopPropagation();
-
- isvolume = false;
- });
- music.addEventListener("touchstart", function (e) {
- e.preventDefault();
- const left = core.dom.gameGroup.offsetLeft;
- const top = core.dom.gameGroup.offsetTop;
- const px = Math.floor(
- (e.touches[0].clientX - left) / core.domStyle.scale
- ),
- py = Math.floor((e.touches[0].clientY - top) / core.domStyle.scale);
- core.ui.music.mousedown(px * 3, py * 3);
- });
- music.addEventListener("touchmove", function (e) {
- e.stopPropagation();
- const left = core.dom.gameGroup.offsetLeft;
- const top = core.dom.gameGroup.offsetTop;
- const px = Math.floor(
- (e.touches[0].clientX - left) / core.domStyle.scale
- ),
- py = Math.floor((e.touches[0].clientY - top) / core.domStyle.scale);
- core.ui.music.mousemove(px * 3, py * 3);
- });
- music.addEventListener("touchend", function (e) {
- e.stopPropagation();
-
- isvolume = false;
- });
- music.addEventListener("touchcancel", function (e) {
- e.stopPropagation();
-
- isvolume = false;
- });
-
- class musicclass {
- constructor() {
- this.musics = ["theme.mp3"];
- //music列表
- //需全塔属性注册并保存在bgms文件夹,每个数组为显示的一页内容
- this.musicMx = [
- [
- "Crawler.opus",
- "Blood_Stain.opus",
- "Blind_Alley.opus",
- "Halbmond.opus",
- ],
- ["theme.mp3", "op.opus", "Asphodelus_Ceui.opus", "ed.opus"],
- ];
- //音乐别名(将在播放器内显示的音乐名,music列表内的都要有对应歌名)
- this.musicname = {
- "Asphodelus_Ceui.opus": "Asphodelus (Full.ver)",
- "Blind_Alley.opus": "Blind Alley",
- "Crawler.opus": "Crawler",
- "op.opus": "Asphodelus",
- "theme.mp3": "One of Episodes",
- "ed.opus": "親愛なる世界へ",
- "Blood_Stain.opus": "Blood Stain",
- "Halbmond.opus": "Halbmond",
- };
- this.selection = [0, 0];
- this.stop = false;
- this.type = "xunhuan";
- this.randomList = [];
- this.random = 0;
- }
-
- //更新
- update() {
- this.background();
- this.drawUI();
- }
- background() {
- //画布大小设置
- if (core.domStyle.isVertical) {
- music.width = 1248;
- music.height = 2028;
- } else {
- music.width = 2028;
- music.height = 1248;
- }
- }
-
- mousedown(px, py) {
- //鼠标按下时
-
- const makeBox = ([x, y], [w, h]) => {
- return [
- [x, y],
- [x + w, y + h],
- ];
- };
- const inRect = ([x, y], [[sx, sy], [dx, dy]]) => {
- return sx <= x && x <= dx && sy <= y && y <= dy;
- };
- const pos = [px, py];
- const backbox = makeBox([15, 35], [210, 90]);
- if (inRect(pos, backbox)) {
- //离开按钮是一致的,其余的记区分横竖屏
- music.style.display = "none";
- core.clearMap(ctx);
-
- core.unregisterAnimationFrame("music");
- core.restart();
-
- return;
- }
- if (core.domStyle.isVertical) {
- //竖屏
-
- const pageupbox = makeBox([100, 1230], [200, 100]);
- const pagedownbox = makeBox([950, 1230], [200, 100]);
- const musicbox = makeBox(
- [100, 200],
- [1048, this.musicMx[page].length * 100]
- );
- const beforebox = makeBox([120, 1620], [100, 100]);
- const afterbox = makeBox([780, 1620], [100, 100]);
- const playbox = makeBox([420, 1580], [200, 200]);
- const typebox = makeBox([1040, 1600], [120, 120]);
-
- const volumebox = makeBox([250, 1940], [1050, 20]);
- if (inRect(pos, pageupbox)) {
- if (page !== 0) page -= 1;
- return;
- }
- if (inRect(pos, pagedownbox)) {
- if (page !== this.musicMx.length - 1) page += 1;
- return;
- }
- if (inRect(pos, playbox)) {
- if (this.stop) {
- this.stop = !this.stop;
-
- core.resumeBgm();
- } else {
- this.stop = !this.stop;
- core.pauseBgm();
- }
- return;
- }
- if (inRect(pos, beforebox)) {
- this.stop = false;
- switch (this.type) {
- case "danqu":
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- page = this.selection[0];
-
- break;
- case "xunhuan":
- for (;;) {
- if (this.selection[1] === 0) {
- if (this.selection[0] === 0) {
- this.selection[0] = this.musicMx.length - 1;
- this.selection[1] =
- this.musicMx[this.selection[0]].length - 1;
- } else {
- this.selection[0] -= 1;
- this.selection[1] =
- this.musicMx[this.selection[0]].length - 1;
- }
- } else {
- this.selection[1] -= 1;
- }
- this.random = this.randomList.indexOf(
- this.musicMx[this.selection[0]][this.selection[1]]
- );
- page = this.selection[0];
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- case "suiji":
- for (;;) {
- if (this.random > 0) {
- this.random -= 1;
- } else {
- this.random = this.randomList.length - 1;
- }
- this.selection[0] = this.musicMx.findIndex((v) =>
- v.includes(this.randomList[this.random])
- );
- this.selection[1] = this.musicMx[this.selection[0]].indexOf(
- this.randomList[this.random]
- );
-
- page = this.selection[0];
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- }
- return;
- }
- if (inRect(pos, afterbox)) {
- this.stop = false;
- switch (this.type) {
- case "danqu":
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- page = this.selection[0];
- break;
- case "xunhuan":
- for (;;) {
- if (
- this.selection[1] ===
- this.musicMx[this.selection[0]].length - 1
- ) {
- if (this.selection[0] === this.musicMx.length - 1) {
- this.selection[0] = 0;
- this.selection[1] = 0;
- } else {
- this.selection[0] += 1;
- this.selection[1] = 0;
- }
- } else {
- this.selection[1] += 1;
- }
- this.random = this.randomList.indexOf(
- this.musicMx[this.selection[0]][this.selection[1]]
- );
- page = this.selection[0];
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- case "suiji":
- for (;;) {
- if (this.random < this.randomList.length - 1) {
- this.random += 1;
- } else {
- this.random = 0;
- }
- this.selection[0] = this.musicMx.findIndex((v) =>
- v.includes(this.randomList[this.random])
- );
- this.selection[1] = this.musicMx[this.selection[0]].indexOf(
- this.randomList[this.random]
- );
-
- page = this.selection[0];
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- }
- return;
- }
- if (inRect(pos, typebox)) {
- switch (this.type) {
- case "danqu":
- this.type = "xunhuan";
- break;
- case "xunhuan":
- this.type = "suiji";
- break;
- case "suiji":
- this.type = "danqu";
- break;
- }
- return;
- }
- if (inRect(pos, musicbox)) {
- const index = Math.floor((py - 200) / 100);
- if (page !== this.selection[0] || index !== this.selection[1]) {
- if (
- this.musics.includes(this.musicMx[page][index]) ||
- page !== this.musicMx.length - 1
- ) {
- this.selection[0] = page;
-
- this.selection[1] = index;
- this.randomList.indexOf(
- this.musicMx[this.selection[0]][this.selection[1]]
- );
-
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- this.stop = false;
- }
- } else {
- if (this.stop) {
- this.stop = !this.stop;
- core.resumeBgm();
- } else {
- this.stop = !this.stop;
- core.pauseBgm();
- }
- }
- return;
- }
-
- if (inRect(pos, volumebox)) {
- const time = Math.min(Math.max((px - 250) / 800, 0), 1);
- audio.setVolume(time);
- core.plugin.audioSystem.soundPlayer.setVolume(time);
- isvolume = true;
- }
- } else {
- //横屏
- const pageupbox = makeBox([1050, 1100], [200, 100]);
- const pagedownbox = makeBox([1550, 1100], [200, 100]);
- const musicbox = makeBox(
- [900, 100],
- [1000, this.musicMx[page].length * 100]
- );
- const beforebox = makeBox([60, 620], [100, 100]);
- const afterbox = makeBox([450, 620], [100, 100]);
- const playbox = makeBox([200, 570], [200, 200]);
- const typebox = makeBox([620, 600], [120, 120]);
-
- const volumebox = makeBox([100, 990], [600, 20]);
- if (inRect(pos, pageupbox)) {
- if (page !== 0) page -= 1;
- return;
- }
- if (inRect(pos, pagedownbox)) {
- if (page !== this.musicMx.length - 1) page += 1;
- return;
- }
- if (inRect(pos, playbox)) {
- if (this.stop) {
- this.stop = !this.stop;
- core.resumeBgm();
- } else {
- this.stop = !this.stop;
- core.pauseBgm();
- }
- return;
- }
- if (inRect(pos, beforebox)) {
- this.stop = false;
- switch (this.type) {
- case "danqu":
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- page = this.selection[0];
-
- break;
- case "xunhuan":
- for (;;) {
- if (this.selection[1] === 0) {
- if (this.selection[0] === 0) {
- this.selection[0] = this.musicMx.length - 1;
- this.selection[1] =
- this.musicMx[this.selection[0]].length - 1;
- } else {
- this.selection[0] -= 1;
- this.selection[1] =
- this.musicMx[this.selection[0]].length - 1;
- }
- } else {
- this.selection[1] -= 1;
- }
- this.random = this.randomList.indexOf(
- this.musicMx[this.selection[0]][this.selection[1]]
- );
- page = this.selection[0];
-
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- case "suiji":
- for (;;) {
- if (this.random > 0) {
- this.random -= 1;
- } else {
- this.random = this.randomList.length - 1;
- }
- this.selection[0] = this.musicMx.findIndex((v) =>
- v.includes(this.randomList[this.random])
- );
- this.selection[1] = this.musicMx[this.selection[0]].indexOf(
- this.randomList[this.random]
- );
-
- page = this.selection[0];
-
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- }
- return;
- }
- if (inRect(pos, afterbox)) {
- this.stop = false;
- switch (this.type) {
- case "danqu":
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- page = this.selection[0];
- break;
- case "xunhuan":
- for (;;) {
- if (
- this.selection[1] ===
- this.musicMx[this.selection[0]].length - 1
- ) {
- if (this.selection[0] === this.musicMx.length - 1) {
- this.selection[0] = 0;
- this.selection[1] = 0;
- } else {
- this.selection[0] += 1;
- this.selection[1] = 0;
- }
- } else {
- this.selection[1] += 1;
- }
- this.randomList.findIndex(
- (v) =>
- v === this.musicMx[this.selection[0]][this.selection[1]]
- );
- page = this.selection[0];
-
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- case "suiji":
- for (;;) {
- if (this.random < this.randomList.length - 1) {
- this.random += 1;
- } else {
- this.random = 0;
- }
- this.selection[0] = this.musicMx.findIndex((v) =>
- v.includes(this.randomList[this.random])
- );
- this.selection[1] = this.musicMx[this.selection[0]].indexOf(
- main.core.ui.music.randomList[main.core.ui.music.random]
- );
-
- page = this.selection[0];
- if (
- this.musics.includes(
- this.musicMx[this.selection[0]][this.selection[1]]
- ) ||
- page !== this.musicMx.length - 1
- )
- break;
- }
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- break;
- }
- return;
- }
- if (inRect(pos, typebox)) {
- switch (this.type) {
- case "danqu":
- this.type = "xunhuan";
- break;
- case "xunhuan":
- this.type = "suiji";
- break;
- case "suiji":
- this.type = "danqu";
- break;
- }
- return;
- }
- if (inRect(pos, musicbox)) {
- const index = Math.floor((py - 100) / 100);
- if (page !== this.selection[0] || index !== this.selection[1]) {
- if (
- this.musics.includes(this.musicMx[page][index]) ||
- page !== this.musicMx.length - 1
- ) {
- this.selection[0] = page;
- this.selection[1] = index;
- this.randomList.indexOf(
- (v) =>
- v === this.musicMx[this.selection[0]][this.selection[1]]
- );
-
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
- this.stop = false;
- }
- } else {
- if (this.stop) {
- this.stop = !this.stop;
- core.resumeBgm();
- } else {
- this.stop = !this.stop;
- core.pauseBgm();
- }
- }
- return;
- }
-
- if (inRect(pos, volumebox)) {
- const time = Math.min(Math.max((px - 100) / 600, 0), 1);
- audio.setVolume(time);
- core.plugin.audioSystem.soundPlayer.setVolume(time);
- isvolume = true;
- }
- }
- }
- mousemove(px, py) {
- if (isvolume) {
- if (core.domStyle.isVertical) {
- const time = Math.min(Math.max((px - 250) / 800, 0), 1);
- audio.setVolume(time);
- core.plugin.audioSystem.soundPlayer.setVolume(time);
- } else {
- const time = Math.min(Math.max((px - 100) / 600, 0), 1);
- audio.setVolume(time);
- core.plugin.audioSystem.soundPlayer.setVolume(time);
- }
- }
- }
-
- drawUI() {
- //绘制页面
- core.clearMap(music);
- const bgVertical = core.material.images.images["bg_2010.webp"]; //竖屏背景
- const bg = core.material.images.images["bg_5043.webp"]; //竖屏背景
- if (core.domStyle.isVertical) {
- //竖屏
-
- core.fillRect(ctx, 0, 0, 1248, 2028, "#000000"); //黑色背景
- ctx.globalAlpha = 0.3; //透明度
- if (bgVertical)
- ctx.drawImage(bgVertical, 0, 0, 1280, 1500, 0, 0, 1248, 2028); //绘制半透明背景图片
- ctx.globalAlpha = 1; //恢复为不透明
-
- core.setTextAlign(ctx, "center");
- core.fillBoldText1(
- ctx,
- "◀离开",
- 110,
- 100,
- "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
-
- ctx.strokeStyle = "#FFFFFF";
- ctx.lineWidth = 3;
- ctx.beginPath();
- ctx.moveTo(100, 200);
- ctx.lineTo(1148, 200);
-
- ctx.stroke();
- let posy = 300;
- const indexList = this.musicMx[page];
- core.setTextAlign(ctx, "left");
- for (let i = 0; i < indexList.length; i++) {
- const text = this.musicname[indexList[i]];
- if (
- this.musics.includes(this.musicMx[page][i]) ||
- page !== this.musicMx.length - 1
- ) {
- core.fillBoldText1(
- ctx,
- text,
- 150,
- posy - 30,
- page === this.selection[0] && i === this.selection[1]
- ? "#FFFFFF"
- : "#444444",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
-
- ctx.strokeStyle = "#FFFFFF";
- ctx.lineWidth = 3;
- ctx.beginPath();
- ctx.moveTo(100, posy);
- ctx.lineTo(1148, posy);
- ctx.stroke();
- }
- posy += 100;
- }
- ctx.beginPath();
- ctx.moveTo(100, 1210);
- ctx.lineTo(1148, 1210);
- ctx.moveTo(100, 1200);
- ctx.lineTo(1148, 1200);
- ctx.stroke();
-
- core.fillBoldText1(
- ctx,
- "上一页",
- 100,
- 1300,
- page === 0 ? "#444444" : "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
-
- core.fillBoldText1(
- ctx,
- page + 1 + "/" + this.musicMx.length,
- 580,
- 1300,
- "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
- core.fillBoldText1(
- ctx,
- "下一页",
- 950,
- 1300,
- page === this.musicMx.length - 1 ? "#444444" : "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
-
- ctx.strokeStyle = "#ffffff";
- ctx.lineWidth = 3;
-
- core.fillBoldText(
- ctx,
- "|",
- 100,
- 1697,
- "#FFFFFF",
- 6,
- core.ui._buildFont(96, true)
- );
- core.fillBoldText(
- ctx,
- "◀",
- 115,
- 1700,
- "#FFFFFF",
- 6,
- core.ui._buildFont(96, true)
- );
-
- ctx.beginPath();
- ctx.arc(505, 1670, 80, 0, 3 * Math.PI);
- ctx.stroke();
- core.fillText(
- ctx,
- "|",
- 835,
- 1697,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
- core.fillText(
- ctx,
- "▶",
- 785,
- 1700,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
-
- if (this.stop) {
- core.fillText(
- ctx,
- "▶",
- 473,
- 1700,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
- } else {
- core.fillText(
- ctx,
- "||",
- 453,
- 1700,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
- }
-
- const img = core.material.images.images[this.type + ".webp"];
- if (img) ctx.drawImage(img, 1000, 1555, 200, 200);
- core.setTextAlign(ctx, "center");
- ctx.font = "bold 52px Verdana";
- ctx.fillText("当前歌曲", 625, 1397);
- ctx.fillText(
- this.musicname[this.musicMx[this.selection[0]][this.selection[1]]],
- 625,
- 1507
- );
-
- ctx.fillStyle = "#ffffff";
- ctx.font = "bold 48px Verdana";
- ctx.fillText("音量", 150, 1970);
- ctx.lineWidth = 3;
- ctx.beginPath();
- ctx.moveTo(250, 1950);
- ctx.lineTo(1050, 1950);
- ctx.stroke();
- ctx.strokeStyle = "#ffffff";
- ctx.lineWidth = 9;
- ctx.fillStyle = "rgba(255,255,255,0.5)";
-
- ctx.beginPath();
- ctx.moveTo(250, 1950);
- ctx.lineTo(800 * audio.getVolume() + 250, 1950);
- ctx.stroke();
- ctx.beginPath();
- ctx.arc(800 * audio.getVolume() + 250, 1950, 10, 0, 2 * Math.PI);
- ctx.fill();
- core.fillBoldText1(
- ctx,
- Math.floor(100 * audio.getVolume()),
- 1120,
- 1970,
- "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(56, true)
- );
- } else {
- //横屏
-
- core.fillRect(ctx, 0, 0, 2028, 1248, "#000000"); //黑色背景
- ctx.globalAlpha = 0.5; //透明度
- if (bg) ctx.drawImage(bg, 0, 0, 1280, 720, 0, 0, 2028, 1248); //绘制半透明背景图片
- ctx.globalAlpha = 1; //恢复为不透明
- core.setTextAlign(ctx, "center");
-
- core.fillBoldText1(
- ctx,
- "◀离开",
- 110,
- 100,
- "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
-
- ctx.strokeStyle = "#FFFFFF";
- ctx.lineWidth = 3;
- ctx.beginPath();
- ctx.moveTo(800, 100);
- ctx.lineTo(800, 1148);
- ctx.moveTo(900, 100);
- ctx.lineTo(1900, 100);
- ctx.stroke();
- let posy = 200;
- const indexList = this.musicMx[page];
- core.setTextAlign(ctx, "left");
- for (let i = 0; i < indexList.length; i++) {
- const text = this.musicname[indexList[i]];
- if (
- this.musics.includes(this.musicMx[page][i]) ||
- page !== this.musicMx.length - 1
- ) {
- core.fillBoldText1(
- ctx,
- text,
- 950,
- posy - 30,
- page === this.selection[0] && i === this.selection[1]
- ? "#FFFFFF"
- : "#444444",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
-
- ctx.strokeStyle = "#FFFFFF";
- ctx.lineWidth = 3;
- ctx.beginPath();
- ctx.moveTo(900, posy);
- ctx.lineTo(1900, posy);
- ctx.stroke();
- }
- posy += 100;
- }
- core.fillBoldText1(
- ctx,
- "上一页",
- 1050,
- 1200 - 30,
- page === 0 ? "#444444" : "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
-
- core.fillBoldText1(
- ctx,
- page + 1 + "/" + this.musicMx.length,
- 1350,
- 1200 - 30,
- "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
- core.fillBoldText1(
- ctx,
- "下一页",
- 1550,
- 1200 - 30,
- page === this.musicMx.length - 1 ? "#444444" : "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(66, true)
- );
- ctx.strokeStyle = "#ffffff";
- ctx.lineWidth = 3;
-
- core.fillText(
- ctx,
- "|",
- 55,
- 697,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
- core.fillText(
- ctx,
- "◀",
- 70,
- 700,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
-
- ctx.beginPath();
- ctx.arc(295, 670, 80, 0, 2 * Math.PI);
- ctx.stroke();
- if (this.stop) {
- core.fillText(
- ctx,
- "▶",
- 265,
- 700,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
- } else {
- core.fillText(
- ctx,
- "||",
- 245,
- 700,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
- }
- core.fillText(
- ctx,
- "|",
- 495,
- 697,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
- core.fillText(
- ctx,
- "▶",
- 450,
- 700,
- "#FFFFFF",
- core.ui._buildFont(96, true)
- );
-
- ctx.font = "bold 48px Verdana";
- ctx.fillText("音量", 350, 900);
- ctx.beginPath();
- ctx.moveTo(100, 1000);
- ctx.lineTo(700, 1000);
- ctx.stroke();
- ctx.strokeStyle = "#ffffff";
- ctx.lineWidth = 9;
- ctx.fillStyle = "rgba(255,255,255,0.5)";
-
- ctx.beginPath();
- ctx.moveTo(100, 1000);
- ctx.lineTo(600 * audio.getVolume() + 100, 1000);
- ctx.stroke();
- ctx.beginPath();
- ctx.arc(600 * audio.getVolume() + 100, 1000, 10, 0, 2 * Math.PI);
- ctx.fill();
- core.fillBoldText1(
- ctx,
- Math.floor(100 * audio.getVolume()),
- 720,
- 1010,
- "#FFFFFF",
- "#000000",
- 6,
- core.ui._buildFont(56, true)
- );
- const img = core.material.images.images[this.type + ".webp"];
- if (img) ctx.drawImage(img, 580, 560, 200, 200);
- core.setTextAlign(ctx, "center");
- ctx.font = "bold 48px Verdana";
- ctx.fillText("当前歌曲", 400, 297);
- ctx.fillText(
- this.musicname[this.musicMx[this.selection[0]][this.selection[1]]],
- 400,
- 397
- );
- }
- }
- }
- core.ui.music = new musicclass();
- main.dom.musicMode.onclick = function () {
- //点击开始页面的CG MODE进入cg回廊
- if (
- (core.getLocalStorage("musics") &&
- core.getLocalStorage("musics").length === 0) ||
- !core.getLocalStorage("musics")
- )
- core.setLocalStorage("musics", ["theme.mp3"]);
- core.ui.music.musics = core.getLocalStorage("musics");
- core.playBgm(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ],
- 0
- );
-
- const arr = main.core.ui.music.musicMx.flat(Infinity);
- main.core.ui.music.randomList = shuffle(arr);
- main.core.ui.music.random = main.core.ui.music.randomList.indexOf(
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ]
- );
- page = 0;
- music.style.display = "block";
- let time = 0;
- core.registerAnimationFrame("music", null, (temptime) => {
- if (temptime > time + 1000 / 60) {
- time = temptime;
- main.core.ui.music.update();
- const duration =
- core.plugin.audioSystem.bgmController.player.getRoute(
- "bgms." +
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ]
- ).duration;
-
- const currentTime =
- core.plugin.audioSystem.bgmController.player.getRoute(
- "bgms." +
- main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
- main.core.ui.music.selection[1]
- ]
- ).currentTime;
- if (currentTime && duration && duration - currentTime < 0.05) {
- if (core.domStyle.isVertical) {
- core.ui.music.mousedown(830, 1770);
- } else {
- core.ui.music.mousedown(475, 765);
- }
- }
- }
- });
- };
- loader.prototype.loadOneMusic = function (name) {
- /* var music = new Audio();
+ // 在此增加新插件
+ const music = document.createElement("canvas");
+ music.style.position = "absolute";
+ music.style.zIndex = 300;
+ music.style.display = "none";
+ music.id = "music";
+ main.dom.startPanel.insertAdjacentElement("afterend", music)
+ const ctx = music.getContext("2d");
+ main.dom.music = music;
+
+ const audio = core.plugin.audioSystem.bgmController;
+
+ let page = 0; //初始页面
+
+ let isvolume = false;
+
+ function shuffle(arr) {
+ let n = arr.length,
+ random;
+ while (n) {
+ random = (Math.random() * n--) >>> 0;
+ [arr[n], arr[random]] = [arr[random], arr[n]];
+ }
+ return arr;
+ }
+ music.addEventListener("mousedown", function (e) {
+ e.stopPropagation();
+ const left = core.dom.gameGroup.offsetLeft;
+ const top = core.dom.gameGroup.offsetTop;
+ const px = Math.floor((e.clientX - left) / core.domStyle.scale),
+ py = Math.floor((e.clientY - top) / core.domStyle.scale);
+ core.ui.music.mousedown(px, py);
+ });
+ music.addEventListener("mousemove", function (e) {
+ e.stopPropagation();
+ const left = core.dom.gameGroup.offsetLeft;
+ const top = core.dom.gameGroup.offsetTop;
+ const px = Math.floor((e.clientX - left) / core.domStyle.scale),
+ py = Math.floor((e.clientY - top) / core.domStyle.scale);
+ core.ui.music.mousemove(px, py);
+ });
+ music.addEventListener("mouseup", function (e) {
+ e.stopPropagation();
+
+ isvolume = false;
+ });
+ music.addEventListener("mouseleave", function (e) {
+ e.stopPropagation();
+
+ isvolume = false;
+ });
+ music.addEventListener("touchstart", function (e) {
+ e.preventDefault();
+ const left = core.dom.gameGroup.offsetLeft;
+ const top = core.dom.gameGroup.offsetTop;
+ const px = Math.floor(
+ (e.touches[0].clientX - left) / core.domStyle.scale
+ ),
+ py = Math.floor((e.touches[0].clientY - top) / core.domStyle.scale);
+ core.ui.music.mousedown(px, py);
+ });
+ music.addEventListener("touchmove", function (e) {
+ e.stopPropagation();
+ const left = core.dom.gameGroup.offsetLeft;
+ const top = core.dom.gameGroup.offsetTop;
+ const px = Math.floor(
+ (e.touches[0].clientX - left) / core.domStyle.scale
+ ),
+ py = Math.floor((e.touches[0].clientY - top) / core.domStyle.scale);
+ core.ui.music.mousemove(px, py);
+ });
+ music.addEventListener("touchend", function (e) {
+ e.stopPropagation();
+
+ isvolume = false;
+ });
+ music.addEventListener("touchcancel", function (e) {
+ e.stopPropagation();
+
+ isvolume = false;
+ });
+
+ class musicclass {
+ constructor() {
+ this.musics = ["theme.mp3"];
+ //music列表
+ //需全塔属性注册并保存在bgms文件夹,每个数组为显示的一页内容
+ this.musicMx = [
+ [
+ "Crawler.opus",
+ "Blood_Stain.opus",
+ "Blind_Alley.opus",
+ "Halbmond.opus",
+ ],
+ ["theme.mp3", "op.opus", "Asphodelus_Ceui.opus", "ed.opus"],
+ ];
+ //音乐别名(将在播放器内显示的音乐名,music列表内的都要有对应歌名)
+ this.musicname = {
+ "Asphodelus_Ceui.opus": "Asphodelus (Full.ver)",
+ "Blind_Alley.opus": "Blind Alley",
+ "Crawler.opus": "Crawler",
+ "op.opus": "Asphodelus",
+ "theme.mp3": "One of Episodes",
+ "ed.opus": "親愛なる世界へ",
+ "Blood_Stain.opus": "Blood Stain",
+ "Halbmond.opus": "Halbmond",
+ };
+ this.selection = [0, 0];
+ this.stop = false;
+ this.type = "xunhuan";
+ this.randomList = [];
+ this.random = 0;
+ }
+
+ //更新
+ update() {
+ this.background();
+ this.drawUI();
+ }
+ background() {
+ //画布大小设置
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+ }
+ }
+
+ mousedown(px, py) {
+ //鼠标按下时
+
+ const makeBox = ([x, y], [w, h]) => {
+ return [
+ [x, y],
+ [x + w, y + h],
+ ];
+ };
+ const inRect = ([x, y], [
+ [sx, sy],
+ [dx, dy]
+ ]) => {
+ return sx <= x && x <= dx && sy <= y && y <= dy;
+ };
+ const pos = [px, py];
+ const backbox = makeBox([5, 12], [70, 30]);
+ if (inRect(pos, backbox)) {
+ //离开按钮是一致的,其余的记区分横竖屏
+ music.style.display = "none";
+ core.clearMap(ctx);
+
+ core.unregisterAnimationFrame("music");
+ core.restart();
+
+ return;
+ }
+ if (core.domStyle.isVertical) {
+ //竖屏
+
+ const pageupbox = makeBox([33, 410], [67, 33]);
+ const pagedownbox = makeBox([317, 410], [67, 33]);
+ const musicbox = makeBox(
+ [33, 67],
+ [349, this.musicMx[page].length * 33]
+ );
+ const beforebox = makeBox([40, 540], [33, 33]);
+ const afterbox = makeBox([260, 540], [33, 33]);
+ const playbox = makeBox([140, 527], [67, 67]);
+ const typebox = makeBox([347, 533], [40, 40]);
+
+ const volumebox = makeBox([83, 647], [350, 7]);
+ if (inRect(pos, pageupbox)) {
+ if (page !== 0) page -= 1;
+ return;
+ }
+ if (inRect(pos, pagedownbox)) {
+ if (page !== this.musicMx.length - 1) page += 1;
+ return;
+ }
+ if (inRect(pos, playbox)) {
+ if (this.stop) {
+ this.stop = !this.stop;
+
+ core.resumeBgm();
+ } else {
+ this.stop = !this.stop;
+ core.pauseBgm();
+ }
+ return;
+ }
+ if (inRect(pos, beforebox)) {
+ this.stop = false;
+ switch (this.type) {
+ case "danqu":
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ page = this.selection[0];
+
+ break;
+ case "xunhuan":
+ for (;;) {
+ if (this.selection[1] === 0) {
+ if (this.selection[0] === 0) {
+ this.selection[0] = this.musicMx.length - 1;
+ this.selection[1] =
+ this.musicMx[this.selection[0]].length - 1;
+ } else {
+ this.selection[0] -= 1;
+ this.selection[1] =
+ this.musicMx[this.selection[0]].length - 1;
+ }
+ } else {
+ this.selection[1] -= 1;
+ }
+ this.random = this.randomList.indexOf(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ );
+ page = this.selection[0];
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ case "suiji":
+ for (;;) {
+ if (this.random > 0) {
+ this.random -= 1;
+ } else {
+ this.random = this.randomList.length - 1;
+ }
+ this.selection[0] = this.musicMx.findIndex((v) =>
+ v.includes(this.randomList[this.random])
+ );
+ this.selection[1] = this.musicMx[this.selection[0]].indexOf(
+ this.randomList[this.random]
+ );
+
+ page = this.selection[0];
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ }
+ return;
+ }
+ if (inRect(pos, afterbox)) {
+ this.stop = false;
+ switch (this.type) {
+ case "danqu":
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ page = this.selection[0];
+ break;
+ case "xunhuan":
+ for (;;) {
+ if (
+ this.selection[1] ===
+ this.musicMx[this.selection[0]].length - 1
+ ) {
+ if (this.selection[0] === this.musicMx.length - 1) {
+ this.selection[0] = 0;
+ this.selection[1] = 0;
+ } else {
+ this.selection[0] += 1;
+ this.selection[1] = 0;
+ }
+ } else {
+ this.selection[1] += 1;
+ }
+ this.random = this.randomList.indexOf(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ );
+ page = this.selection[0];
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ case "suiji":
+ for (;;) {
+ if (this.random < this.randomList.length - 1) {
+ this.random += 1;
+ } else {
+ this.random = 0;
+ }
+ this.selection[0] = this.musicMx.findIndex((v) =>
+ v.includes(this.randomList[this.random])
+ );
+ this.selection[1] = this.musicMx[this.selection[0]].indexOf(
+ this.randomList[this.random]
+ );
+
+ page = this.selection[0];
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ }
+ return;
+ }
+ if (inRect(pos, typebox)) {
+ switch (this.type) {
+ case "danqu":
+ this.type = "xunhuan";
+ break;
+ case "xunhuan":
+ this.type = "suiji";
+ break;
+ case "suiji":
+ this.type = "danqu";
+ break;
+ }
+ return;
+ }
+ if (inRect(pos, musicbox)) {
+ const index = Math.floor((py - 67) / 33);
+ if (page !== this.selection[0] || index !== this.selection[1]) {
+ if (
+ this.musics.includes(this.musicMx[page][index]) ||
+ page !== this.musicMx.length - 1
+ ) {
+ this.selection[0] = page;
+
+ this.selection[1] = index;
+ this.randomList.indexOf(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ );
+
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ this.stop = false;
+ }
+ } else {
+ if (this.stop) {
+ this.stop = !this.stop;
+ core.resumeBgm();
+ } else {
+ this.stop = !this.stop;
+ core.pauseBgm();
+ }
+ }
+ return;
+ }
+
+ if (inRect(pos, volumebox)) {
+ const time = Math.min(Math.max((px - 83) / 267, 0), 1);
+ audio.setVolume(time);
+ core.plugin.audioSystem.soundPlayer.setVolume(time);
+ isvolume = true;
+ }
+ } else {
+ //横屏
+ const pageupbox = makeBox([350, 367], [67, 33]);
+ const pagedownbox = makeBox([517, 367], [67, 33]);
+ const musicbox = makeBox(
+ [300, 33],
+ [333, this.musicMx[page].length * 33]
+ );
+ const beforebox = makeBox([20, 203], [33, 33]);
+ const afterbox = makeBox([150, 203], [33, 33]);
+ const playbox = makeBox([67, 190], [67, 67]);
+ const typebox = makeBox([207, 196], [40, 40]);
+
+ const volumebox = makeBox([33, 330], [200, 7]);
+ if (inRect(pos, pageupbox)) {
+ if (page !== 0) page -= 1;
+ return;
+ }
+ if (inRect(pos, pagedownbox)) {
+ if (page !== this.musicMx.length - 1) page += 1;
+ return;
+ }
+ if (inRect(pos, playbox)) {
+ if (this.stop) {
+ this.stop = !this.stop;
+ core.resumeBgm();
+ } else {
+ this.stop = !this.stop;
+ core.pauseBgm();
+ }
+ return;
+ }
+ if (inRect(pos, beforebox)) {
+ this.stop = false;
+ switch (this.type) {
+ case "danqu":
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ page = this.selection[0];
+
+ break;
+ case "xunhuan":
+ for (;;) {
+ if (this.selection[1] === 0) {
+ if (this.selection[0] === 0) {
+ this.selection[0] = this.musicMx.length - 1;
+ this.selection[1] =
+ this.musicMx[this.selection[0]].length - 1;
+ } else {
+ this.selection[0] -= 1;
+ this.selection[1] =
+ this.musicMx[this.selection[0]].length - 1;
+ }
+ } else {
+ this.selection[1] -= 1;
+ }
+ this.random = this.randomList.indexOf(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ );
+ page = this.selection[0];
+
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ case "suiji":
+ for (;;) {
+ if (this.random > 0) {
+ this.random -= 1;
+ } else {
+ this.random = this.randomList.length - 1;
+ }
+ this.selection[0] = this.musicMx.findIndex((v) =>
+ v.includes(this.randomList[this.random])
+ );
+ this.selection[1] = this.musicMx[this.selection[0]].indexOf(
+ this.randomList[this.random]
+ );
+
+ page = this.selection[0];
+
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ }
+ return;
+ }
+ if (inRect(pos, afterbox)) {
+ this.stop = false;
+ switch (this.type) {
+ case "danqu":
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ page = this.selection[0];
+ break;
+ case "xunhuan":
+ for (;;) {
+ if (
+ this.selection[1] ===
+ this.musicMx[this.selection[0]].length - 1
+ ) {
+ if (this.selection[0] === this.musicMx.length - 1) {
+ this.selection[0] = 0;
+ this.selection[1] = 0;
+ } else {
+ this.selection[0] += 1;
+ this.selection[1] = 0;
+ }
+ } else {
+ this.selection[1] += 1;
+ }
+ this.randomList.findIndex(
+ (v) =>
+ v === this.musicMx[this.selection[0]][this.selection[1]]
+ );
+ page = this.selection[0];
+
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ case "suiji":
+ for (;;) {
+ if (this.random < this.randomList.length - 1) {
+ this.random += 1;
+ } else {
+ this.random = 0;
+ }
+ this.selection[0] = this.musicMx.findIndex((v) =>
+ v.includes(this.randomList[this.random])
+ );
+ this.selection[1] = this.musicMx[this.selection[0]].indexOf(
+ main.core.ui.music.randomList[main.core.ui.music.random]
+ );
+
+ page = this.selection[0];
+ if (
+ this.musics.includes(
+ this.musicMx[this.selection[0]][this.selection[1]]
+ ) ||
+ page !== this.musicMx.length - 1
+ )
+ break;
+ }
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ break;
+ }
+ return;
+ }
+ if (inRect(pos, typebox)) {
+ switch (this.type) {
+ case "danqu":
+ this.type = "xunhuan";
+ break;
+ case "xunhuan":
+ this.type = "suiji";
+ break;
+ case "suiji":
+ this.type = "danqu";
+ break;
+ }
+ return;
+ }
+ if (inRect(pos, musicbox)) {
+ const index = Math.floor((py - 33) / 33);
+ if (page !== this.selection[0] || index !== this.selection[1]) {
+ if (
+ this.musics.includes(this.musicMx[page][index]) ||
+ page !== this.musicMx.length - 1
+ ) {
+ this.selection[0] = page;
+ this.selection[1] = index;
+ this.randomList.indexOf(
+ (v) =>
+ v === this.musicMx[this.selection[0]][this.selection[1]]
+ );
+
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+ this.stop = false;
+ }
+ } else {
+ if (this.stop) {
+ this.stop = !this.stop;
+ core.resumeBgm();
+ } else {
+ this.stop = !this.stop;
+ core.pauseBgm();
+ }
+ }
+ return;
+ }
+
+ if (inRect(pos, volumebox)) {
+ const time = Math.min(Math.max((px - 33) / 200, 0), 1);
+ audio.setVolume(time);
+ core.plugin.audioSystem.soundPlayer.setVolume(time);
+ isvolume = true;
+ }
+ }
+ }
+ mousemove(px, py) {
+ if (isvolume) {
+ if (core.domStyle.isVertical) {
+ const time = Math.min(Math.max((px - 83) / 267, 0), 1);
+ audio.setVolume(time);
+ core.plugin.audioSystem.soundPlayer.setVolume(time);
+ } else {
+ const time = Math.min(Math.max((px - 33) / 200, 0), 1);
+ audio.setVolume(time);
+ core.plugin.audioSystem.soundPlayer.setVolume(time);
+ }
+ }
+ }
+
+ drawUI() {
+ //绘制页面
+ core.clearMap(music);
+ const bgVertical = core.material.images.images["bg_2010.webp"]; //竖屏背景
+ const bg = core.material.images.images["bg_5043.webp"]; //竖屏背景
+ if (core.domStyle.isVertical) {
+ //竖屏
+
+ core.fillRect(ctx, 0, 0, 416, 676, "#000000"); //黑色背景
+ ctx.globalAlpha = 0.3; //透明度
+ if (bgVertical)
+ ctx.drawImage(bgVertical, 0, 0, 1280, 1500, 0, 0, 416, 676); //绘制半透明背景图片
+ ctx.globalAlpha = 1; //恢复为不透明
+
+ core.setTextAlign(ctx, "center");
+ core.fillBoldText1(
+ ctx,
+ "◀离开",
+ 37,
+ 33,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+
+ ctx.strokeStyle = "#FFFFFF";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.moveTo(33, 67);
+ ctx.lineTo(383, 67);
+
+ ctx.stroke();
+ let posy = 100;
+ const indexList = this.musicMx[page];
+ core.setTextAlign(ctx, "left");
+ for (let i = 0; i < indexList.length; i++) {
+ const text = this.musicname[indexList[i]];
+ if (
+ this.musics.includes(this.musicMx[page][i]) ||
+ page !== this.musicMx.length - 1
+ ) {
+ core.fillBoldText(
+ ctx,
+ text,
+ 50,
+ posy - 10,
+ page === this.selection[0] && i === this.selection[1] ?
+ "#FFFFFF" :
+ "#444444",
+ "#000000",
+ core.ui._buildFont(22, true)
+ )
+
+
+
+ ctx.strokeStyle = "#FFFFFF";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.moveTo(33, posy);
+ ctx.lineTo(383, posy);
+ ctx.stroke();
+ }
+ posy += 33;
+ }
+ ctx.beginPath();
+ ctx.moveTo(33, 403);
+ ctx.lineTo(383, 403);
+ ctx.moveTo(33, 400);
+ ctx.lineTo(383, 400);
+ ctx.stroke();
+
+ core.fillBoldText1(
+ ctx,
+ "上一页",
+ 33,
+ 433,
+ page === 0 ? "#444444" : "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+
+ core.fillBoldText1(
+ ctx,
+ page + 1 + "/" + this.musicMx.length,
+ 193,
+ 433,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+ core.fillBoldText1(
+ ctx,
+ "下一页",
+ 317,
+ 433,
+ page === this.musicMx.length - 1 ? "#444444" : "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+
+ ctx.strokeStyle = "#ffffff";
+ ctx.lineWidth = 1;
+
+ core.fillBoldText(
+ ctx,
+ "|",
+ 33,
+ 566,
+ "#FFFFFF",
+ 2,
+ core.ui._buildFont(32, true)
+ );
+ core.fillBoldText(
+ ctx,
+ "◀",
+ 38,
+ 567,
+ "#FFFFFF",
+ 2,
+ core.ui._buildFont(32, true)
+ );
+
+ ctx.beginPath();
+ ctx.arc(168, 557, 27, 0, 2 * Math.PI);
+ ctx.stroke();
+ core.fillText(
+ ctx,
+ "|",
+ 282,
+ 566,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+ core.fillText(
+ ctx,
+ "▶",
+ 262,
+ 567,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+
+ if (this.stop) {
+ core.fillText(
+ ctx,
+ "▶",
+ 158,
+ 567,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+ } else {
+ core.fillText(
+ ctx,
+ "||",
+ 151,
+ 567,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+ }
+
+ const img = core.material.images.images[this.type + ".webp"];
+ if (img) ctx.drawImage(img, 333, 518, 67, 67);
+ core.setTextAlign(ctx, "center");
+ ctx.font = "bold 17px Verdana";
+ ctx.fillText("当前歌曲", 208, 466);
+ ctx.fillText(
+ this.musicname[this.musicMx[this.selection[0]][this.selection[1]]],
+ 108,
+ 502
+ );
+
+ ctx.fillStyle = "#ffffff";
+ ctx.font = "bold 16px Verdana";
+ ctx.fillText("音量", 50, 657);
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.moveTo(83, 650);
+ ctx.lineTo(350, 650);
+ ctx.stroke();
+ ctx.strokeStyle = "#ffffff";
+ ctx.lineWidth = 3;
+ ctx.fillStyle = "rgba(255,255,255,0.5)";
+
+ ctx.beginPath();
+ ctx.moveTo(83, 650);
+ ctx.lineTo(267 * audio.getVolume() + 83, 650);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.arc(267 * audio.getVolume() + 83, 650, 3, 0, 2 * Math.PI);
+ ctx.fill();
+ core.fillBoldText1(
+ ctx,
+ Math.floor(100 * audio.getVolume()),
+ 373,
+ 657,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(19, true)
+ );
+ } else {
+ //横屏
+
+ core.fillRect(ctx, 0, 0, 676, 416, "#000000"); //黑色背景
+ ctx.globalAlpha = 0.5; //透明度
+ if (bg) ctx.drawImage(bg, 0, 0, 1280, 720, 0, 0, 676, 416); //绘制半透明背景图片
+ ctx.globalAlpha = 1; //恢复为不透明
+ core.setTextAlign(ctx, "center");
+
+ core.fillBoldText1(
+ ctx,
+ "◀离开",
+ 37,
+ 33,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+
+ ctx.strokeStyle = "#FFFFFF";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.moveTo(267, 33);
+ ctx.lineTo(267, 383);
+ ctx.moveTo(300, 33);
+ ctx.lineTo(633, 33);
+ ctx.stroke();
+ let posy = 67;
+ const indexList = this.musicMx[page];
+ core.setTextAlign(ctx, "left");
+ for (let i = 0; i < indexList.length; i++) {
+ const text = this.musicname[indexList[i]];
+ if (
+ this.musics.includes(this.musicMx[page][i]) ||
+ page !== this.musicMx.length - 1
+ ) {
+ core.fillBoldText1(
+ ctx,
+ text,
+ 317,
+ posy - 10,
+ page === this.selection[0] && i === this.selection[1] ?
+ "#FFFFFF" :
+ "#444444",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+
+ ctx.strokeStyle = "#FFFFFF";
+ ctx.lineWidth = 2;
+ ctx.beginPath();
+ ctx.moveTo(300, posy);
+ ctx.lineTo(633, posy);
+ ctx.stroke();
+ }
+ posy += 33;
+ }
+ core.fillBoldText1(
+ ctx,
+ "上一页",
+ 350,
+ 400 - 10,
+ page === 0 ? "#444444" : "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+
+ core.fillBoldText1(
+ ctx,
+ page + 1 + "/" + this.musicMx.length,
+ 450,
+ 400 - 10,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+ core.fillBoldText1(
+ ctx,
+ "下一页",
+ 517,
+ 400 - 10,
+ page === this.musicMx.length - 1 ? "#444444" : "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(22, true)
+ );
+ ctx.strokeStyle = "#ffffff";
+ ctx.lineWidth = 1;
+
+ core.fillText(
+ ctx,
+ "|",
+ 18,
+ 232,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+ core.fillText(
+ ctx,
+ "◀",
+ 23,
+ 233,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+
+ ctx.beginPath();
+ ctx.arc(98, 223, 23, 0, 2 * Math.PI);
+ ctx.stroke();
+ if (this.stop) {
+ core.fillText(
+ ctx,
+ "▶",
+ 88,
+ 233,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+ } else {
+ core.fillText(
+ ctx,
+ "||",
+ 82,
+ 233,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+ }
+ core.fillText(
+ ctx,
+ "|",
+ 169,
+ 232,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+ core.fillText(
+ ctx,
+ "▶",
+ 150,
+ 233,
+ "#FFFFFF",
+ core.ui._buildFont(32, true)
+ );
+
+ ctx.font = "bold 16px Verdana";
+ ctx.fillText("音量", 117, 300);
+ ctx.beginPath();
+ ctx.moveTo(33, 333);
+ ctx.lineTo(233, 333);
+ ctx.stroke();
+ ctx.strokeStyle = "#ffffff";
+ ctx.lineWidth = 3;
+ ctx.fillStyle = "rgba(255,255,255,0.5)";
+
+ ctx.beginPath();
+ ctx.moveTo(33, 333);
+ ctx.lineTo(200 * audio.getVolume() + 33, 333);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.arc(200 * audio.getVolume() + 33, 333, 3, 0, 2 * Math.PI);
+ ctx.fill();
+ core.fillBoldText1(
+ ctx,
+ Math.floor(100 * audio.getVolume()),
+ 240,
+ 337,
+ "#FFFFFF",
+ "#000000",
+ 2,
+ core.ui._buildFont(19, true)
+ );
+ const img = core.material.images.images[this.type + ".webp"];
+ if (img) ctx.drawImage(img, 193, 187, 67, 67);
+ core.setTextAlign(ctx, "center");
+ ctx.font = "bold 16px Verdana";
+ ctx.fillText("当前歌曲", 133, 99);
+ ctx.fillText(
+ this.musicname[this.musicMx[this.selection[0]][this.selection[1]]],
+ 133,
+ 132
+ );
+ }
+ }
+ }
+ core.ui.music = new musicclass();
+ main.dom.musicMode.onclick = function () {
+ //点击开始页面的CG MODE进入cg回廊
+ if (
+ (core.getLocalStorage("musics") &&
+ core.getLocalStorage("musics").length === 0) ||
+ !core.getLocalStorage("musics")
+ )
+ core.setLocalStorage("musics", ["theme.mp3"]);
+ core.ui.music.musics = core.getLocalStorage("musics");
+ core.playBgm(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ],
+ 0
+ );
+
+ const arr = main.core.ui.music.musicMx.flat(Infinity);
+ main.core.ui.music.randomList = shuffle(arr);
+ main.core.ui.music.random = main.core.ui.music.randomList.indexOf(
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ]
+ );
+ page = 0;
+ music.style.display = "block";
+ let time = 0;
+ core.registerAnimationFrame("music", null, (temptime) => {
+ if (temptime - time < 50) return
+ time = temptime;
+ main.core.ui.music.update();
+ const duration =
+ core.plugin.audioSystem.bgmController.player.getRoute(
+ "bgms." +
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ]
+ ).duration;
+
+ const currentTime =
+ core.plugin.audioSystem.bgmController.player.getRoute(
+ "bgms." +
+ main.core.ui.music.musicMx[main.core.ui.music.selection[0]][
+ main.core.ui.music.selection[1]
+ ]
+ ).currentTime;
+ if (currentTime && duration && duration - currentTime < 0.05) {
+ if (core.domStyle.isVertical) {
+ core.ui.music.mousedown(277, 590);
+ } else {
+ core.ui.music.mousedown(158, 255);
+ }
+ }
+
+ });
+ };
+ /*loader.prototype.loadOneMusic = function (name) {
+ /* var music = new Audio();
music.preload = "none";
if (main.bgmRemote)
music.src = main.bgmRemoteRoot + core.firstData.name + "/" + name;
else music.src = "project/bgms/" + name;
music.loop = "loop";
core.material.bgms[name] = music;*/
- };
- },
+ //};
+},
"横屏切换": function () {
// 在此增加新插件
this.triggerFullscreen = async function (full) {
@@ -21110,288 +19691,277 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
});
},
"天气叠加": function () {
- //使用方法:使用core.setWeather(天气,等级)来增加天气,使用core.setWeather()来清空天气
- // 天气叠加功能
- ////// 更改天气效果 //////
- control.prototype.setWeather = function (type, level) {
- // 非雨雪
- if (type == null) {
- Object.keys(core.control.weathers).forEach(function (one) {
- core.deleteCanvas("weather" + one);
- });
- core.animateFrame.weather.type = [];
- core.animateFrame.weather.nodes = {};
- core.animateFrame.weather.level = {};
- core.animateFrame.weather.time = {};
- return;
- }
- if (!core.animateFrame.weather.level || level == null)
- core.animateFrame.weather.level = {};
- if (!core.animateFrame.weather.type) core.animateFrame.weather.type = [];
- level = core.clamp(parseInt(level) || 5, 1, 10);
- // 当前天气:则忽略
- if (
- core.animateFrame.weather.type.includes(type) &&
- level == core.animateFrame.weather.level[type]
- )
- return;
- if (core.animateFrame.weather.nodes[type]) return;
- // 计算当前的宽高
- core.createCanvas(
- "weather" + type,
- 0,
- 0,
- core.__PIXELS__,
- core.__PIXELS__,
- 80
- );
- core.animateFrame.weather.type.push(type);
- core.animateFrame.weather.level[type] = level;
- this._setWeather_createNodes(type, level);
- };
- control.prototype._setWeather_createNodes = function (type, level) {
- var number =
- level *
- parseInt(
- (20 * core.bigmap.width * core.bigmap.height) /
- (core.__SIZE__ * core.__SIZE__)
- );
- if (!core.animateFrame.weather.nodes[type])
- core.animateFrame.weather.nodes[type] = [];
- switch (type) {
- case "rain":
- for (var a = 0; a < number; a++) {
- core.animateFrame.weather.nodes.rain.push({
- x: Math.random() * core.bigmap.width * 32,
- y: Math.random() * core.bigmap.height * 32,
- l: Math.random() * 2.5,
- xs: -4 + Math.random() * 4 + 2,
- ys: Math.random() * 10 + 10,
- });
- }
- break;
- case "snow":
- for (var a = 0; a < number; a++) {
- core.animateFrame.weather.nodes.snow.push({
- x: Math.random() * core.bigmap.width * 32,
- y: Math.random() * core.bigmap.height * 32,
- r: Math.random() * 5 + 1,
- d: Math.random() * Math.min(level, 200),
- });
- }
- break;
- case "fog":
- if (core.animateFrame.weather.fog) {
- core.animateFrame.weather.nodes[type] = [
- {
- level: number,
- x: 0,
- y: -core.__PIXELS__ / 2,
- dx: -Math.random() * 1.5,
- dy: Math.random(),
- delta: 0.001,
- },
- ];
- }
- break;
- case "cloud":
- if (core.animateFrame.weather.cloud) {
- core.animateFrame.weather.nodes[type] = [
- {
- level: number,
- x: 0,
- y: -core.__PIXELS__ / 2,
- dx: -Math.random() * 1.5,
- dy: Math.random(),
- delta: 0.001,
- },
- ];
- }
- break;
- case "sun":
- if (core.animateFrame.weather.sun) {
- // 直接绘制
- core.clearMap("weather" + type);
- core.setAlpha("weather" + type, level / 10);
- core.drawImage(
- "weather" + type,
- core.animateFrame.weather.sun,
- 0,
- 0,
- core.animateFrame.weather.sun.width,
- core.animateFrame.weather.sun.height,
- 0,
- 0,
- core.__PIXELS__,
- core.__PIXELS__
- );
- core.setAlpha("weather" + type, 1);
- }
- break;
- }
- };
- core.registerAnimationFrame("weather", true, function (timestamp) {
- var weather = core.animateFrame.weather;
- if (!weather.type) return;
- weather.type.forEach(function (one) {
- if (
- timestamp - weather.time[one] <= 30 ||
- !core.dymCanvas["weather" + one]
- )
- return;
- core.control["_animationFrame_weather_" + one]();
- weather.time[one] = timestamp;
- });
- });
- // 雨
- control.prototype._animationFrame_weather_rain = function () {
- var ctx = core.dymCanvas.weatherrain,
- ox = core.bigmap.offsetX,
- oy = core.bigmap.offsetY;
- core.clearMap("weatherrain");
- ctx.strokeStyle = "rgba(174,194,224,0.8)";
- ctx.lineWidth = 1;
- ctx.lineCap = "round";
- core.animateFrame.weather.nodes.rain.forEach(function (p) {
- ctx.beginPath();
- ctx.moveTo(p.x - ox, p.y - oy);
- ctx.lineTo(p.x + p.l * p.xs - ox, p.y + p.l * p.ys - oy);
- ctx.stroke();
- p.x += p.xs;
- p.y += p.ys;
- if (p.x > core.bigmap.width * 32 || p.y > core.bigmap.height * 32) {
- p.x = Math.random() * core.bigmap.width * 32;
- p.y = -10;
- }
- });
- ctx.fill();
- };
- // 雪
- control.prototype._animationFrame_weather_snow = function () {
- var ctx = core.dymCanvas.weathersnow,
- ox = core.bigmap.offsetX,
- oy = core.bigmap.offsetY;
- core.clearMap("weathersnow");
- ctx.fillStyle = "rgba(255, 255, 255, 0.8)";
- ctx.beginPath();
- if (!core.animateFrame.weather.data) core.animateFrame.weather.data = {};
- core.animateFrame.weather.data.snow =
- core.animateFrame.weather.data.snow || 0;
- core.animateFrame.weather.data.snow += 0.01;
- var angle = core.animateFrame.weather.data.snow;
- core.animateFrame.weather.nodes.snow.forEach(function (p) {
- ctx.moveTo(p.x - ox, p.y - oy);
- ctx.arc(p.x - ox, p.y - oy, p.r, 0, Math.PI * 2, true);
- // update
- p.x += Math.sin(angle) * core.animateFrame.weather.level.snow;
- p.y += Math.cos(angle + p.d) + 1 + p.r / 2;
- if (
- p.x > core.bigmap.width * 32 + 5 ||
- p.x < -5 ||
- p.y > core.bigmap.height * 32
- ) {
- if (Math.random() > 1 / 3) {
- p.x = Math.random() * core.bigmap.width * 32;
- p.y = -10;
- } else {
- if (Math.sin(angle) > 0) p.x = -5;
- else p.x = core.bigmap.width * 32 + 5;
- p.y = Math.random() * core.bigmap.height * 32;
- }
- }
- });
- ctx.fill();
- };
- // 图片天气
- control.prototype.__animateFrame_weather_image = function (image, type) {
- if (!image) return;
- var node = core.animateFrame.weather.nodes[type][0];
- core.setAlpha("weather" + type, node.level / 500);
- var wind = 1.5;
- var width = image.width,
- height = image.height;
- node.x += node.dx * wind;
- node.y += (2 * node.dy - 1) * wind;
- if (node.x + 3 * width <= core.__PIXELS__) {
- node.x += 4 * width;
- while (node.x > 0) node.x -= width;
- }
- node.dy += node.delta;
- if (node.dy >= 1) {
- node.delta = -0.001;
- } else if (node.dy <= 0) {
- node.delta = 0.001;
- }
- if (node.y + 3 * height <= core.__PIXELS__) {
- node.y += 4 * height;
- while (node.y > 0) node.y -= height;
- } else if (node.y >= 0) {
- node.y -= height;
- }
- for (var i = 0; i < 3; ++i) {
- for (var j = 0; j < 3; ++j) {
- if (
- node.x + (i + 1) * width <= 0 ||
- node.x + i * width >= core.__PIXELS__ ||
- node.y + (j + 1) * height <= 0 ||
- node.y + j * height >= core.__PIXELS__
- )
- continue;
- core.drawImage(
- "weather" + type,
- image,
- node.x + i * width,
- node.y + j * height
- );
- }
- }
- core.setAlpha("weather" + type, 1);
- };
- // 雾
- control.prototype._animationFrame_weather_fog = function () {
- core.clearMap("weatherfog");
- this.__animateFrame_weather_image(core.animateFrame.weather.fog, "fog");
- };
- // 云
- control.prototype._animationFrame_weather_cloud = function () {
- core.clearMap("weathercloud");
- this.__animateFrame_weather_image(
- core.animateFrame.weather.cloud,
- "cloud"
- );
- };
- },
+ //使用方法:使用core.setWeather(天气,等级)来增加天气,使用core.setWeather()来清空天气
+ // 天气叠加功能
+
+ ////// 更改天气效果 //////
+ control.prototype.setWeather = function (type, level) {
+ // 非雨雪
+ if (type == null) {
+ Object.keys(core.control.weathers).forEach(function (one) {
+ core.deleteCanvas("weather" + one);
+ });
+ core.animateFrame.weather.type = [];
+ core.animateFrame.weather.nodes = {};
+ core.animateFrame.weather.level = {};
+ core.animateFrame.weather.time = {};
+ return;
+ }
+ if (!core.animateFrame.weather.level || level == null)
+ core.animateFrame.weather.level = {};
+ if (!core.animateFrame.weather.type) core.animateFrame.weather.type = [];
+ level = core.clamp(parseInt(level) || 5, 1, 10);
+ // 当前天气:则忽略
+ if (
+ core.animateFrame.weather.type.includes(type) &&
+ level == core.animateFrame.weather.level[type]
+ )
+ return;
+ if (core.animateFrame.weather.nodes[type]) return;
+ // 计算当前的宽高
+ core.createCanvas(
+ "weather" + type,
+ 0,
+ 0,
+ core.__PIXELS__,
+ core.__PIXELS__,
+ 80
+ );
+ core.animateFrame.weather.type.push(type);
+ core.animateFrame.weather.level[type] = level;
+ this._setWeather_createNodes(type, level);
+ };
+ control.prototype._setWeather_createNodes = function (type, level) {
+ var number =
+ level *
+ parseInt(
+ (20 * core.bigmap.width * core.bigmap.height) /
+ (core.__SIZE__ * core.__SIZE__)
+ );
+ if (!core.animateFrame.weather.nodes[type])
+ core.animateFrame.weather.nodes[type] = [];
+ switch (type) {
+ case "rain":
+ for (var a = 0; a < number; a++) {
+ core.animateFrame.weather.nodes.rain.push({
+ x: Math.random() * core.bigmap.width * 32,
+ y: Math.random() * core.bigmap.height * 32,
+ l: Math.random() * 2.5,
+ xs: -4 + Math.random() * 4 + 2,
+ ys: Math.random() * 10 + 10,
+ });
+ }
+ break;
+ case "snow":
+ for (var a = 0; a < number; a++) {
+ core.animateFrame.weather.nodes.snow.push({
+ x: Math.random() * core.bigmap.width * 32,
+ y: Math.random() * core.bigmap.height * 32,
+ r: Math.random() * 5 + 1,
+ d: Math.random() * Math.min(level, 200),
+ });
+ }
+ break;
+ case "fog":
+ if (core.animateFrame.weather.fog) {
+ core.animateFrame.weather.nodes[type] = [{
+ level: number,
+ x: 0,
+ y: -core.__PIXELS__ / 2,
+ dx: -Math.random() * 1.5,
+ dy: Math.random(),
+ delta: 0.001,
+ }, ];
+ }
+ break;
+ case "cloud":
+ if (core.animateFrame.weather.cloud) {
+ core.animateFrame.weather.nodes[type] = [{
+ level: number,
+ x: 0,
+ y: -core.__PIXELS__ / 2,
+ dx: -Math.random() * 1.5,
+ dy: Math.random(),
+ delta: 0.001,
+ }, ];
+ }
+ break;
+ case "sun":
+ if (core.animateFrame.weather.sun) {
+ // 直接绘制
+ core.clearMap("weather" + type);
+
+ core.drawImage(
+ "weather" + type,
+ core.animateFrame.weather.sun,
+ 0,
+ 0,
+ core.animateFrame.weather.sun.width,
+ core.animateFrame.weather.sun.height,
+ 0,
+ 0,
+ core.__PIXELS__,
+ core.__PIXELS__
+ );
+ core.setAlpha("weather" + type, level / 10);
+ core.animateFrame.weather.nodes.sun = [{ level: level, opacity: level / 10, delta: 0.01 }]
+ }
+ break;
+ }
+ };
+ core.registerAnimationFrame("weather", true, function (timestamp) {
+ var weather = core.animateFrame.weather;
+ if (!weather.type) return;
+ weather.type.forEach(function (one) {
+ if (
+ timestamp - weather.time[one] <= 30 ||
+ !core.dymCanvas["weather" + one]
+ )
+ return;
+ core.control["_animationFrame_weather_" + one]();
+ weather.time[one] = timestamp;
+ });
+ });
+ // 晴
+ control.prototype._animationFrame_weather_sun = function () {
+
+ var node = core.animateFrame.weather.nodes.sun[0]
+ var opacity = node.opacity + node.delta;
+
+ if (opacity > node.level / 11 + 0.3 || opacity < node.level / 11 - 0.3)
+ node.delta = -node.delta;
+ node.opacity = opacity;
+ core.setOpacity("weathersun", core.clamp(opacity, 0, 1));
+
+ };
+ // 雨
+ control.prototype._animationFrame_weather_rain = function () {
+ var ctx = core.dymCanvas.weatherrain,
+ ox = core.bigmap.offsetX,
+ oy = core.bigmap.offsetY;
+ core.clearMap("weatherrain");
+ ctx.strokeStyle = "rgba(174,194,224,0.8)";
+ ctx.lineWidth = 1;
+ ctx.lineCap = "round";
+ core.animateFrame.weather.nodes.rain.forEach(function (p) {
+ ctx.beginPath();
+ ctx.moveTo(p.x - ox, p.y - oy);
+ ctx.lineTo(p.x + p.l * p.xs - ox, p.y + p.l * p.ys - oy);
+ ctx.stroke();
+ p.x += p.xs;
+ p.y += p.ys;
+ if (p.x > core.bigmap.width * 32 || p.y > core.bigmap.height * 32) {
+ p.x = Math.random() * core.bigmap.width * 32;
+ p.y = -10;
+ }
+ });
+ ctx.fill();
+ };
+ // 雪
+ control.prototype._animationFrame_weather_snow = function () {
+ var ctx = core.dymCanvas.weathersnow,
+ ox = core.bigmap.offsetX,
+ oy = core.bigmap.offsetY;
+ core.clearMap("weathersnow");
+ ctx.fillStyle = "rgba(255, 255, 255, 0.8)";
+ ctx.beginPath();
+ if (!core.animateFrame.weather.data) core.animateFrame.weather.data = {};
+ core.animateFrame.weather.data.snow =
+ core.animateFrame.weather.data.snow || 0;
+ core.animateFrame.weather.data.snow += 0.01;
+ var angle = core.animateFrame.weather.data.snow;
+ core.animateFrame.weather.nodes.snow.forEach(function (p) {
+ ctx.moveTo(p.x - ox, p.y - oy);
+ ctx.arc(p.x - ox, p.y - oy, p.r, 0, Math.PI * 2, true);
+ // update
+ p.x += Math.sin(angle) * core.animateFrame.weather.level.snow;
+ p.y += Math.cos(angle + p.d) + 1 + p.r / 2;
+ if (
+ p.x > core.bigmap.width * 32 + 5 ||
+ p.x < -5 ||
+ p.y > core.bigmap.height * 32
+ ) {
+ if (Math.random() > 1 / 3) {
+ p.x = Math.random() * core.bigmap.width * 32;
+ p.y = -10;
+ } else {
+ if (Math.sin(angle) > 0) p.x = -5;
+ else p.x = core.bigmap.width * 32 + 5;
+ p.y = Math.random() * core.bigmap.height * 32;
+ }
+ }
+ });
+ ctx.fill();
+ };
+ // 图片天气
+ control.prototype.__animateFrame_weather_image = function (image, type) {
+ if (!image) return;
+ var node = core.animateFrame.weather.nodes[type][0];
+ core.setAlpha("weather" + type, node.level / 500);
+ var wind = 1.5;
+ var width = image.width,
+ height = image.height;
+ node.x += node.dx * wind;
+ node.y += (2 * node.dy - 1) * wind;
+ if (node.x + 3 * width <= core.__PIXELS__) {
+ node.x += 4 * width;
+ while (node.x > 0) node.x -= width;
+ }
+ node.dy += node.delta;
+ if (node.dy >= 1) {
+ node.delta = -0.001;
+ } else if (node.dy <= 0) {
+ node.delta = 0.001;
+ }
+ if (node.y + 3 * height <= core.__PIXELS__) {
+ node.y += 4 * height;
+ while (node.y > 0) node.y -= height;
+ } else if (node.y >= 0) {
+ node.y -= height;
+ }
+ for (var i = 0; i < 3; ++i) {
+ for (var j = 0; j < 3; ++j) {
+ if (
+ node.x + (i + 1) * width <= 0 ||
+ node.x + i * width >= core.__PIXELS__ ||
+ node.y + (j + 1) * height <= 0 ||
+ node.y + j * height >= core.__PIXELS__
+ )
+ continue;
+ core.drawImage(
+ "weather" + type,
+ image,
+ node.x + i * width,
+ node.y + j * height
+ );
+ }
+ }
+ core.setAlpha("weather" + type, 1);
+ };
+ // 雾
+ control.prototype._animationFrame_weather_fog = function () {
+ core.clearMap("weatherfog");
+ this.__animateFrame_weather_image(core.animateFrame.weather.fog, "fog");
+ };
+ // 云
+ control.prototype._animationFrame_weather_cloud = function () {
+ core.clearMap("weathercloud");
+ this.__animateFrame_weather_image(
+ core.animateFrame.weather.cloud,
+ "cloud"
+ );
+ }
+
+},
"回合战斗动画": function () {
// 在此增加新插件
- const animateAttack = document.createElement("canvas"); //画布设置
- animateAttack.style.zIndex = 80;
- animateAttack.id = "animateAttack";
- animateAttack.classList.add("gameCanvas", "anti-aliasing");
- animateAttack.style.display = "block";
- animateAttack.width = 416;
- animateAttack.height = 416;
- animateAttack.style.width = core.__PIXELS__ * core.domStyle.scale + "px";
- animateAttack.style.height = core.__PIXELS__ * core.domStyle.scale + "px";
- main.dom.animateAttack = animateAttack;
- const ctx = animateAttack.getContext("2d");
+
+
+
const changeY = -30
let easy = false;
const { imagelighter } = core.plugin.utils;
- main.dom.gameDraw.appendChild(animateAttack);
- const { lcm, gcd } = core.plugin.utils;
- const animate2 = document.createElement("canvas"); //画布设置
- animate2.style.zIndex = 91;
- animate2.id = "animate2";
- animate2.classList.add("gameCanvas", "anti-aliasing");
- animate2.style.display = "block";
- animate2.width = 416;
- animate2.height = 416;
- animate2.style.width = core.__PIXELS__ * core.domStyle.scale + "px";
- animate2.style.height = core.__PIXELS__ * core.domStyle.scale + "px";
- main.dom.animate2 = animate2;
- const anctx = animate2.getContext("2d");
- main.dom.gameDraw.appendChild(animate2);
let a = []
function drawAnimate(name, centerX, centerY) {
@@ -21414,32 +19984,31 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"animate": animate,
"centerX": centerX,
"centerY": centerY,
- "start": 0,
"pause": false,
- "pausetime": 0,
"index": 0,
});
return id;
}
+ core.animateFrame.animate2Time = 0
function animationFrame(callback1) {
- let time = 0
+ const ctx = core.getContextByName("animateAttack") ?? core.createCanvas("animateAttack", 0, 0, 416, 416, 80)
+ const anctx = core.getContextByName("animate2") ?? core.createCanvas("animate2", 0, 0, 416, 416, 91)
core.registerAnimationFrame("animate2", true, function (timestamp) {
- let frametime = timestamp - time
- time = timestamp;
if (
+ timestamp - core.animateFrame.animate2Time < 50 ||
!a ||
a.length == 0
)
return;
core.clearMap(anctx);
// 更新帧
-
+ core.animateFrame.animate2Time = timestamp
for (var i = 0; i < a.length; i++) {
var obj = a[i];
- if (obj.start === 0) obj.start = time
- obj.index = Math.floor((time - obj.start) / (1000 / 60))
+
+
if (obj.index >= obj.animate.frames.length) {
(function (callback) {
setTimeout(function () {
@@ -21464,7 +20033,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
obj.animate,
core.status.heroCenter.px,
core.status.heroCenter.py,
- obj.index
+ obj.index,
);
} else {
core.maps._drawAnimateFrame(
@@ -21472,9 +20041,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
obj.animate,
obj.centerX,
obj.centerY,
- obj.index
+ obj.index,
);
}
+ obj.index++
});
core.animateFrame.animateTime = timestamp;
});
@@ -21487,18 +20057,22 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
drawAnimate(name, 130, 180 + changeY);
}
}
-
+ let sp = [1, 2, 4, 8, 16]
+ let A = 1
this.attackAnimate = function (
enemyId,
heroInfo,
enemyInfo,
equipInfo,
- oneTurn,
+ Exspeed,
heroDiffList,
enemyDiffList,
heroanimateList,
enemyanimateList
) {
+
+ const ctx = core.getContextByName("animateAttack") ?? core.createCanvas("animateAttack", 0, 0, 416, 416, 80)
+ const anctx = core.getContextByName("animate2") ?? core.createCanvas("animate2", 0, 0, 416, 416, 91)
//参数分别为怪物id、真实属性,战斗信息,特殊装备(如火焰风衣)属性特殊装备属性为以元组{equipId,oneDamage,speed,now:0}构成的数组(列出每个需要计算的特殊装备,没有则为空数组或不填)
core.lockControl();
core.clearMap(ctx);
@@ -21507,19 +20081,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
enemyInfo.id = enemyId;
enemyInfo.cls = core.getClsFromId(enemyId);
enemyInfo.name = core.material.enemys[enemyId].name;
- let max = heroInfo.speed
- if (enemyInfo.speed > max) max = enemyInfo.speed
- equipInfo.forEach(v => { if (v.speed > max) max = v.speed })
- let i = 1
- while (oneTurn * i / max < 15) {
- i++
- }
- if (heroInfo.onAttack) heroInfo.now *= i
- if (enemyInfo.onAttack) enemyInfo.now *= i
- equipInfo.forEach(v => { if (v.onAttack) v.now *= i })
- oneTurn *= i
- let time = 0,
- farme = 0;
+ heroInfo.turn = 0
+ enemyInfo.turn = 0
+ const oneTurn = 100
+ let farme = 0;
+
return new Promise((res) => {
core.plugin.battle_onclick = function (x, y, px, py) {
const makeBox = ([x, y], [w, h]) => {
@@ -21549,7 +20115,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
(inRect(pos, easyspeedbox) && easy) ||
(inRect(pos, uneasyspeedbox) && !easy)
) {
- flags.qukly = !flags.qukly
+ A++
+ if (A >= sp.length) A = 0
+ flags.qukly = sp[A]
} else if ((inRect(pos, easyClosebox) && easy) ||
(inRect(pos, uneasyClosebox) && !easy)
@@ -21563,7 +20131,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
async function drawAttackAnimate(
heroInfo,
- oneTurn,
enemyInfo,
equipInfo,
farme,
@@ -21587,29 +20154,30 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
equipInfo.forEach(function (v) {
if (v.onAttack) onAttack = true;
});
+ const ctx = core.getContextByName("animateAttack") ?? core.createCanvas("animateAttack", 0, 0, 416, 416, 80)
+ const anctx = core.getContextByName("animate2") ?? core.createCanvas("animate2", 0, 0, 416, 416, 91)
core.clearMap(ctx);
let animate = Math.floor(farme / 15);
- if (flags.qukly) {
- while (true) {
- let goattack = false
- equipInfo.forEach(v => {
- if (v.now >= oneTurn) goattack = true
- });
- if (enemyInfo.now >= oneTurn) goattack = true
- if (heroInfo.now >= oneTurn) goattack = true
+ for (let i = 0; i < (flags.qukly ?? 2) / 2; i++) {
+ let goattack = false
+ equipInfo.forEach(v => {
+ if (v.now >= oneTurn) goattack = true
- if (goattack) break;
- enemyInfo.now += enemyInfo.speed
- heroInfo.now += heroInfo.speed
- equipInfo.forEach(function (v) {
- v.now += v.speed
+ });
+ if (enemyInfo.now >= oneTurn) goattack = true
+ if (heroInfo.now >= oneTurn) goattack = true
+ if (goattack || attack || onAttack) break;
+ enemyInfo.now += enemyInfo.speed / Exspeed
+ heroInfo.now += heroInfo.speed / Exspeed
+ equipInfo.forEach(function (v) {
+ v.now += v.speed / Exspeed
- });
+ });
- }
}
+
if (easy) {
core.fillRect(ctx, 64, 52, 288, 212, "rgba(0,0,0,0.5)");
core.strokeRect(ctx, 64, 52, 288, 212, "rgba(255,255,255,0.5)", 4);
@@ -21740,7 +20308,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
);
core.fillBoldText(
ctx,
- flags.qukly ? "正常" : "极速",
+ "x" + (flags.qukly ?? 2) / 2,
330,
250 + changeY,
"#FFFF60",
@@ -21775,7 +20343,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"bold 36px pala"
);
- if (!attack && !onAttack && !flags.qukly) enemyInfo.now += enemyInfo.speed;
let enemynow = Math.min(100 + (enemyInfo.now / oneTurn) * 215, 315);
ctx.fillStyle = "#FFFFFF";
ctx.beginPath();
@@ -21788,7 +20355,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawLine(ctx, 100, 125 + changeY, 315, 125 + changeY, "#FFFFFF", 5);
equipInfo.forEach(function (v) {
- if (!attack && !onAttack) v.now += v.speed;
let vnow = Math.min(100 + (v.now / oneTurn) * 215, 315);
ctx.beginPath();
ctx.moveTo(vnow, 120 + changeY);
@@ -21800,7 +20366,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawIcon(ctx, v.id, vnow - 16, 84 + changeY, 32, 32);
});
- if (!attack && !onAttack && !flags.qukly) heroInfo.now += hero.speed;
let heronow = Math.min(100 + (heroInfo.now / oneTurn) * 215, 315);
ctx.beginPath();
ctx.moveTo(heronow, 120);
@@ -22060,7 +20625,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
);
core.fillBoldText(
ctx,
- flags.qukly ? "正常" : "极速",
+ "x" + (flags.qukly ?? 2) / 2,
330,
365 + changeY,
"#FFFF60",
@@ -22095,7 +20660,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"bold 36px pala"
);
- if (!attack && !onAttack & !flags.qukly) enemyInfo.now += enemyInfo.speed;
let enemynow = Math.min(100 + (enemyInfo.now / oneTurn) * 215, 315);
ctx.fillStyle = "#FFFFFF";
ctx.beginPath();
@@ -22108,7 +20672,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawLine(ctx, 100, 125 + changeY, 315, 125 + changeY, "#FFFFFF", 5);
equipInfo.forEach(function (v) {
- if (!attack && !onAttack) v.now += v.speed;
let vnow = Math.min(100 + (v.now / oneTurn) * 215, 315);
ctx.beginPath();
ctx.moveTo(vnow, 120 + changeY);
@@ -22120,7 +20683,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.drawIcon(ctx, v.id, vnow - 16, 84 + changeY, 32, 32);
});
- if (!attack && !onAttack && !flags.qukly) heroInfo.now += hero.speed;
let heronow = Math.min(100 + (heroInfo.now / oneTurn) * 215, 315);
ctx.beginPath();
ctx.moveTo(heronow, 120 + changeY);
@@ -22133,11 +20695,13 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
let nowattacking = false;
if (heroInfo.now >= oneTurn && !heroInfo.isAttack) {
+ heroInfo.turn++
heroInfo.onAttack = false;
heroInfo.isAttack = true;
nowattacking = true;
}
if (enemyInfo.now >= oneTurn && !enemyInfo.isAttack) {
+ enemyInfo.turn++
enemyInfo.onAttack = false;
enemyInfo.isAttack = true;
nowattacking = true;
@@ -22152,25 +20716,28 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
});
if (!attack && nowattacking) {
+
let herodamage = enemyDiffList[turn].hp;
if (herodamage > 0) herodamage = "+" + herodamage;
- let text = herodamage === 0 ? "抵抗" : herodamage;
-
+ let text
+ if (core.hasSpecial(enemyInfo.id, 2) && (enemyInfo.turn - 1) % core.material.enemys[enemyInfo.id].baoji)
+ text = "暴击" + herodamage
+ else
+ text = herodamage === 0 ? "抵抗" : herodamage;
Dove.MorePerform.ShowDamagePop.PopDamage(
ctx, // 默认画布名称
270, // 英雄位置 x
160 + changeY, // 英雄位置 y
text, // 伤害值
- 18, // 默认字体大小
+ 22, // 默认字体大小
"Arial", //默认字体
typeof text === "string" && text.startsWith("+") ?
"#22FF44" :
typeof text === "string" ?
"#FFFFFF" :
null, // 默认颜色
- text === "抵抗" ? "#000000" : null, // 默认描边颜色
0, // 默认水平速度
- -1, // 默认垂直速度
+ -0.5, // 默认垂直速度
0, // 默认重力
90 // 默认显示时长(帧数)
);
@@ -22180,22 +20747,24 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
enemyanimateList[turn].forEach((v) => animateonAttack(v, true));
let enemydamage = heroDiffList[turn].hp;
if (enemydamage > 0) enemydamage = "+" + enemydamage;
- text = enemydamage === 0 ? "抵抗" : enemydamage;
+ if (core.hasSpecial(enemyInfo.id, 8) && (heroInfo.turn - 1) % core.material.enemys[enemyInfo.id].duck)
+ text = "闪避"
+ else
+ text = enemydamage === 0 ? "抵抗" : enemydamage;
Dove.MorePerform.ShowDamagePop.PopDamage(
ctx, // 默认画布名称
110, // 英雄位置 x
160 + changeY, // 英雄位置 y
text, // 伤害值
- 18, // 默认字体大小
+ 22, // 默认字体大小
"Arial", //默认字体
typeof text === "string" && text.startsWith("+") ?
"#22FF44" :
typeof text === "string" ?
"#FFFFFF" :
null, // 默认颜色
- text === "抵抗" ? "#000000" : null, // 默认描边颜色
0, // 默认水平速度
- -1, // 默认垂直速度
+ -0.5, // 默认垂直速度
0, // 默认重力
90 // 默认显示时长(帧数)
);
@@ -22208,19 +20777,36 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (heroDiffList[turn] < 0) heroInfo.inAttack = true;
if (heroInfo.hp < 0) heroInfo.hp = 0;
if (enemyInfo.hp < 0) enemyInfo.hp = 0;
- await Promise.all([
+ await new Promise((resolve) => animationFrame(resolve)).then(() => {
+ if (heroInfo.isAttack) {
+ heroInfo.now -= oneTurn;
+ heroInfo.isAttack = false;
+ }
+ if (enemyInfo.isAttack) {
+ enemyInfo.now -= oneTurn;
+ enemyInfo.isAttack = false;
+ }
+ if (equipanimate.length > 0) {
+ equipanimate.forEach((v) => {
+ v.now -= oneTurn;
+ v.isAttack = false;
+ });
+ }
+ turn++
+ })
+ /*await Promise.all([
await new Promise((resolve) => animationFrame(resolve)),
new Promise((resolve) => {
if (heroInfo.isAttack) {
- heroInfo.now = 0;
+ heroInfo.now -= 100;
heroInfo.isAttack = false;
}
resolve();
}),
new Promise((resolve) => {
if (enemyInfo.isAttack) {
- enemyInfo.now = 0;
+ enemyInfo.now -= 100;
enemyInfo.isAttack = false;
}
resolve();
@@ -22228,7 +20814,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
new Promise((resolve) => {
if (equipanimate.length > 0) {
equipanimate.forEach((v) => {
- v.now = 0;
+ v.now -= 100;
v.isAttack = false;
});
}
@@ -22238,7 +20824,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
turn++;
resolve();
}),
- ]);
+ ]);*/
if (heroInfo.hp <= 0 || enemyInfo.hp <= 0) {
core.status.event.id = "";
@@ -22250,13 +20836,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
}
- core.registerAnimationFrame("attackAnimate", true, (temptime) => {
- if (!time) time = temptime
- farme = Math.floor((temptime - time) / (1000 / 60))
- time = temptime;
+ core.registerAnimationFrame("attackAnimate", true, () => {
+
drawAttackAnimate(
heroInfo,
- oneTurn,
enemyInfo,
equipInfo,
farme,
@@ -22265,7 +20848,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
heroanimateList,
enemyanimateList
);
-
+ farme++
});
});
@@ -23194,87 +21777,94 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
};
},
"勇士法抗乘算叠加": function () {
- // 在此增加新插件
- items.prototype.compareEquipment = function (
- compareEquipId,
- beComparedEquipId
- ) {
- var result = { value: {}, percentage: {} };
- var first = core.material.items[compareEquipId],
- second = core.material.items[beComparedEquipId];
- for (var one in result) {
- for (var name in core.status.hero) {
- if (name === "mdef" && one === "percentage") {
- var ans = 1;
- if (first?.equip?.[one]?.[name])
- ans *= 1 - (first.equip[one][name] || 0) / 100;
+ // 在此增加新插件
+ items.prototype.compareEquipment = function (
+ compareEquipId,
+ beComparedEquipId
+ ) {
+ var result = { value: {}, percentage: {} };
+ var first = core.material.items[compareEquipId],
+ second = core.material.items[beComparedEquipId];
+ for (var one in result) {
+ for (var name in core.status.hero) {
+ if (name === "mdef" && one === "percentage") {
+ var ans = 1;
+ if (first?.equip?.[one]?.[name])
+ ans *= 1 - (first.equip[one][name] || 0) / 100;
- if (second?.equip?.[one]?.[name])
- ans /= 1 - (second.equip[one][name] || 0) / 100;
+ if (second?.equip?.[one]?.[name])
+ ans /= 1 - (second.equip[one][name] || 0) / 100;
- if (ans != 1) result[one][name] = ans;
- } else if (name === "mdef" && one === "value") {
- var ans = 0;
- if (first) ans -= ((first.equip || {})[one] || {})[name] || 0;
- if (second) ans += ((second.equip || {})[one] || {})[name] || 0;
- if (ans != 0) result[one][name] = ans;
- } else {
- if (typeof core.status.hero[name] == "number") {
- var ans = 0;
- if (first) ans += ((first.equip || {})[one] || {})[name] || 0;
- if (second) ans -= ((second.equip || {})[one] || {})[name] || 0;
- if (ans != 0) result[one][name] = ans;
- }
- }
- }
- }
- return result;
- };
- let a = 1;
- items.prototype._loadEquipEffect = function (equipId, unloadEquipId) {
- // 比较能力值
- var result = core.compareEquipment(equipId, unloadEquipId);
+ if (ans != 1) result[one][name] = ans;
+ } else if (name === "mdef" && one === "value") {
+ var ans = 0;
+ if (first) ans -= ((first.equip || {})[one] || {})[name] || 0;
+ if (second) ans += ((second.equip || {})[one] || {})[name] || 0;
+ if (ans != 0) result[one][name] = ans;
+ } else {
+ if (typeof core.status.hero[name] == "number") {
+ var ans = 0;
+ if (first) ans += ((first.equip || {})[one] || {})[name] || 0;
+ if (second) ans -= ((second.equip || {})[one] || {})[name] || 0;
+ if (ans != 0) result[one][name] = ans;
+ }
+ }
+ }
+ }
+ return result;
+ };
+ let a = 1;
+ items.prototype._loadEquipEffect = function (equipId, unloadEquipId) {
+ // 比较能力值
+ var result = core.compareEquipment(equipId, unloadEquipId);
- for (var name in result.percentage) {
- if (name === "mdef") {
- a *= result.percentage[name];
- core.setBuff(name, 1 - a);
- } else {
- core.addBuff(name, result.percentage[name] / 100);
- }
- }
- for (var name in result.value)
- core.status.hero[name] += result.value[name];
- };
- },
+ for (var name in result.percentage) {
+ if (name === "mdef") {
+ a *= result.percentage[name];
+ core.setBuff(name, 1 - a);
+ } else {
+ core.addBuff(name, result.percentage[name] / 100);
+ }
+ }
+ for (var name in result.value)
+ core.status.hero[name] += result.value[name];
+ };
+},
"攻速临界": function () {
// 在此增加新插件
//临界表
core.ui._drawBookDetail_turnAndCriticals = function (enemy, floorId, texts) {
// 临界表
- var criticals = core.enemys.nextCriticals(enemy.id, 8, enemy.x, enemy.y, floorId).map(function (v) {
+ var criticals = core.enemys.nextCriticals(enemy.id, 5, enemy.x, enemy.y, floorId).map(function (v) {
return core.formatBigNumber(v[0]) + ":" + core.formatBigNumber(v[1]);
});
while (criticals[0] == '0:0') criticals.shift();
- texts.push("\r[#FF6A6A]\\d攻击临界表:\\d\r[]" + JSON.stringify(criticals));
- var criticals_spell = core.nextCriticals_spell(enemy.id, 8, enemy.x, enemy.y, floorId).map(function (v) {
+ if (criticals.length > 0) {
+ texts.push("\r[#FF6A6A]\\d攻击临界表:\\d\r[]" + JSON.stringify(criticals));
+ }
+ var criticals_spell = core.nextCriticals_spell(enemy.id, 5, enemy.x, enemy.y, floorId).map(function (v) {
return core.formatBigNumber(v[0]) + ":" + core.formatBigNumber(v[1]);
});
while (criticals_spell[0] == '0:0') criticals_spell.shift();
- texts.push("\r[#FF6A6A]\\d法强临界表:\\d\r[]" + JSON.stringify(criticals_spell));
- var criticals_speed = core.nextCriticals_speed(enemy.id, 8, enemy.x, enemy.y, floorId).map(function (v) {
+ if (criticals_spell.length > 0) {
+ texts.push("\r[#FF6A6A]\\d法强临界表:\\d\r[]" + JSON.stringify(criticals_spell));
+ }
+ var criticals_speed = core.nextCriticals_speed(enemy.id, 5, enemy.x, enemy.y, floorId).map(function (v) {
return core.formatBigNumber(v[0]) + ":" + core.formatBigNumber(v[1]);
});
+
while (criticals_speed[0] == '0:0') criticals_speed.shift();
- texts.push("\r[#FF6A6A]\\d速度临界表:\\d\r[]" + JSON.stringify(criticals_speed));
+ if (criticals_speed.length > 0) {
+ texts.push("\r[#FF6A6A]\\d速度临界表:\\d\r[]" + JSON.stringify(criticals_speed));
+ }
}
//攻速临界计算
- core.nextCriticals_speed = function (enemy, number, x, y, floorId) {
+ core.nextCriticals_speed = function (enemy, number, x, y, floorId, config = {}) {
if (typeof enemy == 'string') enemy = core.material.enemys[enemy];
number = number || 1;
- var info = core.getDamageInfo(enemy, null, x, y, floorId);
+ var info = core.getDamageInfo(enemy, config, x, y, floorId);
if (info == null) { // 如果未破防...
return [
['?', '?']
@@ -23286,39 +21876,43 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
[0, 0]
];
}
- return core.enemys._nextSpeedCriticals_useBinarySearch(enemy, info, number, x, y, floorId);
+ return core.enemys._nextSpeedCriticals_useBinarySearch(enemy, info, number, x, y, floorId, config);
}
- enemys.prototype._nextSpeedCriticals_useBinarySearch = function (enemy, info, number, x, y, floorId) {
+ enemys.prototype._nextSpeedCriticals_useBinarySearch = function (enemy, info, number, x, y, floorId, config = {}) {
var mon_hp = info.mon_hp,
- hero_speed = core.status.hero.speed,
+ hero_speed = config.speed ?? core.status.hero.speed,
mon_def = info.mon_def,
- pre = info.damage;
+ damage = info.damage
+ pre = info.mon_turn;
var list = [];
var start_speed = hero_speed;
-
+ var start = core.clone(config)
+ var mid = core.clone(config)
+ var end = core.clone(config)
var calNext = function (currSpeed, maxSpeed) {
- var start = Math.floor(currSpeed),
- end = Math.floor(maxSpeed);
- if (start > end) return null;
+ start.speed = Math.floor(currSpeed)
+ end.speed = Math.floor(maxSpeed);
+ if (start.speed > end.speed) return null;
- while (start < end) {
- var mid = Math.floor((start + end) / 2);
- if (mid - start > end - mid) mid--;
- var nextInfo = core.enemys.getDamageInfo(enemy, { "speed": mid }, x, y, floorId);
+ while (start.speed < end.speed) {
+ mid.speed = Math.floor((start.speed + end.speed) / 2);
+ if (mid.speed - start.speed > end.speed - mid.speed) mid.speed--;
+ var nextInfo = core.enemys.getDamageInfo(enemy, mid, x, y, floorId);
if (nextInfo == null || (typeof nextInfo == 'number')) return null;
- if (pre > nextInfo.damage) end = mid;
- else start = mid + 1;
+ if (pre > nextInfo.mon_turn && damage > nextInfo.damage) end.speed = mid.speed;
+ else start.speed = mid.speed + 1;
}
- var nextInfo = core.enemys.getDamageInfo(enemy, { "speed": start }, x, y, floorId);
- return nextInfo == null || (typeof nextInfo == 'number') || nextInfo.damage >= pre ? null : [start, nextInfo.damage];
+ var nextInfo = core.enemys.getDamageInfo(enemy, start, x, y, floorId);
+ return nextInfo == null || (typeof nextInfo == 'number') || nextInfo.mon_turn >= pre || nextInfo.damage >= damage ? null : [start.speed, nextInfo.damage, nextInfo.mon_turn];
}
var currSpeed = start_speed;
while (true) {
- var next = calNext(currSpeed + 1, Number.MAX_SAFE_INTEGER, pre);
+ var next = calNext(currSpeed + 1, Number.MAX_SAFE_INTEGER, damage, pre);
if (next == null) break;
currSpeed = next[0];
- pre = next[1];
- list.push([currSpeed - hero_speed, info.damage - pre]);
+ damage = next[1]
+ pre = next[2];
+ list.push([currSpeed - hero_speed, info.damage - damage]);
if (pre <= 0 && !core.flags.enableNegativeDamage) break;
if (list.length >= number) break;
}
@@ -23326,11 +21920,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
return list;
}
//法强临界计算
- core.nextCriticals_spell = function (enemy, number, x, y, floorId) {
+ core.nextCriticals_spell = function (enemy, number, x, y, floorId, config = {}) {
if (typeof enemy == 'string') enemy = core.material.enemys[enemy];
number = number || 1;
- var info = core.getDamageInfo(enemy, null, x, y, floorId);
+ var info = core.getDamageInfo(enemy, config, x, y, floorId);
if (info == null) { // 如果未破防...
return [
['?', '?']
@@ -23342,95 +21936,49 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
[0, 0]
];
}
- return core.enemys._nextSpellCriticals_useBinarySearch(enemy, info, number, x, y, floorId);
+ return core.enemys._nextSpellCriticals_useBinarySearch(enemy, info, number, x, y, floorId, config);
}
- enemys.prototype._nextSpellCriticals_useBinarySearch = function (enemy, info, number, x, y, floorId) {
+ enemys.prototype._nextSpellCriticals_useBinarySearch = function (enemy, info, number, x, y, floorId, config = {}) {
var mon_hp = info.mon_hp,
- hero_spell = core.status.hero.spell,
+ hero_spell = config.spell ?? core.status.hero.spell,
mon_def = info.mon_def,
- turn = info.mon_turn,
- pre = info.damage;
+ pre = info.mon_turn,
+ damage = info.damage;
var list = [];
var start_spell = hero_spell;
-
+ var start = core.clone(config)
+ var mid = core.clone(config)
+ var end = core.clone(config)
var calNext = function (currSpell, maxSpell) {
- var start = Math.floor(currSpell),
- end = Math.floor(maxSpell);
- if (start > end) return null;
+ start.spell = Math.floor(currSpell)
+ end.spell = Math.floor(maxSpell);
+ if (start.spell > end.spell) return null;
- while (start < end) {
- var mid = Math.floor((start + end) / 2);
- if (mid - start > end - mid) mid--;
- var nextInfo = core.enemys.getDamageInfo(enemy, { "spell": mid }, x, y, floorId);
+ while (start.spell < end.spell) {
+ mid.spell = Math.floor((start.spell + end.spell) / 2);
+ if (mid.spell - start.spell > end.spell - mid.spell) mid.spell--;
+ var nextInfo = core.enemys.getDamageInfo(enemy, mid, x, y, floorId);
if (nextInfo == null || (typeof nextInfo == 'number')) return null;
- if (turn > nextInfo.mon_turn) end = mid;
- else start = mid + 1;
+ if (pre >= nextInfo.mon_turn & damage > nextInfo.damage) end.spell = mid.spell;
+ else start.spell = mid.spell + 1;
}
- var nextInfo = core.enemys.getDamageInfo(enemy, { "spell": start }, x, y, floorId);
- return nextInfo == null || (typeof nextInfo == 'number') || nextInfo.mon_turn >= turn ? null : [start, nextInfo.damage];
+ var nextInfo = core.enemys.getDamageInfo(enemy, start, x, y, floorId);
+ return nextInfo == null || (typeof nextInfo == 'number') || (nextInfo.mon_turn >= pre || nextInfo.damage >= damage) ? null : [start.spell, nextInfo.damage, nextInfo.mon_turn];
}
var currSpell = start_spell;
while (true) {
- var next = calNext(currSpell + 1, Number.MAX_SAFE_INTEGER, pre, turn);
+ var next = calNext(currSpell + 1, Number.MAX_SAFE_INTEGER, damage, pre);
if (next == null) break;
currSpell = next[0];
- pre = next[1];
- list.push([currSpell - hero_spell, info.damage - pre]);
+ pre = next[2];
+ damage = next[1];
+ list.push([currSpell - hero_spell, info.damage - damag]);
if (pre <= 0 && !core.flags.enableNegativeDamage) break;
if (list.length >= number) break;
}
if (list.length == 0) list.push([0, 0]);
return list;
}
-},
- "手册(临时)": function () {
- // 在此增加新插件
- ui.prototype._drawBook_drawContent = function (index, enemy, top, left) {
- var width = core._PX_ - left; // 9 : 8 : 8 划分三列
- this._drawBook_drawRow1(index, enemy, top, left, width, top + 20);
- this._drawBook_drawRow4(index, enemy, top, left, width, top + 38);
- this._drawBook_drawRow2(index, enemy, top, left, width, top + 56);
- this._drawBook_drawRow3(index, enemy, top, left, width, top + 74);
- this._drawBook_drawRow5(index, enemy, top, left, width, top + 90);
- }
-
- ui.prototype._drawBook_drawRow4 = function (index, enemy, top, left, width, position) {
- // 绘制第一行
- core.setTextAlign('ui', 'left');
- var b13 = this._buildFont(13, true),
- f13 = this._buildFont(13, false);
- var col1 = left,
- col2 = left + width * 9 / 25,
- col3 = left + width * 17 / 25;
- core.fillText('ui', core.getStatusLabel('speed'), col1, position, '#DDDDDD', f13);
- core.fillText('ui', core.formatBigNumber(enemy.speed || 0), col1 + 30, position, null, b13);
- core.fillText('ui', core.getStatusLabel('spell'), col2, position, null, f13);
- core.fillText('ui', core.formatBigNumber(enemy.spell || 0), col2 + 30, position, null, b13);
- core.fillText('ui', core.getStatusLabel('mdef'), col3, position, null, f13);
- core.fillText('ui', core.formatBigNumber(enemy.mdef || 0) + "%", col3 + 30, position, null, b13);
- }
- ui.prototype._drawBook_drawRow5 = function (index, enemy, top, left, width, position) {
- // 绘制第一行
- core.setTextAlign('ui', 'left');
- var b13 = this._buildFont(13, true),
- f13 = this._buildFont(13, false);
- var col1 = left,
- col2 = left + width * 13 / 25;
- core.fillText('ui', '速度临界', col1 - 120, position, '#DDDDDD', f13);
- core.fillText('ui', `[${core.formatBigNumber(enemy.criticalSpeed?.[0] || 0)},${core.formatBigNumber(enemy.criticalSpeed?.[1] || 0)}]`, col1 - 60, position, null, b13);
-
- core.fillText('ui', "勇士出手次数", col1, position, '#DDDDDD', f13);
- core.fillText('ui', core.getDamageInfo(enemy, null) ? core.getDamageInfo(enemy, null).hero_turn : '???', col1 + 80, position, null, b13);
- core.fillText('ui', "怪物出手次数", col2, position, null, f13);
- core.fillText('ui', core.getDamageInfo(enemy, null) ? core.getDamageInfo(enemy, null).mon_turn : '???', col2 + 80, position, null, b13);
-
- }
- ui.prototype._drawBook_pageinfo = function () {
- var per_page = 4;
- var padding_top = 12; // 距离顶端像素
- var per_height = (core._PY_ - 32 - padding_top) / per_page;
- return { per_page: per_page, padding_top: padding_top, per_height: per_height };
- }
},
"新怪物手册": function () {
// 在此增加新插件
@@ -23439,10 +21987,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
book.style.zIndex = 400;
book.style.display = "none";
book.id = "book";
- main.dom.gameGroup.insertAdjacentElement("afterend", book);
- book.style.top = "50%";
- book.style.left = "50%";
- book.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", book)
const ctx = book.getContext("2d");
main.dom.book = book
@@ -23456,52 +22001,3548 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let x, y;
if (core.domStyle.isVertical) { //对竖屏进行坐标转换
- x = py * 3;
- y = 1248 - px * 3;
+ x = py;
+ y = 416 - px;
} else {
- x = px * 3;
- y = py * 3;
+ x = px;
+ y = py;
}
- bookclick(x, y)
+ core.book.bookclick(x, y)
} catch (ee) {
main.log(ee);
}
}
- function bookclick(x, y) { //点击画布(x,y)触发的效果
- const makeBox = ([x, y], [w, h]) => { //创建点击检测区域
- return [
- [x, y],
- [x + w, y + h],
- ];
- };
- const pos = [x, y]; //创建点击坐标pos
- const inRect = ([x, y], [ //检测点击坐标是否在检测区域中
- [sx, sy],
- [dx, dy]
- ]) => {
- return sx <= x && x <= dx && sy <= y && y <= dy;
- };
- /**
- * 使用范例
- *const backbox = makeBox([15, 35], [210, 90]);
- *if(inRect(pos,backbox)){}
- */
- }
- this.drawBook = function (floorId = core.status.floorId) {
- if (core.domStyle.isVertical) { //对竖屏进行绘制坐标变换,只需要考虑横屏绘制,竖屏将自适应转置
- ctx.canvas.width = 1248;
- ctx.canvas.height = 2028;
- ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
- ctx.rotate(Math.PI / 2); //旋转90度
- } else {
- ctx.canvas.width = 2028;
- ctx.canvas.height = 1248;
- }
- //在这里写绘制内容,只写横屏就行
- ctx.restore(); //恢复变换前的坐标,否则将连续转置
+
+ const { Animation, linear, sleep, trigo } = core.plugin.animate
+ class BookInfo {
+ constructor() {
+ this.width = 300
+ this.height = 400
+ this.enemys = []
+ this.page = 0
+ this.floorId = ""
+ this.left = document.createElement("canvas")
+ this.right = document.createElement("canvas")
+ this.tempLeft = document.createElement("canvas")
+ this.tempRight = document.createElement("canvas")
+
+ this.left = this.left.getContext("2d")
+ this.right = this.right.getContext("2d")
+ this.tempLeft = this.tempLeft.getContext("2d")
+ this.tempRight = this.tempRight.getContext("2d")
+ core.maps._setHDCanvasSize(this.left, 300, 400)
+ core.maps._setHDCanvasSize(this.right, 300, 400)
+ core.maps._setHDCanvasSize(this.tempLeft, 300, 400)
+ core.maps._setHDCanvasSize(this.tempRight, 300, 400)
+ this.animateObjs = {}
+ this.atk = 0
+ this.speed = 0
+ this.spell = 0
+ this.def = 0
+ this.atkStep = 1
+ this.speedStep = 1
+ this.spellStep = 1
+ this.defStep = 1
+
+ }
+ getCurrentEnemys(floorId) {
+ this.floorId = floorId
+ this.enemys = core.enemys.getCurrentEnemys(floorId)
+ }
+ drawEmpty() {
+ core.clearMap(this.left)
+ core.clearMap(this.right)
+ core.setTextAlign(this.left, 'center');
+ core.setTextAlign(this.right, 'center');
+ core.fillText(this.left, "无恶意目标", 150, 214, '#644324', core.ui._buildFont(34, true));
+ core.fillText(this.right, "合上书本", 254, 380, '#644324', core.ui._buildFont(16, true));
+ }
+ drawBoxAnimate(ctx, page, x, y) {
+ const blockInfo = core.getBlockInfo(this.enemys[page].id)
+ if (blockInfo.bigImage) {
+ core.status.boxAnimateObjs.push({
+ bigImage: blockInfo.bigImage,
+ face: blockInfo.face,
+ centerX: x ?? 150,
+ centerY: y ?? 50,
+ max_width: 60,
+ ctx: ctx,
+ nobackground: true
+ });
+ } else if (blockInfo.height >= 48) {
+ var originEnemy = core.material.enemys[this.enemys[page]] || {};
+ if (originEnemy.is32x32 == null) {
+ originEnemy.is32x32 = core.ui._drawBook_is32x32(blockInfo);
+ }
+ if (originEnemy.is32x32) {
+ core.status.boxAnimateObjs.push({
+ 'bgx': x ? x - 16 : 134,
+ 'bgy': y ? y - 16 : 34,
+ 'bgWidth': 32,
+ 'bgHeight': 32,
+ 'x': x ? x - 16 : 134,
+ 'y': y ? y - 16 : 34,
+ 'height': 32,
+ 'animate': blockInfo.animate,
+ 'image': blockInfo.image,
+ 'pos': blockInfo.posY * blockInfo.height + blockInfo.height - 32,
+ ctx: ctx,
+ nobackground: true
+ });
+ } else {
+ var drawWidth = 32 * 32 / blockInfo.height;
+ core.status.boxAnimateObjs.push({
+ 'bgx': x ? x - 16 : 134,
+ 'bgy': y ? y - 16 : 34,
+ 'bgWidth': 32,
+ 'bgHeight': 48,
+ 'x': x ? x - 16 : 134,
+ 'y': y ? y - 16 : 34,
+ 'dw': 32,
+ 'dh': 48,
+ 'height': blockInfo.height,
+ 'animate': blockInfo.animate,
+ 'image': blockInfo.image,
+ 'pos': blockInfo.posY * blockInfo.height,
+ ctx: ctx,
+ nobackground: true
+ });
+ }
+ } else {
+ core.status.boxAnimateObjs.push({
+ 'bgx': x ? x - 16 : 134,
+ 'bgy': y ? y - 16 : 34,
+ 'bgWidth': 32,
+ 'bgHeight': 32,
+ 'x': x ? x - 16 : 134,
+ 'y': y ? y - 16 : 34,
+ 'height': 32,
+ 'animate': blockInfo.animate,
+ 'image': blockInfo.image,
+ 'pos': blockInfo.posY * blockInfo.height,
+ ctx: ctx,
+ nobackground: true
+ });
+ }
+
+
+ }
+ drawTempLeft(page) {
+ core.clearMap(this.tempLeft)
+ const enemy = this.enemys[page]
+ core.setTextAlign(this.tempLeft, 'center')
+ core.fillText(this.tempLeft, enemy.name, 150, 120, "#644324", core.ui._buildFont(20, true))
+ core.fillText(this.tempLeft, "基础属性", 150, 150, "#644324", core.ui._buildFont(14, true))
+ core.setTextAlign(this.tempLeft, 'left')
+ core.fillText(this.tempLeft, "生命 " + enemy.hp, 30, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempLeft, "攻击 " + enemy.atk, 120, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempLeft, "防御 " + enemy.def, 210, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempLeft, "法强 " + enemy.spell, 30, 190, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempLeft, "法抗 " + enemy.mdef + '%', 120, 190, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempLeft, "速度 " + enemy.speed, 210, 190, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempLeft, "金币 " + enemy.money, 30, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempLeft, "经验 " + enemy.exp, 120, 210, "#644324", core.ui._buildFont(12, true))
+ core.setTextAlign(this.tempLeft, 'center')
+ core.fillText(this.tempLeft, "特殊属性", 150, 230, "#644324", core.ui._buildFont(14, true))
+ const specials = core.getSpecials()
+ core.enemys._calSpecialContent(enemy.id)
+ const hints = [];
+ for (let i = 0; i < specials.length; i++) {
+ if (core.hasSpecial(enemy, specials[i][0]))
+ hints.push(core.enemys._calSpecialContent(enemy.id, specials[i][1]) +
+ ":" + core.enemys._calSpecialContent(enemy.id, specials[i][2]));
+ }
+ if (hints.length == 0) hints.push("该怪物无特殊属性。");
+ core.drawTextContent(this.tempLeft, hints.join('\n'), {
+ left: 30,
+ top: 240,
+ maxWidth: 220,
+ fontSize: 14,
+ lineHeight: 20,
+ color: "#644324"
+ });
+ if (this.enemys.length <= 8) {
+ for (let i = 0; i < this.enemys.length; i++) {
+ this.drawBoxAnimate(this.tempLeft, i, 167 - (this.enemys.length / 2 - i) * 34, 370)
+ }
+ core.strokeRect(this.tempLeft, 150 - (this.enemys.length / 2 - page) * 34 + 1, 354, 32, 32, "#FFFF00", 2)
+ } else {
+ this.tempLeft.beginPath()
+ this.tempLeft.moveTo(63, 354)
+ this.tempLeft.lineTo(29, 370)
+ this.tempLeft.lineTo(63, 386)
+ this.tempLeft.closePath()
+ this.tempLeft.fillStyle = page < 3 ? "#999999" : "#644324"
+ this.tempLeft.fill()
+ this.tempLeft.beginPath()
+ this.tempLeft.moveTo(237, 353)
+ this.tempLeft.lineTo(271, 370)
+ this.tempLeft.lineTo(237, 386)
+ this.tempLeft.closePath()
+ this.tempLeft.fillStyle = page > this.enemys.length - 4 ? "#644324" : "#000000"
+ this.tempLeft.fill()
+ this.drawBoxAnimate(this.tempLeft, core.clamp(page - 2, 0, this.enemys.length - 5), 80, 370)
+ this.drawBoxAnimate(this.tempLeft, core.clamp(page - 1, 1, this.enemys.length - 4), 114, 370)
+ this.drawBoxAnimate(this.tempLeft, core.clamp(page, 2, this.enemys.length - 3), 148, 370)
+ this.drawBoxAnimate(this.tempLeft, core.clamp(page + 1, 3, this.enemys.length - 2), 182, 370)
+ this.drawBoxAnimate(this.tempLeft, core.clamp(page + 2, 4, this.enemys.length - 1), 216, 370)
+ if (page < 2) core.strokeRect(this.tempLeft, 64 + 34 * page, 354, 32, 32, "#FFFF00", 2)
+ else if (page > this.enemys.length - 3) core.strokeRect(this.tempLeft, 234 - (this.enemys.length - page) * 34, 354, 32, 32, "#FFFF00", 2)
+ else core.strokeRect(this.tempLeft, 132, 354, 32, 32, "#FFFF00", 2)
+ }
+ this.drawBoxAnimate(bookInfo.tempLeft, page)
+ }
+ drawTempRight(page) {
+ core.clearMap(this.tempRight)
+ const enemy = this.enemys[page]
+ core.maps.drawThumbnail(this.floorId, null, { ctx: this.tempRight, size: 0.4, x: 10, y: 220, noEnabled: true })
+ enemy.locs.forEach(v => {
+ this.tempRight.beginPath()
+ this.tempRight.moveTo(10 + (32 * v[0] + 16) * 0.4, 220 + 32 * v[1] * 0.4)
+ this.tempRight.lineTo(10 + (32 * v[0] + 24) * 0.4, 220 + 32 * v[1] * 0.4 - 16 * 0.4)
+ this.tempRight.lineTo(10 + (32 * v[0] + 8) * 0.4, 220 + 32 * v[1] * 0.4 - 16 * 0.4)
+ this.tempRight.closePath()
+ this.tempRight.fillStyle = "#DD0000"
+ this.tempRight.fill()
+ })
+ core.setTextAlign(this.tempRight, 'left')
+ let getDamageInfo = core.getDamageInfo(enemy, null)
+ core.fillText(this.tempRight, "出手次数 " + (getDamageInfo ? getDamageInfo.hero_turn : '???'), 30, 50, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "受击次数 " + (getDamageInfo ? getDamageInfo.mon_turn : '???'), 130, 50, "#644324", core.ui._buildFont(12, true))
+ let color = "#FFFF00",
+ damage = enemy.damage
+
+ if (damage == '???' || damage == null) {
+ damage = '杂鱼喵❤~';
+ color = '#FF2222';
+ } else {
+ if (damage >= core.status.hero.hp) color = '#FF2222';
+ else if (damage >= core.status.hero.hp * 2 / 3) color = '#FF9933';
+ else if (damage <= 0) color = '#11FF11';
+ damage = core.formatBigNumber(damage);
+ }
+ if (enemy.notBomb) damage += "[b]";
+ core.setTextAlign(this.tempRight, 'center');
+ core.fillText(this.tempRight, damage, 240, 50, color, core.ui._buildFont(12, true))
+ core.setTextAlign(this.tempRight, 'left');
+ core.fillText(this.tempRight, "攻击临界 " + enemy.criticalAtk[0], 30, 70, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "速度临界 " + enemy.criticalSpeed[0], 120, 70, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, '法强临界 ' + enemy.criticalSpell[0], 210, 70, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "减伤 " + enemy.criticalAtk[1], 30, 90, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "减伤 " + enemy.criticalSpeed[1], 120, 90, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, '减伤 ' + enemy.criticalSpell[1], 210, 90, "#644324", core.ui._buildFont(12, true))
+
+
+ if (this.atk > 0 || this.def > 0 || this.speed > 0 || this.spell > 0) {
+ core.setTextAlign(this.tempRight, 'center');
+ core.fillText(this.tempRight, "增幅战斗情况", 150, 110, "#644324", core.ui._buildFont(16, true))
+ core.setTextAlign(this.tempRight, 'left');
+ const config = { atk: core.getRealStatus("atk") + this.atk, def: core.getRealStatus("def") + this.def, spell: core.getRealStatus("spell") + this.spell, speed: core.getRealStatus("speed") + this.speed }
+ getDamageInfo = core.getDamageInfo(enemy, config)
+ core.fillText(this.tempRight, "出手次数 " + (getDamageInfo ? getDamageInfo.hero_turn : '???'), 30, 130, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "受击次数 " + (getDamageInfo ? getDamageInfo.mon_turn : '???'), 130, 130, "#644324", core.ui._buildFont(12, true))
+ color = "#FFFF00"
+ damage = getDamageInfo?.damage
+ if (damage == '???' || !getDamageInfo) {
+ damage = '杂鱼喵❤~';
+ color = '#FF2222';
+ } else {
+ if (damage >= core.status.hero.hp) color = '#FF2222';
+ else if (damage >= core.status.hero.hp * 2 / 3) color = '#FF9933';
+ else if (damage <= 0) color = '#11FF11';
+ damage = core.formatBigNumber(damage);
+ }
+ if (enemy.notBomb) damage += "[b]";
+ core.setTextAlign(this.tempRight, 'center');
+ core.fillText(this.tempRight, damage, 240, 130, color, core.ui._buildFont(12, true))
+ core.setTextAlign(this.tempRight, 'left');
+ let atk = core.nextCriticals(enemy, null, null, null, null, config)
+ let speed = core.nextCriticals_speed(enemy, null, null, null, null, config)
+ let spell = core.nextCriticals_spell(enemy, null, null, null, null, config)
+ core.fillText(this.tempRight, "攻击临界 " + atk[0][0], 30, 150, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "速度临界 " + speed[0][0], 120, 150, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, '法强临界 ' + spell[0][0], 210, 150, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "减伤 " + atk[0][1], 30, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "减伤 " + speed[0][1], 120, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, '减伤 ' + spell[0][1], 210, 170, "#644324", core.ui._buildFont(12, true))
+ } else {
+ core.setTextAlign(this.tempRight, 'center');
+ core.fillText(this.tempRight, "临界表", 150, 110, "#644324", core.ui._buildFont(16, true))
+ let texts = []
+ core.ui._drawBookDetail_turnAndCriticals(enemy, this.floorId, texts)
+ core.drawTextContent(this.tempRight, texts.join('\n'), {
+ left: 30,
+ top: 115,
+ maxWidth: 240,
+ fontSize: 10,
+ lineHeight: 12,
+ color: "#644324"
+ });
+ }
+ core.setTextAlign(this.tempRight, 'left')
+ core.fillText(this.tempRight, "攻 " + core.formatBigNumber(this.atk), 30, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "防 " + core.formatBigNumber(this.def), 90, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "法 " + core.formatBigNumber(this.spell), 150, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "速 " + core.formatBigNumber(this.speed), 210, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "攻", 180, 260, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "防", 180, 290, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "法", 180, 320, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "速", 180, 350, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, "-", 200, 262, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "-", 200, 292, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "-", 200, 322, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "-", 200, 352, "#644324", core.ui._buildFont(24, true))
+ core.setTextAlign(this.tempRight, 'center');
+ core.fillText(this.tempRight, core.formatBigNumber(this.atkStep), 230, 260, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, core.formatBigNumber(this.defStep), 230, 290, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, core.formatBigNumber(this.spellStep), 230, 320, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.tempRight, core.formatBigNumber(this.speedStep), 230, 350, "#644324", core.ui._buildFont(12, true))
+ core.setTextAlign(this.tempRight, 'left');
+
+ core.fillText(this.tempRight, "+", 250, 263, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "+", 250, 293, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "+", 250, 323, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "+", 250, 353, "#644324", core.ui._buildFont(24, true))
+
+ core.fillText(this.tempRight, "↑", 265, 265, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "↑", 265, 295, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "↑", 265, 325, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "↑", 265, 355, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.tempRight, "清零", 180, 380, '#644324', core.ui._buildFont(16, true));
+ core.setTextAlign(this.tempRight, 'center');
+ core.fillText(this.tempRight, "当前战斗情况", 150, 30, "#644324", core.ui._buildFont(16, true))
+ core.fillText(this.tempRight, "模拟属性提升", 150, 190, "#644324", core.ui._buildFont(16, true))
+ core.fillText(this.tempRight, "模拟属性调整", 230, 233, "#644324", core.ui._buildFont(16, true))
+ core.fillText(this.tempRight, "合上书本", 254, 380, '#644324', core.ui._buildFont(16, true));
+ }
+ drawLeft() {
+ core.clearMap(this.left)
+ const enemy = this.enemys[this.page]
+ core.setTextAlign(this.left, 'center')
+ core.fillText(this.left, enemy.name, 150, 120, "#644324", core.ui._buildFont(20, true))
+ core.fillText(this.left, "基础属性", 150, 150, "#644324", core.ui._buildFont(14, true))
+ core.setTextAlign(this.left, 'left')
+ core.fillText(this.left, "生命 " + enemy.hp, 30, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.left, "攻击 " + enemy.atk, 120, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.left, "防御 " + enemy.def, 210, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.left, "法强 " + enemy.spell, 30, 190, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.left, "法抗 " + enemy.mdef + '%', 120, 190, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.left, "速度 " + enemy.speed, 210, 190, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.left, "金币 " + enemy.money, 30, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.left, "经验 " + enemy.exp, 120, 210, "#644324", core.ui._buildFont(12, true))
+ core.setTextAlign(this.left, 'center')
+ core.fillText(this.left, "特殊属性", 150, 230, "#644324", core.ui._buildFont(14, true))
+ const specials = core.getSpecials()
+ core.enemys._calSpecialContent(enemy.id)
+ const hints = [];
+ for (let i = 0; i < specials.length; i++) {
+ if (core.hasSpecial(enemy, specials[i][0]))
+ hints.push(core.enemys._calSpecialContent(enemy.id, specials[i][1]) +
+ ":" + core.enemys._calSpecialContent(enemy.id, specials[i][2]));
+ }
+ if (hints.length == 0) hints.push("该怪物无特殊属性。");
+ core.drawTextContent(this.left, hints.join('\n'), {
+ left: 30,
+ top: 240,
+ maxWidth: 240,
+ fontSize: 12,
+ lineHeight: 16,
+ color: "#644324"
+ });
+ if (this.enemys.length <= 8) {
+ for (let i = 0; i < this.enemys.length; i++) {
+ this.drawBoxAnimate(this.left, i, 167 - (this.enemys.length / 2 - i) * 34, 370)
+ }
+ core.strokeRect(this.left, 150 - (this.enemys.length / 2 - this.page) * 34 + 1, 354, 32, 32, "#FFFF00", 2)
+ } else {
+ this.left.beginPath()
+ this.left.moveTo(63, 354)
+ this.left.lineTo(29, 370)
+ this.left.lineTo(63, 386)
+ this.left.closePath()
+ this.left.fillStyle = this.page < 3 ? "#999999" : "#644324"
+ this.left.fill()
+ this.left.beginPath()
+ this.left.moveTo(237, 354)
+ this.left.lineTo(271, 370)
+ this.left.lineTo(237, 386)
+ this.left.closePath()
+ this.left.fillStyle = this.page > this.enemys.length - 4 ? "#999999" : "#644324"
+ this.left.fill()
+ this.drawBoxAnimate(this.left, core.clamp(this.page - 2, 0, this.enemys.length - 5), 80, 370)
+ this.drawBoxAnimate(this.left, core.clamp(this.page - 1, 1, this.enemys.length - 4), 114, 370)
+ this.drawBoxAnimate(this.left, core.clamp(this.page, 2, this.enemys.length - 3), 148, 370)
+ this.drawBoxAnimate(this.left, core.clamp(this.page + 1, 3, this.enemys.length - 2), 182, 370)
+ this.drawBoxAnimate(this.left, core.clamp(this.page + 2, 4, this.enemys.length - 1), 216, 370)
+ if (this.page < 2) core.strokeRect(this.left, 64 + 34 * this.page, 354, 32, 32, "#FFFF00", 2)
+ else if (this.page > this.enemys.length - 3) core.strokeRect(this.left, 234 - (this.enemys.length - this.page) * 34, 354, 32, 32, "#FFFF00", 2)
+ else core.strokeRect(this.left, 132, 354, 32, 32, "#FFFF00", 2)
+ }
+ this.drawBoxAnimate(this.left, this.page)
+
+ }
+ drawRight() {
+ core.clearMap(this.right)
+ const enemy = this.enemys[this.page]
+ core.maps.drawThumbnail(this.floorId, null, { ctx: this.right, size: 0.4, x: 10, y: 220, noEnabled: true })
+ enemy.locs.forEach(v => {
+ this.right.beginPath()
+ this.right.moveTo(10 + (32 * v[0] + 16) * 0.4, 220 + 32 * v[1] * 0.4)
+ this.right.lineTo(10 + (32 * v[0] + 24) * 0.4, 220 + 32 * v[1] * 0.4 - 16 * 0.4)
+ this.right.lineTo(10 + (32 * v[0] + 8) * 0.4, 220 + 32 * v[1] * 0.4 - 16 * 0.4)
+ this.right.closePath()
+ this.right.fillStyle = "#DD0000"
+ this.right.fill()
+ })
+ core.setTextAlign(this.right, 'left')
+ let getDamageInfo = core.getDamageInfo(enemy, null)
+ core.fillText(this.right, "出手次数 " + (getDamageInfo ? getDamageInfo.hero_turn : '???'), 30, 50, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "受击次数 " + (getDamageInfo ? getDamageInfo.mon_turn : '???'), 130, 50, "#644324", core.ui._buildFont(12, true))
+ let color = "#FFFF00",
+ damage = enemy.damage
+ if (damage == '???' || damage == null) {
+ damage = '杂鱼喵❤~';
+ color = '#FF2222';
+ } else {
+ if (damage >= core.status.hero.hp) color = '#FF2222';
+ else if (damage >= core.status.hero.hp * 2 / 3) color = '#FF9933';
+ else if (damage <= 0) color = '#11FF11';
+ damage = core.formatBigNumber(damage);
+ }
+ if (enemy.notBomb) damage += "[b]";
+ core.setTextAlign(this.left, 'center')
+ core.fillText(this.right, damage, 240, 50, color, core.ui._buildFont(12, true))
+ core.setTextAlign(this.left, 'left')
+ core.fillText(this.right, "攻击临界 " + enemy.criticalAtk[0], 30, 70, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "速度临界 " + enemy.criticalSpeed[0], 120, 70, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, '法强临界 ' + enemy.criticalSpell[0], 210, 70, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "减伤 " + enemy.criticalAtk[1], 30, 90, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "减伤 " + enemy.criticalSpeed[1], 120, 90, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, '减伤 ' + enemy.criticalSpell[1], 210, 90, "#644324", core.ui._buildFont(12, true))
+
+
+ if (this.atk > 0 || this.def > 0 || this.speed > 0 || this.spell > 0) {
+ core.setTextAlign(this.right, 'center');
+ core.fillText(this.right, "增幅战斗情况", 150, 110, "#644324", core.ui._buildFont(16, true))
+ core.setTextAlign(this.right, 'left');
+ const config = { atk: core.getRealStatus("atk") + this.atk, def: core.getRealStatus("def") + this.def, spell: core.getRealStatus("spell") + this.spell, speed: core.getRealStatus("speed") + this.speed }
+ getDamageInfo = core.getDamageInfo(enemy, config)
+ core.fillText(this.right, "出手次数 " + (getDamageInfo ? getDamageInfo.hero_turn : '???'), 30, 130, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "受击次数 " + (getDamageInfo ? getDamageInfo.mon_turn : '???'), 130, 130, "#644324", core.ui._buildFont(12, true))
+ color = "#FFFF00"
+ damage = getDamageInfo?.damage
+ if (damage == '???' || !getDamageInfo) {
+ damage = '杂鱼喵❤~';
+ color = '#FF2222';
+ } else {
+ if (damage >= core.status.hero.hp) color = '#FF2222';
+ else if (damage >= core.status.hero.hp * 2 / 3) color = '#FF9933';
+ else if (damage <= 0) color = '#11FF11';
+ damage = core.formatBigNumber(damage);
+ }
+ if (enemy.notBomb) damage += "[b]";
+ core.setTextAlign(this.left, 'center')
+ core.fillText(this.right, damage, 240, 130, color, core.ui._buildFont(12, true))
+ core.setTextAlign(this.left, 'left')
+ let atk = core.nextCriticals(enemy, null, null, null, null, config)
+ let speed = core.nextCriticals_speed(enemy, null, null, null, null, config)
+ let spell = core.nextCriticals_spell(enemy, null, null, null, null, config)
+ core.fillText(this.right, "攻击临界 " + atk[0][0], 30, 150, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "速度临界 " + speed[0][0], 120, 150, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, '法强临界 ' + spell[0][0], 210, 150, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "减伤 " + atk[0][1], 30, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "减伤 " + speed[0][1], 120, 170, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, '减伤 ' + spell[0][1], 210, 170, "#644324", core.ui._buildFont(12, true))
+ } else {
+ core.setTextAlign(this.right, 'center');
+ core.fillText(this.right, "临界表", 150, 110, "#644324", core.ui._buildFont(16, true))
+ let texts = []
+ core.ui._drawBookDetail_turnAndCriticals(enemy, this.floorId, texts)
+ core.drawTextContent(this.right, texts.join('\n'), {
+ left: 30,
+ top: 115,
+ maxWidth: 240,
+ fontSize: 10,
+ lineHeight: 12,
+ color: "#644324"
+ });
+ }
+ core.setTextAlign(this.right, 'left')
+ core.fillText(this.right, "攻 " + core.formatBigNumber(this.atk), 30, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "防 " + core.formatBigNumber(this.def), 90, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "法 " + core.formatBigNumber(this.spell), 150, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "速 " + core.formatBigNumber(this.speed), 210, 210, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "攻", 180, 260, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "防", 180, 290, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "法", 180, 320, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "速", 180, 350, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, "-", 200, 262, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "-", 200, 292, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "-", 200, 322, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "-", 200, 352, "#644324", core.ui._buildFont(24, true))
+ core.setTextAlign(this.right, 'center');
+ core.fillText(this.right, core.formatBigNumber(this.atkStep), 230, 260, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, core.formatBigNumber(this.defStep), 230, 290, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, core.formatBigNumber(this.spellStep), 230, 320, "#644324", core.ui._buildFont(12, true))
+ core.fillText(this.right, core.formatBigNumber(this.speedStep), 230, 350, "#644324", core.ui._buildFont(12, true))
+ core.setTextAlign(this.right, 'left');
+
+ core.fillText(this.right, "+", 250, 263, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "+", 250, 293, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "+", 250, 323, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "+", 250, 353, "#644324", core.ui._buildFont(24, true))
+
+ core.fillText(this.right, "↑", 265, 265, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "↑", 265, 295, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "↑", 265, 325, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "↑", 265, 355, "#644324", core.ui._buildFont(24, true))
+ core.fillText(this.right, "清零", 180, 380, '#644324', core.ui._buildFont(16, true));
+ core.setTextAlign(this.right, 'center');
+ core.fillText(this.right, "当前战斗情况", 150, 30, "#644324", core.ui._buildFont(16, true))
+ core.fillText(this.right, "模拟属性提升", 150, 190, "#644324", core.ui._buildFont(16, true))
+ core.fillText(this.right, "模拟属性调整", 230, 233, "#644324", core.ui._buildFont(16, true))
+ core.fillText(this.right, "合上书本", 254, 380, '#644324', core.ui._buildFont(16, true));
+
+ }
+
+ clear() {
+ core.clearUI()
+ core.clearMap(this.left)
+ core.clearMap(this.right)
+ core.clearMap(this.tempLeft)
+ core.clearMap(this.tempRight)
+ }
+ clearEx() {
+ this.atk = 0
+ this.speed = 0
+ this.spell = 0
+ this.def = 0
+ }
+ init(floorId) {
+ this.page = 0
+ this.getCurrentEnemys(floorId)
+ if (this.enemys.length == 0) {
+ return this.drawEmpty();
+ }
+ this.drawLeft()
+ this.drawRight()
+
+
+ }
+ }
+ const bookInfo = new BookInfo()
+ core.bookInfo = bookInfo
+ class Book {
+ constructor() {
+ this.width = 300
+ this.height = 400
+ this.pagemax = 1
+ this.page = 0
+ this.paperpages = []
+ this.ani = new Animation()
+ this.time = 1000
+ }
+ bookclick(x, y) { //点击画布(x,y)触发的效果
+ const makeBox = ([x, y], [w, h]) => { //创建点击检测区域
+ return [
+ [x, y],
+ [x + w, y + h],
+ ];
+ };
+ const pos = [x, y]; //创建点击坐标pos
+ const inRect = ([x, y], [ //检测点击坐标是否在检测区域中
+ [sx, sy],
+ [dx, dy]
+ ]) => {
+ return sx <= x && x <= dx && sy <= y && y <= dy;
+ };
+ const leftbox = makeBox([(676 - this.width * 2) / 2, (416 - this.height) / 2], [this.width, this.height])
+ const rightbox = makeBox([338, (416 - this.height) / 2], [this.width, this.height])
+ const exitbox = makeBox([555, 365], [70, 35])
+ const atkupbox = makeBox([581, 251], [25, 25])
+ const atkdownbox = makeBox([531, 251], [25, 25])
+ const atkchangebox = makeBox([606, 251], [25, 25])
+ const defupbox = makeBox([581, 281], [25, 25])
+ const defdownbox = makeBox([531, 281], [25, 25])
+ const defchangebox = makeBox([606, 281], [25, 25])
+ const spellupbox = makeBox([581, 311], [25, 25])
+ const spelldownbox = makeBox([531, 311], [25, 25])
+ const spellchangebox = makeBox([606, 311], [25, 25])
+ const speedupbox = makeBox([581, 341], [25, 25])
+ const speeddownbox = makeBox([531, 341], [25, 25])
+ const speedchangebox = makeBox([606, 341], [25, 25])
+ const zerochangebox = makeBox([515, 365], [35, 35])
+ if (this.isAnimate) return
+ let length = bookInfo.enemys.length
+ if (length > 0) {
+ if (length > 8 && inRect(pos, makeBox([66, 361], [238, 34]))) {
+ let num = core.clamp(Math.floor((x - 66) / 34), 0, 6)
+
+ if (num === 0) this.turnleft(this.page - 1)
+
+ else if (num === 1) {
+ const clamp = core.clamp(bookInfo.page - 2, 0, length - 5)
+
+ if (clamp < this.page - 1) this.turnleft(clamp + 1)
+ } else if (num === 2) {
+ const clamp = core.clamp(bookInfo.page - 1, 1, length - 4)
+
+ if (clamp < this.page - 1) this.turnleft(clamp + 1)
+ else if (clamp > this.page - 1) this.turnright(clamp + 1)
+ } else if (num === 3) {
+ const clamp = core.clamp(bookInfo.page, 2, length - 3)
+
+ if (clamp < this.page - 1) this.turnleft(clamp + 1)
+ else if (clamp > this.page - 1) this.turnright(clamp + 1)
+ } else if (num === 4) {
+ const clamp = core.clamp(bookInfo.page + 1, 3, length - 2)
+
+ if (clamp < this.page - 1) this.turnleft(clamp + 1)
+ else if (clamp > this.page - 1) this.turnright(clamp + 1)
+ } else if (num === 5) {
+ const clamp = core.clamp(bookInfo.page + 2, 4, length - 1)
+
+ if (clamp < this.page - 1) this.turnleft(clamp + 1)
+ else if (clamp > this.page - 1) this.turnright(clamp + 1)
+ } else if (num === 6) this.turnright(this.page + 1)
+ } else if (length <= 8 && inRect(pos, makeBox([187 - length * 17, 361], [length * 34, 34]))) {
+ let num = core.clamp(Math.floor((x - 187 + length * 17) / 34), 0, length - 1)
+ if (num > this.page - 1) this.turnright(num + 1)
+ else if (num < this.page - 1) this.turnleft(num + 1)
+ } else if (inRect(pos, atkupbox)) {
+ bookInfo.atk += bookInfo.atkStep
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, atkdownbox)) {
+ bookInfo.atk -= bookInfo.atkStep
+ if (bookInfo.atk < 0) bookInfo.atk = 0
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, atkchangebox)) {
+ core.myprompt("请输入攻击调整步距(只可输入数字)", null, (value) => {
+ if (value && !Number.isNaN(Number(value)) && Number(value) >= 1) {
+ bookInfo.atkStep = Number(value)
+ bookInfo.drawRight()
+ this.update()
+ } else if (value) {
+ alert("无效的输入!");
+ } else if (value === "") {
+
+ }
+ });
+ } else if (inRect(pos, defupbox)) {
+ bookInfo.def += bookInfo.defStep
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, defdownbox)) {
+ bookInfo.def -= bookInfo.defStep
+ if (bookInfo.def < 0) bookInfo.def = 0
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, defchangebox)) {
+ core.myprompt("请输入防御调整步距(只可输入数字)", null, (value) => {
+ if (value && !Number.isNaN(Number(value)) && Number(value) >= 1) {
+ bookInfo.defStep = Number(value)
+ bookInfo.drawRight()
+ this.update()
+ } else if (value) {
+ alert("无效的输入!");
+ } else if (value === "") {
+
+ }
+ });
+ } else if (inRect(pos, spellupbox)) {
+ bookInfo.spell += bookInfo.spellStep
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, spelldownbox)) {
+ bookInfo.spell -= bookInfo.spellStep
+ if (bookInfo.spell < 0) bookInfo.spell = 0
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, spellchangebox)) {
+ core.myprompt("请输入法强调整步距(只可输入数字)", null, (value) => {
+ if (value && !Number.isNaN(Number(value)) && Number(value) >= 1) {
+ bookInfo.spellStep = Number(value)
+ bookInfo.drawRight()
+ this.update()
+ } else if (value) {
+ alert("无效的输入!");
+ } else if (value === "") {
+
+ }
+ });
+ } else if (inRect(pos, speedupbox)) {
+ bookInfo.speed += bookInfo.speedStep
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, speeddownbox)) {
+ bookInfo.speed -= bookInfo.speedStep
+ if (bookInfo.speed < 0) bookInfo.speed = 0
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, speedchangebox)) {
+ core.myprompt("请输入速度调整步距(只可输入数字)", null, (value) => {
+ if (value && !Number.isNaN(Number(value)) && Number(value) >= 1) {
+ bookInfo.speedStep = Number(value)
+ bookInfo.drawRight()
+ this.update()
+ } else if (value) {
+ alert("无效的输入!");
+ } else if (value === "") {
+
+ }
+ });
+ } else if (inRect(pos, zerochangebox)) {
+ bookInfo.clearEx()
+ bookInfo.drawRight()
+ this.update()
+ } else if (inRect(pos, exitbox)) {
+ core.playSound('取消');
+ core.book.close()
+ if (core.events.recoverEvents(core.status.event.interval)) {
+ return;
+ } else if (core.status.event.ui != null) {
+ core.status.boxAnimateObjs = [];
+ core.ui._drawViewMaps(core.status.event.ui);
+ } else core.ui.closePanel();
+
+ return;
+ } else if (inRect(pos, leftbox)) {
+
+ this.turnleft(this.page - 1)
+ } else if (inRect(pos, rightbox)) {
+
+ this.turnright(this.page + 1)
+ }
+ return
+ }
+ if (inRect(pos, exitbox)) {
+ core.playSound('取消');
+ core.book.close()
+ if (core.events.recoverEvents(core.status.event.interval)) {
+ return;
+ } else if (core.status.event.ui != null) {
+ core.status.boxAnimateObjs = [];
+ core.ui._drawViewMaps(core.status.event.ui);
+ } else core.ui.closePanel();
+
+ return;
+ }
+ }
+ async turnleft(page) {
+ if (this.page <= 1) return
+ if (!this.paperpages[page - 1]) this.paperpages[page - 1] = [this.paperTexture('left'), this.paperTexture('right')]
+ this.isAnimate = true
+ bookInfo.drawTempLeft(page - 1)
+ bookInfo.drawTempRight(page - 1)
+ core.drawBoxAnimate()
+ await this.ani.time(1)
+ .absolute()
+ .mode(linear()).move(0, 0).n(1)
+
+ const fn = () => {
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+ ctx.save();
+ ctx.translate(416, 0);
+ ctx.rotate(Math.PI / 2);
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+ ctx.save();
+ }
+
+ // 1. 先绘制背景底色
+ core.fillRect(ctx, 0, 0, 676, 416, "#000000")
+
+ // 2. 绘制书脊和封面背景
+ const dx = (676 - this.width * 2) / 2,
+ dy = (416 - this.height) / 2
+
+
+ //绘制打开的书皮,416*676,暗红色
+ const bookWidth = 676;
+ const bookHeight = 416;
+ const spineWidth = 26;
+ const spineX = bookWidth / 2;
+
+ const foldSize = 8; // 折角大小
+
+ // 左侧连接处折角
+ ctx.fillStyle = "rgba(60, 40, 20, 0.6)";
+ ctx.beginPath();
+ // 上部折角
+ ctx.moveTo(spineX - spineWidth / 2, 0);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize, foldSize);
+ ctx.lineTo(spineX - spineWidth / 2, foldSize * 2);
+ // 下部折角
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize, bookHeight - foldSize);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.fill();
+
+ // 右侧连接处折角
+ ctx.beginPath();
+ // 上部折角
+ ctx.moveTo(spineX + spineWidth / 2, 0);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize, foldSize);
+ ctx.lineTo(spineX + spineWidth / 2, foldSize * 2);
+ // 下部折角
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize, bookHeight - foldSize);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.fill();
+
+ // 添加折角高光效果
+ ctx.strokeStyle = "rgba(200, 180, 150, 0.3)";
+ ctx.lineWidth = 1;
+ // 左侧高光
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, foldSize * 2);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize / 2, foldSize * 1.5);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize / 2, bookHeight - foldSize * 1.5);
+ ctx.stroke();
+ // 右侧高光
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, foldSize * 2);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize / 2, foldSize * 1.5);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize / 2, bookHeight - foldSize * 1.5);
+ ctx.stroke();
+ // 创建更丰富的书皮渐变
+ const coverGradient = ctx.createLinearGradient(0, 0, bookWidth, 0);
+ coverGradient.addColorStop(0, "#6b3a3a");
+ coverGradient.addColorStop(0.49, "#4a2222");
+ coverGradient.addColorStop(0.5, "#4a2222");
+ coverGradient.addColorStop(0.51, "#4a2222");
+ coverGradient.addColorStop(1, "#6b3a3a");
+
+ // 绘制书皮主体
+ ctx.fillStyle = coverGradient;
+ ctx.beginPath();
+ ctx.moveTo(0, 0);
+ ctx.lineTo(bookWidth, 0);
+ ctx.lineTo(bookWidth, bookHeight);
+ ctx.lineTo(0, bookHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 添加精美的边缘花纹
+
+ ctx.strokeStyle = "rgba(180, 140, 100, 0.4)";
+ ctx.lineWidth = 2;
+
+ // 顶部花纹
+ ctx.beginPath();
+ for (let x = 20; x < bookWidth; x += 40) {
+ ctx.moveTo(x, 5);
+ ctx.lineTo(x + 10, 15);
+ ctx.lineTo(x + 20, 5);
+ }
+ ctx.stroke();
+
+ // 底部花纹
+ ctx.beginPath();
+ for (let x = 10; x < bookWidth; x += 40) {
+ ctx.moveTo(x, bookHeight - 5);
+ ctx.lineTo(x + 15, bookHeight - 15);
+ ctx.lineTo(x + 30, bookHeight - 5);
+ }
+ ctx.stroke();
+
+
+ // 添加精美的书脊装饰
+
+
+
+ // 书脊主线条
+ ctx.strokeStyle = "rgba(120, 80, 60, 0.8)";
+ ctx.lineWidth = 2;
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, 0);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight);
+ ctx.moveTo(spineX + spineWidth / 2, 0);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight);
+ ctx.stroke();
+
+ // 书脊装饰花纹 - 古典风格
+ ctx.fillStyle = "rgba(200, 160, 120, 0.3)";
+ for (let y = 50; y < bookHeight; y += 80) {
+ // 花纹单元
+ ctx.beginPath();
+ ctx.moveTo(spineX, y - 15);
+ ctx.lineTo(spineX - 8, y - 5);
+ ctx.lineTo(spineX - 12, y + 5);
+ ctx.lineTo(spineX - 8, y + 15);
+ ctx.lineTo(spineX, y + 20);
+ ctx.lineTo(spineX + 8, y + 15);
+ ctx.lineTo(spineX + 12, y + 5);
+ ctx.lineTo(spineX + 8, y - 5);
+ ctx.closePath();
+ ctx.fill();
+
+ // 连接线
+ ctx.strokeStyle = "rgba(180, 140, 100, 0.4)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.moveTo(spineX, y + 20);
+ ctx.lineTo(spineX, y + 60);
+ ctx.stroke();
+ }
+
+
+ // 添加更精细的阴影效果
+
+ ctx.shadowColor = "rgba(0, 0, 0, 0.6)";
+ ctx.shadowBlur = 20;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+ // 重新绘制边缘以应用阴影
+ ctx.strokeStyle = "rgba(80, 50, 30, 0.8)";
+ ctx.lineWidth = 4;
+ ctx.beginPath();
+ ctx.rect(2, 2, bookWidth - 4, bookHeight - 4);
+ ctx.stroke();
+
+
+ // 添加精细的皮质纹理
+
+ ctx.fillStyle = "rgba(40, 25, 15, 0.08)";
+
+ // 水平纹理
+ for (let y = 10; y < bookHeight; y += 8) {
+ ctx.beginPath();
+ ctx.moveTo(0, y);
+ for (let x = 0; x < bookWidth; x += 20) {
+ ctx.lineTo(x, y + (x % 40 < 20 ? 2 : -2));
+ }
+ ctx.lineTo(bookWidth, y);
+ ctx.lineTo(bookWidth, y + 1);
+ for (let x = bookWidth; x > 0; x -= 20) {
+ ctx.lineTo(x, y + 1 + (x % 40 < 20 ? -1 : 1));
+ }
+ ctx.closePath();
+ ctx.fill();
+ }
+
+ // 垂直纹理
+ ctx.fillStyle = "rgba(30, 20, 10, 0.05)";
+ for (let x = 10; x < bookWidth; x += 12) {
+ ctx.beginPath();
+ ctx.moveTo(x, 0);
+ for (let y = 0; y < bookHeight; y += 20) {
+ ctx.lineTo(x + (y % 40 < 20 ? 1 : -1), y);
+ }
+ ctx.lineTo(x + 1, bookHeight);
+ ctx.lineTo(x - 1, bookHeight);
+ for (let y = bookHeight; y > 0; y -= 20) {
+ ctx.lineTo(x + (y % 40 < 20 ? -1 : 1), y);
+ }
+ ctx.closePath();
+ ctx.fill();
+ }
+
+
+ // 添加精美的书角金属装饰
+
+ const cornerSize = 30;
+ const cornerGradient = ctx.createLinearGradient(0, 0, cornerSize, cornerSize);
+ cornerGradient.addColorStop(0, "rgba(200, 170, 100, 0.8)");
+ cornerGradient.addColorStop(1, "rgba(150, 120, 70, 0.8)");
+
+ // 四个角
+
+
+
+ let [x, y] = [0, 0];
+ // 绘制三角形装饰
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + cornerSize, y);
+ ctx.lineTo(x, y + cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, 0, Math.PI / 2);
+ ctx.stroke();
+
+ // 绘制放射线装饰
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+
+ [x, y] = [bookWidth, 0]
+
+ // 绘制三角形装饰(水平翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x - cornerSize, y);
+ ctx.lineTo(x, y + cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(水平翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, Math.PI / 2, Math.PI);
+ ctx.stroke();
+
+ // 绘制放射线装饰(水平翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = Math.PI - i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+ [x, y] = [0, bookHeight]
+
+ // 绘制三角形装饰(垂直翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + cornerSize, y);
+ ctx.lineTo(x, y - cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(垂直翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, -Math.PI / 2, 0);
+ ctx.stroke();
+
+ // 绘制放射线装饰(垂直翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = -i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+ x = bookWidth;
+ y = bookHeight;
+
+ // 绘制三角形装饰(水平和垂直翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x - cornerSize, y);
+ ctx.lineTo(x, y - cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(水平和垂直翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, Math.PI, Math.PI * 3 / 2);
+ ctx.stroke();
+
+ // 绘制放射线装饰(水平和垂直翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = Math.PI + i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+
+ // 外边缘厚阴影
+ ctx.shadowColor = "rgba(0, 0, 0, 0.7)";
+ ctx.shadowBlur = 15;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+ ctx.strokeStyle = "rgba(80, 50, 30, 0.8)";
+ ctx.lineWidth = 4;
+ ctx.beginPath();
+ ctx.rect(2, 2, bookWidth - 4, bookHeight - 4);
+ ctx.stroke();
+
+ // 内边缘阴影(模拟厚度)
+ ctx.shadowColor = "transparent";
+ const innerShadowWidth = 8;
+
+ // 顶部内阴影
+ const topShadow = ctx.createLinearGradient(0, 0, 0, innerShadowWidth);
+ topShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ topShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = topShadow;
+ ctx.fillRect(0, 0, bookWidth, innerShadowWidth);
+
+ // 底部内阴影
+ const bottomShadow = ctx.createLinearGradient(0, bookHeight, 0, bookHeight - innerShadowWidth);
+ bottomShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ bottomShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = bottomShadow;
+ ctx.fillRect(0, bookHeight - innerShadowWidth, bookWidth, innerShadowWidth);
+
+ // 左侧内阴影
+ const leftShadow = ctx.createLinearGradient(0, 0, innerShadowWidth, 0);
+ leftShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ leftShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = leftShadow;
+ ctx.fillRect(0, 0, innerShadowWidth, bookHeight);
+
+ // 右侧内阴影
+ const rightShadow = ctx.createLinearGradient(bookWidth, 0, bookWidth - innerShadowWidth, 0);
+ rightShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ rightShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = rightShadow;
+ ctx.fillRect(bookWidth - innerShadowWidth, 0, innerShadowWidth, bookHeight);
+
+ // 书脊两侧的特殊阴影
+
+ const spineShadowWidth = 4;
+
+ // 书脊左侧阴影
+ const spineLeftShadow = ctx.createLinearGradient(
+ spineX - spineWidth / 2, 0,
+ spineX - spineWidth / 2 - spineShadowWidth, 0
+ );
+ spineLeftShadow.addColorStop(0, "rgba(0, 0, 0, 0.5)");
+ spineLeftShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = spineLeftShadow;
+ ctx.fillRect(
+ spineX - spineWidth / 2 - spineShadowWidth, 0,
+ spineShadowWidth, bookHeight
+ );
+
+ // 书脊右侧阴影
+ const spineRightShadow = ctx.createLinearGradient(
+ spineX + spineWidth / 2, 0,
+ spineX + spineWidth / 2 + spineShadowWidth, 0
+ );
+ spineRightShadow.addColorStop(0, "rgba(0, 0, 0, 0.5)");
+ spineRightShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = spineRightShadow;
+ ctx.fillRect(
+ spineX + spineWidth / 2, 0,
+ spineShadowWidth, bookHeight
+ );
+
+ const pageLiftHeight = 20;
+
+ // 左侧书页翻起效果
+ ctx.fillStyle = "rgba(250, 240, 230, 0.7)";
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - 5, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight / 2 + pageLiftHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 右侧书页翻起效果
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + 5, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight / 2 + pageLiftHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 添加翻起部分的阴影
+ ctx.fillStyle = "rgba(0, 0, 0, 0.1)";
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - 5, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2 - 2, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight + 3);
+ ctx.closePath();
+ ctx.fill();
+
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + 5, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2 + 2, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight + 3);
+ ctx.closePath();
+ ctx.fill();
+
+ // 4. 绘制书页 - 添加抗锯齿边缘处理
+ // 先绘制一个作为书页底色
+ ctx.fillStyle = '#cfbf96';
+ ctx.beginPath();
+ ctx.moveTo(dx, dy);
+ ctx.lineTo(dx + 2 * this.width, dy);
+ ctx.lineTo(dx + 2 * this.width, this.height + dy);
+ ctx.lineTo(dx, this.height + dy);
+ ctx.closePath();
+
+ ctx.fill();
+ // 使用更精细的渐变填充
+ // 创建更复杂的渐变效果
+ const leftGradient = ctx.createLinearGradient(dx / 2, 0, dx, 0);
+ leftGradient.addColorStop(0, "#f0e8c8");
+ leftGradient.addColorStop(0.3, "#d8c8a0");
+ leftGradient.addColorStop(0.5, "#b09868");
+ leftGradient.addColorStop(0.7, "#9e804a");
+ leftGradient.addColorStop(1, "#8a6c3a");
+
+ // 绘制左侧封面
+ ctx.beginPath();
+ ctx.moveTo(dx, this.height + dy);
+ ctx.lineTo(dx / 2, this.height + dy);
+ ctx.lineTo(dx / 2, dy);
+ ctx.lineTo(dx, dy);
+ ctx.closePath();
+ ctx.fillStyle = leftGradient;
+ ctx.fill();
+
+ // 添加竖向条纹效果(像素感破旧边缘)
+
+ ctx.strokeStyle = "rgba(120, 90, 60, 0.3)";
+ ctx.lineWidth = 1;
+ for (let i = 0; i < 10; i++) {
+ const x = dx / 2 + i * 2;
+ ctx.beginPath();
+ ctx.moveTo(x, dy);
+ ctx.lineTo(x, dy + this.height);
+ ctx.stroke();
+ }
+
+
+ // 添加不规则暗色区域(不使用随机数)
+ ctx.fillStyle = "rgba(90, 70, 40, 0.15)";
+ ctx.beginPath();
+ ctx.moveTo(dx / 2 + 10, dy + 50);
+ ctx.lineTo(dx / 2 + 30, dy + 40);
+ ctx.lineTo(dx / 2 + 25, dy + 100);
+ ctx.lineTo(dx / 2 + 15, dy + 120);
+ ctx.closePath();
+ ctx.fill();
+
+ ctx.beginPath();
+ ctx.moveTo(dx / 2 + 5, dy + 180);
+ ctx.lineTo(dx / 2 + 35, dy + 200);
+ ctx.lineTo(dx / 2 + 20, dy + 250);
+ ctx.lineTo(dx / 2, dy + 230);
+ ctx.closePath();
+ ctx.fill();
+
+ // 右侧封面同理
+ const rightGradient = ctx.createLinearGradient(676 - dx, 0, 676 - dx / 2, 0);
+ rightGradient.addColorStop(0, "#8a6c3a");
+ rightGradient.addColorStop(0.3, "#9e804a");
+ rightGradient.addColorStop(0.5, "#b09868");
+ rightGradient.addColorStop(0.7, "#d8c8a0");
+ rightGradient.addColorStop(1, "#f0e8c8");
+
+ ctx.beginPath();
+ ctx.moveTo(676 - dx / 2, this.height + dy);
+ ctx.lineTo(676 - dx, this.height + dy);
+ ctx.lineTo(676 - dx, dy);
+ ctx.lineTo(676 - dx / 2, dy);
+ ctx.closePath();
+ ctx.fillStyle = rightGradient;
+ ctx.fill();
+
+ // 添加右侧竖向条纹
+
+ ctx.strokeStyle = "rgba(120, 90, 60, 0.3)";
+ ctx.lineWidth = 1;
+ for (let i = 0; i < 10; i++) {
+ const x = 676 - dx / 2 - i * 2;
+ ctx.beginPath();
+ ctx.moveTo(x, dy);
+ ctx.lineTo(x, dy + this.height);
+ ctx.stroke();
+ }
+
+
+ // 添加右侧不规则暗色区域
+ ctx.fillStyle = "rgba(90, 70, 40, 0.15)";
+ ctx.beginPath();
+ ctx.moveTo(676 - dx / 2 - 10, dy + 70);
+ ctx.lineTo(676 - dx / 2 - 25, dy + 80);
+ ctx.lineTo(676 - dx / 2 - 20, dy + 140);
+ ctx.lineTo(676 - dx / 2 - 5, dy + 130);
+ ctx.closePath();
+ ctx.fill();
+ // 添加书页边缘老化渐变效果
+ // 创建边缘渐变遮罩
+ const edgeGradient = ctx.createRadialGradient(
+ dx + this.width / 2, this.height / 2, 5, // 内圆
+ dx + this.width / 2, this.height / 2, Math.max(this.width, this.height) / 2 // 外圆
+ );
+ edgeGradient.addColorStop(0, "rgba(0,0,0,0)"); // 中心透明
+ edgeGradient.addColorStop(0.7, "rgba(0,0,0,0)"); // 中间部分透明
+ edgeGradient.addColorStop(1, "rgba(50,40,20,0.15)"); // 边缘轻微老化效果
+
+ // 应用边缘渐变
+ ctx.fillStyle = edgeGradient;
+ ctx.globalCompositeOperation = 'multiply'; // 使用乘法混合模式使边缘变暗
+ ctx.beginPath();
+ ctx.moveTo(dx, dy);
+ ctx.lineTo(dx + 2 * this.width, dy);
+ ctx.lineTo(dx + 2 * this.width, this.height + dy);
+ ctx.lineTo(dx, this.height + dy);
+ ctx.closePath();
+ ctx.fill();
+ ctx.globalCompositeOperation = 'source-over'; // 恢复默认混合模式
+
+ // 进一步添加边缘老化效果 - 左右边框
+ const sideEdgeGradientLeft = ctx.createLinearGradient(dx, 0, dx + this.width, 0);
+ sideEdgeGradientLeft.addColorStop(0, "rgba(90,70,50,0.15)");
+ sideEdgeGradientLeft.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ sideEdgeGradientLeft.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ sideEdgeGradientLeft.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = sideEdgeGradientLeft;
+ ctx.fillRect(dx, 0, this.width, this.height);
+
+ const sideEdgeGradientRight = ctx.createLinearGradient(dx + this.width, 0, dx, 0);
+ sideEdgeGradientRight.addColorStop(0, "rgba(90,70,50,0.15)");
+ sideEdgeGradientRight.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ sideEdgeGradientRight.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ sideEdgeGradientRight.addColorStop(1, "rgba(90,70,50,0.15)");
+ ctx.fillStyle = sideEdgeGradientRight;
+ ctx.fillRect(dx, 0, this.width, this.height);
+
+ // 上下边缘老化效果
+ const topEdgeGradient = ctx.createLinearGradient(0, dy, 0, dy + this.height);
+ topEdgeGradient.addColorStop(0, "rgba(90,70,50,0.15)");
+ topEdgeGradient.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ topEdgeGradient.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ topEdgeGradient.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = topEdgeGradient;
+ ctx.fillRect(dx, dy, this.width, this.height);
+
+ const bottomEdgeGradient = ctx.createLinearGradient(0, dy + this.height, 0, dy);
+ bottomEdgeGradient.addColorStop(0, "rgba(90,70,50,0.15)");
+ bottomEdgeGradient.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ bottomEdgeGradient.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ bottomEdgeGradient.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = bottomEdgeGradient;
+ ctx.fillRect(dx, dy, this.width, this.height);
+ // 使用阴影模糊来柔化边缘
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ core.drawBoxAnimate()
+ // 绘制左页
+ core.drawImage(ctx, this.paperpages[this.page - 1][0], this.ani.x / (this.width * 2) * 300, 0, 300 - this.ani.x / (this.width * 2) * 300, 400, dx + this.ani.x / (this.width * 2) * 300, dy, 300 - this.ani.x / (this.width * 2) * 300, this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.left.canvas, 0, 0, bookInfo.left.canvas.width, bookInfo.left.canvas.height, dx, dy, this.width, this.height);
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ // 绘制右页
+ core.drawImage(ctx, this.paperpages[this.page - 1][1], Math.max(0, this.ani.x - 300), 0, Math.min(600 - this.ani.x, 300), 400, dx + this.width + Math.max(0, this.ani.x - 300), dy, Math.min(600 - this.ani.x, 300), this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.right.canvas, 0, 0, bookInfo.right.canvas.width, bookInfo.right.canvas.height, dx + this.width, dy, this.width, this.height);
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ //绘制上一页左页
+ core.drawImage(ctx, this.paperpages[page - 1][0], 0, 0, this.ani.x / (this.width * 2) * 300, 400, dx, dy, this.ani.x / 2, this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.tempLeft.canvas, 0, 0, this.ani.x / (this.width * 2) * bookInfo.tempLeft.canvas.width, bookInfo.tempLeft.canvas.height, dx, dy, this.ani.x / 2, this.height);
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ //绘制翻起的右页
+ core.drawImage(ctx, this.paperpages[page - 1][1], 300 - this.ani.x / (this.width * 2) * 300, 0, this.ani.x / (this.width * 2) * 300, 400, this.ani.x / 2 + dx, dy, this.ani.x / 2, this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.tempRight.canvas, bookInfo.tempRight.canvas.width - this.ani.x / (this.width * 2) * bookInfo.tempRight.canvas.width, 0, this.ani.x / (this.width * 2) * bookInfo.tempRight.canvas.width, bookInfo.tempRight.canvas.height, this.ani.x / 2 + dx, dy, this.ani.x / 2, this.height);
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ const gradientleft = ctx.createLinearGradient(dx + this.ani.x / 2 - 20, (416 - this.height) / 2, dx + this.ani.x / 2 + 10, (416 - this.height) / 2)
+ gradientleft.addColorStop(0, "rgba(0,0,0,0)")
+ gradientleft.addColorStop(0.67, "rgba(0,0,0,0.2)")
+ gradientleft.addColorStop(1, "rgba(0,0,0,0)")
+ core.fillRect(ctx, dx + this.ani.x / 2 - 20, (416 - this.height) / 2, 30, this.height, gradientleft)
+ const gradientright = ctx.createLinearGradient(this.ani.x + dx, (416 - this.height) / 2, this.ani.x + dx + 20, (416 - this.height) / 2)
+ gradientright.addColorStop(1, "rgba(0,0,0,0)")
+ gradientright.addColorStop(0.2, "rgba(0,0,0,0.2)")
+ gradientright.addColorStop(0, "rgba(0,0,0,0.4)")
+ core.fillRect(ctx, this.ani.x + dx, (416 - this.height) / 2, 20, this.height, gradientright)
+
+ // 重置阴影
+ ctx.shadowColor = "transparent";
+ ctx.restore();
+ }
+ this.ani.ticker.add(fn)
+ await this.ani.time(this.time)
+ .absolute()
+ .mode(trigo("sin", "in-out"))
+ .move(this.width * 2, 0).n(1)
+ this.ani.ticker.clear()
+ this.isAnimate = false
+ this.page = page
+ bookInfo.page = page - 1;
+ [bookInfo.left, bookInfo.tempLeft] = [bookInfo.tempLeft, bookInfo.left];
+ [bookInfo.right, bookInfo.tempRight] = [bookInfo.tempRight, bookInfo.right]
+ core.status.boxAnimateObjs = core.status.boxAnimateObjs.filter(v => v.ctx === bookInfo.left)
+ core.drawBoxAnimate()
+
+ this.update()
+ core.clearMap(bookInfo.tempLeft)
+ core.clearMap(bookInfo.tempRight)
+
+ }
+ async turnright(page) {
+ if (this.page >= this.pagemax) return
+ if (!this.paperpages[page - 1]) this.paperpages[page - 1] = [this.paperTexture('left'), this.paperTexture('right')]
+ this.isAnimate = true
+ bookInfo.drawTempLeft(page - 1)
+ bookInfo.drawTempRight(page - 1)
+ core.drawBoxAnimate()
+ await this.ani.time(1)
+ .absolute()
+ .mode(linear()).move(0, 0).n(1)
+
+ const fn = () => {
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+ ctx.save();
+ ctx.translate(416, 0);
+ ctx.rotate(Math.PI / 2);
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+ ctx.save();
+ }
+
+ // 1. 先绘制背景底色
+ core.fillRect(ctx, 0, 0, 676, 416, "#000000")
+
+ // 2. 绘制书脊和封面背景
+ const dx = (676 - this.width * 2) / 2,
+ dy = (416 - this.height) / 2
+
+
+ //绘制打开的书皮,416*676,暗红色
+ const bookWidth = 676;
+ const bookHeight = 416;
+ const spineWidth = 26;
+ const spineX = bookWidth / 2;
+
+ const foldSize = 8; // 折角大小
+
+ // 左侧连接处折角
+ ctx.fillStyle = "rgba(60, 40, 20, 0.6)";
+ ctx.beginPath();
+ // 上部折角
+ ctx.moveTo(spineX - spineWidth / 2, 0);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize, foldSize);
+ ctx.lineTo(spineX - spineWidth / 2, foldSize * 2);
+ // 下部折角
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize, bookHeight - foldSize);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.fill();
+
+ // 右侧连接处折角
+ ctx.beginPath();
+ // 上部折角
+ ctx.moveTo(spineX + spineWidth / 2, 0);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize, foldSize);
+ ctx.lineTo(spineX + spineWidth / 2, foldSize * 2);
+ // 下部折角
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize, bookHeight - foldSize);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.fill();
+
+ // 添加折角高光效果
+ ctx.strokeStyle = "rgba(200, 180, 150, 0.3)";
+ ctx.lineWidth = 1;
+ // 左侧高光
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, foldSize * 2);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize / 2, foldSize * 1.5);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize / 2, bookHeight - foldSize * 1.5);
+ ctx.stroke();
+ // 右侧高光
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, foldSize * 2);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize / 2, foldSize * 1.5);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize / 2, bookHeight - foldSize * 1.5);
+ ctx.stroke();
+ // 创建更丰富的书皮渐变
+ const coverGradient = ctx.createLinearGradient(0, 0, bookWidth, 0);
+ coverGradient.addColorStop(0, "#6b3a3a");
+ coverGradient.addColorStop(0.49, "#4a2222");
+ coverGradient.addColorStop(0.5, "#4a2222");
+ coverGradient.addColorStop(0.51, "#4a2222");
+ coverGradient.addColorStop(1, "#6b3a3a");
+
+ // 绘制书皮主体
+ ctx.fillStyle = coverGradient;
+ ctx.beginPath();
+ ctx.moveTo(0, 0);
+ ctx.lineTo(bookWidth, 0);
+ ctx.lineTo(bookWidth, bookHeight);
+ ctx.lineTo(0, bookHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 添加精美的边缘花纹
+
+ ctx.strokeStyle = "rgba(180, 140, 100, 0.4)";
+ ctx.lineWidth = 2;
+
+ // 顶部花纹
+ ctx.beginPath();
+ for (let x = 20; x < bookWidth; x += 40) {
+ ctx.moveTo(x, 5);
+ ctx.lineTo(x + 10, 15);
+ ctx.lineTo(x + 20, 5);
+ }
+ ctx.stroke();
+
+ // 底部花纹
+ ctx.beginPath();
+ for (let x = 10; x < bookWidth; x += 40) {
+ ctx.moveTo(x, bookHeight - 5);
+ ctx.lineTo(x + 15, bookHeight - 15);
+ ctx.lineTo(x + 30, bookHeight - 5);
+ }
+ ctx.stroke();
+
+
+ // 添加精美的书脊装饰
+
+
+
+ // 书脊主线条
+ ctx.strokeStyle = "rgba(120, 80, 60, 0.8)";
+ ctx.lineWidth = 2;
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, 0);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight);
+ ctx.moveTo(spineX + spineWidth / 2, 0);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight);
+ ctx.stroke();
+
+ // 书脊装饰花纹 - 古典风格
+ ctx.fillStyle = "rgba(200, 160, 120, 0.3)";
+ for (let y = 50; y < bookHeight; y += 80) {
+ // 花纹单元
+ ctx.beginPath();
+ ctx.moveTo(spineX, y - 15);
+ ctx.lineTo(spineX - 8, y - 5);
+ ctx.lineTo(spineX - 12, y + 5);
+ ctx.lineTo(spineX - 8, y + 15);
+ ctx.lineTo(spineX, y + 20);
+ ctx.lineTo(spineX + 8, y + 15);
+ ctx.lineTo(spineX + 12, y + 5);
+ ctx.lineTo(spineX + 8, y - 5);
+ ctx.closePath();
+ ctx.fill();
+
+ // 连接线
+ ctx.strokeStyle = "rgba(180, 140, 100, 0.4)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.moveTo(spineX, y + 20);
+ ctx.lineTo(spineX, y + 60);
+ ctx.stroke();
+ }
+
+
+ // 添加更精细的阴影效果
+
+ ctx.shadowColor = "rgba(0, 0, 0, 0.6)";
+ ctx.shadowBlur = 20;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+ // 重新绘制边缘以应用阴影
+ ctx.strokeStyle = "rgba(80, 50, 30, 0.8)";
+ ctx.lineWidth = 4;
+ ctx.beginPath();
+ ctx.rect(2, 2, bookWidth - 4, bookHeight - 4);
+ ctx.stroke();
+
+
+ // 添加精细的皮质纹理
+
+ ctx.fillStyle = "rgba(40, 25, 15, 0.08)";
+
+ // 水平纹理
+ for (let y = 10; y < bookHeight; y += 8) {
+ ctx.beginPath();
+ ctx.moveTo(0, y);
+ for (let x = 0; x < bookWidth; x += 20) {
+ ctx.lineTo(x, y + (x % 40 < 20 ? 2 : -2));
+ }
+ ctx.lineTo(bookWidth, y);
+ ctx.lineTo(bookWidth, y + 1);
+ for (let x = bookWidth; x > 0; x -= 20) {
+ ctx.lineTo(x, y + 1 + (x % 40 < 20 ? -1 : 1));
+ }
+ ctx.closePath();
+ ctx.fill();
+ }
+
+ // 垂直纹理
+ ctx.fillStyle = "rgba(30, 20, 10, 0.05)";
+ for (let x = 10; x < bookWidth; x += 12) {
+ ctx.beginPath();
+ ctx.moveTo(x, 0);
+ for (let y = 0; y < bookHeight; y += 20) {
+ ctx.lineTo(x + (y % 40 < 20 ? 1 : -1), y);
+ }
+ ctx.lineTo(x + 1, bookHeight);
+ ctx.lineTo(x - 1, bookHeight);
+ for (let y = bookHeight; y > 0; y -= 20) {
+ ctx.lineTo(x + (y % 40 < 20 ? -1 : 1), y);
+ }
+ ctx.closePath();
+ ctx.fill();
+ }
+
+
+ // 添加精美的书角金属装饰
+
+ const cornerSize = 30;
+ const cornerGradient = ctx.createLinearGradient(0, 0, cornerSize, cornerSize);
+ cornerGradient.addColorStop(0, "rgba(200, 170, 100, 0.8)");
+ cornerGradient.addColorStop(1, "rgba(150, 120, 70, 0.8)");
+
+ // 四个角
+
+
+
+ let [x, y] = [0, 0];
+ // 绘制三角形装饰
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + cornerSize, y);
+ ctx.lineTo(x, y + cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, 0, Math.PI / 2);
+ ctx.stroke();
+
+ // 绘制放射线装饰
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+
+ [x, y] = [bookWidth, 0]
+
+ // 绘制三角形装饰(水平翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x - cornerSize, y);
+ ctx.lineTo(x, y + cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(水平翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, Math.PI / 2, Math.PI);
+ ctx.stroke();
+
+ // 绘制放射线装饰(水平翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = Math.PI - i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+ [x, y] = [0, bookHeight]
+
+ // 绘制三角形装饰(垂直翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + cornerSize, y);
+ ctx.lineTo(x, y - cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(垂直翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, -Math.PI / 2, 0);
+ ctx.stroke();
+
+ // 绘制放射线装饰(垂直翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = -i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+ x = bookWidth;
+ y = bookHeight;
+
+ // 绘制三角形装饰(水平和垂直翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x - cornerSize, y);
+ ctx.lineTo(x, y - cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(水平和垂直翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, Math.PI, Math.PI * 3 / 2);
+ ctx.stroke();
+
+ // 绘制放射线装饰(水平和垂直翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = Math.PI + i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+
+ // 外边缘厚阴影
+ ctx.shadowColor = "rgba(0, 0, 0, 0.7)";
+ ctx.shadowBlur = 15;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+ ctx.strokeStyle = "rgba(80, 50, 30, 0.8)";
+ ctx.lineWidth = 4;
+ ctx.beginPath();
+ ctx.rect(2, 2, bookWidth - 4, bookHeight - 4);
+ ctx.stroke();
+
+ // 内边缘阴影(模拟厚度)
+ ctx.shadowColor = "transparent";
+ const innerShadowWidth = 8;
+
+ // 顶部内阴影
+ const topShadow = ctx.createLinearGradient(0, 0, 0, innerShadowWidth);
+ topShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ topShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = topShadow;
+ ctx.fillRect(0, 0, bookWidth, innerShadowWidth);
+
+ // 底部内阴影
+ const bottomShadow = ctx.createLinearGradient(0, bookHeight, 0, bookHeight - innerShadowWidth);
+ bottomShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ bottomShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = bottomShadow;
+ ctx.fillRect(0, bookHeight - innerShadowWidth, bookWidth, innerShadowWidth);
+
+ // 左侧内阴影
+ const leftShadow = ctx.createLinearGradient(0, 0, innerShadowWidth, 0);
+ leftShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ leftShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = leftShadow;
+ ctx.fillRect(0, 0, innerShadowWidth, bookHeight);
+
+ // 右侧内阴影
+ const rightShadow = ctx.createLinearGradient(bookWidth, 0, bookWidth - innerShadowWidth, 0);
+ rightShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ rightShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = rightShadow;
+ ctx.fillRect(bookWidth - innerShadowWidth, 0, innerShadowWidth, bookHeight);
+
+ // 书脊两侧的特殊阴影
+
+ const spineShadowWidth = 4;
+
+ // 书脊左侧阴影
+ const spineLeftShadow = ctx.createLinearGradient(
+ spineX - spineWidth / 2, 0,
+ spineX - spineWidth / 2 - spineShadowWidth, 0
+ );
+ spineLeftShadow.addColorStop(0, "rgba(0, 0, 0, 0.5)");
+ spineLeftShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = spineLeftShadow;
+ ctx.fillRect(
+ spineX - spineWidth / 2 - spineShadowWidth, 0,
+ spineShadowWidth, bookHeight
+ );
+
+ // 书脊右侧阴影
+ const spineRightShadow = ctx.createLinearGradient(
+ spineX + spineWidth / 2, 0,
+ spineX + spineWidth / 2 + spineShadowWidth, 0
+ );
+ spineRightShadow.addColorStop(0, "rgba(0, 0, 0, 0.5)");
+ spineRightShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = spineRightShadow;
+ ctx.fillRect(
+ spineX + spineWidth / 2, 0,
+ spineShadowWidth, bookHeight
+ );
+
+ const pageLiftHeight = 20;
+
+ // 左侧书页翻起效果
+ ctx.fillStyle = "rgba(250, 240, 230, 0.7)";
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - 5, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight / 2 + pageLiftHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 右侧书页翻起效果
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + 5, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight / 2 + pageLiftHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 添加翻起部分的阴影
+ ctx.fillStyle = "rgba(0, 0, 0, 0.1)";
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - 5, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2 - 2, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight + 3);
+ ctx.closePath();
+ ctx.fill();
+
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + 5, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2 + 2, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight + 3);
+ ctx.closePath();
+ ctx.fill();
+
+ // 4. 绘制书页 - 添加抗锯齿边缘处理
+ // 先绘制一个作为书页底色
+ ctx.fillStyle = '#cfbf96';
+ ctx.beginPath();
+ ctx.moveTo(dx, dy);
+ ctx.lineTo(dx + 2 * this.width, dy);
+ ctx.lineTo(dx + 2 * this.width, this.height + dy);
+ ctx.lineTo(dx, this.height + dy);
+ ctx.closePath();
+
+ ctx.fill();
+ // 使用更精细的渐变填充
+ // 创建更复杂的渐变效果
+ const leftGradient = ctx.createLinearGradient(dx / 2, 0, dx, 0);
+ leftGradient.addColorStop(0, "#f0e8c8");
+ leftGradient.addColorStop(0.3, "#d8c8a0");
+ leftGradient.addColorStop(0.5, "#b09868");
+ leftGradient.addColorStop(0.7, "#9e804a");
+ leftGradient.addColorStop(1, "#8a6c3a");
+
+ // 绘制左侧封面
+ ctx.beginPath();
+ ctx.moveTo(dx, this.height + dy);
+ ctx.lineTo(dx / 2, this.height + dy);
+ ctx.lineTo(dx / 2, dy);
+ ctx.lineTo(dx, dy);
+ ctx.closePath();
+ ctx.fillStyle = leftGradient;
+ ctx.fill();
+
+ // 添加竖向条纹效果(像素感破旧边缘)
+
+ ctx.strokeStyle = "rgba(120, 90, 60, 0.3)";
+ ctx.lineWidth = 1;
+ for (let i = 0; i < 10; i++) {
+ const x = dx / 2 + i * 2;
+ ctx.beginPath();
+ ctx.moveTo(x, dy);
+ ctx.lineTo(x, dy + this.height);
+ ctx.stroke();
+ }
+
+
+ // 添加不规则暗色区域(不使用随机数)
+ ctx.fillStyle = "rgba(90, 70, 40, 0.15)";
+ ctx.beginPath();
+ ctx.moveTo(dx / 2 + 10, dy + 50);
+ ctx.lineTo(dx / 2 + 30, dy + 40);
+ ctx.lineTo(dx / 2 + 25, dy + 100);
+ ctx.lineTo(dx / 2 + 15, dy + 120);
+ ctx.closePath();
+ ctx.fill();
+
+ ctx.beginPath();
+ ctx.moveTo(dx / 2 + 5, dy + 180);
+ ctx.lineTo(dx / 2 + 35, dy + 200);
+ ctx.lineTo(dx / 2 + 20, dy + 250);
+ ctx.lineTo(dx / 2, dy + 230);
+ ctx.closePath();
+ ctx.fill();
+
+ // 右侧封面同理
+ const rightGradient = ctx.createLinearGradient(676 - dx, 0, 676 - dx / 2, 0);
+ rightGradient.addColorStop(0, "#8a6c3a");
+ rightGradient.addColorStop(0.3, "#9e804a");
+ rightGradient.addColorStop(0.5, "#b09868");
+ rightGradient.addColorStop(0.7, "#d8c8a0");
+ rightGradient.addColorStop(1, "#f0e8c8");
+
+ ctx.beginPath();
+ ctx.moveTo(676 - dx / 2, this.height + dy);
+ ctx.lineTo(676 - dx, this.height + dy);
+ ctx.lineTo(676 - dx, dy);
+ ctx.lineTo(676 - dx / 2, dy);
+ ctx.closePath();
+ ctx.fillStyle = rightGradient;
+ ctx.fill();
+
+ // 添加右侧竖向条纹
+
+ ctx.strokeStyle = "rgba(120, 90, 60, 0.3)";
+ ctx.lineWidth = 1;
+ for (let i = 0; i < 10; i++) {
+ const x = 676 - dx / 2 - i * 2;
+ ctx.beginPath();
+ ctx.moveTo(x, dy);
+ ctx.lineTo(x, dy + this.height);
+ ctx.stroke();
+ }
+
+
+ // 添加右侧不规则暗色区域
+ ctx.fillStyle = "rgba(90, 70, 40, 0.15)";
+ ctx.beginPath();
+ ctx.moveTo(676 - dx / 2 - 10, dy + 70);
+ ctx.lineTo(676 - dx / 2 - 25, dy + 80);
+ ctx.lineTo(676 - dx / 2 - 20, dy + 140);
+ ctx.lineTo(676 - dx / 2 - 5, dy + 130);
+ ctx.closePath();
+ ctx.fill();
+ // 添加书页边缘老化渐变效果
+ // 创建边缘渐变遮罩
+ const edgeGradient = ctx.createRadialGradient(
+ dx + this.width / 2, this.height / 2, 5, // 内圆
+ dx + this.width / 2, this.height / 2, Math.max(this.width, this.height) / 2 // 外圆
+ );
+ edgeGradient.addColorStop(0, "rgba(0,0,0,0)"); // 中心透明
+ edgeGradient.addColorStop(0.7, "rgba(0,0,0,0)"); // 中间部分透明
+ edgeGradient.addColorStop(1, "rgba(50,40,20,0.15)"); // 边缘轻微老化效果
+
+ // 应用边缘渐变
+ ctx.fillStyle = edgeGradient;
+ ctx.globalCompositeOperation = 'multiply'; // 使用乘法混合模式使边缘变暗
+ ctx.beginPath();
+ ctx.moveTo(dx, dy);
+ ctx.lineTo(dx + 2 * this.width, dy);
+ ctx.lineTo(dx + 2 * this.width, this.height + dy);
+ ctx.lineTo(dx, this.height + dy);
+ ctx.closePath();
+ ctx.fill();
+ ctx.globalCompositeOperation = 'source-over'; // 恢复默认混合模式
+
+ // 进一步添加边缘老化效果 - 左右边框
+ const sideEdgeGradientLeft = ctx.createLinearGradient(dx, 0, dx + this.width, 0);
+ sideEdgeGradientLeft.addColorStop(0, "rgba(90,70,50,0.15)");
+ sideEdgeGradientLeft.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ sideEdgeGradientLeft.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ sideEdgeGradientLeft.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = sideEdgeGradientLeft;
+ ctx.fillRect(dx, 0, this.width, this.height);
+
+ const sideEdgeGradientRight = ctx.createLinearGradient(dx + this.width, 0, dx, 0);
+ sideEdgeGradientRight.addColorStop(0, "rgba(90,70,50,0.15)");
+ sideEdgeGradientRight.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ sideEdgeGradientRight.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ sideEdgeGradientRight.addColorStop(1, "rgba(90,70,50,0.15)");
+ ctx.fillStyle = sideEdgeGradientRight;
+ ctx.fillRect(dx, 0, this.width, this.height);
+
+ // 上下边缘老化效果
+ const topEdgeGradient = ctx.createLinearGradient(0, dy, 0, dy + this.height);
+ topEdgeGradient.addColorStop(0, "rgba(90,70,50,0.15)");
+ topEdgeGradient.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ topEdgeGradient.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ topEdgeGradient.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = topEdgeGradient;
+ ctx.fillRect(dx, dy, this.width, this.height);
+
+ const bottomEdgeGradient = ctx.createLinearGradient(0, dy + this.height, 0, dy);
+ bottomEdgeGradient.addColorStop(0, "rgba(90,70,50,0.15)");
+ bottomEdgeGradient.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ bottomEdgeGradient.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ bottomEdgeGradient.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = bottomEdgeGradient;
+ ctx.fillRect(dx, dy, this.width, this.height);
+ // 使用阴影模糊来柔化边缘
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ core.drawBoxAnimate()
+ // 绘制左页
+ core.drawImage(ctx, this.paperpages[this.page - 1][0], 0, 0, 300 - Math.max(0, this.ani.x - this.width) / this.width * 300, 400, dx, dy, 300 - Math.max(0, this.ani.x - this.width) / this.width * 300, this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.left.canvas, 0, 0, bookInfo.left.canvas.width, bookInfo.left.canvas.height, dx, dy, this.width, this.height);
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ // 绘制右页
+ core.drawImage(ctx, this.paperpages[this.page - 1][1], 0, 0, 300 - this.ani.x / (this.width * 2) * 300, 400, dx + this.width, dy, 300 - this.ani.x / (this.width * 2) * 300, this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.right.canvas, 0, 0, bookInfo.right.canvas.width, bookInfo.right.canvas.height, dx + this.width, dy, this.width, this.height);
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ //绘制翻起的左页
+ core.drawImage(ctx, this.paperpages[page - 1][0], 0, 0, this.ani.x / (this.width * 2) * 300, 400, 676 - dx - this.ani.x, dy, this.ani.x / 2, this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.tempLeft.canvas, 0, 0, this.ani.x / (this.width * 2) * bookInfo.tempLeft.canvas.width, bookInfo.tempLeft.canvas.height, 676 - dx - this.ani.x, dy, this.ani.x / 2, this.height);
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+ //绘制下一页右页
+ core.drawImage(ctx, this.paperpages[page - 1][1], 300 - this.ani.x / (this.width * 2) * 300, 0, this.ani.x / (this.width * 2) * 300, 400, 676 - dx - this.ani.x / 2, dy, this.ani.x / 2, this.height);
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.tempRight.canvas, bookInfo.tempRight.canvas.width - this.ani.x / (this.width * 2) * bookInfo.tempRight.canvas.width, 0, this.ani.x / (this.width * 2) * bookInfo.tempRight.canvas.width, bookInfo.tempRight.canvas.height, 676 - dx - this.ani.x / 2, dy, this.ani.x / 2, this.height);
+
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+
+ const gradientleft = ctx.createLinearGradient(676 - dx - this.ani.x, (416 - this.height) / 2, 676 - dx - this.ani.x - 20, (416 - this.height) / 2)
+ gradientleft.addColorStop(1, "rgba(0,0,0,0)")
+ gradientleft.addColorStop(0.2, "rgba(0,0,0,0.2)")
+ gradientleft.addColorStop(0, "rgba(0,0,0,0.4)")
+ core.fillRect(ctx, 676 - dx - this.ani.x - 20, (416 - this.height) / 2, 20, this.height, gradientleft)
+ const gradientright = ctx.createLinearGradient(676 - dx - this.ani.x / 2 - 10, (416 - this.height) / 2, 676 - dx - this.ani.x / 2 + 20, (416 - this.height) / 2)
+ gradientright.addColorStop(1, "rgba(0,0,0,0)")
+ gradientright.addColorStop(0.33, "rgba(0,0,0,0.2)")
+ gradientright.addColorStop(0, "rgba(0,0,0,0)")
+ core.fillRect(ctx, 676 - dx - this.ani.x / 2 - 10, (416 - this.height) / 2, 30, this.height, gradientright)
+
+ // 重置阴影
+ ctx.shadowColor = "transparent";
+ ctx.restore();
+ }
+ this.ani.ticker.add(fn)
+ await this.ani.time(this.time)
+ .absolute()
+ .mode(trigo("sin", "in-out"))
+ .move(this.width * 2, 0).n(1)
+ this.ani.ticker.clear()
+ this.isAnimate = false
+ this.page = page
+ bookInfo.page = page - 1;
+ [bookInfo.left, bookInfo.tempLeft] = [bookInfo.tempLeft, bookInfo.left];
+ [bookInfo.right, bookInfo.tempRight] = [bookInfo.tempRight, bookInfo.right]
+ core.status.boxAnimateObjs = core.status.boxAnimateObjs.filter(v => v.ctx === bookInfo.left)
+ core.drawBoxAnimate()
+ this.update()
+ core.clearMap(bookInfo.tempLeft)
+ core.clearMap(bookInfo.tempRight)
+ }
+
+ paperTexture(dir, num = 0) {
+ const textureCanvas = document.createElement('canvas');
+ textureCanvas.width = 300;
+ textureCanvas.height = 400;
+ const textureCtx = textureCanvas.getContext('2d');
+
+
+ const createPageCurveMask = () => {
+ const curveCanvas = document.createElement('canvas');
+ curveCanvas.width = 300;
+ curveCanvas.height = 400;
+ const curveCtx = curveCanvas.getContext('2d');
+ curveCtx.clearRect(0, 0, 300, 400);
+
+ // 创建带毛边的路径
+ const createTornEdgePath = (ctx) => {
+ ctx.beginPath();
+
+ // 生成更自然的毛边函数
+ const createTornEdge = (startX, startY, endX, endY, intensity, steps) => {
+ const points = [];
+ const length = Math.sqrt(Math.pow(endX - startX, 2) + Math.pow(endY - startY, 2));
+ const baseStep = length / steps;
+
+
+ // 生成控制点
+ for (let i = 0; i <= steps; i++) {
+ const t = i / steps;
+ const x = startX + (endX - startX) * t;
+ const y = startY + (endY - startY) * t
+ // 使用噪声函数生成更自然的毛边
+ const noise = Math.sin(t * Math.PI * 4 * Math.random()) * intensity * 0.5 +
+ Math.sin(t * Math.PI * 8) * intensity * 0.3 +
+ Math.sin(t * Math.PI * 16 * Math.random()) * intensity * 0.2;
+
+ const perpendicularX = (endY - startY) / length;
+ const perpendicularY = (endX - startX) / length;
+ if (t < 0.2 || t > 0.8) points.push({
+ x: x,
+ y: y
+ });
+ else
+ points.push({
+ x: x + perpendicularX * noise * (0.8 + Math.random() * 0.4),
+ y: y + perpendicularY * noise * (0.8 + Math.random() * 0.4)
+ });
+
+ }
+
+ // 绘制毛边路径
+ ctx.lineTo(points[0].x, points[0].y);
+ for (let i = 1; i < points.length; i++) {
+ const p = points[i];
+ const prev = points[i - 1];
+
+ // 使用二次贝塞尔曲线使过渡更平滑
+ const cpX = (prev.x + p.x) / 2;
+ const cpY = (prev.y + p.y) / 2;
+ ctx.quadraticCurveTo(cpX, cpY, p.x, p.y);
+ }
+ };
+ ctx.moveTo(0, 0);
+
+ // 上边缘曲线(添加毛边)
+
+ createTornEdge(0, 0, 300, 0, Math.random() * 10 + 10, Math.random() * 60 + 10);
+ ctx.lineTo(300, 0)
+
+ // 右侧边缘(根据方向决定是否添加毛边)
+ if (dir === "right") {
+ createTornEdge(300, 0, 300, 400, Math.random() * 10 + 10, Math.random() * 60 + 10);
+ ctx.lineTo(300, 400)
+ } else {
+ ctx.lineTo(300, 400);
+ }
+
+ // 下边缘曲线(添加毛边)
+
+ createTornEdge(300, 400, 0, 400, Math.random() * 10 + 10, Math.random() * 60 + 10);
+
+ ctx.lineTo(0, 400)
+ // 左侧边缘(根据方向决定是否添加毛边)
+ if (dir === "left") {
+ createTornEdge(0, 400, 0, 0, Math.random() * 10 + 10, Math.random() * 60 + 10);
+ ctx.lineTo(0, 0)
+ } else {
+ ctx.lineTo(0, 0);
+ }
+
+ ctx.closePath();
+ };
+
+ // 创建上蒙版(顶部有毛边)
+ createTornEdgePath(curveCtx);
+ curveCtx.fillStyle = 'white';
+ curveCtx.fill();
+
+ // 创建下蒙版(底部有毛边)
+ curveCtx.clearRect(0, 0, 300, 400);
+ createTornEdgePath(curveCtx);
+ curveCtx.fillStyle = 'white';
+ curveCtx.fill();
+
+ return curveCanvas;
+ };
+
+
+ // 创建书页内容 (400px高,居中放置)
+ const createPageContent = () => {
+ const canvas = document.createElement('canvas');
+ canvas.width = 300;
+ canvas.height = 400;
+ const gl = canvas.getContext('webgl') || canvas.getContext('experimental-webgl');
+ const contentCanvas = document.createElement('canvas');
+ contentCanvas.width = 300;
+ contentCanvas.height = 400;
+ const contentCtx = contentCanvas.getContext('2d');
+
+ // 生成羊皮纸基础色(更精细的暖色调范围)
+ const baseHue = 45; // 35-60黄色到橙色范围
+ const baseSaturation = 40; // 25-50%饱和度
+ const baseLightness = 70; // 80-95%亮度
+
+ // 创建高度自然的基底纹理
+ const createOrganicBase = () => {
+ if (gl) {
+ // 创建WebGL着色器程序
+ const vertShader = gl.createShader(gl.VERTEX_SHADER);
+ gl.shaderSource(vertShader, `
+ attribute vec2 position;
+ void main() {
+ gl_Position = vec4(position, 0.0, 1.0);
+ }
+ `);
+ gl.compileShader(vertShader);
+
+ const fragShader = gl.createShader(gl.FRAGMENT_SHADER);
+ gl.shaderSource(fragShader, `
+ precision highp float;
+
+ // 噪声函数
+ float noise(vec2 p) {
+ return fract(sin(dot(p, vec2(12.9898, 78.233))) * 43758.5453);
+ }
+
+ // 简化版Perlin噪声
+ float perlinNoise(vec2 p) {
+ vec2 i = floor(p);
+ vec2 f = fract(p);
+
+ // 四个角落的随机值
+ float a = noise(i);
+ float b = noise(i + vec2(1.0, 0.0));
+ float c = noise(i + vec2(0.0, 1.0));
+ float d = noise(i + vec2(1.0, 1.0));
+
+ // 平滑插值
+ vec2 u = f * f * (3.0 - 2.0 * f);
+
+ return mix(a, b, u.x) +
+ (c - a) * u.y * (1.0 - u.x) +
+ (d - b) * u.x * u.y;
+ }
+
+ // HSL转RGB
+ vec3 hsl2rgb(float h, float s, float l) {
+ float c = (1.0 - abs(2.0 * l - 1.0)) * s;
+ float x = c * (1.0 - abs(mod(h / 60.0, 2.0) - 1.0));
+ float m = l - c / 2.0;
+
+ if (h < 60.0) return vec3(c + m, x + m, m);
+ else if (h < 120.0) return vec3(x + m, c + m, m);
+ else if (h < 180.0) return vec3(m, c + m, x + m);
+ else if (h < 240.0) return vec3(m, x + m, c + m);
+ else if (h < 300.0) return vec3(x + m, m, c + m);
+ else return vec3(c + m, m, x + m);
+ }
+
+ void main() {
+ vec2 uv = gl_FragCoord.xy / vec2(300.0, 400.0);
+
+ // 多层Perlin噪声叠加
+ float n = perlinNoise(uv * 10.0) * 0.5 +
+ perlinNoise(uv * 30.0) * 0.3 +
+ perlinNoise(uv * 60.0) * 0.2;
+
+ // 基础颜色参数
+ float baseHue = 45.0;
+ float baseSaturation = 0.35;
+ float baseLightness = 0.6;
+
+ // 应用噪声变化
+ float hue = mod(baseHue + n * 10.0, 360.0);
+ float saturation = clamp(baseSaturation + n * 0.15, 0.1, 0.7);
+ float lightness = clamp(baseLightness + n * 0.08, 0.7, 0.98);
+
+ // 转换为RGB
+ vec3 color = hsl2rgb(hue, saturation, lightness);
+
+ gl_FragColor = vec4(color, 1.0);
+ }
+ `);
+ gl.compileShader(fragShader);
+ const program = gl.createProgram();
+ gl.attachShader(program, vertShader);
+ gl.attachShader(program, fragShader);
+ gl.linkProgram(program);
+ gl.useProgram(program);
+
+ // 创建全屏四边形
+ const buffer = gl.createBuffer();
+ gl.bindBuffer(gl.ARRAY_BUFFER, buffer);
+ gl.bufferData(gl.ARRAY_BUFFER, new Float32Array([
+ -1, -1, 1, -1, -1, 1,
+ -1, 1, 1, -1, 1, 1
+ ]), gl.STATIC_DRAW);
+
+ const positionLoc = gl.getAttribLocation(program, "position");
+ gl.enableVertexAttribArray(positionLoc);
+ gl.vertexAttribPointer(positionLoc, 2, gl.FLOAT, false, 0, 0);
+
+ // 渲染到canvas
+ gl.viewport(0, 0, 300, 400);
+ gl.drawArrays(gl.TRIANGLES, 0, 6);
+ contentCtx.drawImage(canvas, 0, 0, 300, 400)
+ } else {
+ console.warn("当前浏览器不支持webgl,回退使用canvas2d实现")
+ // 基础底色(轻微噪点纹理)
+ contentCtx.fillStyle = `hsl(${baseHue}, ${baseSaturation}%, ${baseLightness}%)`;
+ contentCtx.fillRect(0, 0, 300, 400);
+
+ // 生成有机噪点纹理(模拟羊皮纸纤维)
+ const noiseData = contentCtx.createImageData(300, 400);
+ for (let i = 0; i < noiseData.data.length; i += 4) {
+ // Perlin噪声生成更自然的纹理
+ const x = (i / 4) % 300;
+ const y = Math.floor((i / 4) / 300);
+ const noiseVal = this.perlinNoise(x / 50, y / 50) * 0.5 +
+ this.perlinNoise(x / 20, y / 20) * 0.3 +
+ this.perlinNoise(x / 5, y / 5) * 0.2;
+
+ // 基于噪声调整颜色
+ const hueVar = noiseVal * 10;
+ const satVar = noiseVal * 15;
+ const lightVar = noiseVal * 8;
+
+ noiseData.data[i] = this.HSLtoRGB(
+ (baseHue + hueVar) % 360,
+ Math.max(10, Math.min(70, baseSaturation + satVar)),
+ Math.max(70, Math.min(98, baseLightness + lightVar))
+ ).r;
+ noiseData.data[i + 1] = this.HSLtoRGB(
+ (baseHue + hueVar) % 360,
+ Math.max(10, Math.min(70, baseSaturation + satVar)),
+ Math.max(70, Math.min(98, baseLightness + lightVar))
+ ).g;
+ noiseData.data[i + 2] = this.HSLtoRGB(
+ (baseHue + hueVar) % 360,
+ Math.max(10, Math.min(70, baseSaturation + satVar)),
+ Math.max(70, Math.min(98, baseLightness + lightVar))
+ ).b;
+ noiseData.data[i + 3] = 255;
+ }
+ contentCtx.putImageData(noiseData, 0, 0);
+ }
+ };
+ createOrganicBase();
+ // 更自然的边缘破损效果
+ const addEdgeTears = () => {
+ const tearCount = Math.floor(Math.random() * 4) + 2;
+
+ for (let i = 0; i < tearCount; i++) {
+ const size = 5 + Math.random() * 12;
+ const roughness = 2 + Math.random() * 3;
+
+ if (dir === "left") {
+ // 左侧边缘破损
+ if (Math.random() > 0.3) {
+ const y = Math.random() * 350 + 25;
+ createOrganicTear(0, y, size, Math.PI / 2, roughness);
+ } else {
+ const x = Math.random() * 50;
+ const y = Math.random() > 0.5 ? 0 : 400;
+ createOrganicTear(x, y, size * 0.7, Math.random() > 0.5 ? 0 : Math.PI, roughness);
+ }
+ } else {
+ // 右侧边缘破损
+ if (Math.random() > 0.3) {
+ const y = Math.random() * 350 + 25;
+ createOrganicTear(300, y, size, -Math.PI / 2, roughness);
+ } else {
+ const x = 250 + Math.random() * 50;
+ const y = Math.random() > 0.5 ? 0 : 400;
+ createOrganicTear(x, y, size * 0.7, Math.random() > 0.5 ? 0 : Math.PI, roughness);
+ }
+ }
+ }
+
+ function createOrganicTear(x, y, size, angle, roughness) {
+ const points = [];
+ const steps = 10 + Math.floor(Math.random() * 10);
+
+ // 生成有机形状的点
+ for (let i = 0; i <= steps; i++) {
+ const t = i / steps;
+ const r = size * (0.8 + Math.random() * 0.4);
+ const a = angle + Math.PI + t * Math.PI;
+ const noiseX = (Math.random() * 2 - 1) * roughness;
+ const noiseY = (Math.random() * 2 - 1) * roughness;
+
+ points.push({
+ x: x + r * Math.cos(a) * (0.5 + t * 0.5) + noiseX,
+ y: y + r * Math.sin(a) * (0.5 + t * 0.5) + noiseY
+ });
+ }
+
+ // 绘制破损形状
+ contentCtx.beginPath();
+ contentCtx.moveTo(x, y);
+ points.forEach(p => contentCtx.lineTo(p.x, p.y));
+ contentCtx.closePath();
+
+ // 破损内部阴影
+ contentCtx.fillStyle = `rgba(140, 110, 80, ${0.18 + Math.random()*0.07})`;
+ contentCtx.fill();
+
+ // 破损边缘线
+ contentCtx.lineWidth = 0.3 + Math.random() * 0.4;
+ contentCtx.strokeStyle = `rgba(100, 80, 60, ${0.4 + Math.random()*0.2})`;
+ contentCtx.stroke();
+
+ // 添加一些细节线条
+ for (let j = 0; j < 2; j++) {
+ contentCtx.beginPath();
+ const detailX = x + (points[0].x - x) * 0.3 * (j + 1);
+ const detailY = y + (points[0].y - y) * 0.3 * (j + 1);
+ contentCtx.moveTo(detailX, detailY);
+
+ for (let k = 1; k < points.length; k++) {
+ const p = points[k];
+ const toX = x + (p.x - x) * 0.3 * (j + 1);
+ const toY = y + (p.y - y) * 0.3 * (j + 1);
+ contentCtx.lineTo(toX, toY);
+ }
+
+ contentCtx.lineWidth = 0.1 + Math.random() * 0.2;
+ contentCtx.strokeStyle = `rgba(120, 90, 70, ${0.3 + Math.random()*0.1})`;
+ contentCtx.stroke();
+ }
+ }
+ };
+ addEdgeTears();
+ /**
+ * 根据方向调整边缘阴影强度,适配弯曲蒙版
+ * @param {string} dir 方向参数('left'或'right')
+ */
+ const addMasterfulEdgeShadows = (dir) => {
+ const shadowHue = baseHue - 8;
+ const shadowSaturation = baseSaturation + 15;
+ const shadowLightness = baseLightness * 0.55;
+ const shadowSize = 10;
+ // 转换为RGB
+ const rgb = this.HSLtoRGB(shadowHue, shadowSaturation, shadowLightness);
+ const shadowCanvas = document.createElement('canvas');
+ shadowCanvas.width = 300;
+ shadowCanvas.height = 400;
+ const shadowCtx = shadowCanvas.getContext('2d');
+
+ const topShadow = ctx.createLinearGradient(0, 0, 0, shadowSize);
+ topShadow.addColorStop(0, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, 0.7)`);
+ topShadow.addColorStop(1, "transparent");
+ shadowCtx.fillStyle = topShadow;
+ shadowCtx.beginPath()
+ shadowCtx.moveTo(0, 0)
+ shadowCtx.lineTo(300, 0)
+ shadowCtx.lineTo(300 - shadowSize * (dir === "left" ? 0.6 : 1), shadowSize)
+ shadowCtx.lineTo(shadowSize * (dir === "left" ? 1 : 0.6), shadowSize)
+ shadowCtx.lineTo(0, 0)
+ shadowCtx.closePath()
+ shadowCtx.fill()
+
+
+ const leftShadow = ctx.createLinearGradient(0, 0, shadowSize * (dir === "left" ? 1 : 0.6), 0);
+ leftShadow.addColorStop(0, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b},${dir === "left"?0.7:0.6*0.7})`);
+ leftShadow.addColorStop(1, "transparent");
+ shadowCtx.fillStyle = leftShadow;
+ shadowCtx.beginPath()
+ shadowCtx.moveTo(0, 0)
+ shadowCtx.lineTo(shadowSize * (dir === "left" ? 1 : 0.6), shadowSize)
+ shadowCtx.lineTo(shadowSize * (dir === "left" ? 1 : 0.6), 400 - shadowSize)
+ shadowCtx.lineTo(0, 400)
+ shadowCtx.lineTo(0, 0)
+ shadowCtx.closePath()
+ shadowCtx.fill()
+
+
+ const rightShadow = ctx.createLinearGradient(300, 0, 300 - shadowSize * (dir === "left" ? 0.6 : 1), 0);
+ rightShadow.addColorStop(0, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, ${dir === "left"?0.7*0.6:0.7})`);
+ rightShadow.addColorStop(1, "transparent");
+ shadowCtx.fillStyle = rightShadow;
+ shadowCtx.beginPath()
+ shadowCtx.moveTo(300, 0)
+ shadowCtx.lineTo(300 - shadowSize * (dir === "left" ? 0.6 : 1), shadowSize)
+ shadowCtx.lineTo(300 - shadowSize * (dir === "left" ? 0.6 : 1), 400 - shadowSize)
+ shadowCtx.lineTo(300, 400)
+ shadowCtx.lineTo(3000, 0)
+ shadowCtx.closePath()
+ shadowCtx.fill()
+
+ const bottomShadow = ctx.createLinearGradient(0, 400, 0, 400 - shadowSize);
+ bottomShadow.addColorStop(0, `rgba(${rgb.r}, ${rgb.g}, ${rgb.b}, 0.7)`);
+ bottomShadow.addColorStop(1, "transparent");
+ shadowCtx.fillStyle = bottomShadow;
+ shadowCtx.beginPath()
+ shadowCtx.moveTo(0, 400)
+ shadowCtx.lineTo(shadowSize * (dir === "left" ? 1 : 0.6), 400 - shadowSize)
+ shadowCtx.lineTo(300 - shadowSize * (dir === "left" ? 0.6 : 1), 400 - shadowSize)
+ shadowCtx.lineTo(300, 400)
+ shadowCtx.lineTo(0, 400)
+ shadowCtx.closePath()
+ shadowCtx.fill()
+ shadowCtx.fillRect(0, 400 - shadowSize, 300, shadowSize);
+
+
+ const createHighlight = () => {
+ const highlightCanvas = document.createElement('canvas');
+ highlightCanvas.width = 300;
+ highlightCanvas.height = 400;
+ const highlightCtx = highlightCanvas.getContext('2d');
+ highlightCtx.clearRect(0, 0, 300, 400);
+
+ // 根据方向设置高光位置
+ const gradient = dir === 'right' ?
+ highlightCtx.createLinearGradient(0, 0, 10, 0) :
+ highlightCtx.createLinearGradient(300, 0, 290, 0);
+
+ gradient.addColorStop(1, 'rgba(0,0,0,0)');
+ gradient.addColorStop(0.2, 'rgba(0,0,0,0.4)');
+ gradient.addColorStop(0, 'rgba(0,0,0,0.7)');
+
+ highlightCtx.fillStyle = gradient;
+ highlightCtx.fillRect(dir === 'right' ? 0 : 290, 0, 10, 400);
+
+
+ return highlightCanvas;
+ };
+ //应用高光
+ contentCtx.drawImage(createHighlight(), 0, 0)
+ // 应用阴影
+ contentCtx.globalCompositeOperation = 'multiply';
+ contentCtx.drawImage(shadowCanvas, 0, 0);
+ contentCtx.globalCompositeOperation = 'source-over'
+
+ }
+ addMasterfulEdgeShadows(dir);
+
+ // 超真实细节系统
+ const addHyperRealisticDetails = () => {
+ // 3.1 纤维纹理(模拟羊皮纸纤维)
+ for (let i = 0; i < 2000; i++) {
+ const x = Math.random() * 300;
+ const y = Math.random() * 400;
+ const length = 1 + Math.random() * 4;
+ const angle = Math.random() * Math.PI * 2;
+ const lightVar = (Math.random() > 0.5 ? 5 : -5) * (0.5 + Math.random());
+
+ contentCtx.beginPath();
+ contentCtx.moveTo(x, y);
+ contentCtx.lineTo(
+ x + Math.cos(angle) * length,
+ y + Math.sin(angle) * length
+ );
+ contentCtx.strokeStyle = `hsla(
+ ${baseHue + (Math.random() - 0.5) * 8},
+ ${baseSaturation * (0.7 + Math.random() * 0.6)}%,
+ ${baseLightness + lightVar}%,
+ ${0.03 + Math.random() * 0.04}
+ )`;
+ contentCtx.lineWidth = 0.2 + Math.random() * 0.3;
+ contentCtx.stroke();
+ }
+
+ // 自然划痕系统
+ for (let i = 0; i < 10 + Math.random() * 10; i++) {
+ const scratchLength = 15 + Math.random() * 60;
+ const startX = Math.random() * 300;
+ const startY = Math.random() * 400;
+ const angle = Math.random() * Math.PI * 2;
+ const curveIntensity = 5 + Math.random() * 10;
+
+ // 主划痕路径
+ contentCtx.beginPath();
+ contentCtx.moveTo(startX, startY);
+
+ // 贝塞尔曲线控制点
+ const cp1x = startX + Math.cos(angle) * scratchLength * 0.3 + (Math.random() - 0.5) * curveIntensity;
+ const cp1y = startY + Math.sin(angle) * scratchLength * 0.3 + (Math.random() - 0.5) * curveIntensity;
+ const cp2x = startX + Math.cos(angle) * scratchLength * 0.7 + (Math.random() - 0.5) * curveIntensity;
+ const cp2y = startY + Math.sin(angle) * scratchLength * 0.7 + (Math.random() - 0.5) * curveIntensity;
+ const endX = startX + Math.cos(angle) * scratchLength;
+ const endY = startY + Math.sin(angle) * scratchLength;
+
+ contentCtx.bezierCurveTo(cp1x, cp1y, cp2x, cp2y, endX, endY);
+
+ // 划痕样式(宽度变化)
+ const lineWidth = 0.1 + Math.random() * 0.4;
+ const scratchDarkness = 0.6 + Math.random() * 0.3;
+
+ contentCtx.strokeStyle = `hsla(
+ ${baseHue - 5 + Math.random() * 10},
+ ${baseSaturation + 5 + Math.random() * 15}%,
+ ${baseLightness * scratchDarkness}%,
+ ${0.4 + Math.random() * 0.3}
+ )`;
+ contentCtx.lineWidth = lineWidth;
+ contentCtx.lineCap = 'round';
+ contentCtx.stroke();
+
+ // 划痕高光(模拟凹陷)
+ if (Math.random() > 0.3) {
+ contentCtx.beginPath();
+ contentCtx.moveTo(
+ startX + (Math.random() - 0.5) * lineWidth * 2,
+ startY + (Math.random() - 0.5) * lineWidth * 2
+ );
+ contentCtx.bezierCurveTo(
+ cp1x + (Math.random() - 0.5) * lineWidth * 2,
+ cp1y + (Math.random() - 0.5) * lineWidth * 2,
+ cp2x + (Math.random() - 0.5) * lineWidth * 2,
+ cp2y + (Math.random() - 0.5) * lineWidth * 2,
+ endX + (Math.random() - 0.5) * lineWidth * 2,
+ endY + (Math.random() - 0.5) * lineWidth * 2
+ );
+
+ contentCtx.strokeStyle = `hsla(
+ ${baseHue + 5 + Math.random() * 5},
+ ${baseSaturation * 0.7}%,
+ ${baseLightness * 1.1}%,
+ ${0.2 + Math.random() * 0.1}
+ )`;
+ contentCtx.lineWidth = lineWidth * 0.7;
+ contentCtx.stroke();
+ }
+ }
+
+ // 专业级污渍系统
+ for (let i = 0; i < 3 + Math.random() * 5; i++) {
+ const stainType = Math.floor(Math.random() * 3); // 0: 液体污渍, 1: 指纹, 2: 老化斑点
+
+
+ if (stainType === 1) {
+ // 指纹污渍
+ const centerX = Math.random() * 300;
+ const centerY = Math.random() * 400;
+ const size = 10 + Math.random() * 15;
+ const rotation = Math.random() * Math.PI * 2;
+
+ // 指纹纹路
+ for (let j = 0; j < 15 + Math.random() * 10; j++) {
+ const radius = size * (0.3 + Math.random() * 0.7);
+ const angle = (j / 15) * Math.PI * 2 + rotation;
+ const width = size * (0.03 + Math.random() * 0.05);
+
+ contentCtx.beginPath();
+ contentCtx.arc(
+ centerX + Math.cos(angle) * radius * 0.5,
+ centerY + Math.sin(angle) * radius * 0.5,
+ width, 0, Math.PI * 2
+ );
+
+ contentCtx.fillStyle = `hsla(
+ ${baseHue - 5 + Math.random() * 10},
+ ${baseSaturation + 5}%,
+ ${baseLightness * 0.8}%,
+ ${0.1 + Math.random() * 0.05}
+ )`;
+ contentCtx.fill();
+ }
+ } else {
+ // 老化斑点
+ const centerX = Math.random() * 300;
+ const centerY = Math.random() * 400;
+ const size = 5 + Math.random() * 15;
+ const points = 8 + Math.floor(Math.random() * 6);
+
+ contentCtx.beginPath();
+ contentCtx.moveTo(
+ centerX + size * Math.cos(0),
+ centerY + size * Math.sin(0)
+ );
+
+ for (let j = 1; j <= points; j++) {
+ const angle = (j / points) * Math.PI * 2;
+ const radius = size * (0.7 + Math.random() * 0.6);
+ contentCtx.lineTo(
+ centerX + radius * Math.cos(angle),
+ centerY + radius * Math.sin(angle)
+ );
+ }
+ contentCtx.closePath();
+
+ const gradient = contentCtx.createRadialGradient(
+ centerX, centerY, 0,
+ centerX, centerY, size * 1.2
+ );
+ gradient.addColorStop(0, `hsla(
+ ${baseHue - 15 + Math.random() * 20},
+ ${baseSaturation + 20}%,
+ ${baseLightness * 0.5}%,
+ ${0.2 + Math.random() * 0.1}
+ )`);
+ gradient.addColorStop(1, 'hsla(0, 0%, 0%, 0)');
+
+ contentCtx.fillStyle = gradient;
+ contentCtx.fill();
+ }
+ }
+
+
+ };
+
+
+
+
+ addHyperRealisticDetails();
+
+ return contentCanvas;
+ }
+
+ // 创建弯曲阴影(新增)
+ const createCurvedShadow = () => {
+ const shadowCanvas = document.createElement('canvas');
+ shadowCanvas.width = 300;
+ shadowCanvas.height = 400;
+ const shadowCtx = shadowCanvas.getContext('2d');
+ shadowCtx.clearRect(0, 0, 300, 400);
+
+ // 绘制顶部阴影(跟随曲线)
+ const topShadow = shadowCtx.createLinearGradient(0, 0, 0, 50);
+ topShadow.addColorStop(0, 'rgba(0,0,0,0.25)');
+ topShadow.addColorStop(1, 'rgba(0,0,0,0)');
+
+
+ shadowCtx.fillStyle = topShadow;
+ shadowCtx.fillRect(0, 0, 300, 50);
+
+
+ // 绘制底部阴影(跟随曲线)
+ const bottomShadow = shadowCtx.createLinearGradient(0, 350, 0, 400);
+ bottomShadow.addColorStop(0, 'rgba(0,0,0,0)');
+ bottomShadow.addColorStop(1, 'rgba(0,0,0,0.25)');
+
+
+ shadowCtx.fillStyle = bottomShadow;
+ shadowCtx.fillRect(0, 350, 300, 50);
+
+
+ return shadowCanvas;
+ };
+
+ // 应用弯曲变形
+ const applyPageCurve = (content, mask) => {
+ const resultCanvas = document.createElement('canvas');
+ resultCanvas.width = 300;
+ resultCanvas.height = 400;
+ const resultCtx = resultCanvas.getContext('2d');
+ resultCtx.clearRect(0, 0, 300, 400);
+
+
+
+ // 绘制内容并应用蒙版
+ resultCtx.drawImage(content, 0, 0);
+ resultCtx.globalCompositeOperation = 'destination-in';
+ resultCtx.drawImage(mask, 0, 0);
+ resultCtx.globalCompositeOperation = 'source-over';
+
+ return resultCanvas;
+ };
+
+ // 主流程
+ const mask = createPageCurveMask();
+ const content = createPageContent();
+ const curvedPage = applyPageCurve(content, mask);
+
+ // 最终绘制
+ textureCtx.drawImage(curvedPage, 0, 0);
+
+ return textureCanvas;
+ }
+
+ // 辅助函数(需要在类中定义)
+ /**
+ * 2D Perlin噪声生成器
+ * @param {number} x x坐标
+ * @param {number} y y坐标
+ * @returns {number} 噪声值(-1到1之间)
+ */
+ perlinNoise(x, y) {
+ // 梯度向量表
+ const grad3 = [
+ [1, 1, 0],
+ [-1, 1, 0],
+ [1, -1, 0],
+ [-1, -1, 0],
+ [1, 0, 1],
+ [-1, 0, 1],
+ [1, 0, -1],
+ [-1, 0, -1],
+ [0, 1, 1],
+ [0, -1, 1],
+ [0, 1, -1],
+ [0, -1, -1]
+ ];
+
+ // 置换表(随机排列0-255)
+ if (!this.perm) {
+ this.perm = new Array(512);
+ for (let i = 0; i < 256; i++) {
+ this.perm[i] = this.perm[i + 256] = Math.floor(Math.random() * 256);
+ }
+ }
+
+ // 辅助函数
+ const dot = (g, x, y) => g[0] * x + g[1] * y;
+ const fade = t => t * t * t * (t * (t * 6 - 15) + 10);
+ const lerp = (a, b, t) => a + t * (b - a);
+
+ // 确定单元方块
+ const X = Math.floor(x) & 255;
+ const Y = Math.floor(y) & 255;
+
+ // 相对单元方块的坐标
+ x -= Math.floor(x);
+ y -= Math.floor(y);
+
+ // 计算四个角落的梯度贡献
+ const n00 = dot(grad3[this.perm[X + this.perm[Y]] % 12], x, y);
+ const n01 = dot(grad3[this.perm[X + this.perm[Y + 1]] % 12], x, y - 1);
+ const n10 = dot(grad3[this.perm[X + 1 + this.perm[Y]] % 12], x - 1, y);
+ const n11 = dot(grad3[this.perm[X + 1 + this.perm[Y + 1]] % 12], x - 1, y - 1);
+
+ // 使用缓和曲线插值
+ const u = fade(x);
+ const v = fade(y);
+
+ return lerp(
+ lerp(n00, n10, u),
+ lerp(n01, n11, u),
+ v
+ );
+ }
+
+ /**
+ * HSL颜色空间转RGB
+ * @param {number} h 色相(0-360)
+ * @param {number} s 饱和度(0-100)
+ * @param {number} l 亮度(0-100)
+ * @returns {Object} {r, g, b} 各通道值(0-255)
+ */
+ HSLtoRGB(h, s, l) {
+ h /= 360;
+ s /= 100;
+ l /= 100;
+
+ let r, g, b;
+
+ if (s === 0) {
+ r = g = b = l; // 灰度
+ } else {
+ const hue2rgb = (p, q, t) => {
+ if (t < 0) t += 1;
+ if (t > 1) t -= 1;
+ if (t < 1 / 6) return p + (q - p) * 6 * t;
+ if (t < 1 / 2) return q;
+ if (t < 2 / 3) return p + (q - p) * (2 / 3 - t) * 6;
+ return p;
+ };
+
+ const q = l < 0.5 ? l * (1 + s) : l + s - l * s;
+ const p = 2 * l - q;
+
+ r = hue2rgb(p, q, h + 1 / 3);
+ g = hue2rgb(p, q, h);
+ b = hue2rgb(p, q, h - 1 / 3);
+ }
+
+ return {
+ r: Math.round(r * 255),
+ g: Math.round(g * 255),
+ b: Math.round(b * 255)
+ };
+ }
+
+
+ background() {
+ book.style.display = "block"
+
+ if (core.domStyle.isVertical) {
+ core.maps._setHDCanvasSize(ctx, 416, 676)
+ ctx.save();
+ ctx.translate(416, 0);
+ ctx.rotate(Math.PI / 2);
+ } else {
+ core.maps._setHDCanvasSize(ctx, 676, 416)
+ ctx.save();
+ }
+
+ // 1. 先绘制背景底色
+ core.fillRect(ctx, 0, 0, 676, 416, "#000000")
+
+ // 2. 绘制书脊和封面背景
+ const dx = (676 - this.width * 2) / 2,
+ dy = (416 - this.height) / 2
+
+
+ //绘制打开的书皮,416*676,暗红色
+ const bookWidth = 676;
+ const bookHeight = 416;
+ const spineWidth = 26;
+ const spineX = bookWidth / 2;
+
+ const foldSize = 8; // 折角大小
+
+ // 左侧连接处折角
+ ctx.fillStyle = "rgba(60, 40, 20, 0.6)";
+ ctx.beginPath();
+ // 上部折角
+ ctx.moveTo(spineX - spineWidth / 2, 0);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize, foldSize);
+ ctx.lineTo(spineX - spineWidth / 2, foldSize * 2);
+ // 下部折角
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize, bookHeight - foldSize);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.fill();
+
+ // 右侧连接处折角
+ ctx.beginPath();
+ // 上部折角
+ ctx.moveTo(spineX + spineWidth / 2, 0);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize, foldSize);
+ ctx.lineTo(spineX + spineWidth / 2, foldSize * 2);
+ // 下部折角
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize, bookHeight - foldSize);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.fill();
+
+ // 添加折角高光效果
+ ctx.strokeStyle = "rgba(200, 180, 150, 0.3)";
+ ctx.lineWidth = 1;
+ // 左侧高光
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, foldSize * 2);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize / 2, foldSize * 1.5);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.lineTo(spineX - spineWidth / 2 - foldSize / 2, bookHeight - foldSize * 1.5);
+ ctx.stroke();
+ // 右侧高光
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, foldSize * 2);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize / 2, foldSize * 1.5);
+ ctx.stroke();
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight - foldSize * 2);
+ ctx.lineTo(spineX + spineWidth / 2 + foldSize / 2, bookHeight - foldSize * 1.5);
+ ctx.stroke();
+ // 创建更丰富的书皮渐变
+ const coverGradient = ctx.createLinearGradient(0, 0, bookWidth, 0);
+ coverGradient.addColorStop(0, "#6b3a3a");
+ coverGradient.addColorStop(0.49, "#4a2222");
+ coverGradient.addColorStop(0.5, "#4a2222");
+ coverGradient.addColorStop(0.51, "#4a2222");
+ coverGradient.addColorStop(1, "#6b3a3a");
+
+ // 绘制书皮主体
+ ctx.fillStyle = coverGradient;
+ ctx.beginPath();
+ ctx.moveTo(0, 0);
+ ctx.lineTo(bookWidth, 0);
+ ctx.lineTo(bookWidth, bookHeight);
+ ctx.lineTo(0, bookHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 添加精美的边缘花纹
+
+ ctx.strokeStyle = "rgba(180, 140, 100, 0.4)";
+ ctx.lineWidth = 2;
+
+ // 顶部花纹
+ ctx.beginPath();
+ for (let x = 20; x < bookWidth; x += 40) {
+ ctx.moveTo(x, 5);
+ ctx.lineTo(x + 10, 15);
+ ctx.lineTo(x + 20, 5);
+ }
+ ctx.stroke();
+
+ // 底部花纹
+ ctx.beginPath();
+ for (let x = 10; x < bookWidth; x += 40) {
+ ctx.moveTo(x, bookHeight - 5);
+ ctx.lineTo(x + 15, bookHeight - 15);
+ ctx.lineTo(x + 30, bookHeight - 5);
+ }
+ ctx.stroke();
+
+
+ // 添加精美的书脊装饰
+
+
+
+ // 书脊主线条
+ ctx.strokeStyle = "rgba(120, 80, 60, 0.8)";
+ ctx.lineWidth = 2;
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, 0);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight);
+ ctx.moveTo(spineX + spineWidth / 2, 0);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight);
+ ctx.stroke();
+
+ // 书脊装饰花纹 - 古典风格
+ ctx.fillStyle = "rgba(200, 160, 120, 0.3)";
+ for (let y = 50; y < bookHeight; y += 80) {
+ // 花纹单元
+ ctx.beginPath();
+ ctx.moveTo(spineX, y - 15);
+ ctx.lineTo(spineX - 8, y - 5);
+ ctx.lineTo(spineX - 12, y + 5);
+ ctx.lineTo(spineX - 8, y + 15);
+ ctx.lineTo(spineX, y + 20);
+ ctx.lineTo(spineX + 8, y + 15);
+ ctx.lineTo(spineX + 12, y + 5);
+ ctx.lineTo(spineX + 8, y - 5);
+ ctx.closePath();
+ ctx.fill();
+
+ // 连接线
+ ctx.strokeStyle = "rgba(180, 140, 100, 0.4)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.moveTo(spineX, y + 20);
+ ctx.lineTo(spineX, y + 60);
+ ctx.stroke();
+ }
+
+
+ // 添加更精细的阴影效果
+
+ ctx.shadowColor = "rgba(0, 0, 0, 0.6)";
+ ctx.shadowBlur = 20;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+ // 重新绘制边缘以应用阴影
+ ctx.strokeStyle = "rgba(80, 50, 30, 0.8)";
+ ctx.lineWidth = 4;
+ ctx.beginPath();
+ ctx.rect(2, 2, bookWidth - 4, bookHeight - 4);
+ ctx.stroke();
+
+
+ // 添加精细的皮质纹理
+
+ ctx.fillStyle = "rgba(40, 25, 15, 0.08)";
+
+ // 水平纹理
+ for (let y = 10; y < bookHeight; y += 8) {
+ ctx.beginPath();
+ ctx.moveTo(0, y);
+ for (let x = 0; x < bookWidth; x += 20) {
+ ctx.lineTo(x, y + (x % 40 < 20 ? 2 : -2));
+ }
+ ctx.lineTo(bookWidth, y);
+ ctx.lineTo(bookWidth, y + 1);
+ for (let x = bookWidth; x > 0; x -= 20) {
+ ctx.lineTo(x, y + 1 + (x % 40 < 20 ? -1 : 1));
+ }
+ ctx.closePath();
+ ctx.fill();
+ }
+
+ // 垂直纹理
+ ctx.fillStyle = "rgba(30, 20, 10, 0.05)";
+ for (let x = 10; x < bookWidth; x += 12) {
+ ctx.beginPath();
+ ctx.moveTo(x, 0);
+ for (let y = 0; y < bookHeight; y += 20) {
+ ctx.lineTo(x + (y % 40 < 20 ? 1 : -1), y);
+ }
+ ctx.lineTo(x + 1, bookHeight);
+ ctx.lineTo(x - 1, bookHeight);
+ for (let y = bookHeight; y > 0; y -= 20) {
+ ctx.lineTo(x + (y % 40 < 20 ? -1 : 1), y);
+ }
+ ctx.closePath();
+ ctx.fill();
+ }
+
+
+ // 添加精美的书角金属装饰
+
+ const cornerSize = 30;
+ const cornerGradient = ctx.createLinearGradient(0, 0, cornerSize, cornerSize);
+ cornerGradient.addColorStop(0, "rgba(200, 170, 100, 0.8)");
+ cornerGradient.addColorStop(1, "rgba(150, 120, 70, 0.8)");
+
+ // 四个角
+
+
+
+ let [x, y] = [0, 0];
+ // 绘制三角形装饰
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + cornerSize, y);
+ ctx.lineTo(x, y + cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, 0, Math.PI / 2);
+ ctx.stroke();
+
+ // 绘制放射线装饰
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+
+ [x, y] = [bookWidth, 0]
+
+ // 绘制三角形装饰(水平翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x - cornerSize, y);
+ ctx.lineTo(x, y + cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(水平翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, Math.PI / 2, Math.PI);
+ ctx.stroke();
+
+ // 绘制放射线装饰(水平翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = Math.PI - i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+ [x, y] = [0, bookHeight]
+
+ // 绘制三角形装饰(垂直翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + cornerSize, y);
+ ctx.lineTo(x, y - cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(垂直翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, -Math.PI / 2, 0);
+ ctx.stroke();
+
+ // 绘制放射线装饰(垂直翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = -i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+ x = bookWidth;
+ y = bookHeight;
+
+ // 绘制三角形装饰(水平和垂直翻转)
+ ctx.fillStyle = cornerGradient;
+ ctx.beginPath();
+ ctx.moveTo(x, y);
+ ctx.lineTo(x - cornerSize, y);
+ ctx.lineTo(x, y - cornerSize);
+ ctx.closePath();
+ ctx.fill();
+
+ // 绘制弧线装饰(水平和垂直翻转)
+ ctx.strokeStyle = "rgba(80, 60, 30, 0.8)";
+ ctx.lineWidth = 1;
+ ctx.beginPath();
+ ctx.arc(x, y, cornerSize * 0.7, Math.PI, Math.PI * 3 / 2);
+ ctx.stroke();
+
+ // 绘制放射线装饰(水平和垂直翻转)
+ ctx.beginPath();
+ for (let i = 0; i < 5; i++) {
+ const a = Math.PI + i * Math.PI / 10;
+ ctx.moveTo(x, y);
+ ctx.lineTo(x + Math.cos(a) * cornerSize, y + Math.sin(a) * cornerSize);
+ }
+ ctx.stroke();
+
+ // 外边缘厚阴影
+ ctx.shadowColor = "rgba(0, 0, 0, 0.7)";
+ ctx.shadowBlur = 15;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+ ctx.strokeStyle = "rgba(80, 50, 30, 0.8)";
+ ctx.lineWidth = 4;
+ ctx.beginPath();
+ ctx.rect(2, 2, bookWidth - 4, bookHeight - 4);
+ ctx.stroke();
+
+ // 内边缘阴影(模拟厚度)
+ ctx.shadowColor = "transparent";
+ const innerShadowWidth = 8;
+
+ // 顶部内阴影
+ const topShadow = ctx.createLinearGradient(0, 0, 0, innerShadowWidth);
+ topShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ topShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = topShadow;
+ ctx.fillRect(0, 0, bookWidth, innerShadowWidth);
+
+ // 底部内阴影
+ const bottomShadow = ctx.createLinearGradient(0, bookHeight, 0, bookHeight - innerShadowWidth);
+ bottomShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ bottomShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = bottomShadow;
+ ctx.fillRect(0, bookHeight - innerShadowWidth, bookWidth, innerShadowWidth);
+
+ // 左侧内阴影
+ const leftShadow = ctx.createLinearGradient(0, 0, innerShadowWidth, 0);
+ leftShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ leftShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = leftShadow;
+ ctx.fillRect(0, 0, innerShadowWidth, bookHeight);
+
+ // 右侧内阴影
+ const rightShadow = ctx.createLinearGradient(bookWidth, 0, bookWidth - innerShadowWidth, 0);
+ rightShadow.addColorStop(0, "rgba(0, 0, 0, 0.4)");
+ rightShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = rightShadow;
+ ctx.fillRect(bookWidth - innerShadowWidth, 0, innerShadowWidth, bookHeight);
+
+ // 书脊两侧的特殊阴影
+
+ const spineShadowWidth = 4;
+
+ // 书脊左侧阴影
+ const spineLeftShadow = ctx.createLinearGradient(
+ spineX - spineWidth / 2, 0,
+ spineX - spineWidth / 2 - spineShadowWidth, 0
+ );
+ spineLeftShadow.addColorStop(0, "rgba(0, 0, 0, 0.5)");
+ spineLeftShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = spineLeftShadow;
+ ctx.fillRect(
+ spineX - spineWidth / 2 - spineShadowWidth, 0,
+ spineShadowWidth, bookHeight
+ );
+
+ // 书脊右侧阴影
+ const spineRightShadow = ctx.createLinearGradient(
+ spineX + spineWidth / 2, 0,
+ spineX + spineWidth / 2 + spineShadowWidth, 0
+ );
+ spineRightShadow.addColorStop(0, "rgba(0, 0, 0, 0.5)");
+ spineRightShadow.addColorStop(1, "transparent");
+ ctx.fillStyle = spineRightShadow;
+ ctx.fillRect(
+ spineX + spineWidth / 2, 0,
+ spineShadowWidth, bookHeight
+ );
+
+ const pageLiftHeight = 20;
+
+ // 左侧书页翻起效果
+ ctx.fillStyle = "rgba(250, 240, 230, 0.7)";
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - 5, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight / 2 + pageLiftHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 右侧书页翻起效果
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + 5, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight / 2 + pageLiftHeight);
+ ctx.closePath();
+ ctx.fill();
+
+ // 添加翻起部分的阴影
+ ctx.fillStyle = "rgba(0, 0, 0, 0.1)";
+ ctx.beginPath();
+ ctx.moveTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX - spineWidth / 2 - 5, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2 - 2, bookHeight / 2);
+ ctx.lineTo(spineX - spineWidth / 2, bookHeight / 2 - pageLiftHeight + 3);
+ ctx.closePath();
+ ctx.fill();
+
+ ctx.beginPath();
+ ctx.moveTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight);
+ ctx.lineTo(spineX + spineWidth / 2 + 5, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2 + 2, bookHeight / 2);
+ ctx.lineTo(spineX + spineWidth / 2, bookHeight / 2 - pageLiftHeight + 3);
+ ctx.closePath();
+ ctx.fill();
+
+ // 4. 绘制书页 - 添加抗锯齿边缘处理
+ // 先绘制一个作为书页底色
+ ctx.fillStyle = '#cfbf96';
+ ctx.beginPath();
+ ctx.moveTo(dx, dy);
+ ctx.lineTo(dx + 2 * this.width, dy);
+ ctx.lineTo(dx + 2 * this.width, this.height + dy);
+ ctx.lineTo(dx, this.height + dy);
+ ctx.closePath();
+
+ ctx.fill();
+ // 使用更精细的渐变填充
+ // 创建更复杂的渐变效果
+ const leftGradient = ctx.createLinearGradient(dx / 2, 0, dx, 0);
+ leftGradient.addColorStop(0, "#f0e8c8");
+ leftGradient.addColorStop(0.3, "#d8c8a0");
+ leftGradient.addColorStop(0.5, "#b09868");
+ leftGradient.addColorStop(0.7, "#9e804a");
+ leftGradient.addColorStop(1, "#8a6c3a");
+
+ // 绘制左侧封面
+ ctx.beginPath();
+ ctx.moveTo(dx, this.height + dy);
+ ctx.lineTo(dx / 2, this.height + dy);
+ ctx.lineTo(dx / 2, dy);
+ ctx.lineTo(dx, dy);
+ ctx.closePath();
+ ctx.fillStyle = leftGradient;
+ ctx.fill();
+
+ // 添加竖向条纹效果(像素感破旧边缘)
+
+ ctx.strokeStyle = "rgba(120, 90, 60, 0.3)";
+ ctx.lineWidth = 1;
+ for (let i = 0; i < 10; i++) {
+ const x = dx / 2 + i * 2;
+ ctx.beginPath();
+ ctx.moveTo(x, dy);
+ ctx.lineTo(x, dy + this.height);
+ ctx.stroke();
+ }
+
+
+ // 添加不规则暗色区域(不使用随机数)
+ ctx.fillStyle = "rgba(90, 70, 40, 0.15)";
+ ctx.beginPath();
+ ctx.moveTo(dx / 2 + 10, dy + 50);
+ ctx.lineTo(dx / 2 + 30, dy + 40);
+ ctx.lineTo(dx / 2 + 25, dy + 100);
+ ctx.lineTo(dx / 2 + 15, dy + 120);
+ ctx.closePath();
+ ctx.fill();
+
+ ctx.beginPath();
+ ctx.moveTo(dx / 2 + 5, dy + 180);
+ ctx.lineTo(dx / 2 + 35, dy + 200);
+ ctx.lineTo(dx / 2 + 20, dy + 250);
+ ctx.lineTo(dx / 2, dy + 230);
+ ctx.closePath();
+ ctx.fill();
+
+ // 右侧封面同理
+ const rightGradient = ctx.createLinearGradient(676 - dx, 0, 676 - dx / 2, 0);
+ rightGradient.addColorStop(0, "#8a6c3a");
+ rightGradient.addColorStop(0.3, "#9e804a");
+ rightGradient.addColorStop(0.5, "#b09868");
+ rightGradient.addColorStop(0.7, "#d8c8a0");
+ rightGradient.addColorStop(1, "#f0e8c8");
+
+ ctx.beginPath();
+ ctx.moveTo(676 - dx / 2, this.height + dy);
+ ctx.lineTo(676 - dx, this.height + dy);
+ ctx.lineTo(676 - dx, dy);
+ ctx.lineTo(676 - dx / 2, dy);
+ ctx.closePath();
+ ctx.fillStyle = rightGradient;
+ ctx.fill();
+
+ // 添加右侧竖向条纹
+
+ ctx.strokeStyle = "rgba(120, 90, 60, 0.3)";
+ ctx.lineWidth = 1;
+ for (let i = 0; i < 10; i++) {
+ const x = 676 - dx / 2 - i * 2;
+ ctx.beginPath();
+ ctx.moveTo(x, dy);
+ ctx.lineTo(x, dy + this.height);
+ ctx.stroke();
+ }
+
+
+ // 添加右侧不规则暗色区域
+ ctx.fillStyle = "rgba(90, 70, 40, 0.15)";
+ ctx.beginPath();
+ ctx.moveTo(676 - dx / 2 - 10, dy + 70);
+ ctx.lineTo(676 - dx / 2 - 25, dy + 80);
+ ctx.lineTo(676 - dx / 2 - 20, dy + 140);
+ ctx.lineTo(676 - dx / 2 - 5, dy + 130);
+ ctx.closePath();
+ ctx.fill();
+ // 添加书页边缘老化渐变效果
+ // 创建边缘渐变遮罩
+ const edgeGradient = ctx.createRadialGradient(
+ dx + this.width / 2, this.height / 2, 5, // 内圆
+ dx + this.width / 2, this.height / 2, Math.max(this.width, this.height) / 2 // 外圆
+ );
+ edgeGradient.addColorStop(0, "rgba(0,0,0,0)"); // 中心透明
+ edgeGradient.addColorStop(0.7, "rgba(0,0,0,0)"); // 中间部分透明
+ edgeGradient.addColorStop(1, "rgba(50,40,20,0.15)"); // 边缘轻微老化效果
+
+ // 应用边缘渐变
+ ctx.fillStyle = edgeGradient;
+ ctx.globalCompositeOperation = 'multiply'; // 使用乘法混合模式使边缘变暗
+ ctx.beginPath();
+ ctx.moveTo(dx, dy);
+ ctx.lineTo(dx + 2 * this.width, dy);
+ ctx.lineTo(dx + 2 * this.width, this.height + dy);
+ ctx.lineTo(dx, this.height + dy);
+ ctx.closePath();
+ ctx.fill();
+ ctx.globalCompositeOperation = 'source-over'; // 恢复默认混合模式
+
+ // 进一步添加边缘老化效果 - 左右边框
+ const sideEdgeGradientLeft = ctx.createLinearGradient(dx, 0, dx + this.width, 0);
+ sideEdgeGradientLeft.addColorStop(0, "rgba(90,70,50,0.15)");
+ sideEdgeGradientLeft.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ sideEdgeGradientLeft.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ sideEdgeGradientLeft.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = sideEdgeGradientLeft;
+ ctx.fillRect(dx, 0, this.width, this.height);
+
+ const sideEdgeGradientRight = ctx.createLinearGradient(dx + this.width, 0, dx, 0);
+ sideEdgeGradientRight.addColorStop(0, "rgba(90,70,50,0.15)");
+ sideEdgeGradientRight.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ sideEdgeGradientRight.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ sideEdgeGradientRight.addColorStop(1, "rgba(90,70,50,0.15)");
+ ctx.fillStyle = sideEdgeGradientRight;
+ ctx.fillRect(dx, 0, this.width, this.height);
+
+ // 上下边缘老化效果
+ const topEdgeGradient = ctx.createLinearGradient(0, dy, 0, dy + this.height);
+ topEdgeGradient.addColorStop(0, "rgba(90,70,50,0.15)");
+ topEdgeGradient.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ topEdgeGradient.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ topEdgeGradient.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = topEdgeGradient;
+ ctx.fillRect(dx, dy, this.width, this.height);
+
+ const bottomEdgeGradient = ctx.createLinearGradient(0, dy + this.height, 0, dy);
+ bottomEdgeGradient.addColorStop(0, "rgba(90,70,50,0.15)");
+ bottomEdgeGradient.addColorStop(0.1, "rgba(90,70,50,0.07)");
+ bottomEdgeGradient.addColorStop(0.9, "rgba(90,70,50,0.07)");
+ bottomEdgeGradient.addColorStop(1, "rgba(90,70,50,0.15)");
+
+ ctx.fillStyle = bottomEdgeGradient;
+ ctx.fillRect(dx, dy, this.width, this.height);
+ // 使用阴影模糊来柔化边缘
+ ctx.shadowColor = "rgba(0,0,0,0.5)";
+ ctx.shadowBlur = 10;
+ ctx.shadowOffsetX = 0;
+ ctx.shadowOffsetY = 0;
+
+ // 绘制左页
+ core.drawImage(ctx, this.paperpages[this.page - 1][0], 0, 0, 300, 400, dx, dy, this.width, this.height);
+
+
+ // 绘制右页
+ core.drawImage(ctx, this.paperpages[this.page - 1][1], 0, 0, 300, 400, dx + this.width, dy, this.width, this.height);
+
+ // 重置阴影
+ ctx.shadowColor = "transparent";
+ core.drawImage(ctx, bookInfo.left.canvas, 0, 0, bookInfo.left.canvas.width, bookInfo.left.canvas.height, dx, dy, this.width, this.height)
+ core.drawImage(ctx, bookInfo.right.canvas, 0, 0, bookInfo.right.canvas.width, bookInfo.right.canvas.height, dx + this.width, dy, this.width, this.height)
+
+ ctx.restore();
+ }
+
+ clearPage() {
+ this.paperpages.forEach(v => {
+
+ v[0].remove();
+
+ v[1].remove();
+
+
+ })
+ this.paperpages = []
+ }
+ update() {
+ if (this.paperpages.length === 0) this.paperpages.push([this.paperTexture('left'), this.paperTexture('right')])
+ if (this.pagemax < 1) this.pagemax = 1
+ if (this.page < 1) this.page = 1
+ this.background()
+ }
+ close() {
+ this.clearPage()
+ bookInfo.clear()
+ this.page = 1
+ book.style.display = 'none'
+ this.paperpages = [
+ [this.paperTexture('left'), this.paperTexture('right')]
+ ]
+ this.pagemax = 1
+ }
+
+
+ }
+ core.book = new Book()
+
+
+ ////// 绘制怪物手册 //////
+ ui.prototype.drawBook = function (index) {
+ var floorId = core.floorIds[(core.status.event.ui || {}).index] || core.status.floorId;
+ // 清除浏览地图时的光环缓存
+ if (floorId != core.status.floorId && core.status.checkBlock) {
+ core.status.checkBlock.cache = {};
+ }
+ core.clearUI()
+ bookInfo.init(floorId)
+ core.book.update()
+ if (bookInfo.enemys.length > 1) core.book.pagemax = bookInfo.enemys.length
}
},
"存读档": function () {
@@ -23511,10 +25552,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
saveLoad.style.zIndex = 390;
saveLoad.style.display = "none";
saveLoad.id = "saveLoad";
- main.dom.gameGroup.insertAdjacentElement("afterend", saveLoad);
- saveLoad.style.top = "50%";
- saveLoad.style.left = "50%";
- saveLoad.style.transform = "translate(-50%,-50%)";
+ main.dom.startPanel.insertAdjacentElement("afterend", saveLoad)
const ctx = saveLoad.getContext("2d");
main.dom.saveLoad = saveLoad
let cg = false
@@ -23562,11 +25600,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
let x, y;
if (core.domStyle.isVertical) { //对竖屏进行坐标转换
- x = py * 3;
- y = 1248 - px * 3;
+ x = py;
+ y = 416 - px;
} else {
- x = px * 3;
- y = py * 3;
+ x = px;
+ y = py;
}
saveLoadclick(x, y)
} catch (ee) {
@@ -23636,6 +25674,32 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
return;
};
+ control.prototype._doSL_replayLoad_afterGet = function (id, data) {
+ if (!data) {
+ core.playSound("操作失败");
+ return core.drawTip("无效的存档");
+ }
+ if (data.version != core.firstData.version) {
+ core.playSound("操作失败");
+ return core.drawTip("存档版本不匹配");
+ }
+ if (data.hero.flags.__events__ && data.guid != core.getGuid()) {
+ core.playSound("操作失败");
+ return core.drawTip("此存档可能存在风险,无法读档");
+ }
+ var route = core.subarray(core.status.route, core.decodeRoute(data.route));
+ if (route == null) {
+ core.playSound("操作失败");
+ return core.drawTip("无法从此存档回放录像");
+ }
+ core.closePanel()
+ core.loadData(data, function () {
+ core.removeFlag("__fromLoad__");
+ core.startReplay(route);
+ core.drawTip("回退到存档节点");
+ });
+ };
+
function saveLoadclick(x, y) { //点击画布(x,y)触发的效果
const makeBox = ([x, y], [w, h]) => { //创建点击检测区域
return [
@@ -23654,35 +25718,35 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
offset = core.status.event.data.offset;
let index = page * 10 + offset;
- const upbox = makeBox([675, 370], [100, 100]);
- const upupbox = makeBox([675, 260], [100, 110]);
- const upupupbox = makeBox([675, 150], [100, 120]);
- const downbox = makeBox([675, 660], [100, 100]);
- const downdownbox = makeBox([675, 760], [100, 110]);
- const downdowndownbox = makeBox([675, 870], [100, 120]);
- const addbox = makeBox([650, 1010], [150, 100]);
- const modebox = makeBox([30, 124], [270, 1000]);
- const save0box = makeBox([300, 100], [350, 124]);
- const savebox = makeBox([300, 224], [350, 800]);
- const save9box = makeBox([300, 1024], [350, 124]);
- const backbox = makeBox([1750, 1150], [200, 100]);
- const savenamebox = makeBox([800, 970], [250, 70]);
- const classnamebox = makeBox([800, 1070], [250, 70]);
- const savetextbox = makeBox([1050, 982], [640, 150]);
- const cgbox = makeBox([1200, 1150], [300, 100])
- const changebox = makeBox([1700, 970], [200, 70])
- const deletebox = makeBox([1700, 1070], [200, 70])
- const gobox = makeBox([800, 100], [1050, 870])
- const favbox = makeBox([900, 300], [500, 110])
- const class1box = makeBox([900, 410], [500, 110])
- const class2box = makeBox([900, 520], [500, 110])
- const class3box = makeBox([900, 630], [500, 110])
- const class4box = makeBox([900, 740], [500, 110])
- const class5box = makeBox([1400, 300], [500, 110])
- const class6box = makeBox([1400, 410], [500, 110])
- const class7box = makeBox([1400, 520], [500, 110])
- const class8box = makeBox([1400, 630], [500, 110])
- const changebackbox = makeBox([1700, 740], [130, 110])
+ const upbox = makeBox([225, 123], [33, 33]);
+ const upupbox = makeBox([225, 87], [33, 37]);
+ const upupupbox = makeBox([225, 50], [33, 40]);
+ const downbox = makeBox([225, 220], [33, 33]);
+ const downdownbox = makeBox([225, 253], [33, 37]);
+ const downdowndownbox = makeBox([225, 290], [33, 40]);
+ const addbox = makeBox([217, 337], [50, 33]);
+ const modebox = makeBox([10, 41], [90, 333]);
+ const save0box = makeBox([100, 33], [117, 41]);
+ const savebox = makeBox([100, 78], [117, 267]);
+ const save9box = makeBox([100, 345], [117, 41]);
+ const backbox = makeBox([583, 383], [67, 33]);
+ const savenamebox = makeBox([267, 323], [83, 23]);
+ const classnamebox = makeBox([267, 357], [83, 23]);
+ const savetextbox = makeBox([350, 327], [213, 50]);
+ const cgbox = makeBox([400, 383], [100, 33])
+ const changebox = makeBox([567, 323], [67, 23])
+ const deletebox = makeBox([567, 357], [67, 5])
+ const gobox = makeBox([267, 33], [380, 250])
+ const favbox = makeBox([300, 100], [167, 37])
+ const class1box = makeBox([300, 137], [167, 37])
+ const class2box = makeBox([300, 173], [167, 37])
+ const class3box = makeBox([300, 210], [167, 37])
+ const class4box = makeBox([300, 247], [167, 37])
+ const class5box = makeBox([467, 100], [167, 37])
+ const class6box = makeBox([467, 137], [167, 37])
+ const class7box = makeBox([467, 173], [167, 37])
+ const class8box = makeBox([467, 210], [167, 37])
+ const changebackbox = makeBox([567, 247], [167, 37])
if (inRect(pos, upbox)) {
choose = false
@@ -23749,7 +25813,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
if (inRect(pos, modebox)) {
choose = false
- let mode = Math.floor((y - 124) / 100) - 1
+ let mode = Math.floor((y - 41) / 33) - 1
if (mode < 0 && core.status.event.data.mode !== "all") {
core.status.event.data.mode = "all"
page = parseInt((core.saves.saveIndex - 1) / 9);
@@ -23782,49 +25846,46 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
if (inRect(pos, savebox)) {
choose = false
- let a = Math.ceil((y - 224) / 100)
+ let a = Math.ceil((y - 75) / 33)
let real_id = 9 * page + a
- if (real_id == index) {
- if (core.status.event.data.mode === "fav") {
- real_id = core.saves.favorite[a - 1]
- }
- if (core.status.event.data.mode !== "fav" && core.status.event.data.mode !== "all") {
- real_id = core.saves[core.status.event.data.mode][a - 1]
- }
+ if (core.status.event.data.mode === "fav") {
+ real_id = core.saves.favorite[9 * page + a - 1]
+ }
+ if (core.status.event.data.mode !== "fav" && core.status.event.data.mode !== "all") {
+ real_id = core.saves[core.status.event.data.mode][9 * page + a - 1]
+ }
+ if (10 * page + a == index) {
+
+
core.saveLoad.setId(real_id)
+
core.doSL(real_id, core.status.event.id)
return
} else {
- if (core.status.event.data.mode === "fav") {
- real_id = core.saves.favorite[a - 1]
- }
- if (core.status.event.data.mode !== "fav" && core.status.event.data.mode !== "all") {
- real_id = core.saves[core.status.event.data.mode][a - 1]
- }
+
+
core.saveLoad.setId(real_id)
}
core.ui._drawSLPanel(10 * page + a)
+
return;
}
if (inRect(pos, save9box)) {
choose = false
let real_id = 9 * page + 9
- if (real_id == index) {
- if (core.status.event.data.mode === "fav") {
- real_id = core.saves.favorite[9 * page + 8]
- }
- if (core.status.event.data.mode !== "fav" && core.status.event.data.mode !== "all") {
- real_id = core.saves[core.status.event.data.mode][9 * page + 8]
- }
+ if (core.status.event.data.mode === "fav") {
+ real_id = core.saves.favorite[9 * page + 8]
+ }
+ if (core.status.event.data.mode !== "fav" && core.status.event.data.mode !== "all") {
+ real_id = core.saves[core.status.event.data.mode][9 * page + 8]
+ }
+ if (10 * page + 9 == index) {
+
core.saveLoad.setId(real_id)
core.doSL(real_id, core.status.event.id)
return
} else {
- real_id = core.saves.favorite[9 * page + 8]
- if (core.status.event.data.mode !== "fav" && core.status.event.data.mode !== "all") {
- real_id = core.saves[core.status.event.data.mode][9 * page + 8]
- }
core.saveLoad.setId(real_id)
}
@@ -23870,7 +25931,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.myprompt("请输入想要显示的存档名(长度不超过5字符)", null, function (value) {
if (value && value.length <= 5) {
+
core.saves.favoriteName[real_id] = value;
+
+
+ core.setLocalStorage("_saveName", core.saves.favoriteName)
core.control._updateFavoriteSaves();
core.ui._drawSLPanel(10 * page + offset);
} else if (value) {
@@ -23953,6 +26018,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.saves.favorite = core.saves.favorite.sort(function (a, b) { return a - b; }); // 保证有序
}
+
core.control._updateFavoriteSaves()
core.ui._drawSLPanel(index);
return
@@ -24146,11 +26212,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
for (let i = 1; i < 9; i++) {
core.setLocalStorage("class_" + i, core.saves["class_" + i])
}
+
core.setLocalStorage("favoriteName", core.saves.favoriteName);
};
////// 绘制存档/读档界面 //////
ui.prototype._drawSLPanel = function (index, refresh) {
- core.control._updateFavoriteSaves()
+
core.control._loadClassSaves();
core.control._loadFavoriteSaves();
@@ -24196,14 +26263,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
ui.prototype._drawSLPanel_draw = function (page, max_page) {
if (core.domStyle.isVertical) {
- ctx.canvas.width = 1248;
- ctx.canvas.height = 2028;
+ core.maps._setHDCanvasSize(ctx, 416, 676)
ctx.save(); //保存设置
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
} else {
- ctx.canvas.width = 2028;
- ctx.canvas.height = 1248;
+ core.maps._setHDCanvasSize(ctx, 676, 416)
}
// --- 绘制背景
this._drawSLPanel_drawBackground();
@@ -24211,223 +26276,223 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
// --- 绘制文字
core.setTextAlign(ctx, 'center');
- var bottom = 1248 - 39;
+ var bottom = 403;
core.fillBoldText1(
ctx,
"返回游戏",
- 1850,
+ 617,
bottom,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
if (core.status.event.selection)
core.setFillStyle(ctx, '#FF6A6A');
ctx.strokeStyle = "#DDDDDD";
ctx.fillStyle = "#BBBB44"
- ctx.lineWidth = 6
+ ctx.lineWidth = 2
ctx.beginPath();
- ctx.moveTo(300, 124)
- ctx.lineTo(60, 124)
- ctx.arcTo(30, 124, 30, 224, 30)
- ctx.lineTo(30, 194)
- ctx.arcTo(30, 224, 300, 224, 30)
- ctx.lineTo(300, 224)
+ ctx.moveTo(100, 41)
+ ctx.lineTo(20, 41)
+ ctx.arcTo(10, 41, 10, 75, 10)
+ ctx.lineTo(10, 65)
+ ctx.arcTo(10, 75, 100, 75, 10)
+ ctx.lineTo(100, 75)
ctx.stroke()
if (core.status.event.data.mode === "all") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 224)
- ctx.lineTo(60, 224)
- ctx.arcTo(30, 224, 30, 324, 30)
- ctx.lineTo(30, 294)
- ctx.arcTo(30, 324, 300, 324, 30)
- ctx.lineTo(300, 324)
+ ctx.moveTo(100, 75)
+ ctx.lineTo(20, 75)
+ ctx.arcTo(10, 75, 10, 108, 10)
+ ctx.lineTo(10, 98)
+ ctx.arcTo(10, 108, 100, 108, 10)
+ ctx.lineTo(100, 108)
ctx.stroke()
if (core.status.event.data.mode === "fav") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 324)
- ctx.lineTo(60, 324)
- ctx.arcTo(30, 324, 30, 424, 30)
- ctx.lineTo(30, 394)
- ctx.arcTo(30, 424, 300, 424, 30)
- ctx.lineTo(300, 424)
+ ctx.moveTo(100, 108)
+ ctx.lineTo(20, 108)
+ ctx.arcTo(10, 108, 10, 141, 10)
+ ctx.lineTo(10, 131)
+ ctx.arcTo(10, 141, 100, 141, 10)
+ ctx.lineTo(100, 141)
ctx.stroke()
if (core.status.event.data.mode === "class_1") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 424)
- ctx.lineTo(60, 424)
- ctx.arcTo(30, 424, 30, 524, 30)
- ctx.lineTo(30, 494)
- ctx.arcTo(30, 524, 300, 524, 30)
- ctx.lineTo(300, 524)
+ ctx.moveTo(100, 141)
+ ctx.lineTo(20, 141)
+ ctx.arcTo(10, 141, 10, 175, 10)
+ ctx.lineTo(10, 165)
+ ctx.arcTo(10, 175, 100, 175, 10)
+ ctx.lineTo(100, 175)
ctx.stroke()
if (core.status.event.data.mode === "class_2") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 524)
- ctx.lineTo(60, 524)
- ctx.arcTo(30, 524, 30, 624, 30)
- ctx.lineTo(30, 594)
- ctx.arcTo(30, 624, 300, 624, 30)
- ctx.lineTo(300, 624)
+ ctx.moveTo(100, 175)
+ ctx.lineTo(20, 175)
+ ctx.arcTo(10, 175, 10, 208, 10)
+ ctx.lineTo(10, 198)
+ ctx.arcTo(10, 208, 100, 208, 10)
+ ctx.lineTo(100, 208)
ctx.stroke()
if (core.status.event.data.mode === "class_3") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 624)
- ctx.lineTo(60, 624)
- ctx.arcTo(30, 624, 30, 724, 30)
- ctx.lineTo(30, 694)
- ctx.arcTo(30, 724, 300, 724, 30)
- ctx.lineTo(300, 724)
+ ctx.moveTo(100, 208)
+ ctx.lineTo(20, 208)
+ ctx.arcTo(10, 208, 10, 241, 10)
+ ctx.lineTo(10, 231)
+ ctx.arcTo(10, 241, 100, 241, 10)
+ ctx.lineTo(100, 241)
ctx.stroke()
if (core.status.event.data.mode === "class_4") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 724)
- ctx.lineTo(60, 724)
- ctx.arcTo(30, 724, 30, 824, 30)
- ctx.lineTo(30, 794)
- ctx.arcTo(30, 824, 300, 824, 30)
- ctx.lineTo(300, 824)
+ ctx.moveTo(100, 241)
+ ctx.lineTo(20, 241)
+ ctx.arcTo(10, 241, 10, 275, 10)
+ ctx.lineTo(10, 265)
+ ctx.arcTo(10, 275, 100, 275, 10)
+ ctx.lineTo(100, 275)
ctx.stroke()
if (core.status.event.data.mode === "class_5") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 824)
- ctx.lineTo(60, 824)
- ctx.arcTo(30, 824, 30, 924, 30)
- ctx.lineTo(30, 894)
- ctx.arcTo(30, 924, 300, 924, 30)
- ctx.lineTo(300, 924)
+ ctx.moveTo(100, 275)
+ ctx.lineTo(20, 275)
+ ctx.arcTo(10, 275, 10, 308, 10)
+ ctx.lineTo(10, 298)
+ ctx.arcTo(10, 308, 100, 308, 10)
+ ctx.lineTo(100, 308)
ctx.stroke()
if (core.status.event.data.mode === "class_6") ctx.fill()
ctx.beginPath();
- ctx.moveTo(300, 924)
- ctx.lineTo(60, 924)
- ctx.arcTo(30, 924, 30, 1024, 30)
- ctx.lineTo(30, 994)
- ctx.arcTo(30, 1024, 300, 1024, 30)
- ctx.lineTo(300, 1024)
+ ctx.moveTo(100, 308)
+ ctx.lineTo(20, 308)
+ ctx.arcTo(10, 308, 10, 341, 10)
+ ctx.lineTo(10, 331)
+ ctx.arcTo(10, 341, 100, 341, 10)
+ ctx.lineTo(100, 341)
ctx.stroke()
if (core.status.event.data.mode === "class_7") ctx.fill()
ctx.beginPath()
- ctx.moveTo(300, 1024)
- ctx.lineTo(60, 1024)
- ctx.arcTo(30, 1024, 30, 1124, 30)
- ctx.lineTo(30, 1094)
- ctx.arcTo(30, 1124, 300, 1124, 30)
- ctx.lineTo(300, 1124)
+ ctx.moveTo(100, 341)
+ ctx.lineTo(20, 341)
+ ctx.arcTo(10, 341, 10, 375, 10)
+ ctx.lineTo(10, 365)
+ ctx.arcTo(10, 375, 100, 375, 10)
+ ctx.lineTo(100, 375)
ctx.stroke()
if (core.status.event.data.mode === "class_8") ctx.fill()
core.fillBoldText1(
ctx,
'全部',
- 170,
- 190,
+ 57,
+ 63,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
'收藏★',
- 170,
- 290,
+ 57,
+ 97,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_1", "默认分类1"),
- 170,
- 390,
+ 57,
+ 130,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_2", "默认分类2"),
- 170,
- 490,
+ 57,
+ 163,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_3", "默认分类3"),
- 170,
- 590,
+ 57,
+ 197,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_4", "默认分类4"),
- 170,
- 690,
+ 57,
+ 230,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_5", "默认分类5"),
- 170,
- 790,
+ 57,
+ 263,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_6", "默认分类6"),
- 170,
- 890,
+ 57,
+ 297,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_7", "默认分类7"),
- 170,
- 990,
+ 57,
+ 330,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.getLocalStorage("slClass_8", "默认分类8"),
- 170,
- 1090,
+ 57,
+ 363,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
- core.strokeRoundRect(ctx, 300, 100, 1648, 1048, 30, "#DDDDDD")
+ core.strokeRoundRect(ctx, 100, 33, 549, 349, 10, "#DDDDDD")
// --- 绘制记录
this._drawSLPanel_drawRecords();
ctx.restore();
@@ -24439,17 +26504,17 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
ui.prototype._drawSLPanel_drawBackground = function () {
const bg = core.material.images.images["eve_011101.webp"]; //背景
- core.fillRect(ctx, 0, 0, 2028, 1248, "#000000"); //黑色背景
+ core.fillRect(ctx, 0, 0, 676, 416, "#000000"); //黑色背景
ctx.globalAlpha = 0.5; //透明度
- if (bg) ctx.drawImage(bg, 0, 0, 1280, 720, 0, 0, 2028, 1248); //绘制半透明背景图片
+ if (bg) ctx.drawImage(bg, 0, 0, 1280, 720, 0, 0, 676, 416); //绘制半透明背景图片
ctx.globalAlpha = 1; //恢复为不透明
}
ui.prototype._drawSLPanel_loadSave = function (page, callback) {
var ids = [0];
- for (var i = 1; i <= 10; ++i) {
- var id = 10 * page + i;
+ for (var i = 1; i <= 9; ++i) {
+ var id = 9 * page + i;
if (core.status.event.data.mode == 'fav')
id = core.saves.favorite[id - 1]; // 因为favorite第一个不是自动存档 所以要偏移1
if (core.status.event.data.mode !== 'fav' && core.status.event.data.mode !== "all")
@@ -24470,14 +26535,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
var id = 9 * page + offset
core.drawWindowSkin(
"winskin.webp",
- ctx, 1032,
- 252,
- 660,
- 660,
- null,
- null,
- null,
- 3
+ ctx, 344,
+ 84,
+ 220,
+ 220
);
if (data && data.floorId) {
core.setTextAlign('ui', "center");
@@ -24489,325 +26550,301 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
heroIcon: data.hero.image,
flags: data.hero.flags,
ctx: ctx,
- x: 1050,
- y: 270,
- size: 1.5,
+ x: 350,
+ y: 90,
+ size: 0.5,
centerX: data.hero.loc.x,
centerY: data.hero.loc.y,
noHD: true
});
if (core.isPlaying() && core.getFlag("hard") != data.hero.flags.hard) {
- core.fillRect(ctx, 1050, 270, 624, 624, [0, 0, 0, 0.4]);
- core.fillText(ctx, data.hard, 1362, 620, data.hero.flags.__hardColor__ || 'white', this._buildFont(180, true));
+ core.fillRect(ctx, 350, 90, 208, 208, [0, 0, 0, 0.4]);
+ core.fillText(ctx, data.hard, 454, 207, data.hero.flags.__hardColor__ || 'white', this._buildFont(60, true));
}
- core.drawIcon(ctx, "hp", 800, 260, 96, 96);
- core.drawIcon(ctx, "atk", 800, 370, 96, 96);
- core.drawIcon(ctx, "def", 800, 470, 96, 96);
- core.drawIcon(ctx, "I374", 800, 580, 96, 96);
- core.drawIcon(ctx, "jumpShoes", 800, 690, 96, 96);
- core.drawIcon(ctx, "money", 800, 810, 96, 96);
+ core.drawIcon(ctx, "hp", 267, 87, 32, 32);
+ core.drawIcon(ctx, "atk", 267, 123, 32, 32);
+ core.drawIcon(ctx, "def", 267, 157, 32, 32);
+ core.drawIcon(ctx, "I374", 267, 193, 32, 32);
+ core.drawIcon(ctx, "jumpShoes", 267, 230, 32, 32);
+ core.drawIcon(ctx, "money", 267, 270, 32, 32);
core.setTextAlign(ctx, 'left');
core.fillBoldText1(
ctx,
core.formatBigNumber(data.hero.hp, true),
- 900,
- 320,
+ 300,
+ 107,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.formatBigNumber(data.hero.atk, true),
- 900,
- 430,
+ 300,
+ 143,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.formatBigNumber(data.hero.def, true),
- 900,
- 540,
+ 300,
+ 180,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.formatBigNumber(data.hero.spell, true),
- 900,
- 650,
+ 300,
+ 217,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.formatBigNumber(data.hero.speed, true),
- 900,
- 760,
+ 300,
+ 253,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
core.formatBigNumber(data.hero.money, true),
- 900,
- 880,
+ 300,
+ 293,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.setTextAlign(ctx, 'center');
core.fillBoldText1(
ctx,
core.floors[data.floorId].title,
- 1350,
- 150,
+ 450,
+ 50,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
`[${core.floors[data.floorId].areas}]`,
- 1350,
- 220,
+ 450,
+ 73,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.drawWindowSkin(
"winskin.webp",
- ctx, 1700,
- 260,
- 96,
- 96,
- null,
- null,
- null,
- 1
+ ctx, 567,
+ 87,
+ 32,
+ 32
);
core.drawWindowSkin(
"winskin.webp",
- ctx, 1700,
- 400,
- 96,
- 96,
- null,
- null,
- null,
- 1
+ ctx, 567,
+ 133,
+ 32,
+ 32
);
core.drawWindowSkin(
"winskin.webp",
- ctx, 1700,
- 540,
- 96,
- 96,
- null,
- null,
- null,
- 1
+ ctx, 567,
+ 180,
+ 32,
+ 32
);
core.drawWindowSkin(
"winskin.webp",
- ctx, 1700,
- 680,
- 96,
- 96,
- null,
- null,
- null,
- 1
+ ctx, 567,
+ 227,
+ 32,
+ 32
);
core.drawWindowSkin(
"winskin.webp",
- ctx, 1700,
- 810,
- 96,
- 96,
- null,
- null,
- null,
- 1
+ ctx, 567,
+ 270,
+ 32,
+ 32
);
- if (data.hero.equipment[0]) core.drawIcon(ctx, data.hero.equipment[0], 1700, 260, 96, 96)
+ if (data.hero.equipment[0]) core.drawIcon(ctx, data.hero.equipment[0], 567, 87, 32, 32)
else core.fillBoldText1(
ctx,
"无",
- 1750,
- 320,
+ 583,
+ 107,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
- if (data.hero.equipment[1]) core.drawIcon(ctx, data.hero.equipment[1], 1700, 400, 96, 96)
+ if (data.hero.equipment[1]) core.drawIcon(ctx, data.hero.equipment[1], 567, 133, 32, 32)
else core.fillBoldText1(
ctx,
"无",
- 1750,
- 460,
+ 583,
+ 153,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
- if (data.hero.equipment[2]) core.drawIcon(ctx, data.hero.equipment[2], 1700, 540, 96, 96)
+ if (data.hero.equipment[2]) core.drawIcon(ctx, data.hero.equipment[2], 567, 180, 32, 32)
else core.fillBoldText1(
ctx,
"无",
- 1750,
- 600,
+ 583,
+ 200,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
- if (data.hero.equipment[3]) core.drawIcon(ctx, data.hero.equipment[3], 1700, 680, 96, 96)
+ if (data.hero.equipment[3]) core.drawIcon(ctx, data.hero.equipment[3], 567, 227, 32, 32)
else core.fillBoldText1(
ctx,
"无",
- 1750,
- 740,
+ 583,
+ 247,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
- if (data.hero.equipment[3]) core.drawIcon(ctx, data.hero.equipment[3], 1700, 810, 96, 96)
+ if (data.hero.equipment[3]) core.drawIcon(ctx, data.hero.equipment[3], 567, 270, 32, 32)
else core.fillBoldText1(
ctx,
"无",
- 1750,
- 870,
+ 583,
+ 290,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
- core.drawIcon(ctx, "yellowKey", 1800, 260, 96, 96)
- core.drawIcon(ctx, "blueKey", 1800, 420, 96, 96)
- core.drawIcon(ctx, "redKey", 1800, 580, 96, 96)
- core.drawIcon(ctx, "greenKey", 1800, 740, 96, 96)
+ core.drawIcon(ctx, "yellowKey", 600, 87, 32, 32)
+ core.drawIcon(ctx, "blueKey", 600, 140, 32, 32)
+ core.drawIcon(ctx, "redKey", 600, 193, 32, 32)
+ core.drawIcon(ctx, "greenKey", 600, 647, 32, 32)
core.fillBoldText1(
ctx,
data.hero.items.tools.yellowKey ?? 0,
- 1850,
- 390,
+ 617,
+ 130,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
data.hero.items.tools.blueKey ?? 0,
- 1850,
- 550,
+ 617,
+ 183,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
data.hero.items.tools.redKey ?? 0,
- 1850,
- 710,
+ 617,
+ 237,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
data.hero.items.tools.greenKey ?? 0,
- 1850,
- 870,
+ 617,
+ 290,
'#DDDDDD',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
core.fillBoldText1(
ctx,
`存档时间${core.formatDate(new Date(data.time))}`,
- 1350, 960, data.hero.flags.debug ? '#FF6A6A' : '#FFFFFF',
+ 450, 320, data.hero.flags.debug ? '#FF6A6A' : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
if (offset !== 0) core.fillBoldText1(
ctx,
"修改存档名",
- 920, 1020, '#FFFFFF',
+ 307, 340, '#FFFFFF',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
if (offset !== 0) core.fillBoldText1(
ctx,
"存档分类",
- 1800, 1020, '#FFFFFF',
+ 600, 340, '#FFFFFF',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
if (offset !== 0) core.fillBoldText1(
ctx,
"删除存档",
- 1800, 1120, '#FFFFFF',
+ 600, 373, '#FFFFFF',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
if (core.status.event.data.mode !== "all" && core.status.event.data.mode !== "fav") core.fillBoldText1(
ctx,
"修改分类名",
- 920, 1120, '#FFFFFF',
+ 307, 373, '#FFFFFF',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
if (data.hero.flags._cgText) {
core.fillBoldText1(
ctx,
cg ? "剧情CG模式" : "缩略图模式",
- 1350, 1220, '#FFFFFF',
+ 450, 407, '#FFFFFF',
"#000000",
- 6,
- this._buildFont(45, true)
+ 2,
+ this._buildFont(15, true)
);
if (!cg) {
core.drawWindowSkin(
"winskin.webp",
- ctx, 805,
- 252,
- 1140,
- 660,
- null,
- null,
- null,
- 3
+ ctx, 268,
+ 84,
+ 380,
+ 220
);
- core.drawImage(ctx, data.cg.image, 823, 270, 1104, 624)
+ core.drawImage(ctx, data.cg.image, 274, 90, 368, 208)
let s = 0.5
data.cg.bodyList.forEach((v) => {
//绘制立绘
@@ -24815,7 +26852,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (v.filter) ctx.filter = "brightness(50%)";
if (body) {
- if (!v.w && !v.h && !v.scale) v.scale = 1.7;
+ if (!v.w && !v.h && !v.scale) v.scale = 0.6;
if (!v.w && !v.h) {
ctx.drawImage(
@@ -24824,8 +26861,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
0,
body.width,
body.height,
- 823 + v.px * s,
- 894 - body.height * v.scale * s,
+ 274 + v.px * s,
+ 298 - body.height * v.scale * s,
body.width * v.scale * s,
body.height * v.scale * s
);
@@ -24836,8 +26873,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
0,
body.width,
body.height,
- 823 + v.px * s,
- 894 - (v.h ?? body.height) * s,
+ 274 + v.px * s,
+ 298 - (v.h ?? body.height) * s,
v.w ?? body.width * s,
v.h ?? body.height * s
);
@@ -24845,7 +26882,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
ctx.filter = "none";
});
- core.fillRect(ctx, 823, 694, 1104, 200, "rgba(0,0,0,0.3)")
+ core.fillRect(ctx, 274, 231, 268, 67, "rgba(0,0,0,0.3)")
const head = core.material.images.images?.[data.cg.head.name];
if (head) {
//绘制头像
@@ -24855,46 +26892,40 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
0,
head.width,
head.height,
- 823 + data.cg.head.px * s,
- 894 - head.height * 2.2 * s,
- head.width * 2.2 * s,
- head.height * 2.2 * s
+ 274 + data.cg.head.px * s,
+ 298 - head.height * 0.7 * s,
+ head.width * 0.7 * s,
+ head.height * 0.7 * s
);
}
core.setTextAlign(ctx, "left")
- if (data.cg.name) core.fillBoldText1(
+ if (data.cg.name) core.fillText(
ctx,
`【${data.cg.name}】`,
- 1143, 720, '#FFFFFF',
- "#000000",
- 2,
- this._buildFont(30, true)
+ 381, 240, '#FFFFFF',
+ this._buildFont(10, true)
);
if (data.cg.text) core.drawTextContent(ctx, data.cg.text, {
- left: 1143,
- top: 750,
+ left: 381,
+ top: 250,
bold: true,
color: "#FFFFFF",
align: "left",
- fontSize: 30,
+ fontSize: 10,
time: 0,
font: "Verdana",
- maxWidth: 800,
+ maxWidth: 267,
});
}
}
if (offset !== 0) core.drawWindowSkin(
"winskin.webp",
- ctx, 1050,
- 982,
- 640,
- 150,
- null,
- null,
- null,
- 1
+ ctx, 350,
+ 327,
+ 213,
+ 50
);
let real_id = id
if (core.status.event.data.mode === "fav") {
@@ -24904,119 +26935,115 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
real_id = core.saves[core.status.event.data.mode][id - 1]
}
if (offset !== 0) core.drawTextContent(ctx, core.getLocalStorage("_slText" + real_id, "点击填写存档笔记"), {
- left: 1070,
- top: 1000,
+ left: 357,
+ top: 333,
bold: true,
color: "#FFFFFF",
align: "left",
- fontSize: 30,
+ fontSize: 10,
time: 0,
font: "HATTEN",
- maxWidth: 620,
+ maxWidth: 207,
});
if (choose) {
core.drawWindowSkin(
"winskin.webp",
- ctx, 805,
- 252,
- 1140,
- 660,
- null,
- null,
- null,
- 3
+ ctx, 268,
+ 84,
+ 380,
+ 220
);
- core.fillRect(ctx, 823, 270, 1104, 624, "#000000")
+ core.fillRect(ctx, 274, 90, 368, 208, "#000000")
core.setTextAlign(ctx, 'left')
core.fillBoldText1(
ctx,
`${core.saves.favorite.indexOf(real_id)>=0?"☑":"□"}收藏★`,
- 920, 370, core.saves.favorite.indexOf(real_id) >= 0 ? '#FFFF44' : '#FFFFFF',
+ 307, 123, core.saves.favorite.indexOf(real_id) >= 0 ? '#FFFF44' : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_1.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_1", "默认分类1")}`,
- 920, 480, core.saves.class_1.indexOf(real_id) >= 0 ? '#FFFF44' : '#FFFFFF',
+ 307, 160, core.saves.class_1.indexOf(real_id) >= 0 ? '#FFFF44' : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_2.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_2", "默认分类2")}`,
- 920, 590, core.saves.class_2.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
+ 307, 197, core.saves.class_2.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_3.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_3", "默认分类3")}`,
- 920, 700, core.saves.class_3.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
+ 307, 233, core.saves.class_3.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_4.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_4", "默认分类4")}`,
- 920, 810, core.saves.class_4.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
+ 307, 270, core.saves.class_4.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_5.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_5", "默认分类5")}`,
- 1400, 370, core.saves.class_5.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
+ 467, 123, core.saves.class_5.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_6.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_6", "默认分类6")}`,
- 1400, 480, core.saves.class_6.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
+ 467, 160, core.saves.class_6.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_7.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_7", "默认分类7")}`,
- 1400, 590, core.saves.class_7.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
+ 467, 197, core.saves.class_7.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
`${core.saves.class_8.indexOf(real_id)>=0?"☑":"□"}${core.getLocalStorage("slClass_8", "默认分类8")}`,
- 1400, 700, core.saves.class_8.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
+ 467, 233, core.saves.class_8.indexOf(real_id) >= 0 ? "#FFFF44" : '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
core.fillBoldText1(
ctx,
"返回",
- 1700, 810, '#FFFFFF',
+ 567, 270, '#FFFFFF',
"#000000",
- 6,
- this._buildFont(60, true)
+ 2,
+ this._buildFont(20, true)
);
}
- ctx.lineWidth = 6
+ ctx.lineWidth = 2
core.setTextAlign(ctx, "center")
} else {
- core.fillRect(ctx, 1050, 270, 624, 624, '#333333');
- core.fillText(ctx, '无存档', 1362, 620, "#444444", this._buildFont(180, true));
+ core.fillRect(ctx, 350, 90, 208, 208, '#333333');
+ core.fillText(ctx, '无存档', 454, 207, "#444444", this._buildFont(60, true));
}
}
@@ -25024,146 +27051,146 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
var page = core.status.event.data.page;
var offset = core.status.event.data.offset;
var name = core.status.event.id == 'save' ? "存档" : core.status.event.id == 'load' ? "读档" : "回放";
- core.drawLine(ctx, 650, 100, 650, 1148)
- core.drawLine(ctx, 800, 100, 800, 1148)
+ core.drawLine(ctx, 217, 33, 217, 383)
+ core.drawLine(ctx, 267, 33, 267, 383)
let liney = 0
core.fillText(
ctx,
"自动存档",
- 470,
- 190,
+ 157,
+ 63,
offset === 0 ? '#DDDD44' : core.status.event.ui[0] ? "#FFFFFF" : "#BBBBBB",
- this._buildFont(45, true)
+ this._buildFont(15, true)
);
core.setStrokeStyle(ctx, "#DDDDDD")
- core.drawLine(ctx, 300, 224, 650, 224)
+ core.drawLine(ctx, 100, 75, 217, 75)
core.fillText(
ctx,
"▲",
- 725,
- 240,
+ 242,
+ 80,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▲",
- 725,
- 220,
+ 242,
+ 73,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▲",
- 725,
- 200,
+ 242,
+ 67,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▲",
- 725,
- 320,
+ 242,
+ 107,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▲",
- 725,
- 340,
+ 242,
+ 113,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▲",
- 725,
- 440,
+ 242,
+ 147,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
page + 1,
- 725,
- 540,
+ 242,
+ 180,
"#DDDD44",
- this._buildFont(45, true)
+ this._buildFont(15, true)
);
core.fillText(
ctx,
"/",
- 725,
- 590,
+ 242,
+ 197,
"#DDDDDD",
- this._buildFont(45, true)
+ this._buildFont(15, true)
);
core.fillText(
ctx,
core.saveLoad.max_page,
- 725,
- 640,
+ 242,
+ 213,
"#DDDDDD",
- this._buildFont(45, true)
+ this._buildFont(15, true)
);
core.fillText(
ctx,
"▼",
- 725,
- 740,
+ 242,
+ 247,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▼",
- 725,
- 820,
+ 242,
+ 273,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▼",
- 725,
- 840,
+ 242,
+ 280,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▼",
- 725,
- 940,
+ 242,
+ 313,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▼",
- 725,
- 960,
+ 242,
+ 320,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
core.fillText(
ctx,
"▼",
- 725,
- 980,
+ 242,
+ 327,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
if (core.status.event.data.mode === 'all' && core.getLocalStorage("save_page", 0) !== 8000) core.fillText(
ctx,
"扩容",
- 725,
- 1090,
+ 242,
+ 363,
"#DDDDDD",
- this._buildFont(60, true)
+ this._buildFont(20, true)
);
this._drawSLPanel_drawRecord(page, offset)
@@ -25183,17 +27210,17 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
if (data && data.__toReplay__) title = '[R]' + title;
- liney += 100
+ liney += 33
core.fillText(
ctx,
title,
- 470,
- 190 + liney,
+ 157,
+ 63 + liney,
offset === i ? '#DDDD44' : data ? "#FFFFFF" : "#BBBBBB",
- this._buildFont(45, true)
+ this._buildFont(15, true)
);
core.setStrokeStyle(ctx, "#DDDDDD")
- if (i != 9) core.drawLine(ctx, 300, 224 + liney, 650, 224 + liney)
+ if (i != 9) core.drawLine(ctx, 100, 75 + liney, 217, 75 + liney)
}
};
@@ -25329,7 +27356,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
var index = page * 10 + offset;
if (keycode == 27 || keycode == 88 || (core.status.event.id == 'save' && keycode == 83) || (core.status.event.id == 'load' && keycode == 68)) { //退出
- saveLoadclick(1800, 1200);
+ saveLoadclick(600, 400);
return;
}
if (keycode >= 48 && keycode <= 57) {
@@ -25638,6 +27665,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
},
"动画": function () {
+
// 在此增加新插件
const { Transition, linear, bezier, circle, hyper, trigo, power, inverseTrigo, shake, sleep } = core.plugin.animate;
//////移动动画//////
@@ -25667,35 +27695,31 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
control.prototype._animationFrame_animate = function (timestamp) {
- let frametime = timestamp - core.animateFrame.animateTime
- core.animateFrame.animateTime = timestamp;
- if (!core.status.animateObjs || core.status.animateObjs.length == 0) return;
-
+ if (timestamp - core.animateFrame.animateTime < 50 || !core.status.animateObjs || core.status.animateObjs.length == 0) return;
+ core.animateFrame.animateTime = timestamp
core.clearMap('animate');
// 更新帧
for (var i = 0; i < core.status.animateObjs.length; i++) {
var obj = core.status.animateObjs[i];
- if (obj.pause) obj.pausetime += frametime
- if (obj.start === 0) obj.start = core.animateFrame.animateTime
- obj.index = Math.floor((core.animateFrame.animateTime - obj.start - obj.pausetime) / (1000 / 60))
- if (obj.reverse) obj.index = obj.animate.frames.length - obj.index
- if ((!obj.reverse && obj.index >= obj.animate.frames.length) || (obj.reverse && obj.index <= 0)) {
- if (obj.loop) {
- if (obj.reverse) {
- obj.index = obj.animate.frames.length
- obj.start = core.animateFrame.animateTime
- obj.pausetime = 0
- } else {
- obj.start = core.animateFrame.animateTime
- obj.index = 0
- obj.pausetime = 0
- }
- } else
- (function (callback) {
- setTimeout(function () {
- if (callback) callback();
- });
- })(obj.callback);
+ if (!obj.pause) {
+
+ if ((!obj.reverse && obj.index >= obj.animate.frames.length) || (obj.reverse && obj.index <= 0)) {
+ if (obj.loop) {
+ if (obj.reverse) {
+ obj.index = obj.animate.frames.length
+
+ } else {
+
+ obj.index = 0
+
+ }
+ } else
+ (function (callback) {
+ setTimeout(function () {
+ if (callback) callback();
+ });
+ })(obj.callback);
+ }
}
}
core.status.animateObjs = core.status.animateObjs.filter(function (obj) {
@@ -25726,7 +27750,12 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.maps._drawAnimateFrame('animate', obj.animate, tran.value[obj.id + obj.name + "x"], tran.value[obj.id + obj.name + "y"], obj.index);
}
+ if (!obj.pause) {
+ if (obj.reverse) obj.index--
+ else obj.index++
+ }
});
+
}
core.registerAnimationFrame("animate", true, core.control._animationFrame_animate);
@@ -25748,21 +27777,19 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
centerX += core.bigmap.offsetX;
centerY += core.bigmap.offsetY;
}
+ var id = setTimeout();
animate.se = animate.se || {};
if (typeof animate.se == 'string') animate.se = { 1: animate.se };
tran.mode(linear()).time(1).absolute()
tran.value[id + name + "x"] = centerX
tran.value[id + name + "y"] = centerY
- var id = setTimeout(null);
core.status.animateObjs.push({
"name": name,
"id": id,
"animate": animate,
"centerX": centerX,
"centerY": centerY,
- "start": 0,
"pause": false,
- "pausetime": 0,
"index": 0,
"callback": callback
});
@@ -25788,7 +27815,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
animate.se = animate.se || {};
if (typeof animate.se == 'string') animate.se = { 1: animate.se };
- var id = id || setTimeout(null);
+ var id = id || setTimeout();
tran.mode(linear()).time(1).absolute()
if (!hero) tran.value[id + name + "x"] = centerX
if (!hero) tran.value[id + name + "y"] = centerY
@@ -25798,11 +27825,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"animate": animate,
"hero": true,
"reverse": reverse,
- "start": 0,
"pause": false,
"loop": loop,
- "pausetime": 0,
- "index": 0,
+ "index": reverse ? animate.frames.length : 0,
"callback": callback
})
else core.status.animateObjs.push({
@@ -25812,11 +27837,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"centerX": centerX,
"centerY": centerY,
"reverse": reverse,
- "start": 0,
"pause": false,
"loop": loop,
- "pausetime": 0,
- "index": 0,
+ "index": reverse ? animate.frames.length : 0,
"callback": callback
});
@@ -25869,7 +27892,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
var ctx = core.getContextByName(name);
if (!ctx) return;
var frame = animate.frames[index % animate.frame];
+
core.playSound((animate.se || {})[index % animate.frame + 1], (animate.pitch || {})[index % animate.frame + 1]);
+
var ratio = animate.ratio;
frame.forEach(function (t) {
var image = animate.images[t.index];
@@ -25936,18 +27961,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"帧动画(游戏画面)": function () {
// 在此增加新插件
// 在此增加新插件
- const animate3 = document.createElement("canvas"); //画布设置
- animate3.style.zIndex = 71;
- animate3.id = "animate3";
- animate3.classList.add("gameCanvas", "anti-aliasing");
- animate3.style.display = "block";
- animate3.width = 416;
- animate3.height = 416;
- animate3.style.width = core.__PIXELS__ * core.domStyle.scale + "px";
- animate3.style.height = core.__PIXELS__ * core.domStyle.scale + "px";
- main.dom.animate3 = animate3;
- const anctx = animate3.getContext("2d");
+ const anctx = core.createCanvas("animate3", 0, 0, 416, 416, 71)
main.dom.gameDraw.appendChild(animate3);
core.plugin.playing = new Set();
@@ -26001,8 +28016,11 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.setFlag("animate_" + name);
};
let thistime = 0;
- this.playanimate = function (name, id, x, y, hero, scalex, scaley, loop, reverse) {
- if (!id) id = setTimeout(null)
+ this.playanimate = function (name, id, x, y, hero, scalex, scaley, loop, reverse, callback) {
+ if (!flags["animate_" + name]) {
+ callback?.()
+ }
+ if (!id) id = setTimeout()
tran.mode(linear()).time(1).absolute()
if (!hero) tran.value[id + name + "x"] = x
if (!hero) tran.value[id + name + "y"] = y
@@ -26015,15 +28033,15 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
hero: hero,
scalex: scalex,
scaley: scaley,
- start: 0,
pause: false,
loop: loop,
reverse: reverse,
- pausetime: 0,
- farme: 0,
+ farme: reverse ? flags["animate_" + name].allFarme : 0,
+ callback: callback
};
core.plugin.playing.add(data);
+
return id
};
this.animateloop = function (id, loop) {
@@ -26035,8 +28053,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
core.plugin.playing.forEach(v => {
if (!id || v.id === id) {
const data = flags["animate_" + v.name]
- if (reverse && !v.reverse) v.start -= (data.allFarme - v.farme * 2) * (1000 / 60)
- if (!reverse && v.reverse) v.start -= (v.farme * 2 - data.allFarme) * (1000 / 60)
+
v.reverse = reverse
}
})
@@ -26051,41 +28068,40 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (!id || v.id === id) core.plugin.playing.delete(v)
})
}
+ core.animateFrame.animate3Time = 0
core.registerAnimationFrame("animateonmap", true, function (timestamp) {
- let frametime = timestamp - thistime
- thistime = timestamp;
-
-
+ if (timestamp - core.animateFrame.animate3Time < 50 || !core.plugin.playing || core.plugin.playing.length == 0) return;
core.clearMap(anctx);
+ core.animateFrame.animate3Time = timestamp
core.plugin.playing.forEach((one) => {
const data = flags["animate_" + one.name];
if (!data) {
core.plugin.playing.delete(one);
} else {
- if (one.start === 0) one.start = thistime
- if (one.pause) one.pausetime += frametime
- one.farme = Math.floor((thistime - one.start - one.pausetime) / (1000 / 60))
+ if (!one.pause) {
+ if (one.reverse) one.farme--
+ else one.farme++
- if (one.reverse) one.farme = data.allFarme - one.farme
- if ((!one.reverse && one.farme > data.allFarme) || (one.reverse && one.farme < 0)) {
- if (one.loop) {
- if (one.reverse) {
- one.farme = data.allFarme
- one.start = thistime
- one.pausetime = 0
- } else {
- one.start = thistime
- one.farme = 0
- one.pausetime = 0
+ if (one.reverse) one.farme = data.allFarme - one.farme
+ if ((!one.reverse && one.farme > data.allFarme) || (one.reverse && one.farme < 0)) {
+ if (one.loop) {
+ if (one.reverse) {
+ one.farme = data.allFarme
+
+ } else {
+ one.start = thistime
+
+ }
}
}
- }
- if ((!one.reverse && one.farme > data.allFarme) || (one.reverse && one.farme < 0)) {
- delete tran.value[one.id + one.name + "x"]
- delete tran.value[one.id + one.name + "y"]
- core.plugin.playing.delete(one)
+ if ((!one.reverse && one.farme > data.allFarme) || (one.reverse && one.farme < 0)) {
+ one.callback?.()
+ delete tran.value[one.id + one.name + "x"]
+ delete tran.value[one.id + one.name + "y"]
+ core.plugin.playing.delete(one)
- return
+ return
+ }
}
data.imageList.forEach(function (image) {
@@ -26205,6 +28221,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
}
}
}
+ if (!one.pause) {
+ if (one.reverse) one.farme--
+ else one.farme++
+ }
});
data.soundList.forEach(function (sound) {
const lisen =
@@ -26214,6 +28234,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
if (one.farme == sound.startfarme && lisen) {
if (sound.stopbefore) core.stopSound();
core.playSound(sound.sound);
+
}
});
@@ -26221,5 +28242,849 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
});
});
+},
+ "任务系统": function () {
+ // 在此增加新插件
+ //详细的任务信息及要求存放在core.events.task,供TaskSystem使用
+ //以下均为任务名构成的数组,在任务接取或提交时转换
+ this.可接取任务 = ["新手任务"]
+ this.已提交任务 = []
+ //当前任务及任务状态在TaskSystem内部,无需数组
+ class TaskSystem {
+ constructor() {
+ this.tasksInfo = []
+ }
+ setTask(name) {
+ let task = core.enents.task[name]
+ if (task && core.plugin.可接取任务.includes(name)) {
+ this.tasksInfo.push({ name, text: task.text, n: task.n, action: task.action, tasks: task.info.map(v => new Task(v)) })
+ this.tasksInfo[this.tasksInfo.length - 1].complter = this.checkTask(this.tasksInfo.length - 1)
+ }
+ }
+ checkTask(index) {
+ if (index < 0 || index > this.tasksInfo.length - 1) return false
+ if (this.tasksInfo[index].success) return true
+ else return this.tasksInfo[index].tasks.reduce((a, b) => a + Number(b.check()), 0) >= this.tasksInfo[index].n
+ }
+ removeTaskByName(name) {
+ const index = this.tasksInfo.findIndex(v => v.name === name)
+ removeTask(index)
+ }
+ removeTask(index) {
+ if (index < 0 || index > this.tasksInfo.length - 1) return
+ this.tasksInfo.splice(index, 1)
+ }
+ clearTesk() {
+ this.tasksInfo = []
+ }
+ checkAll() {
+ for (let i = 0; i < this.tasksInfo.length; i++) {
+ this.checkTask(i)
+ }
+ }
+ submitTask() {
+ for (let i = 0; i < this.tasksInfo.length; i++) {
+ this.trymitTask(i)
+ }
+ this.clearTesk()
+ }
+ trymitTask(index) {
+ if (index < 0 || index > this.tasksInfo.length - 1) return
+ if (this.checkTask(index)) {
+ if (this.tasksInfo[i].action) core.insertAction(this.tasksInfo[i].action)
+ core.plugin.已提交任务.push(this.tasksInfo[i].name)
+ this.removeTask(index)
+ }
+
+ }
+ trymitTaskByName(name) {
+ const index = this.tasksInfo.findIndex(v => v.name === name)
+ if (index < 0 || index > this.tasksInfo.length - 1) return
+ if (this.checkTask(index)) {
+ if (this.tasksInfo[i].action) core.insertAction(this.tasksInfo[i].action)
+ core.plugin.已提交任务.push(name)
+ this.removeTask(index)
+ }
+
+ }
+ successTesk(index) {
+ if (index < 0 || index > this.tasksInfo.length - 1) return
+ this.tasksInfo[index].success = true
+ this.tasksInfo[index].complter = true
+ }
+ successTeskByName(name) {
+ const index = this.tasksInfo.findIndex(v => v.name === name)
+ if (index < 0 || index > this.tasksInfo.length - 1) return
+ this.successTesk(index)
+ }
+ save() {
+ return this.tasksInfo.map(v => {
+ const c = core.clone(v)
+ const b = v.tasks.map(a => a.save());
+ c.tasks = b
+ return c
+ })
+ }
+ load(data) {
+ this.tasksInfo = data.map(v => {
+ const c = core.clone(v)
+ const b = v.tasks.map(a => new Task(a))
+ c.tasks = b
+ return c
+ })
+
+ }
+
+ }
+ class Task {
+ constructor(info) {
+ this.type = info.type
+ this.text = info.text
+ if (info.type === "checkItem") {
+ this.checkItem = info.checkItem
+ this.count = info.count
+ this.operator = info.operator
+ this.has = info.has ?? core.itemCount(this.checkItem)
+ } else if (info.type === "checkStatus") {
+ this.checkStatus = info.checkStatus
+ this.count = info.count
+ this.operator = info.operator
+ this.has = info.has ?? core.getRealStatus(this.checkStatus)
+ } else if (info.type === "checkFlag") {
+ this.checkFlag = info.checkFlag
+ this.count = info.count
+ this.operator = info.operator
+ this.has = info.has ?? core.getFlag(this.checkFlag)
+ } else if (info.type === "checkBlock") { //剩余图块
+ this.checkBlock = info.checkBlock
+ this.count = info.count
+ this.operator = info.operator
+ this.floorId = info.floorId //楼层数组
+ this.has = info.has ?? core.searchBlock(this.checkBlock, this.floorId).length
+ } else if (info.type === "kill") {
+ this.floorId = info.floorId //楼层数组,不填为任意楼层
+ this.kill = info.kill //空为任意怪物
+ this.count = info.count
+ this.has = info.has ?? 0
+ this.operator = info.operator
+ } else if (info.type === "killLocs") {
+ this.floorId = info.floorId //楼层名
+ this.loc = info.loc
+ this.count = info.count
+ this.has = info.has ?? 0
+ this.operator = info.operator
+ } else if (info.type === "killSpecial") {
+ this.floorId = info.floorId //楼层数组,不填为任意楼层
+ this.killSpecial = info.killSpecial //特技数字
+ this.count = info.count
+ this.has = info.has ?? 0
+ this.operator = info.operator
+ } else if (info.type === "killAll") {
+ this.floorId = info.floorId //楼层数组
+ this.has = info.has ?? core.searchBlockWithFilter(block => block.event.cls.startsWith("enemy"), this.floorId).length
+ } else if (info.type === "specialBlock") { //踩雷
+ this.floorId = info.floorId //楼层数组,不填为任意楼层
+ this.specialType = info.specialType //地形伤害名,如血网伤害
+ this.count = info.count
+ this.has = info.has ?? 0
+ this.operator = info.operator
+ } else if (info.type === "gosthFloor") { //进行楼层切换次数
+ this.floorId = info.floorId //楼层数组
+ this.count = info.count
+ this.has = info.has ?? 0
+ this.operator = info.operator
+ } else if (info.type === "arrival") { //抵达某楼层
+ this.floorId = info.floorId //楼层名
+ this.has = info.has ?? 0
+ }
+
+
+ }
+ check() {
+ if (this.type === "checkItem") return this.checkInfo(this.count, this.has = core.itemCount(this.checkItem))
+ else if (this.type === "checkStatus") return this.checkInfo(this.count, this.has = core.getRealStatus(this.checkStatus))
+ else if (this.type === "checkFlag") return this.checkInfo(this.count, this.has = core.getFlag(this.checkFlag))
+ else if (this.type === "checkBlock") return this.checkInfo(this.count, this.has = core.searchBlock(this.checkBlock, this.floorId).length)
+ else if (this.type === "killAll") return this.has = core.searchBlockWithFilter(block => block.event.cls.startsWith("enemy"), this.floorId).length, this.has === 0
+ else if (this.type === "specialBlock" || this.type === "gosthFloor" || this.type === "kill" || this.type === "killSpecial" || this.type === "killLocs") return this.checkInfo(this.count, this.has)
+ else if (this.type === "arrival") return Boolean(this.has)
+ else if (this.type === "outer") return false
+
+ }
+ checkInfo(check, has) {
+ switch (this.operator) {
+ case "=":
+ return check === has
+ case "<":
+ return check > has
+ case "<=":
+ return check >= has
+ case ">":
+ return check < has
+ case ">=":
+ return check <= has
+ }
+ }
+ save() {
+ let info = { type: this.type, text: this.text }
+ if (info.type === "checkItem") {
+ info.checkItem = this.checkItem
+ info.count = this.count
+ info.operator = this.operator
+ info.has = this.has
+ } else if (info.type === "checkStatus") {
+ info.checkStatus = this.checkStatus
+ info.count = this.count
+ info.operator = this.operator
+ info.has = this.has
+ } else if (info.type === "checkFlag") {
+ info.checkFlag = this.checkFlag
+ info.count = this.count
+ info.operator = this.operator
+ info.has = this.has
+ } else if (info.type === "checkBlock") {
+ info.checkBlock = this.checkBlock
+ info.count = this.count
+ info.operator = this.operator
+ info.floorId = this.floorId
+ info.has = this.has
+ } else if (info.type === "kill") {
+ info.floorId = this.floorId
+ info.kill = this.kill
+ info.count = this.count
+ info.has = this.has
+ info.operator = this.operator
+ } else if (info.type === "killLocs") {
+ info.floorId = this.floorId
+ info.loc = this.loc
+ info.count = this.count
+ info.has = this.has
+ info.operator = this.operator
+ } else if (info.type === "killSpecial") {
+ info.floorId = this.floorId
+ info.killSpecial = this.killSpecial
+ info.count = this.count
+ info.has = this.has
+ info.operator = this.operator
+ } else if (info.type === "killAll") {
+ info.floorId = this.floorId
+ info.has = this.has
+ } else if (info.type === "specialBlock") {
+ info.floorId = this.floorId
+ info.specialType = this.specialType
+ info.count = this.count
+ info.has = this.has
+ info.operator = this.operator
+ } else if (info.type === "gosthFloor") {
+ info.floorId = this.floorId
+ info.count = this.count
+ info.has = this.has
+ info.operator = this.operator
+ } else if (info.type === "arrival") {
+ info.floorId = this.floorId
+ info.has = this.has
+ }
+ return info
+ }
+
+ }
+ core.taskSystem = new TaskSystem()
+
+ core.registerEvent("setTask", (data) => {
+ core.taskSystem.setTask(data.name)
+ core.doAction()
+ })
+ core.registerEvent("removeTask", (data) => {
+ core.taskSystem.removeTask(data.index)
+ core.doAction()
+ })
+ core.registerEvent("removeTaskByName", (data) => {
+ core.taskSystem.removeTaskByName(data.name)
+ core.doAction()
+ })
+ core.registerEvent("successTask", (data) => {
+ core.taskSystem.successTask(data.index)
+ core.doAction()
+ })
+ core.registerEvent("successTaskByName", (data) => {
+ core.taskSystem.successTaskByName(data.name)
+ core.doAction()
+ })
+ core.registerEvent("clearTask", () => {
+ core.taskSystem.clearTask()
+ core.doAction()
+ })
+ core.registerEvent("trymitTask", (data) => {
+ core.taskSystem.trymitTask(data.index)
+ core.doAction()
+ })
+ core.registerEvent("trymitTaskByName", (data) => {
+ core.taskSystem.trymitTaskByName(data.name)
+ core.doAction()
+ })
+ core.registerEvent("submitTask", () => {
+ core.taskSystem.submitTask()
+ core.doAction()
+ })
+},
+ "NPC菜单": function () {
+ // 在此增加新插件
+
+ class menu {
+
+ setcanvas(list, x, y) {
+ let textmax = ""
+ list.forEach(v => textmax = v.length > textmax.length ? v : textmax)
+ if (!this.canvas) {
+ this.canvas = core.createCanvas("menu", x * 32 + 16, y * 32 + 16, 30, 30, 70)
+ core.setFont(this.canvas, "18px cjx")
+ }
+ let length = this.canvas.measureText(textmax).width
+ let px = x * 32 + 16
+ let py = y * 32 + 16
+ if (px + length + 32 > 416) px -= length + 32
+ if (py + list.length * 32 > 416) py -= list.length * 32
+ this.canvas = core.createCanvas("menu", px, py, length + 32, list.length * 32, 70)
+ core.setFont(this.canvas, "18px cjx")
+ this.x = px
+ this.y = py
+ this.w = length + 32
+ this.h = list.length * 32
+ this.list = list
+ core.clearMap(this.canvas)
+ core.fillRect(this.canvas, 0, 0, this.w, this.h, "rgba(0,0,0,0.7)")
+ core.fillRect(this.canvas, 0, 0, this.w, 32, "rgba(0,0,0,0.7)")
+ core.setTextAlign(this.canvas, "center")
+ let dy = 0
+ this.list.forEach(v => {
+ core.fillText(this.canvas, v, this.w / 2, 22 + dy, "#FFFFFF")
+ dy += 32
+ })
+ this.selection = 0
+ core.strokeRoundRect(this.canvas, 2, 34 + this.selection * 32, this.w - 4, 28, 4, "#FFFF00", 2)
+ }
+ update() {
+ core.clearMap(this.canvas)
+ core.fillRect(this.canvas, 0, 0, this.w, this.h, "rgba(0,0,0,0.7)")
+ core.fillRect(this.canvas, 0, 0, this.w, 32, "rgba(0,0,0,0.7)")
+ core.setTextAlign(this.canvas, "center")
+ let dy = 0
+ this.list.forEach(v => {
+ core.fillText(this.canvas, v, this.w / 2, 22 + dy, "#FFFFFF")
+ dy += 32
+ })
+ core.strokeRoundRect(this.canvas, 2, 34 + this.selection * 32, this.w - 4, 28, 4, "#FFFF00", 2)
+ }
+ }
+ core.menu = new menu()
+
+ function action_menu(data, x, y, prefix) {
+ data.choices = data.choices.filter(function (x) {
+ if (x._disabled) return false;
+ if (x.condition == null || x.condition == "") return true;
+ try {
+ return core.calValue(x.condition, prefix);
+ } catch (e) {
+ return true;
+ }
+ });
+ if (data.choices.length == 0) return core.doAction()
+ let list = []
+ list.push(core.replaceText(data.text, prefix))
+ for (var i = 0; i < data.choices.length; i++) {
+ if (typeof data.choices[i] === "string")
+ data.choices[i] = { text: data.choices[i] };
+ data.choices[i].text = core.replaceText(data.choices[i].text, prefix);
+ list.push(data.choices[i].text)
+ }
+ core.menu.setcanvas(list, x, y)
+ if (core.isReplaying()) {
+ var action = core.status.replay.toReplay.shift();
+ if (
+ action.indexOf("menu:") == 0) {
+ var index = action.substring(5);
+ if (!menu_replaying(data, index)) {
+ core.control._replay_error(action);
+ return;
+ }
+ } else {
+ ``
+ // 容错录像
+ if (main.replayChecking) {
+ // 录像验证系统中选返回
+ if (action != "menu:none")
+ core.status.replay.toReplay.unshift(action); // 首先归还刚才读出的下一步操作
+ menu_replaying(data, "none");
+ } else {
+ // 正常游戏中弹窗选择
+ core.myprompt(
+ "录像回放出错!当前需要执行选择项但录像中未记录。\n如需修复请输入您要选的项(从0起),点击取消将不会修复。",
+ 0,
+ function (value) {
+ if (value == null) {
+ core.control._replay_error(action);
+ return;
+ }
+ if (action != "menu:none")
+ core.status.replay.toReplay.unshift(action); // 首先归还刚才读出的下一步操作
+ menu_replaying(
+ data,
+ ((parseInt(value) || 0) + data.choices.length) %
+ data.choices.length
+ );
+ }
+ );
+ }
+ }
+ }
+
+ }
+
+ function menu_replaying(data, index) {
+ var selection = index;
+
+ if (index != "none") {
+ selection = parseInt(index);
+ if (Number.isNaN(selection)) return false;
+ if (selection < 0) selection += data.choices.length;
+ if (selection < 0) return false;
+ if (selection % 100 > data.choices.length) return false;
+ core.menu.selection = index
+ }
+ core.status.event.selection = selection;
+
+ setTimeout(
+ function () {
+ core.status.route.push("choices:" + index);
+ if (selection != "none") {
+ // 检查
+ var choice = data.choices[selection];
+ if (
+ choice.need != null &&
+ choice.need != "" &&
+ !core.calValue(choice.need)
+ ) {
+ // 无法选择此项
+ core.control._replay_error("无法选择项:" + index);
+ return;
+ } else {
+ core.insertAction(choice.action);
+ }
+ }
+ core.clearMap(core.menu.canvas)
+ core.doAction();
+ },
+ core.status.replay.speed == 24 ?
+ 1 :
+ 750 / Math.max(1, core.status.replay.speed)
+ );
+ return true;
+ }
+ core.registerEvent("menu", function (data, x, y, prefix) {
+
+ action_menu(data, x, y, prefix)
+ })
+},
+ "任务栏": function () {
+ // 在此增加新插件
+ if (main.mode == "editor") {
+ //#region 配置表格初始化
+ let TableFileName = "project/table/task_comment.js";
+ let TableRow = `
+ var task_comment = {"_type": "object",
+ "_data": {
+ "task": {
+ "_type": "object",
+ "_data": function (key) {
+ var obj = {
+ "检测音乐如果没有开启则系统提示开启": {
+ "_leaf": true,
+ "_type": "object",
+ "_data": "检测音乐如果没有开启则系统提示开启"
+ },
+
+ }
+ if (obj[key]) return obj[key];
+ return {
+ "_leaf": true,
+ "_type": "object",
+ "_data": "任务栏"
+ }
+ }
+ }
+ }}
+ `;
+ if (!events_c12a15a8_c380_4b28_8144_256cba95f760.task) {
+ /**
+ * @type {{[EvnetName:actionParserJson]}}
+ */
+ events_c12a15a8_c380_4b28_8144_256cba95f760.task = {
+ 检测音乐如果没有开启则系统提示开启: [{
+ type: "if",
+ condition: "!core.musicStatus.bgmStatus",
+ true: [
+ "\t[系统提示]你当前音乐处于关闭状态,本塔开音乐游戏效果更佳",
+ ],
+ false: [],
+ }, ],
+ 仿新新魔塔一次性商人: [{
+ type: "if",
+ condition: "switch:A",
+ true: [
+ "\t[行商,trader]\b[this]这是购买我的道具后我给玩家的提示。",
+ {
+ type: "comment",
+ text: "下一条指令可视情况使用或不使用",
+ },
+ {
+ type: "hide",
+ remove: true,
+ time: 250,
+ },
+ ],
+ false: [{
+ type: "confirm",
+ text: "我有3把黄钥匙,\n你出50金币就卖给你。",
+ yes: [{
+ type: "if",
+ condition: "status:money>=50",
+ true: [{
+ type: "setValue",
+ name: "status:money",
+ operator: "-=",
+ value: "50",
+ },
+ {
+ type: "setValue",
+ name: "item:yellowKey",
+ operator: "+=",
+ value: "3",
+ },
+ {
+ type: "playSound",
+ name: "确定",
+ stop: true,
+ },
+ {
+ type: "setValue",
+ name: "switch:A",
+ value: "true",
+ },
+ ],
+ false: [{
+ type: "playSound",
+ name: "操作失败",
+ },
+ "\t[行商,trader]\b[this]你的金币不足!",
+ ],
+ }, ],
+ no: [],
+ }, ],
+ }, ],
+ 全地图选中一个点: [{
+ type: "comment",
+ text: "全地图选中一个点,需要用鼠标或触屏操作",
+ },
+ {
+ type: "setValue",
+ name: "temp:X",
+ value: "status:x",
+ },
+ {
+ type: "setValue",
+ name: "temp:Y",
+ value: "status:y",
+ },
+ {
+ type: "tip",
+ text: "再次点击闪烁位置确认",
+ },
+ {
+ type: "while",
+ condition: "true",
+ data: [{
+ type: "drawSelector",
+ image: "winskin.webp",
+ code: 1,
+ x: "32*temp:X",
+ y: "32*temp:Y",
+ width: 32,
+ height: 32,
+ },
+ {
+ type: "wait",
+ },
+ {
+ type: "if",
+ condition: "(flag:type === 1)",
+ true: [{
+ type: "if",
+ condition: "((temp:X===flag:x)&&(temp:Y===flag:y))",
+ true: [{
+ type: "break",
+ n: 1,
+ }, ],
+ },
+ {
+ type: "setValue",
+ name: "temp:X",
+ value: "flag:x",
+ },
+ {
+ type: "setValue",
+ name: "temp:Y",
+ value: "flag:y",
+ },
+ ],
+ },
+ ],
+ },
+ {
+ type: "drawSelector",
+ code: 1,
+ },
+ {
+ type: "comment",
+ text: "流程进行到这里可以对[X,Y]点进行处理,比如",
+ },
+ {
+ type: "closeDoor",
+ id: "yellowDoor",
+ loc: ["temp:X", "temp:Y"],
+ },
+ ],
+ 多阶段Boss战斗: [{
+ type: "comment",
+ text: "多阶段boss,请直接作为战后事件使用",
+ },
+ {
+ type: "setValue",
+ name: "switch:A",
+ operator: "+=",
+ value: "1",
+ },
+ {
+ type: "switch",
+ condition: "switch:A",
+ caseList: [{
+ case: "1",
+ action: [{
+ type: "setBlock",
+ number: "redSlime",
+ },
+ "\t[2阶段boss,redSlime]\b[this]你以为你已经打败我了吗?没听说过史莱姆有九条命吗?",
+ ],
+ },
+ {
+ case: "2",
+ action: [{
+ type: "setBlock",
+ number: "blackSlime",
+ },
+ "\t[3阶段boss,blackSlime]\b[this]不能消灭我的,只会让我更强大!",
+ ],
+ },
+ {
+ case: "3",
+ action: [{
+ type: "setBlock",
+ number: "slimelord",
+ },
+ "\t[4阶段boss,slimelord]\b[this]我还能打!",
+ ],
+ },
+ {
+ case: "4",
+ action: ["\t[4阶段boss,slimelord]我一定会回来的!"],
+ },
+ ],
+ },
+ ],
+ };
+ }
+ // 新增模板選項
+ let editModeSelect = document.getElementById("editModeSelect");
+ let newEditModeOption = document.createElement("option");
+ newEditModeOption.value = "task";
+ newEditModeOption.text = "任务表";
+ editModeSelect.add(newEditModeOption);
+
+ //檢查可用的編輯模板ID
+ let leftIDNumber = 11 - 1;
+ let ExistLeftElement = document.querySelector(".main");
+ while (ExistLeftElement) {
+ leftIDNumber++;
+ ExistLeftElement = document.getElementById(`left${leftIDNumber}`);
+ }
+
+ //新增編輯模板
+ let MainDiv = document.querySelector(".main");
+
+ let CommonEventTemplateMainDiv = document.createElement("div");
+ CommonEventTemplateMainDiv.id = `left${leftIDNumber}`;
+ CommonEventTemplateMainDiv.className = "leftTab";
+ CommonEventTemplateMainDiv.style.zIndex = "-1";
+ CommonEventTemplateMainDiv.style.opacity = "0";
+
+ CommonEventTemplateMainDiv.innerHTML = `
+
+
+ `;
+ MainDiv.appendChild(CommonEventTemplateMainDiv);
+
+ (async function () {
+ //等待編輯器初始化
+ while (!editor_mode.ids) {
+ await Sleep(100);
+ }
+ //新增編輯模板ID
+ editor_mode.ids.task = `left${leftIDNumber}`;
+ editor_mode.init_dom_ids();
+ //切換至任务栏
+ editor_mode.task = function (callback) {
+ var objs = [];
+ editor.file.editTask([], function (objs_) {
+ objs = objs_;
+ //console.log(objs_)
+ });
+ //只查询不修改时,内部实现不是异步的,所以可以这么写
+ var tableinfo = editor.table.objToTable(objs[0], objs[1]);
+ document.getElementById(
+ "table_298572d8-93dd-4c6e-a278-6a7d49831e3b"
+ ).innerHTML = tableinfo.HTML;
+ tableinfo.listen(tableinfo.guids);
+ if (Boolean(callback)) callback();
+ };
+
+ //檢查配置表格存在
+ let TableRowExist = null;
+ fs.readFile(TableFileName, "base64", function (err, data) {
+ if (err) {
+ console.log(`察覺常見事件模板配置表格不存在,原因:${err}`);
+ console.log("新建一個常見事件模板配置表格。");
+ TableRowExist = false;
+ } else {
+ TableRowExist = true;
+ }
+ });
+ //等待配置表格載入完畢(最多0.3秒,超過則視為失敗)
+ for (let i = 0; i < 3; i++) {
+ if (TableRowExist == null) {
+ await Sleep(100);
+ }
+ }
+ //配置表格初始化
+ if (TableRowExist != true) {
+ fs.mkdir("project/table", function (err, data) {
+ if (err) throw `任务栏配置表格目錄初始化失敗,原因:${err}`;
+ });
+ fs.writeFile(
+ TableFileName,
+ editor.util.encode64(TableRow || ""),
+ "base64",
+ function (err, data) {
+ if (err) throw `任务栏板配置表格文件初始化失敗,原因:${err}`;
+ }
+ );
+ }
+ //載入配置表格
+ //editor.file.loadCommentjs(callback);
+ (function () {
+ var key = "task_comment";
+ var script = document.createElement("script");
+ script.src = "project/table/" + key + ".js";
+ document.body.appendChild(script);
+ script.onload = function () {
+ editor.file[key] = eval(key.replace(".", "_"));
+ var loaded = Boolean(editor.file[key]);
+ };
+ })();
+ //按下配置表格
+ editor_multi.taskEditCommentJs = function (mod) {
+ editor_multi.lintAutocomplete = true;
+ editor_multi.setLint();
+ editor_multi.importFile(TableFileName);
+ };
+
+
+ //添加表格列
+ editor.table.taskAddFunc = function () {
+ let obj = events_c12a15a8_c380_4b28_8144_256cba95f760;
+
+ // 1.输入id
+ let newid = prompt("请输入新项的ID(支持中文)");
+ if (newid == null || newid.length == 0) {
+ return;
+ }
+
+ // 2.检查id是否符合规范或与已有id重复
+ var conflict = true;
+ var basefield = "".replace(/\[[^\[]*\]$/, "");
+
+ try {
+ var baseobj = eval("obj" + basefield);
+ conflict = newid in baseobj;
+ } catch (ee) {
+ // 理论上这里不会发生错误
+ printe(ee);
+ throw ee;
+ }
+
+ if (conflict) {
+ printe("id已存在, 请直接修改该项的值");
+ return;
+ }
+
+ // 3.添加
+ editor_mode.addAction(["add", basefield + "['" + newid + "']", null]);
+ editor_mode.onmode("save", function () {
+ printf("添加成功,刷新后生效;也可以继续新增其他项目。");
+ }); //自动保存 删掉此行的话点保存按钮才会保存
+ };
+ //對表格的存讀
+ editor.file.editTask = function (actionList, callback) {
+ /*actionList:[
+ ["change","['test']",['123']],
+ ]
+ 为[]时只查询不修改
+ */
+ var data_obj =
+ events_c12a15a8_c380_4b28_8144_256cba95f760.task;
+ checkCallback(callback);
+ if (isset(actionList) && actionList.length > 0) {
+ actionList.forEach(function (value) {
+ value[1] = "['task']" + value[1];
+ });
+ editor.file.saveSetting("events", actionList, function (err) {
+ callback([err]);
+ });
+ } else {
+ callback([
+ Object.assign({}, data_obj),
+ editor.file.task_comment._data.task,
+ null,
+ ]);
+ }
+ };
+ })();
+ }
}
}
\ No newline at end of file
diff --git a/project/table/CommonEventTemplate_comment.js b/project/table/CommonEventTemplate_comment.js
index f805344..0df90bd 100644
--- a/project/table/CommonEventTemplate_comment.js
+++ b/project/table/CommonEventTemplate_comment.js
@@ -1,43 +1,43 @@
-
- var CommonEventTemplate_comment = {"_type": "object",
- "_data": {
- "CommonEventTemplate": {
- "_type": "object",
- "_data": function (key) {
- var obj = {
- "检测音乐如果没有开启则系统提示开启": {
- "_leaf": true,
- "_type": "event",
- "_event": "commonEvent",
- "_data": "检测音乐如果没有开启则系统提示开启"
- },
- "仿新新魔塔一次性商人": {
- "_leaf": true,
- "_type": "event",
- "_event": "commonEvent",
- "_data": "仿新新魔塔一次性商人"
- },
- "全地图选中一个点": {
- "_leaf": true,
- "_type": "event",
- "_event": "commonEvent",
- "_data": "全地图选中一个点"
- },
- "多阶段Boss战斗": {
- "_leaf": true,
- "_type": "event",
- "_event": "commonEvent",
- "_data": "多阶段Boss战斗"
- },
- }
- if (obj[key]) return obj[key];
- return {
- "_leaf": true,
- "_type": "event",
- "_event": "commonEvent",
- "_data": "常見事件模板"
- }
- }
- }
- }}
-
\ No newline at end of file
+var CommonEventTemplate_comment = {
+ "_type": "object",
+ "_data": {
+ "CommonEventTemplate": {
+ "_type": "object",
+ "_data": function (key) {
+ var obj = {
+ "检测音乐如果没有开启则系统提示开启": {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "commonEvent",
+ "_data": "检测音乐如果没有开启则系统提示开启"
+ },
+ "仿新新魔塔一次性商人": {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "commonEvent",
+ "_data": "仿新新魔塔一次性商人"
+ },
+ "全地图选中一个点": {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "commonEvent",
+ "_data": "全地图选中一个点"
+ },
+ "多阶段Boss战斗": {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "commonEvent",
+ "_data": "多阶段Boss战斗"
+ },
+ }
+ if (obj[key]) return obj[key];
+ return {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "commonEvent",
+ "_data": "常見事件模板"
+ }
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/project/table/task_comment.js b/project/table/task_comment.js
new file mode 100644
index 0000000..c8ae3f6
--- /dev/null
+++ b/project/table/task_comment.js
@@ -0,0 +1,121 @@
+var task_comment = {
+ "_type": "object",
+ "_data": {
+ "task": {
+ "_type": "object",
+ "_data": function (key) {
+ var obj = {
+ "新手任务": {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "taskEvent",
+ "_data": "开局就有"
+ },
+ "task1": {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "taskEvent",
+ "_data": "新"
+ },
+ }
+ if (obj[key]) return obj[key];
+ return {
+ "_leaf": true,
+ "_type": "event",
+ "_event": "taskEvent",
+ "_template": `{
+ "type": "taskEvent",
+ "name": "mission name",
+ "n": 1,
+ "text": "任务描述",
+ "info": [
+ {
+ "type": "checkItem",
+ "checkItem": "yellowKey",
+ "operator": ">=",
+ "count": 0
+ },
+ {
+ "type": "checkStatus",
+ "checkStatus": "atk",
+ "operator": ">=",
+ "count": 10
+ },
+ {
+ "type": "checkFlag",
+ "checkFlag": "flag1",
+ "operator": "=",
+ "count": "\"value\""
+ },
+ {
+ "type": "checkBlock",
+ "checkBlock": "bat",
+ "floorId": [
+ "MT1",
+ "MT2"
+ ],
+ "operator": "<=",
+ "count": 0
+ },
+ {
+ "type": "kill",
+ "operator": ">=",
+ "count": 0
+ },
+ {
+ "type": "killLocs",
+ "loc": [
+ [
+ 1,
+ 1
+ ]
+ ],
+ "floorId": "MT1",
+ "operator": ">=",
+ "count": 1
+ },
+ {
+ "type": "killSpecial",
+ "killSpecial": "61",
+ "floorId": [
+ "61"
+ ],
+ "operator": ">=",
+ "count": 1
+ },
+ {
+ "type": "killAll",
+ "floorId": [
+ "MT1"
+ ]
+ },
+ {
+ "type": "specialBlock",
+ "floorId": [
+ "MT1"
+ ],
+ "specialBlock": "血网伤害",
+ "operator": "<",
+ "count": 1
+ },
+ {
+ "type": "gosthFloor",
+ "floorId": [
+ "MT1"
+ ],
+ "operator": "<",
+ "count": 1
+ }
+ ],
+ "action": [
+ {
+ "type": "setmusics"
+ }
+ ]
+ }`,
+ "_data": "..."
+ }
+ }
+ }
+ }
+}
\ No newline at end of file
diff --git a/project/tilesets/2233.png b/project/tilesets/2233.png
new file mode 100644
index 0000000..a3bba4f
Binary files /dev/null and b/project/tilesets/2233.png differ