diff --git a/_server/MotaAction.g4 b/_server/MotaAction.g4
index b4a2a2f..e685be9 100644
--- a/_server/MotaAction.g4
+++ b/_server/MotaAction.g4
@@ -1183,7 +1183,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 +1195,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 +1248,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 +1259,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 +2061,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';
@@ -2614,7 +2614,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 +2668,7 @@ return code;
*/;
stopAnimate_s
- : '停止动画编号'PosString?'(不填写编号为继续所有)' '执行动画回调' Bool Newline
+ : '停止动画编号'PosString?'(不填写编号为停止所有)' '执行动画回调' Bool Newline
/* stopAnimate_s
tooltip : stopAnimate:停止动画(不填写编号为继续所有)
diff --git a/_server/MotaActionParser.js b/_server/MotaActionParser.js
index 9c9fd92..e180ffd 100644
--- a/_server/MotaActionParser.js
+++ b/_server/MotaActionParser.js
@@ -569,7 +569,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 +691,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;
@@ -2069,7 +2069,7 @@ MotaActionParser = function () {
data.memory1 ?? false,
data.img2 ?? "",
data.memory2 ?? false,
- data.time ?? 30,
+ data.time ?? 10,
data.style,
this.next,
]);
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/control.js b/libs/control.js
index f7fa011..665f8a1 100644
--- a/libs/control.js
+++ b/libs/control.js
@@ -2310,7 +2310,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);
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/maps.js b/libs/maps.js
index 35e6b8d..6107008 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,7 @@ maps.prototype._drawThumbnail_drawTempCanvas = function (floorId, blocks, option
} else core.maps._setHDCanvasSize(tempCanvas, width * 32, height * 32);
}
options.ctx = tempCanvas;
-
+
// 地图过大的缩略图不绘制显伤
if (width * height > core.bigmap.threshold)
options.damage = false;
diff --git a/libs/ui.js b/libs/ui.js
index 88a73ef..bba436e 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) {
@@ -1270,7 +1271,7 @@ ui.prototype._drawTextContent_drawChar = function (tempCtx, content, config, ch)
// 输出
var left = config.offsetX, top = config.offsetY + config.topMargin;
tempCtx.lineWidth = 2;
- tempCtx.strokeText( ch, left, top);
+
tempCtx.fillText( ch, left, top);
config.blocks.push({
left: config.offsetX, top: config.offsetY,
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 0ac8807..430065d 100644
--- a/project/data.js
+++ b/project/data.js
@@ -2160,7 +2160,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/events.js b/project/events.js
index 634691d..9d49015 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": "场景切换"
},
{
@@ -2243,7 +2243,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 30,
@@ -2251,7 +2251,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_440101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -2261,7 +2261,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 30,
@@ -2269,7 +2269,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_440101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -2279,7 +2279,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 30,
@@ -2287,7 +2287,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_440101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -2297,7 +2297,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 30,
@@ -2315,7 +2315,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440101.webp",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 30,
@@ -2333,7 +2333,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440105.webp",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 30,
@@ -2351,7 +2351,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440101.webp",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 30,
@@ -2369,7 +2369,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440110.webp",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 30,
@@ -2387,7 +2387,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440101.webp",
- "px": -300
+ "px": -100
},
"index": "28",
"time": 30,
@@ -2405,7 +2405,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440102.webp",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 30,
@@ -2428,7 +2428,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3026.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2441,7 +2441,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "eve_030101.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2449,7 +2449,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030102.webp",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 30,
@@ -2467,7 +2467,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030101.webp",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 30,
@@ -2489,7 +2489,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "32",
"time": 30,
@@ -2507,7 +2507,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "33",
"time": 30,
@@ -2525,7 +2525,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "34",
"time": 30,
@@ -2543,7 +2543,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "35",
"time": 30,
@@ -2561,7 +2561,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "36",
"time": 30,
@@ -2579,7 +2579,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "37",
"time": 30,
@@ -2597,7 +2597,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "38",
"time": 30,
@@ -2615,7 +2615,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "39",
"time": 30,
@@ -2633,7 +2633,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "40",
"time": 30,
@@ -2651,7 +2651,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "41",
"time": 30,
@@ -2673,7 +2673,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "42",
"time": 30,
@@ -2692,7 +2692,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3021.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2700,7 +2700,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "43",
"time": 30,
@@ -2718,7 +2718,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "44",
"time": 30,
@@ -2736,7 +2736,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "45",
"time": 30,
@@ -2754,7 +2754,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "46",
"time": 30,
@@ -2772,7 +2772,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "47",
"time": 30,
@@ -2791,7 +2791,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3026.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -2799,7 +2799,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030107.webp",
- "px": -300
+ "px": -100
},
"index": "48",
"time": 30,
@@ -2817,7 +2817,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_130104.webp",
- "px": -300
+ "px": -100
},
"index": "49",
"time": 30,
@@ -2835,7 +2835,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440103.webp",
- "px": -300
+ "px": -100
},
"index": "50",
"time": 30,
@@ -2853,7 +2853,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030145.webp",
- "px": -300
+ "px": -100
},
"index": "51",
"time": 30,
@@ -2871,7 +2871,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440107.webp",
- "px": -300
+ "px": -100
},
"index": "52",
"time": 30,
@@ -2889,7 +2889,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030145.webp",
- "px": -300
+ "px": -100
},
"index": "53",
"time": 30,
@@ -2907,7 +2907,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "54",
"time": 30,
@@ -2925,7 +2925,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320105.webp",
- "px": -300
+ "px": -100
},
"index": "55",
"time": 30,
@@ -2943,7 +2943,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "56",
"time": 30,
@@ -2961,7 +2961,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "57",
"time": 30,
@@ -2979,7 +2979,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030124.webp",
- "px": -300
+ "px": -100
},
"index": "58",
"time": 30,
@@ -2997,7 +2997,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320107.webp",
- "px": -300
+ "px": -100
},
"index": "59",
"time": 30,
@@ -3015,7 +3015,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030125.webp",
- "px": -300
+ "px": -100
},
"index": "60",
"time": 30,
@@ -3033,7 +3033,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030141.webp",
- "px": -300
+ "px": -100
},
"index": "61",
"time": 30,
@@ -3051,7 +3051,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "62",
"time": 30,
@@ -3069,7 +3069,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440102.webp",
- "px": -300
+ "px": -100
},
"index": "63",
"time": 30,
@@ -3087,7 +3087,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440109.webp",
- "px": -300
+ "px": -100
},
"index": "64",
"time": 30,
@@ -3105,7 +3105,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "65",
"time": 30,
@@ -3123,7 +3123,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320108.webp",
- "px": -300
+ "px": -100
},
"index": "66",
"time": 30,
@@ -3141,7 +3141,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030145.webp",
- "px": -300
+ "px": -100
},
"index": "67",
"time": 30,
@@ -3159,7 +3159,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "68",
"time": 30,
@@ -3177,7 +3177,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "69",
"time": 30,
@@ -3195,7 +3195,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030101.webp",
- "px": -300
+ "px": -100
},
"index": "70",
"time": 30,
@@ -3213,7 +3213,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "71",
"time": 30,
@@ -3231,7 +3231,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030105.webp",
- "px": -300
+ "px": -100
},
"index": "72",
"time": 30,
@@ -3249,7 +3249,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440106.webp",
- "px": -300
+ "px": -100
},
"index": "73",
"time": 30,
@@ -3267,7 +3267,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "74",
"time": 30,
@@ -3285,7 +3285,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_440102.webp",
- "px": -300
+ "px": -100
},
"index": "75",
"time": 30,
@@ -3303,7 +3303,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_030125.webp",
- "px": -300
+ "px": -100
},
"index": "76",
"time": 30,
@@ -3321,7 +3321,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_130124.webp",
- "px": -300
+ "px": -100
},
"index": "77",
"time": 30,
@@ -3339,7 +3339,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320102.webp",
- "px": -300
+ "px": -100
},
"index": "78",
"time": 30,
@@ -3357,7 +3357,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_320101.webp",
- "px": -300
+ "px": -100
},
"index": "79",
"time": 30,
@@ -3376,7 +3376,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
],
@@ -3387,7 +3387,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3801.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -3399,7 +3399,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 30,
@@ -3417,7 +3417,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 30,
@@ -3435,7 +3435,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 30,
@@ -3453,7 +3453,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 30,
@@ -3471,7 +3471,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "4",
"time": 30,
@@ -3489,7 +3489,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "5",
"time": 30,
@@ -3507,7 +3507,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "6",
"time": 30,
@@ -3525,7 +3525,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "7",
"time": 30,
@@ -3543,7 +3543,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "8",
"time": 30,
@@ -3561,7 +3561,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "9",
"time": 30,
@@ -3579,7 +3579,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "10",
"time": 30,
@@ -3597,7 +3597,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "11",
"time": 30,
@@ -3615,7 +3615,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "12",
"time": 30,
@@ -3633,7 +3633,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "13",
"time": 30,
@@ -3655,7 +3655,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "14",
"time": 30,
@@ -3673,7 +3673,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "15",
"time": 30,
@@ -3691,7 +3691,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "16",
"time": 30,
@@ -3709,7 +3709,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "17",
"time": 30,
@@ -3727,7 +3727,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "18",
"time": 30,
@@ -3753,7 +3753,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "19",
"time": 30,
@@ -3771,7 +3771,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 30,
@@ -3789,7 +3789,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 30,
@@ -3807,7 +3807,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 30,
@@ -3825,7 +3825,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 30,
@@ -3843,7 +3843,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 30,
@@ -3861,7 +3861,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 30,
@@ -3879,7 +3879,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 30,
@@ -3897,7 +3897,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 30,
@@ -3915,7 +3915,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "28",
"time": 30,
@@ -3933,7 +3933,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 30,
@@ -3951,7 +3951,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 30,
@@ -3969,7 +3969,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 30,
@@ -3987,7 +3987,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "32",
"time": 30,
@@ -4005,7 +4005,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "33",
"time": 30,
@@ -4023,7 +4023,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "34",
"time": 30,
@@ -4041,7 +4041,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "35",
"time": 30,
@@ -4059,7 +4059,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "36",
"time": 30,
@@ -4077,7 +4077,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "37",
"time": 30,
@@ -4095,7 +4095,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "38",
"time": 30,
@@ -4113,7 +4113,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "39",
"time": 30,
@@ -4131,7 +4131,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "40",
"time": 30,
@@ -4149,7 +4149,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "41",
"time": 30,
@@ -4167,7 +4167,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "42",
"time": 30,
@@ -4185,7 +4185,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "43",
"time": 30,
@@ -4203,7 +4203,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "44",
"time": 30,
@@ -4221,7 +4221,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "45",
"time": 30,
@@ -4239,7 +4239,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "46",
"time": 30,
@@ -4257,7 +4257,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "47",
"time": 30,
@@ -4275,7 +4275,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "48",
"time": 30,
@@ -4297,7 +4297,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "49",
"time": 30,
@@ -4315,7 +4315,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "50",
"time": 30,
@@ -4333,7 +4333,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "51",
"time": 30,
@@ -4351,7 +4351,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "52",
"time": 30,
@@ -4369,7 +4369,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "53",
"time": 30,
@@ -4387,7 +4387,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "54",
"time": 30,
@@ -4464,7 +4464,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_0000.png",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -4473,7 +4473,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3801.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -6044,7 +6044,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
],
@@ -6055,7 +6055,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3512.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引入"
},
{
@@ -6064,7 +6064,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3522.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -6073,7 +6073,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3602.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -6082,7 +6082,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "bg_3551.webp",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -6094,7 +6094,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120122.webp",
- "px": -300
+ "px": -100
},
"index": "0",
"time": 0,
@@ -6112,7 +6112,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120101.webp",
- "px": -300
+ "px": -100
},
"index": "1",
"time": 0,
@@ -6120,7 +6120,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6130,7 +6130,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "2",
"time": 0,
@@ -6138,7 +6138,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6148,7 +6148,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "3",
"time": 0,
@@ -6156,7 +6156,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6166,7 +6166,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "4",
"time": 0,
@@ -6174,7 +6174,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6184,7 +6184,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120102.webp",
- "px": -300
+ "px": -100
},
"index": "5",
"time": 0,
@@ -6192,7 +6192,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6202,7 +6202,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "6",
"time": 0,
@@ -6210,7 +6210,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6220,7 +6220,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "7",
"time": 0,
@@ -6228,7 +6228,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6238,7 +6238,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120111.webp",
- "px": -300
+ "px": -100
},
"index": "8",
"time": 0,
@@ -6246,7 +6246,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6256,7 +6256,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "9",
"time": 0,
@@ -6264,7 +6264,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6274,7 +6274,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120127.webp",
- "px": -300
+ "px": -100
},
"index": "10",
"time": 0,
@@ -6282,7 +6282,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120127.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6292,7 +6292,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "11",
"time": 0,
@@ -6300,7 +6300,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120127.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6310,7 +6310,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "12",
"time": 0,
@@ -6318,7 +6318,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6328,7 +6328,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "13",
"time": 0,
@@ -6336,7 +6336,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6346,7 +6346,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "14",
"time": 0,
@@ -6354,7 +6354,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6364,7 +6364,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "15",
"time": 0,
@@ -6372,7 +6372,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6382,7 +6382,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "16",
"time": 0,
@@ -6390,7 +6390,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6400,7 +6400,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "17",
"time": 0,
@@ -6408,7 +6408,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6418,7 +6418,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "18",
"time": 0,
@@ -6426,7 +6426,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6436,7 +6436,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120121.webp",
- "px": -300
+ "px": -100
},
"index": "19",
"time": 0,
@@ -6444,7 +6444,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120121.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6454,7 +6454,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120102.webp",
- "px": -300
+ "px": -100
},
"index": "20",
"time": 0,
@@ -6462,7 +6462,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6472,7 +6472,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120111.webp",
- "px": -300
+ "px": -100
},
"index": "21",
"time": 0,
@@ -6480,7 +6480,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120111.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6490,7 +6490,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "22",
"time": 0,
@@ -6498,7 +6498,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6508,7 +6508,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "23",
"time": 0,
@@ -6516,7 +6516,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6526,7 +6526,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120106.webp",
- "px": -300
+ "px": -100
},
"index": "24",
"time": 0,
@@ -6534,7 +6534,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120106.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6544,7 +6544,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "25",
"time": 0,
@@ -6552,7 +6552,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120106.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6562,7 +6562,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "26",
"time": 0,
@@ -6570,7 +6570,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120113.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6584,7 +6584,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120122.webp",
- "px": -300
+ "px": -100
},
"index": "27",
"time": 0,
@@ -6592,7 +6592,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120122.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6602,7 +6602,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "28",
"time": 0,
@@ -6610,7 +6610,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6620,7 +6620,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "29",
"time": 0,
@@ -6628,7 +6628,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120107.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6638,7 +6638,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "30",
"time": 0,
@@ -6646,7 +6646,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_120112.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6656,7 +6656,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "31",
"time": 0,
@@ -6674,7 +6674,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "32",
"time": 0,
@@ -6692,7 +6692,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "33",
"time": 0,
@@ -6710,7 +6710,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "34",
"time": 0,
@@ -6718,7 +6718,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6728,7 +6728,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "35",
"time": 0,
@@ -6736,7 +6736,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6746,7 +6746,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "36",
"time": 0,
@@ -6754,7 +6754,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6764,7 +6764,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340102.webp",
- "px": -300
+ "px": -100
},
"index": "37",
"time": 0,
@@ -6772,7 +6772,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6782,7 +6782,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "38",
"time": 0,
@@ -6790,7 +6790,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340102.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6800,7 +6800,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340101.webp",
- "px": -300
+ "px": -100
},
"index": "39",
"time": 0,
@@ -6808,7 +6808,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6818,7 +6818,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "40",
"time": 0,
@@ -6826,7 +6826,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_340101.webp",
- "px": 600,
+ "px": 200,
"filter": false
}
]
@@ -6836,7 +6836,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "41",
"time": 0,
@@ -6844,7 +6844,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6854,7 +6854,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "42",
"time": 0,
@@ -6862,7 +6862,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6872,7 +6872,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340104.webp",
- "px": -300
+ "px": -100
},
"index": "43",
"time": 0,
@@ -6880,7 +6880,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340104.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6890,7 +6890,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "44",
"time": 0,
@@ -6898,7 +6898,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6908,7 +6908,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "45",
"time": 0,
@@ -6916,7 +6916,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6926,7 +6926,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340108.webp",
- "px": -300
+ "px": -100
},
"index": "46",
"time": 0,
@@ -6934,7 +6934,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340108.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6944,7 +6944,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340114.webp",
- "px": -300
+ "px": -100
},
"index": "47",
"time": 0,
@@ -6952,7 +6952,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340114.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6962,7 +6962,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "48",
"time": 0,
@@ -6970,7 +6970,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340114.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -6980,7 +6980,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340102.webp",
- "px": -300
+ "px": -100
},
"index": "49",
"time": 0,
@@ -6988,7 +6988,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": 67,
"filter": false
}
]
@@ -6998,7 +6998,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "50",
"time": 0,
@@ -7006,7 +7006,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7016,7 +7016,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340104.webp",
- "px": -300
+ "px": -100
},
"index": "51",
"time": 0,
@@ -7024,7 +7024,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340104.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7034,7 +7034,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "52",
"time": 0,
@@ -7042,7 +7042,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340107.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7052,7 +7052,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120132.webp",
- "px": -300
+ "px": -100
},
"index": "53",
"time": 0,
@@ -7060,12 +7060,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
}
]
@@ -7075,7 +7075,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120101.webp",
- "px": -300
+ "px": -100
},
"index": "54",
"time": 0,
@@ -7083,12 +7083,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
}
]
@@ -7098,7 +7098,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120121.webp",
- "px": -300
+ "px": -100
},
"index": "55",
"time": 0,
@@ -7106,12 +7106,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
}
]
@@ -7121,7 +7121,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "56",
"time": 0,
@@ -7129,7 +7129,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7139,7 +7139,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "57",
"time": 0,
@@ -7147,7 +7147,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340102.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7157,7 +7157,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340101.webp",
- "px": -300
+ "px": -100
},
"index": "58",
"time": 0,
@@ -7165,7 +7165,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7175,7 +7175,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "59",
"time": 0,
@@ -7183,7 +7183,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"bodyList": [
{
"name": "tati_z340101.webp",
- "px": -200,
+ "px": -67,
"filter": false
}
]
@@ -7193,7 +7193,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120102.webp",
- "px": -300
+ "px": -100
},
"index": "60",
"time": 0,
@@ -7201,12 +7201,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
}
]
@@ -7216,7 +7216,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "61",
"time": 0,
@@ -7224,12 +7224,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
}
]
@@ -7239,7 +7239,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340102.webp",
- "px": -300
+ "px": -100
},
"index": "62",
"time": 0,
@@ -7247,12 +7247,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
}
]
@@ -7262,7 +7262,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340110.webp",
- "px": -300
+ "px": -100
},
"index": "63",
"time": 0,
@@ -7270,12 +7270,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
}
]
@@ -7285,7 +7285,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "64",
"time": 0,
@@ -7293,12 +7293,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
}
]
@@ -7308,7 +7308,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120101.webp",
- "px": -300
+ "px": -100
},
"index": "65",
"time": 0,
@@ -7316,12 +7316,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
}
]
@@ -7331,7 +7331,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "66",
"time": 0,
@@ -7339,12 +7339,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
}
]
@@ -7354,7 +7354,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120121.webp",
- "px": -300
+ "px": -100
},
"index": "67",
"time": 0,
@@ -7362,12 +7362,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
}
]
@@ -7377,7 +7377,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120132.webp",
- "px": -300
+ "px": -100
},
"index": "68",
"time": 0,
@@ -7385,12 +7385,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
}
]
@@ -7400,7 +7400,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340106.webp",
- "px": -300
+ "px": -100
},
"index": "69",
"time": 0,
@@ -7408,12 +7408,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
}
]
@@ -7423,7 +7423,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340112.webp",
- "px": -300
+ "px": -100
},
"index": "70",
"time": 0,
@@ -7431,12 +7431,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
}
]
@@ -7446,7 +7446,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "71",
"time": 0,
@@ -7454,12 +7454,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
}
]
@@ -7469,7 +7469,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340108.webp",
- "px": -300
+ "px": -100
},
"index": "72",
"time": 0,
@@ -7477,12 +7477,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
}
]
@@ -7492,7 +7492,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340105.webp",
- "px": -300
+ "px": -100
},
"index": "73",
"time": 0,
@@ -7500,12 +7500,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
}
]
@@ -7515,7 +7515,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120107.webp",
- "px": -300
+ "px": -100
},
"index": "74",
"time": 0,
@@ -7523,12 +7523,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
}
]
@@ -7538,7 +7538,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "75",
"time": 0,
@@ -7546,12 +7546,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
}
]
@@ -7561,7 +7561,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "",
- "px": -300
+ "px": -100
},
"index": "76",
"time": 0,
@@ -7569,12 +7569,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
}
]
@@ -7584,7 +7584,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340103.webp",
- "px": -300
+ "px": -100
},
"index": "77",
"time": 0,
@@ -7592,12 +7592,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
}
]
@@ -7607,7 +7607,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340101.webp",
- "px": -300
+ "px": -100
},
"index": "78",
"time": 0,
@@ -7615,12 +7615,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
}
]
@@ -7630,7 +7630,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120113.webp",
- "px": -300
+ "px": -100
},
"index": "79",
"time": 0,
@@ -7638,12 +7638,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
}
]
@@ -7653,7 +7653,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_120112.webp",
- "px": -300
+ "px": -100
},
"index": "80",
"time": 0,
@@ -7661,12 +7661,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
}
]
@@ -7676,7 +7676,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"WindowSkin": false,
"head": {
"name": "face_340107.webp",
- "px": -300
+ "px": -100
},
"index": "81",
"time": 0,
@@ -7684,12 +7684,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
}
]
@@ -7700,7 +7700,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "引出"
}
],
@@ -7746,7 +7746,7 @@ var events_c12a15a8_c380_4b28_8144_256cba95f760 =
"memory1": false,
"img2": "",
"memory2": false,
- "time": 30,
+ "time": 10,
"style": "场景切换"
},
{
@@ -7755,12 +7755,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,
@@ -7775,12 +7773,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,
@@ -7795,12 +7791,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,
@@ -7815,12 +7809,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,
@@ -7850,12 +7842,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,
diff --git a/project/functions.js b/project/functions.js
index 0c3f792..98db7b7 100644
--- a/project/functions.js
+++ b/project/functions.js
@@ -1299,7 +1299,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;
diff --git a/project/items.js b/project/items.js
index 53adda0..1512c13 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",
diff --git a/project/plugins.js b/project/plugins.js
index c565f81..584c838 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";
@@ -2586,48 +2636,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 +2711,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 +2724,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 +2760,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,36 +2778,36 @@ 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";
+ main.dom.cgText.style.width = obj.totalWidth + "px";
+ main.dom.cgText.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";
+ main.dom.video.style.width = obj.totalWidth + "px";
+ main.dom.video.style.height = obj.totalHeight + "px";
if (core.domStyle.isVertical)
- main.dom.video.style.width = obj.totalHeight + 3 + "px";
+ main.dom.video.style.width = obj.totalHeight + "px";
if (core.domStyle.isVertical)
- main.dom.video.style.height = obj.totalWidth + 3 + "px";
+ main.dom.video.style.height = obj.totalWidth + "px";
main.dom.video.style.top = "50%";
main.dom.video.style.left = "50%";
@@ -2770,34 +2817,34 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
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 +2856,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 =
@@ -2845,52 +2893,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 = -2;
+ if (globalAlphafloor === 0) globalAlphafloorStatus = 2;
- 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.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.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 +2952,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 +2985,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,
@@ -3028,27 +3075,27 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
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 + 42,
+ MAP_BLOCK_TOP_VERTICAL + 57
);
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 + 57
);
uictx.globalAlpha = 1;
}
@@ -3056,11 +3103,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,
@@ -3081,11 +3125,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"]; //横屏背景(右)
@@ -3132,19 +3173,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",
- 3
+ 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);
@@ -3155,59 +3194,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",
- 3
+ 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",
- 3
+ 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",
- 3
+ 62,
+ 41,
+ TEXT_COLOR
);
}
- drawStatusList(110 * 3, 93 * 3);
+ drawStatusList(110, 93);
//core.drawImage("outerUI", "lane1.png", 0, 30);
core.drawImage(
"outerUI",
@@ -3217,9 +3251,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
400,
350,
0,
- 30,
- 360,
- 315
+ 0,
+ 120,
+ 105
);
}
}
@@ -3245,8 +3279,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
32,
posx,
posy,
- 30 * 3,
- 30 * 3
+ 30,
+ 30
);
const cnt = core.itemCount(item);
if (
@@ -3256,10 +3290,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"
);
}
};
@@ -3268,14 +3302,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);
}
});
@@ -3284,14 +3318,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);
}
});
@@ -3310,19 +3344,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 {
@@ -3334,10 +3368,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
32 * icon,
32,
32,
- baseX + 5 * 3,
+ baseX + 5,
baseY,
- 32 * 3,
- 32 * 3
+ 32,
+ 32
);
}
};
@@ -3346,8 +3380,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,
@@ -3357,7 +3391,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",
@@ -3365,28 +3399,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",
"无"
@@ -3396,8 +3430,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,
@@ -3407,14 +3441,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",
@@ -3422,21 +3456,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",
"无"
@@ -3455,7 +3489,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);
@@ -3463,14 +3497,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 {
@@ -3478,7 +3512,7 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
"outerUI",
todraw[i],
baseX + delta,
- baseY + 32 * 3,
+ baseY + 32,
TEXT_COLOR
);
}
@@ -3489,22 +3523,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) {
@@ -3524,8 +3558,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
26,
x,
y,
- 13 * 3,
- 26 * 3
+ 13,
+ 26
);
}
_update_infoWindow() {
@@ -3540,8 +3574,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) {
@@ -3550,8 +3584,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(
@@ -3561,17 +3595,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 {
@@ -3579,18 +3613,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(
@@ -3600,17 +3634,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,
});
}
}
@@ -3638,8 +3672,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++) {
@@ -3647,10 +3681,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
);
}
}
@@ -3659,8 +3693,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++) {
@@ -3668,10 +3702,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
);
}
}
@@ -3700,6 +3734,9 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 =
case "book":
core.openBook(true);
break;
+ case "fly":
+ core.useFly(true);
+ break;
default:
core.useItem(itemId);
}
@@ -3718,12 +3755,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 (
@@ -3743,12 +3780,12 @@ 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.isReplaying()) {
@@ -3767,7 +3804,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 (
@@ -3786,7 +3823,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() ||
@@ -3806,12 +3843,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 (
@@ -3831,12 +3868,12 @@ 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.isReplaying()) {
@@ -4209,221 +4246,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);
@@ -4663,6 +4487,7 @@ let time=0
}
}
core.animateFrame.tip.push(one)
+ if(core.animateFrame.tip.length>4)core.animateFrame.tip.shift()
}
},
"额外信息": function () {
@@ -5754,18 +5579,7 @@ let time=0
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 () {
// 这个插件有点离谱 个人觉得参数过多只会降低可读性,还不如硬编码
@@ -9628,8 +9442,8 @@ let time=0
};
},
"音频系统": function () {
- // 在此增加新插件
- /*首先,在造塔群下载所需的库文件,然后放置在塔目录下的 libs/thirdparty 或其他目录下,之后在 index.html 的最后加上下面这几行:
+ // 在此增加新插件
+ /*首先,在造塔群下载所需的库文件,然后放置在塔目录下的 libs/thirdparty 或其他目录下,之后在 index.html 的最后加上下面这几行:
@@ -9637,2083 +9451,2101 @@ let time=0
*/
- // 将__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
// 自訂常見事件模板插件
@@ -13203,81 +13035,81 @@ let time=0
};
},
"瞬移轨迹": 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; // 编辑器模式下使用
@@ -13393,7 +13225,7 @@ let time=0
// ---- 可自定义,默认数值
const defaultValue = {
font: "Verdana", // 默认字体
- scale: 60, // 默认地图缩放比例
+ scale: 20, // 默认地图缩放比例
depth: Infinity, // 默认的遍历深度
};
@@ -13687,26 +13519,26 @@ let time=0
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) {
@@ -13753,8 +13585,8 @@ let time=0
19,
fx + min / 4,
fy + (min * 5) / 16,
- 32,
- 19
+ 11,
+ 6
);
// 显示漏怪数量
if (core.getFlag("showEnemy")) {
@@ -13774,7 +13606,7 @@ let time=0
fx + (w * 3) / 10,
fy + (h * 7) / 10,
color,
- 22 + "px normal"
+ 7 + "px normal"
);
ctx.shadowBlur = 0;
}
@@ -13786,1136 +13618,11 @@ let time=0
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 () {
// 在此增加新插件
@@ -14940,7 +13647,7 @@ let time=0
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);
}
@@ -14999,11 +13706,11 @@ let time=0
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");
}
@@ -15029,7 +13736,7 @@ let time=0
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";
@@ -15039,16 +13746,16 @@ let time=0
}
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) {
@@ -15067,9 +13774,9 @@ let time=0
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;
}
@@ -15079,9 +13786,9 @@ let time=0
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;
}
@@ -15091,9 +13798,9 @@ let time=0
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;
}
@@ -15103,9 +13810,9 @@ let time=0
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;
}
@@ -15115,9 +13822,9 @@ let time=0
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;
}
@@ -15129,21 +13836,21 @@ let time=0
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++;
@@ -15160,7 +13867,7 @@ let time=0
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;
}
}
@@ -15168,7 +13875,7 @@ let time=0
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;
}
}
@@ -15176,7 +13883,7 @@ let time=0
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;
}
}
@@ -15184,7 +13891,7 @@ let time=0
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;
}
}
@@ -15192,7 +13899,7 @@ let time=0
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;
}
}
@@ -15200,7 +13907,7 @@ let time=0
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;
}
}
@@ -15216,54 +13923,54 @@ let time=0
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)
);
// 添加向上翻页和向下翻页的按钮
@@ -15273,92 +13980,92 @@ let time=0
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的画框
@@ -15366,39 +14073,39 @@ let time=0
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
);
}
}
@@ -15424,42 +14131,42 @@ let time=0
};
},
"光标设置": 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 () {
// 在此增加新插件
/* 弹出显示某个内容
@@ -15704,13 +14411,11 @@ let time=0
const move = document.createElement("canvas");
const move2 = document.createElement("canvas");
- move.width = 416;
- move.height = 416;
- move2.width = 416;
- move2.height = 416;
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,
@@ -15769,10 +14474,10 @@ let time=0
);
const v = dirData[dir][1], // 水平数值
h = dirData[dir][0]; //竖直数值
- ctx.clearRect(0, 0, 416, 416);
- ctx2.clearRect(0, 0, 416, 416);
+ 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: 0,
y: 0,
@@ -15781,7 +14486,7 @@ let time=0
});
if (dir !== "upFloor" && dir !== "downFloor") {
core.drawThumbnail(toFloorId, null, {
- damage: dataTo.damage,
+ damage: false,
ctx: ctx2,
x: 0,
y: 0,
@@ -15826,7 +14531,6 @@ let time=0
y1, 416, 416)
ctx3.drawImage(
move,
- 0, 0, 416, 416,
x1,
y1, 416, 416
@@ -15834,7 +14538,6 @@ let time=0
ctx3.drawImage(
move2,
- 0, 0, 416, 416,
x2,
y2,
416, 416
@@ -15932,7 +14635,7 @@ let time=0
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);
}
@@ -15966,7 +14669,7 @@ let time=0
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);
}
@@ -15997,7 +14700,7 @@ let time=0
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);
}
@@ -16033,7 +14736,7 @@ let time=0
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);
}
@@ -16045,10 +14748,10 @@ let time=0
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 = "";
@@ -16080,22 +14783,22 @@ let time=0
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)) ||
@@ -16127,7 +14830,7 @@ let time=0
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);
@@ -16135,7 +14838,7 @@ let time=0
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);
@@ -16154,16 +14857,15 @@ let time=0
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.cgText.style.display = "none";
+ core.doAction();
}
});
} else if (
@@ -16344,7 +15046,7 @@ let time=0
ctx.restore();
ctx.save(); //保存设置
if (core.domStyle.isVertical) {
- ctx.translate(1248, 0); //重新定位右上角为基准
+ ctx.translate(416, 0); //重新定位右上角为基准
ctx.rotate(Math.PI / 2); //旋转90度
}
ctx.drawImage(
@@ -16411,35 +15113,33 @@ let time=0
}
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 (
@@ -16457,37 +15157,37 @@ let time=0
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);
@@ -16495,96 +15195,94 @@ let time=0
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) => {
@@ -16592,7 +15290,7 @@ let time=0
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,
@@ -16601,7 +15299,7 @@ let time=0
body.width,
body.height,
v.px,
- 1248 - body.height * v.scale,
+ 416 - body.height * v.scale,
body.width * v.scale,
body.height * v.scale
);
@@ -16613,7 +15311,7 @@ let time=0
body.width,
body.height,
v.px,
- 1248 - (v.h ?? body.height),
+ 416 - (v.h ?? body.height),
v.w ?? body.width,
v.h ?? body.height
);
@@ -16625,14 +15323,11 @@ let time=0
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) {
@@ -16644,113 +15339,100 @@ let time=0
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 (
@@ -16780,15 +15462,15 @@ let time=0
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,
});
}
@@ -16812,36 +15494,34 @@ let time=0
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()) {
@@ -16852,9 +15532,10 @@ let time=0
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);
@@ -16863,15 +15544,15 @@ let time=0
//绘制背景
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);
@@ -16896,25 +15577,26 @@ let time=0
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();
});
@@ -16923,14 +15605,14 @@ let time=0
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,
}, ]
) {
@@ -16943,249 +15625,247 @@ let time=0
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();
+
});
};
@@ -17198,34 +15878,33 @@ let time=0
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");
@@ -17239,34 +15918,34 @@ let time=0
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";
@@ -17278,47 +15957,47 @@ let time=0
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");
@@ -17338,20 +16017,18 @@ let time=0
//绘制背景
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();
}
@@ -17474,14 +16151,12 @@ let time=0
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];
@@ -17508,7 +16183,7 @@ let time=0
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;
@@ -17516,8 +16191,6 @@ let time=0
// 更新帧
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) {
@@ -17529,12 +16202,12 @@ let time=0
}
}
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++);
});
}
@@ -17554,19 +16227,19 @@ let time=0
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()
) {
@@ -17576,10 +16249,10 @@ let time=0
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()
) {
@@ -17758,42 +16431,38 @@ let time=0
);
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();
@@ -17801,7 +16470,7 @@ let time=0
}
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();
@@ -17814,24 +16483,23 @@ let time=0
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");
@@ -17839,14 +16507,15 @@ let time=0
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");
@@ -17877,44 +16546,44 @@ let time=0
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; //下面写其余技能
@@ -17938,11 +16607,11 @@ let time=0
};
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;
@@ -17975,7 +16644,7 @@ let time=0
} 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;
@@ -17987,14 +16656,12 @@ let time=0
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);
@@ -18002,143 +16669,129 @@ let time=0
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(
@@ -18148,73 +16801,73 @@ let time=0
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:
@@ -18223,64 +16876,64 @@ let time=0
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;
}
@@ -18403,20 +17056,18 @@ let time=0
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)"
);
@@ -18425,21 +17076,21 @@ let time=0
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()
@@ -18453,133 +17104,125 @@ let time=0
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() {
@@ -18588,21 +17231,19 @@ let time=0
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);
@@ -18611,7 +17252,7 @@ let time=0
}
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();
@@ -18665,25 +17306,23 @@ let time=0
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
);
}
@@ -18695,22 +17334,20 @@ let time=0
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);
@@ -18721,124 +17358,118 @@ let time=0
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;
}
});
@@ -18846,247 +17477,239 @@ let time=0
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;
}
});
}
@@ -19098,328 +17721,314 @@ let time=0
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;
}
});
}
@@ -19427,7 +18036,7 @@ let time=0
}
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);
@@ -19440,68 +18049,64 @@ let time=0
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();
+ }
+
+ });
+ }
+
});
});
}
@@ -19513,58 +18118,54 @@ let time=0
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();
+ }
+
+ });
+ }
+
});
});
}
@@ -19572,188 +18173,188 @@ let time=0
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.gameGroup.insertAdjacentElement("afterend", video);
+ video.style.top = "50%";
+ video.style.left = "50%";
+ video.style.transform = "translate(-50%,-50%)";
+ 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.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) {
+ 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 (
@@ -19772,39 +18373,36 @@ let time=0
let now = 0;
- let start = 0
- let sounds = []
+ 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 (
@@ -19853,13 +18451,13 @@ let time=0
(((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 =
@@ -19876,1167 +18474,1167 @@ let time=0
one.sound &&
core.sounds[one.sound] &&
core.musicStatus.soundStatus;
- if (farme >= one.startfarme && lisen && !one.start && sounds.includes(farme)) {
- one.start = true
+ if (farme >= one.startfarme && lisen) {
if (one.stopbefore) core.stopSound();
core.playSound(one.sound);
- sounds.includes(farme)
+
}
});
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.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, 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.fillBoldText1(
+ ctx,
+ text,
+ 50,
+ posy - 100,
+ page === this.selection[0] && i === this.selection[1] ?
+ "#FFFFFF" :
+ "#444444",
+ "#000000",
+ 6,
+ 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,
+ "|",
+ 278,
+ 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,
+ "|",
+ 165,
+ 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) {
@@ -21462,35 +20060,14 @@ let time=0
},
"回合战斗动画": 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 ctx = core.createCanvas("animateAttack", 0, 0, 416, 416, 80)
+
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);
+ const anctx = core.createCanvas("animate2", 0, 0, 416, 416, 91)
let a = []
function drawAnimate(name, centerX, centerY) {
@@ -21513,33 +20090,30 @@ let time=0
"animate": animate,
"centerX": centerX,
"centerY": centerY,
- "start": 0,
"pause": false,
- "pausetime": 0,
- 'sounds': [],
"index": 0,
});
return id;
}
+ core.animateFrame.animate2Time = 0
function animationFrame(callback1) {
let time = 0
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 () {
@@ -21565,7 +20139,6 @@ let time=0
core.status.heroCenter.px,
core.status.heroCenter.py,
obj.index,
- obj.sounds
);
} else {
core.maps._drawAnimateFrame(
@@ -21574,9 +20147,9 @@ let time=0
obj.centerX,
obj.centerY,
obj.index,
- obj.sounds
);
}
+ obj.index++
});
core.animateFrame.animateTime = timestamp;
});
@@ -22354,7 +20927,7 @@ let time=0
core.registerAnimationFrame("attackAnimate", true, (temptime) => {
if (!time) time = temptime
- farme = Math.floor((temptime - time) / (1000 / 60))
+ if (temptime - time < 50) return
time = temptime;
drawAttackAnimate(
heroInfo,
@@ -22367,7 +20940,7 @@ let time=0
heroanimateList,
enemyanimateList
);
-
+ farme++
});
});
@@ -23296,59 +21869,59 @@ let time=0
};
},
"勇士法抗乘算叠加": 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 () {
// 在此增加新插件
//临界表
@@ -23664,11 +22237,11 @@ let time=0
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) {
@@ -23765,7 +22338,6 @@ let time=0
};
function saveLoadclick(x, y) { //点击画布(x,y)触发的效果
- debugger
const makeBox = ([x, y], [w, h]) => { //创建点击检测区域
return [
[x, y],
@@ -23783,35 +22355,35 @@ let time=0
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
@@ -23878,7 +22450,7 @@ let time=0
}
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);
@@ -23911,7 +22483,7 @@ let time=0
}
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 (core.status.event.data.mode === "fav") {
real_id = core.saves.favorite[9 * page + a - 1]
@@ -24328,14 +22900,12 @@ let time=0
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();
@@ -24343,223 +22913,223 @@ let time=0
// --- 绘制文字
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();
@@ -24571,9 +23141,9 @@ let time=0
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; //恢复为不透明
}
@@ -24602,14 +23172,10 @@ let time=0
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");
@@ -24621,325 +23187,301 @@ let time=0
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) => {
//绘制立绘
@@ -24947,7 +23489,7 @@ let time=0
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(
@@ -24956,8 +23498,8 @@ let time=0
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
);
@@ -24968,8 +23510,8 @@ let time=0
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
);
@@ -24977,7 +23519,7 @@ let time=0
}
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) {
//绘制头像
@@ -24987,46 +23529,40 @@ let time=0
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") {
@@ -25036,119 +23572,115 @@ let time=0
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));
}
}
@@ -25156,146 +23688,146 @@ let time=0
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)
@@ -25315,17 +23847,17 @@ let time=0
}
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)
}
};
@@ -25461,7 +23993,7 @@ let time=0
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) {
@@ -25770,6 +24302,7 @@ let time=0
},
"动画": function () {
+
// 在此增加新插件
const { Transition, linear, bezier, circle, hyper, trigo, power, inverseTrigo, shake, sleep } = core.plugin.animate;
//////移动动画//////
@@ -25799,40 +24332,31 @@ let time=0
}
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.sounds = []
- 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.sounds = []
- obj.pausetime = 0
- } else {
- obj.start = core.animateFrame.animateTime
- obj.sounds = []
- 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) {
@@ -25856,15 +24380,19 @@ let time=0
const heroy = core.status.hero.loc.y * 32 + 32 + sy - core.material.icons.hero.height / 2;
core.status.animateObjs.forEach(function (obj) {
-
if (obj.hero) {
- core.maps._drawAnimateFrame('animate', obj.animate, herox, heroy, obj.index, obj.sounds);
+ core.maps._drawAnimateFrame('animate', obj.animate, herox, heroy, obj.index);
} else {
- core.maps._drawAnimateFrame('animate', obj.animate, tran.value[obj.id + obj.name + "x"], tran.value[obj.id + obj.name + "y"], obj.index, obj.sounds);
+ 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);
@@ -25892,18 +24420,14 @@ let time=0
tran.mode(linear()).time(1).absolute()
tran.value[id + name + "x"] = centerX
tran.value[id + name + "y"] = centerY
-
core.status.animateObjs.push({
"name": name,
"id": id,
"animate": animate,
"centerX": centerX,
"centerY": centerY,
- "start": 0,
"pause": false,
- "pausetime": 0,
"index": 0,
- 'sounds': [],
"callback": callback
});
@@ -25938,12 +24462,9 @@ let time=0
"animate": animate,
"hero": true,
"reverse": reverse,
- "start": 0,
"pause": false,
"loop": loop,
- "pausetime": 0,
- "index": 0,
- 'sounds': [],
+ "index": reverse ? animate.frames.length : 0,
"callback": callback
})
else core.status.animateObjs.push({
@@ -25953,12 +24474,9 @@ let time=0
"centerX": centerX,
"centerY": centerY,
"reverse": reverse,
- "start": 0,
"pause": false,
"loop": loop,
- "pausetime": 0,
- "index": 0,
- 'sounds': [],
+ "index": reverse ? animate.frames.length : 0,
"callback": callback
});
@@ -25992,7 +24510,6 @@ let time=0
"pause": false,
"pausetime": 0,
"index": 0,
- 'sounds': [],
"callback": callback
});
@@ -26008,14 +24525,13 @@ let time=0
////// 绘制动画的某一帧 //////
- maps.prototype._drawAnimateFrame = function (name, animate, centerX, centerY, index, sounds) {
+ maps.prototype._drawAnimateFrame = function (name, animate, centerX, centerY, index) {
var ctx = core.getContextByName(name);
if (!ctx) return;
var frame = animate.frames[index % animate.frame];
- if (!sounds.includes(index)) {
- core.playSound((animate.se || {})[index % animate.frame + 1], (animate.pitch || {})[index % animate.frame + 1]);
- sounds.push(index)
- }
+
+ 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];
@@ -26082,18 +24598,8 @@ let time=0
"帧动画(游戏画面)": 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();
@@ -26147,7 +24653,10 @@ let time=0
core.setFlag("animate_" + name);
};
let thistime = 0;
- this.playanimate = function (name, id, x, y, hero, scalex, scaley, loop, reverse) {
+ this.playanimate = function (name, id, x, y, hero, scalex, scaley, loop, reverse, callback) {
+ if (!flags["animate_" + name]) {
+ callback?.()
+ }
if (!id) id = setTimeout(null)
tran.mode(linear()).time(1).absolute()
if (!hero) tran.value[id + name + "x"] = x
@@ -26161,16 +24670,15 @@ let time=0
hero: hero,
scalex: scalex,
scaley: scaley,
- start: 0,
pause: false,
loop: loop,
reverse: reverse,
- pausetime: 0,
- farme: 0,
- sounds: []
+ farme: reverse ? flags["animate_" + name].allFarme : 0,
+
};
core.plugin.playing.add(data);
+ callback?.()
return id
};
this.animateloop = function (id, loop) {
@@ -26182,8 +24690,7 @@ let time=0
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
}
})
@@ -26198,43 +24705,39 @@ let time=0
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
- one.sounds = []
- } else {
- one.start = thistime
- one.farme = 0
- one.pausetime = 0
- one.sounds = []
+ 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)) {
+ 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) {
@@ -26354,16 +24857,20 @@ let time=0
}
}
}
+ if (!one.pause) {
+ if (one.reverse) one.farme--
+ else one.farme++
+ }
});
data.soundList.forEach(function (sound) {
const lisen =
sound.sound &&
core.material.sounds[sound.sound] &&
core.musicStatus.soundStatus;
- if (one.farme == sound.startfarme && lisen && one.sounds.includes(one.farme)) {
+ if (one.farme == sound.startfarme && lisen) {
if (sound.stopbefore) core.stopSound();
core.playSound(sound.sound);
- one.sounds.push(one.farme)
+
}
});