diff --git a/package.json b/package.json index 9398318..4d604a9 100644 --- a/package.json +++ b/package.json @@ -18,7 +18,7 @@ "chart.js": "^4.0.1", "lodash": "^4.17.21", "lz-string": "^1.4.4", - "mutate-animate": "^0.1.0", + "mutate-animate": "^1.0.0", "vue": "^3.2.41" }, "devDependencies": { diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 21404e2..59c9fa3 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -20,7 +20,7 @@ specifiers: less: ^4.1.3 lodash: ^4.17.21 lz-string: ^1.4.4 - mutate-animate: ^0.1.0 + mutate-animate: ^1.0.0 terser: ^5.15.1 ts-node: ^10.9.1 typescript: ^4.6.4 @@ -36,7 +36,7 @@ dependencies: chart.js: 4.0.1 lodash: 4.17.21 lz-string: 1.4.4 - mutate-animate: 0.1.0 + mutate-animate: 1.0.0 vue: 3.2.45 devDependencies: @@ -2468,8 +2468,8 @@ packages: resolution: {integrity: sha512-Tr1knR3d2mKvvWthlk7202rywKbiOm4rVFLsfAaSIhJ6dt9o47W4S+JMtWhd/PW9Wrdew2/S2fSvhz3E2gkfEg==} dev: true - /mutate-animate/0.1.0: - resolution: {integrity: sha512-XOdyX/PDFYZDpUpaqPeLOfdeDYXQcThWsuLUQpp3z6FbReDV23jIN0Vzv5QLUy+6CDMHEBZHfsumODrlKJva+g==} + /mutate-animate/1.0.0: + resolution: {integrity: sha512-Vt6zDunYjunQAJQ8mXTnamjbubWOM/hM0W+umvJKOvFP6klRAJPHO5R1XUKqEe2/mM9QM+aUfKb2q8Z0Ybwj/A==} dev: false /nan/2.17.0: diff --git a/public/project/floors/MT0.js b/public/project/floors/MT0.js index fc7a2e2..a0b4f62 100644 --- a/public/project/floors/MT0.js +++ b/public/project/floors/MT0.js @@ -37,7 +37,7 @@ main.floors.MT0= "请耐心等待字体加载完成,否则很多地方显示会很奇怪,大概需要十秒,过一段时间打开任意界面再关闭即可", { "type": "function", - "function": "function(){\ncore.displayChapter(0);\n}" + "function": "function(){\ncore.showChapter('序章 起源');\n}" } ], "parallelDo": "", diff --git a/public/project/plugins.js b/public/project/plugins.js index 4f2a453..96f6aa8 100644 --- a/public/project/plugins.js +++ b/public/project/plugins.js @@ -3547,236 +3547,6 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 = { } } }, - chapter: function () { - // 章节显示 - var chapter = '', - description = ''; - // 显示章节 - this.displayChapter = function (index) { - if (core.isReplaying()) return; - var number = core.replaceNumberWithChinese(index); - // 获取第几章 - chapter = '第' + number + '章'; - if (index == 0) chapter = '序章'; - // 获取描述 - switch (index) { - case 0: - description = '起源'; - break; - case 1: - description = '勇气'; - break; - case 2: - description = '智慧'; - break; - } - core.coreChapterAnimate(chapter, description); - }; - // 替换数字大小写 - this.replaceNumberWithChinese = function (number) { - if (number == 0) return '零'; - if (number == 1) return '一'; - if (number == 2) return '二'; - if (number == 3) return '三'; - if (number == 4) return '四'; - if (number == 5) return '五'; - if (number == 6) return '六'; - if (number == 7) return '七'; - if (number == 8) return '八'; - if (number == 9) return '九'; - if (number == 10) return '十'; - }; - // 核心动画运算 - this.coreChapterAnimate = function (chapter, description) { - // 先建画布 - if (core.isReplaying()) return; - core.createCanvas('chapter', 0, 0, 480, 480, 100); - var frame = 0, - speed = 0, - left = -480, - down = 240; - // 一秒50帧 - core.lockControl(); - var interval = setInterval(() => { - core.clearMap('chapter'); - speed = core.hyperbolicCosine((frame - 84) * 0.05); - left += speed / 2; - // 背景 - if (frame <= 110) { - core.fillRect( - 'chapter', - 0, - -240 - left, - 480, - left + 480, - '#000000' - ); - core.fillRect( - 'chapter', - 0, - 240, - 480, - left + 480, - '#000000' - ); - } else { - core.fillRect('chapter', 0, 0, 480, down, '#000000'); - core.fillRect( - 'chapter', - 0, - 480 - down, - 480, - down, - '#000000' - ); - down -= speed / 2; - } - // 中间矩形 - if (frame <= 100) { - core.fillRect( - 'chapter', - 0, - 240 - frame / 5, - 480, - frame / 2.5, - [255, 255, 255, 0.5 + frame / 200] - ); - } else { - core.fillRect( - 'chapter', - 0, - 240 - 2100 / (205 - frame), - 480, - 4200 / (205 - frame), - [255, 255, 255, (175 - frame) / 75] - ); - } - // 上下方线 - core.fillRect('chapter', left, 210, 300, 10, '#FF4D00'); - core.fillRect('chapter', 180 - left, 260, 300, 10, '#2DFFFC'); - core.fillRect('chapter', left + 310, 210, 10, 10, '#FF4D00'); - core.fillRect('chapter', 160 - left, 260, 10, 10, '#2DFFFC'); - core.fillPolygon( - 'chapter', - [ - [left + 330, 210], - [left + 330, 220], - [left + 340, 220] - ], - '#FF4D00' - ); - core.fillPolygon( - 'chapter', - [ - [150 - left, 260], - [140 - left, 260], - [150 - left, 270] - ], - '#2DFFFC' - ); - // 闪光条 - for (var i = 5; i > 0; i--) { - if (frame <= 150) { - core.drawLine( - 'chapter', - 0, - 220, - left + 320, - 220, - [255, 255, 255, 0.4], - i - ); - core.drawLine( - 'chapter', - 480, - 260, - 160 - left, - 260, - [255, 255, 255, 0.4], - i - ); - } else { - core.drawLine( - 'chapter', - 0, - 220, - left + 320, - 220, - [255, 255, 255, 0.4 - (frame - 150) / 125], - i - ); - core.drawLine( - 'chapter', - 480, - 260, - 160 - left, - 260, - [255, 255, 255, 0.4 - (frame - 150) / 125], - i - ); - } - } - core.fillEllipse( - 'chapter', - left + 320, - 220, - 7, - 3, - 0, - [255, 255, 255, 0.8] - ); - core.fillEllipse( - 'chapter', - left + 320, - 220, - 2, - 10, - 0, - [255, 255, 255, 0.8] - ); - core.fillEllipse( - 'chapter', - 160 - left, - 260, - 7, - 3, - 0, - [255, 255, 255, 0.8] - ); - core.fillEllipse( - 'chapter', - 160 - left, - 260, - 2, - 10, - 0, - [255, 255, 255, 0.8] - ); - // 字 - core.setTextAlign('chapter', 'center'); - core.fillBoldText( - 'chapter', - chapter + ' ' + description, - left + 360, - 250, - '#ffffff', - '#000000', - '28px scroll' - ); - if (frame >= 200) { - clearInterval(interval); - core.deleteCanvas('chapter'); - core.unlockControl(); - } - if (frame == 80) core.playSound('chapter.mp3'); - frame++; - }, 20); - }; - // 返回双曲余弦值 - this.hyperbolicCosine = function (number) { - return 0.5 * (Math.pow(Math.E, number) + Math.pow(Math.E, -number)); - }; - }, intelligenceTree: function () { // 智慧加点 var list; @@ -9046,6 +8816,8 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 = { if (core.isReplaying()) showToolbox = true; core.plugin.showStatusBar.value = false; + var statusItems = core.dom.status, + toolItems = core.dom.tools; core.setFlag('hideStatusBar', true); core.setFlag('showToolbox', showToolbox || null); if ( @@ -9059,5 +8831,10 @@ var plugins_bb40132b_638b_4a9f_b028_d3fe47acc8d1 = { core.dom.toolBar.style.display = 'none'; } }; + + this.showChapter = function (chapter) { + core.plugin.chapterContent.value = chapter; + core.plugin.chapterShowed.value = true; + }; } }; diff --git a/public/styles.css b/public/styles.css index 29ef8be..8b55efb 100644 --- a/public/styles.css +++ b/public/styles.css @@ -408,25 +408,25 @@ p#name { @-webkit-keyframes selector { 0% { - opacity: 0.95; - } - 50% { opacity: 0.55; } + 50% { + opacity: 0.25; + } 100% { - opacity: 0.95; + opacity: 0.55; } } @keyframes selector { 0% { - opacity: 0.95; - } - 50% { opacity: 0.55; } + 50% { + opacity: 0.25; + } 100% { - opacity: 0.95; + opacity: 0.55; } } diff --git a/src/App2.vue b/src/App2.vue index e3b1c0e..9413a79 100644 --- a/src/App2.vue +++ b/src/App2.vue @@ -2,6 +2,7 @@
+
@@ -10,6 +11,8 @@ import { ref } from 'vue'; import StatusBar from './ui/statusBar.vue'; import { showStatusBar } from './plugin/uiController'; import MarkedEnemy from './ui/markedEnemy.vue'; +import Chapter from './ui/chapter.vue'; +import { chapterContent, chapterShowed } from './plugin/ui/chapter'; diff --git a/src/ui/equipbox.vue b/src/ui/equipbox.vue index 54acb97..bdcafe8 100644 --- a/src/ui/equipbox.vue +++ b/src/ui/equipbox.vue @@ -461,7 +461,7 @@ onUnmounted(() => { width: 100%; display: flex; flex-direction: row; - font-size: 2em; + font-size: 3.2vh; height: 5vh; justify-content: space-between; font-family: 'normal'; diff --git a/src/ui/toolbox.vue b/src/ui/toolbox.vue index 72aeab3..d1aef37 100644 --- a/src/ui/toolbox.vue +++ b/src/ui/toolbox.vue @@ -275,7 +275,7 @@ onUnmounted(() => { display: flex; flex-direction: row; font-family: 'normal'; - font-size: 2em; + font-size: 3.2vh; height: 5vh; justify-content: space-between; @@ -403,12 +403,11 @@ onUnmounted(() => { #toolbox-main { flex-direction: column-reverse; height: 100%; - border-top: 1px solid #ddd4; } .item-list { width: 100%; - height: 100%; + height: 40vh; } .divider {