-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathindex.html
More file actions
536 lines (472 loc) · 53.7 KB
/
index.html
File metadata and controls
536 lines (472 loc) · 53.7 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
<!DOCTYPE html><html lang="zh-CN"><head><meta charset="UTF-8"/><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=2"/><meta name="theme-color" content="#222"/><meta http-equiv="X-UA-COMPATIBLE" content="IE=edge,chrome=1"/><meta name="renderer" content="webkit"/><link rel="icon" type="image/ico" sizes="32x32" href="/assets/core/favicon.ico"/><link rel="apple-touch-icon" sizes="180x180" href="/assets/core/apple-touch-icon.png"/><meta name="msvalidate.01" content="8EDE155D32FABF416CBC99317CAFFEBF"/><meta name="google-site-verification" content="HhoMl-Ti78sYFRZ3SDmymFEV-FbcwWW8Q1_hK8kOOh8"/><link rel="alternate" href="/rss.xml" title="FLwolfy's Blog" type="application/rss+xml"><link rel="alternate" href="/atom.xml" title="FLwolfy's Blog" type="application/atom+xml"><link rel="alternate" type="application/json" title="FLwolfy's Blog" href="https://blog.flwolfy.xyz/feed.json"/><link rel="preconnect" href="https://s4.zstatic.net"/><link rel="preconnect" href="https://at.alicdn.com"/><link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Mulish:400,400italic,700,700italic%7CFredericka%20the%20Great:400,400italic,700,700italic%7CNoto%20Serif%20JP:400,400italic,700,700italic%7CNoto%20Serif%20SC:400,400italic,700,700italic%7CInconsolata:400,400italic,700,700italic&display=swap&subset=latin,latin-ext" media="none" onload="this.media='all'"><link rel="modulepreload" href="/js/siteInit.js"></link><link rel="modulepreload" href="/js/nyx-player-K45IUCTB.js"></link><link rel="modulepreload" href="/js/copy-tex-642YCF4S.js"></link><link rel="modulepreload" href="/js/post-PS7YM4ED.js"></link><link rel="modulepreload" href="/js/chunk-YCNKP3UL.js"></link><link rel="modulepreload" href="/js/waline-NJEHS6ZH.js"></link><link rel="modulepreload" href="/js/comments-T2X4FPQK.js"></link><link rel="modulepreload" href="/js/chunk-BN7M2PYC.js"></link><link rel="modulepreload" href="/js/chunk-DEA3AV5B.js"></link><link rel="modulepreload" href="/js/pagefind-EHHRKGRH.js"></link><link rel="modulepreload" href="/js/index.esm-SNXVHCWG.js"></link><link rel="modulepreload" href="/js/chunk-N6JCCXE4.js"></link><link rel="modulepreload" href="/js/chunk-7QVYXSBW.js"></link><link rel="modulepreload" href="/js/chunk-WIQECBEN.js"></link><link rel="stylesheet" href="/css/siteInit.css" media="none" onload="this.media='all'"></link><link rel="stylesheet" href="/css/waline-K5W2JRFF.css" media="none" onload="this.media='all'"></link><link rel="stylesheet" href="/css/comments-TSKJFMW4.css" media="none" onload="this.media='all'"></link><link rel="preload" href="https://imgs.flwolfy.site/img/carousel/cover6.webp" as="image" fetchpriority="high"><link rel="preload" href="https://imgs.flwolfy.site/img/carousel/cover3.webp" as="image" fetchpriority="high"><link rel="preload" href="https://imgs.flwolfy.site/img/carousel/cover2.webp" as="image" fetchpriority="high"><link rel="preload" href="https://imgs.flwolfy.site/img/carousel/cover5.webp" as="image" fetchpriority="high"><link rel="preload" href="https://imgs.flwolfy.site/img/carousel/cover4.webp" as="image" fetchpriority="high"><link rel="preload" href="https://imgs.flwolfy.site/img/carousel/cover2.webp" as="image" fetchpriority="high"><meta name="keywords" content="blog, 博客, programming, 编程, game, 游戏, anime, 动漫"/><meta name="description" content="编程、游戏、动漫爱好者!"/><link rel="canonical" href="https://blog.flwolfy.xyz/"><link rel="stylesheet" href="/css/page.css?v=0.5.4"><title>Wolfiora</title><meta name="generator" content="Hexo 7.3.0"></head><body itemscope itemtype="http://schema.org/WebPage"><div id="loading"><div class="cat"><div class="body"></div><div class="head"><div class="face"></div></div><div class="foot"><div class="tummy-end"></div><div class="bottom"></div><div class="legs left"></div><div class="legs right"></div></div><div class="paw"><div class="hands left"></div><div class="hands right"></div></div></div></div><div id="pagefind_mount"></div><div id="container"><header id="header" itemscope itemtype="http://schema.org/WPHeader"><div class="inner"><div id="brand"><div class="pjax"><a class="logo" href="/" rel="start"><p class="artboard">Wolfiora</p><h1 class="title" itemprop="name headline">FLwolfy's Blog</h1></a><p class="meta" itemprop="description">= 寄蜉蝣于天地 · 渺沧海之一粟 =</p></div></div><nav id="nav"><div class="inner"><div class="toggle"><div class="lines" aria-label="切换导航栏"><span class="line"></span><span class="line"></span><span class="line"></span></div></div><ul class="menu"><li class="item title"><a href="/" rel="start">Wolfiora</a></li></ul><ul class="right" id="rightNav"><li class="item theme"><i class="ic i-sun"></i></li><li class="item search"><i class="ic i-search"></i></li></ul></div></nav></div><div class="pjax" id="imgs"><ul><li class="item" style="background-image: url("https://imgs.flwolfy.site/img/carousel/cover6.webp");"></li><li class="item" style="background-image: url("https://imgs.flwolfy.site/img/carousel/cover3.webp");"></li><li class="item" style="background-image: url("https://imgs.flwolfy.site/img/carousel/cover2.webp");"></li><li class="item" style="background-image: url("https://imgs.flwolfy.site/img/carousel/cover5.webp");"></li><li class="item" style="background-image: url("https://imgs.flwolfy.site/img/carousel/cover4.webp");"></li><li class="item" style="background-image: url("https://imgs.flwolfy.site/img/carousel/cover2.webp");"></li></ul></div></header><div id="waves"><svg class="waves" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 24 150 28" preserveAspectRatio="none" shape-rendering="auto"><defs><path id="gentle-wave" d="M-160 44c30 0 58-18 88-18s 58 18 88 18 58-18 88-18 58 18 88 18 v44h-352z"></path></defs><g class="parallax"><use xlink:href="#gentle-wave" x="48" y="0"></use><use xlink:href="#gentle-wave" x="48" y="3"></use><use xlink:href="#gentle-wave" x="48" y="5"></use><use xlink:href="#gentle-wave" x="48" y="7"></use></g></svg></div><main><div class="inner"><div class="pjax" id="main"><div class="index wrap"><h2 class="divider">置顶文章</h2><div class="segments sticky"><article class="item"><div class="cover"><a href="/other/announce/" itemprop="url" title="公告栏"><img loading="eager" decoding="async" src="https://imgs.flwolfy.site/img/post/announce/Cover.webp" alt="article cover"></a></div><div class="info"><div class="meta"><span class="item" title="创建时间:2025-04-13 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-04-13T00:00:00+08:00">2025-04-13</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>1.1k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>1 分钟</span></span></div><h3><a href="/other/announce/" itemprop="url" title="公告栏">公告栏</a></h3><div class="excerpt">⚠️本公告栏永远置顶,并且会不定期更新内容。里面信息具有时效性,如果有需要了解里面最新的内容,请定期查看以了解最新的资讯和通知。</div><div class="meta footer"><span><a href="/categories/other/" itemprop="url" title="其他"><i class="ic i-flag"></i>其他</a></span></div><a href="/other/announce/" class="btn" itemprop="url" title="公告栏">more...</a></div></article></div><h2 class="divider">精选分类</h2><div class="cards"><section class="item"><div class="cover" data-background-image="/anime/cover.jpg"><h2 class="title">动漫</h2></div><div class="info"><div class="ribbon"><a href="/categories/anime/" itemprop="url" title="动漫">动漫</a></div><div class="inner"><ul class="posts"><a href="/categories/anime/pilgrimage/" title="圣地巡礼">圣地巡礼</a></ul><div class="meta footer"><span><i class="ic i-file"></i>1 个子项,1 篇文章</span></div></div><a href="/categories/anime/" class="btn" itemprop="url" title="动漫">more...</a></div></section><section class="item"><div class="cover" data-background-image="/game/cover.jpg"><h2 class="title">游戏</h2></div><div class="info"><div class="ribbon"><a href="/categories/game/" itemprop="url" title="游戏">游戏</a></div><div class="inner"><ul class="posts"><a href="/categories/game/guide/" title="攻略">攻略</a><a href="/categories/game/review/" title="赏析">赏析</a></ul><div class="meta footer"><span><i class="ic i-file"></i>2 个子项,2 篇文章</span></div></div><a href="/categories/game/" class="btn" itemprop="url" title="游戏">more...</a></div></section></div><h2 class="divider">文章列表</h2><div class="segments posts"><article class="item"><div class="cover"><a href="/game/review/wothn-review/" itemprop="url" title="旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事"><img loading="lazy" decoding="async" src="https://imgs.flwolfy.site/img/post/wothn-review/Cover.webp" alt="article cover"></a></div><div class="info"><div class="meta"><span class="item" title="创建时间:2025-11-01 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-11-01T00:00:00+08:00">2025-11-01</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>12k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>11 分钟</span></span></div><h3><a href="/game/review/wothn-review/" itemprop="url" title="旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事">旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事</a></h3><div class="excerpt">本文对《魔法使之夜》故事进行了整理与分析,涵盖主要剧情、人物关系以及关键战斗事件,重点讨论了青子、橙子、有珠和草十郎的心理变化与信念冲突,同时对作品的社会背景和泡沫经济时期的时代特征进行了简要思考。</div><div class="meta footer"><span><a href="/categories/game/review/" itemprop="url" title="赏析"><i class="ic i-flag"></i>赏析</a></span></div><a href="/game/review/wothn-review/" class="btn" itemprop="url" title="旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事">more...</a></div></article><article class="item"><div class="cover"><a href="/game/guide/lucario-guide/" itemprop="url" title="路卡利欧全方位教程"><img loading="lazy" decoding="async" src="https://imgs.flwolfy.site/img/post/lucario-guide/Cover.webp" alt="article cover"></a></div><div class="info"><div class="meta"><span class="item" title="创建时间:2025-06-21 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-06-21T00:00:00+08:00">2025-06-21</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>11k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>10 分钟</span></span></div><h3><a href="/game/guide/lucario-guide/" itemprop="url" title="路卡利欧全方位教程">路卡利欧全方位教程</a></h3><div class="excerpt">本指南面向《任天堂明星大乱斗—特别版》的路卡利欧玩家,旨在提供角色定位、玩法思路及实战技巧的全方位参考,内容整合自国外教学资料及实战经验,方便玩家查阅与学习。</div><div class="meta footer"><span><a href="/categories/game/guide/" itemprop="url" title="攻略"><i class="ic i-flag"></i>攻略</a></span></div><a href="/game/guide/lucario-guide/" class="btn" itemprop="url" title="路卡利欧全方位教程">more...</a></div></article><article class="item"><div class="cover"><a href="/anime/pilgrimage/sg-visit/" itemprop="url" title="《命运石之门》圣地巡礼"><img loading="lazy" decoding="async" src="https://imgs.flwolfy.site/img/post/sg-visit/Cover.webp" alt="article cover"></a></div><div class="info"><div class="meta"><span class="item" title="创建时间:2025-05-27 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-05-27T00:00:00+08:00">2025-05-27</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>4.4k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>4 分钟</span></span></div><h3><a href="/anime/pilgrimage/sg-visit/" itemprop="url" title="《命运石之门》圣地巡礼">《命运石之门》圣地巡礼</a></h3><div class="excerpt">难得去了一次秋叶原,想着把我最喜欢的动漫之一《命运石之门》里面的场景都去实地考察一下~</div><div class="meta footer"><span><a href="/categories/anime/pilgrimage/" itemprop="url" title="圣地巡礼"><i class="ic i-flag"></i>圣地巡礼</a></span></div><a href="/anime/pilgrimage/sg-visit/" class="btn" itemprop="url" title="《命运石之门》圣地巡礼">more...</a></div></article></div></div></div><div id="sidebar"><div class="inner"><div class="panels"><div class="inner"><div class="contents panel pjax" data-title="文章目录"></div><div class="related panel pjax" data-title="系列文章"></div><div class="overview panel" data-title="站点概览"><div class="author" itemprop="author" itemscope="itemscope" itemtype="http://schema.org/Person"><img class="image" loading="lazy" decoding="async" itemprop="image" alt="FLwolfy" src="/assets/core/avatar.jpg"/><p class="name" itemprop="name">FLwolfy</p><div class="description" itemprop="description">编程、游戏、动漫爱好者!</div></div><nav class="state"><div class="item posts"><a href="/archives/"><span class="count">4</span><span class="name">文章</span></a></div><div class="item categories"><a href="/categories/"><span class="count">6</span><span class="name">分类</span></a></div><div class="item tags"><a href="/tags/"><span class="count">9</span><span class="name">标签</span></a></div></nav><div class="social"><a target="_blank" rel="noopener" href="https://github.com/flwolfy" class="item github" title="https://github.com/flwolfy"><i class="ic i-github"></i></a><a target="_blank" rel="noopener" href="https://twitter.com/fl_wolfy" class="item twitter" title="https://twitter.com/fl_wolfy"><i class="ic i-twitter"></i></a><a href="mailto:hsuankailiao@gmail.com" class="item email" title="mailto:hsuankailiao@gmail.com"><i class="ic i-envelope"></i></a></div><div class="menu"><li class="item"><a href="/" rel="section"><i class="ic i-home"></i>首页</a></li><li class="item dropdown"><a href="#" onclick="return false;"><i class="ic i-feather"></i>文章</a><ul class="submenu"><li class="item"><a href="/archives/" rel="section"><i class="ic i-archive"></i>归档</a></li><li class="item"><a href="/categories/" rel="section"><i class="ic i-th"></i>分类</a></li><li class="item"><a href="/tags/" rel="section"><i class="ic i-tags"></i>标签</a></li></ul></li><li class="item dropdown"><a href="#" onclick="return false;"><i class="ic i-address-card"></i>关于</a><ul class="submenu"><li class="item"><a href="/aboutsite/" rel="section"><i class="ic i-guanyu"></i>站点信息</a></li><li class="item"><a href="/stats/" rel="section"><i class="ic i-tongji"></i>站点统计</a></li></ul></li></div></div></div></div><ul id="quick"><li class="prev pjax"></li><li class="up"><i class="ic i-arrow-up"></i></li><li class="down"><i class="ic i-arrow-down"></i></li><li class="next pjax"></li><li class="percent"></li></ul></div></div><div class="dimmer"></div></div><div id="player"></div></main><footer id="footer"><div class="inner"><div class="widgets"><div class="rpost pjax"><h2>随机文章</h2><ul><li class="item"><div class="breadcrumb"><a href="/categories/game/" title="分类于游戏">游戏</a><i class="ic i-angle-right"></i><a href="/categories/game/guide/" title="分类于攻略">攻略</a></div><span><a href="/game/guide/lucario-guide/">路卡利欧全方位教程</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/other/" title="分类于其他">其他</a></div><span><a href="/other/announce/">公告栏</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/anime/" title="分类于动漫">动漫</a><i class="ic i-angle-right"></i><a href="/categories/anime/pilgrimage/" title="分类于圣地巡礼">圣地巡礼</a></div><span><a href="/anime/pilgrimage/sg-visit/">《命运石之门》圣地巡礼</a></span></li><li class="item"><div class="breadcrumb"><a href="/categories/game/" title="分类于游戏">游戏</a><i class="ic i-angle-right"></i><a href="/categories/game/review/" title="分类于赏析">赏析</a></div><span><a href="/game/review/wothn-review/">旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事</a></span></li></ul></div><div class="rpost pjax"><h2>最新评论</h2><ul class="leancloud-recent-comment" id="new-comment"></ul></div></div><div class="status"><div class="copyright">© 2022 -<span itemprop="copyrightYear">2025</span><span class="with-love"><i class="ic i-sakura rotate"></i></span><span class="author" itemprop="copyrightHolder">FLwolfy @ Wolfiora</span></div><div class="count"><span class="post-meta-item-icon"><i class="ic i-chart-area"></i></span><span title="站点总字数">29k 字</span><span class="post-meta-divider"> | </span><span class="post-meta-item-icon"><i class="ic i-coffee"></i></span><span title="站点阅读时长">26 分钟</span></div><div class="powered-by">基于 <a target="_blank" rel="noopener" href="https://hexo.io/">Hexo</a> & Theme.<a target="_blank" rel="noopener" href="https://github.com/theme-shoka-x/hexo-theme-shokaX/">ShokaX</a></div></div><script>(function() {
// ======================================================
// 全局 siteData — 完全响应式
// ======================================================
// 派发自定义事件
function dispatchSiteDataChange(path, value) {
window.dispatchEvent(new CustomEvent('siteDataChange', {
detail: { path, value }
}));
}
// 创建可深层监听的 Proxy
window.createReactiveObject = function(obj, path = []) {
return new Proxy(obj, {
set(target, key, value) {
const fullPath = [...path, key];
const newValue = (typeof value === 'object' && value !== null)
? window.createReactiveObject(value, fullPath)
: value;
target[key] = newValue;
dispatchSiteDataChange(fullPath.join('.'), newValue);
return true;
},
get(target, key) {
const value = target[key];
// 确保深层对象也始终是 reactive
if (typeof value === 'object' && value !== null && !value.__isProxy) {
target[key] = window.createReactiveObject(value, [...path, key]);
target[key].__isProxy = true;
}
return target[key];
}
});
};
})();</script></div></footer></div><script data-config type="text/javascript">var LOCAL = {
ispost: false,
path: ``,
favicon: {
show: `欢迎来到狼宝典~ (ノ◕ヮ◕)ノ*:・゚✧|ʕ•ᴥ•ʔ 想学习技巧还是偷看小秘密呢?| (>^ω^<) 准备好冒险了吗?`,
hide: `哎呀,被你发现了! (。•́︿•̀。)| (╯°□°)╯休息一下再回来吧~| ( ̄▽ ̄)~* 不要忘了回来继续探索哦!`
},
search: {
placeholder: "文章搜索",
empty: "关于 「 ${query} 」,什么也没搜到",
stats: "${time} ms 内找到 ${hits} 条结果"
},
nocopy: "false",
copyright: `复制成功,转载请遵守 <i class="ic i-creative-commons"></i>BY-NC-SA 协议。`,
copy_tex: false,
katex: false,
mermaid: false,
audio: undefined,
nocopy: false,
outime: true,
template: `<div class="note warning"><p><span class="label warning">文章时效性提示</span><br>这是一篇发布于 {{publish}} 天前,最后一次更新在 {{updated}} 天前的文章,部分信息可能已经发生改变,请注意甄别。</p></div>`,
quiz: {
choice: `单选题`,
multiple: `多选题`,
true_false: `判断题`,
essay: `问答题`,
gap_fill: `填空题`,
mistake: `错题备注`
}
};
</script><script async="async" src="https://www.googletagmanager.com/gtag/js?id=G-P4BPV1LJ9Z"></script><script>window.dataLayer = window.dataLayer || [];
function gtag() {
dataLayer.push(arguments);
}
gtag('js', new Date());
gtag('config', 'G-P4BPV1LJ9Z');</script><script src="/js/siteInit.js?v=0.5.4" type="module" fetchpriority="high" defer></script><script src="/js/binft.js"></script><script>(function(){
document.addEventListener('DOMContentLoaded', function(){
const logo = document.querySelector('a.logo');
const titleEl = logo.querySelector('h1.title');
if(!titleEl) return;
binft(titleEl, titleEl.textContent);
});
})();</script><link rel="stylesheet" href="/css/fish.css"/><script src="/js/fish.js"></script><script>(function(){
document.addEventListener('DOMContentLoaded', function(){
// 获取全局 waves 容器
var waves = document.getElementById('imgs');
if(!waves) return;
// 创建 fish 容器
var fishContainer = document.createElement('div');
fishContainer.id = 'jsi-flying-fish-container';
// 放入 waves
waves.appendChild(fishContainer);
// 初始化 fish
if(typeof RENDERER !== 'undefined' && RENDERER.init){
RENDERER.$container = fishContainer;
RENDERER.width = fishContainer.offsetWidth;
RENDERER.height = fishContainer.offsetHeight;
RENDERER.init();
}
// 非顶部隐藏
function checkTop() {
var threshold = 15 * parseFloat(getComputedStyle(document.documentElement).fontSize);
fishContainer.style.display = window.scrollY > threshold ? 'none' : 'block';
}
window.addEventListener('scroll', checkTop);
checkTop();
});
})();</script><script>const config = {
path: {
homePath: "/",
modelPath: "/live2d/resources/",
cssPath: "/css/live2d.css",
tipsJsonPath: "/live2d/waifu-tips.json",
tipsJsPath: "/live2d/waifu-tips.js",
live2dCorePath: "/live2d/live2dcubismcore.js",
live2dSdkPath: "/live2d/live2d-sdk.js"
},
tools: ["hitokoto", "asteroids", "express", "photo", "info", "quit"],
drag: {
enable: true,
direction: ["x"]
},
switchType: "order"
}
if (screen.width >= 768) {
Promise.all([
loadExternalResource(config.path.cssPath, "css"),
loadExternalResource(config.path.live2dCorePath, "js"),
loadExternalResource(config.path.live2dSdkPath, "js"),
loadExternalResource(config.path.tipsJsPath, "js")
]).then(() => {
initWidget({
waifuPath: config.path.tipsJsonPath,
cdnPath: config.path.modelPath,
tools: config.tools,
dragEnable: config.drag.enable,
dragDirection: config.drag.direction,
switchType: config.switchType
});
// ================================
// 点击 Live2D 抖动功能
// ================================
window.addEventListener("click", (event) => clickShake(event));
// ======================================================
// 触顶隐藏
// ======================================================
const SCROLL_THRESHOLD = 50;
onLive2dScrollTop(SCROLL_THRESHOLD);
window.addEventListener("scroll", () => onLive2dScrollTop(SCROLL_THRESHOLD));
});
}
function onLive2dScrollTop(threshold) {
const waifuEl = document.getElementById("waifu");
if (!waifuEl) return;
const scrollTop = window.scrollY || document.documentElement.scrollTop;
if (scrollTop < threshold) {
let rect = waifuEl.getBoundingClientRect();
let visualHeight = rect.height;
waifuEl.style.transform = `translateY(${visualHeight}px)`;
} else {
waifuEl.style.transform = "translateY(0)";
}
}
function clickShake(event) {
if (event.target.id !== "live2d") return;
event.target.classList.add("live-2d-shake");
event.target.addEventListener("animationend", function handler() {
event.target.classList.remove("live-2d-shake");
event.target.removeEventListener("animationend", handler);
});
}
function loadExternalResource(url, type) {
return new Promise((resolve, reject) => {
let tag;
if (type === "css") {
tag = document.createElement("link");
tag.rel = "stylesheet";
tag.href = url;
}
else if (type === "js") {
tag = document.createElement("script");
tag.src = url;
}
if (tag) {
tag.onload = () => resolve(url);
tag.onerror = () => reject(url);
document.head.appendChild(tag);
}
});
}</script><script>// ======================================================
// 配置区(只需要改这里)
// ======================================================
const ALLOW_ALL = true; // 是否允许所有页面显示漂浮物
const URL_ALLOW_LIST = ["/about/", "/friends/"]; // ALLOW_ALL = false 时允许的页面
const FLOAT_IMG_SRC = "/assets/core/sakura.png"; // 漂浮物图片路径
const FLOAT_COUNT = 10; // 漂浮物数量
const FLOAT_SCROLL_THRESHOLD = 50; // 顶部缓冲区 px
const FADE_SPEED = 0.05; // 每帧透明度变化
const OPACITY_THRESHOLD = 0.01; // 透明度阈值(低于该值时隐藏)
// ======================================================
// 全局变量区
// ======================================================
var isAllowFloat = false;
var stop;
var img = new Image();
img.src = FLOAT_IMG_SRC;
let canvas; // 全局 canvas
let canvasOpacity = 0; // 当前透明度
let targetOpacity = 1; // 滚动目标透明度
// ======================================================
// 工具函数
// ======================================================
function GetUrlRelativePath() {
var url = document.location.toString();
var arrUrl = url.split("//");
var start = arrUrl[1].indexOf("/");
var relUrl = arrUrl[1].substring(start);
if (relUrl.indexOf("?") != -1) relUrl = relUrl.split("?")[0];
return relUrl;
}
function createCanvas() {
if (canvas) return canvas;
canvas = document.createElement("canvas");
canvas.id = "canvas_float";
canvas.style.position = "fixed";
canvas.style.left = "0";
canvas.style.top = "0";
canvas.style.pointerEvents = "none";
canvas.style.opacity = "0";
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
document.body.appendChild(canvas);
return canvas;
}
function updateCanvasOpacity() {
if (!canvas) return;
canvasOpacity += (targetOpacity - canvasOpacity) * FADE_SPEED;
canvas.style.opacity = canvasOpacity;
// 当接近 0 时隐藏,提高性能
if (canvasOpacity < OPACITY_THRESHOLD) {
canvas.style.display = "none";
} else {
canvas.style.display = "block";
}
}
// ======================================================
// 判断是否允许启用漂浮物
// ======================================================
function decide() {
isAllowFloat = true;
if (!ALLOW_ALL) {
var url = GetUrlRelativePath();
isAllowFloat = URL_ALLOW_LIST.includes(url);
}
console.log("[Float] 是否启用漂浮物:", isAllowFloat);
if (isAllowFloat) startFloat();
}
// ======================================================
// 漂浮物类
// ======================================================
function Float(x, y, s, r, fn) {
this.x = x;
this.y = y;
this.s = s;
this.r = r;
this.fn = fn;
}
Float.prototype.draw = function (cxt) {
cxt.save();
cxt.translate(this.x, this.y);
cxt.rotate(this.r);
cxt.drawImage(img, 0, 0, 35 * this.s, 35 * this.s);
cxt.restore();
};
Float.prototype.update = function () {
this.x = this.fn.x(this.x, this.y);
this.y = this.fn.y(this.x, this.y);
this.r = this.fn.r(this.r);
if (
this.x > window.innerWidth ||
this.x < 0 ||
this.y > window.innerHeight ||
this.y < 0
) {
this.r = getRandom("fnr");
if (Math.random() > 0.4) {
this.x = getRandom("x");
this.y = 0;
this.s = getRandom("s");
this.r = getRandom("r");
} else {
this.x = window.innerWidth;
this.y = getRandom("y");
this.s = getRandom("s");
this.r = getRandom("r");
}
}
};
// ======================================================
// 漂浮物列表
// ======================================================
function FloatList() {
this.list = [];
}
FloatList.prototype.push = function (float) {
this.list.push(float);
};
FloatList.prototype.update = function () {
for (var i = 0; i < this.list.length; i++) {
this.list[i].update();
}
};
FloatList.prototype.draw = function (cxt) {
for (var i = 0; i < this.list.length; i++) {
this.list[i].draw(cxt);
}
};
// ======================================================
// 随机生成器
// ======================================================
function getRandom(option) {
var ret, random;
switch (option) {
case "x": ret = Math.random() * window.innerWidth; break;
case "y": ret = Math.random() * window.innerHeight; break;
case "s": ret = Math.random(); break;
case "r": ret = Math.random() * 6; break;
case "fnx":
random = -0.5 + Math.random() * 1;
ret = (x, y) => x + 0.5 * random - 0.6;
break;
case "fny":
random = 0.8 + Math.random() * 0.7;
ret = (x, y) => y + random;
break;
case "fnr":
random = Math.random() * 0.03;
ret = r => r + random;
break;
}
return ret;
}
// ======================================================
// 启动漂浮物
// ======================================================
function startFloat() {
requestAnimationFrame =
window.requestAnimationFrame ||
window.mozRequestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.msRequestAnimationFrame;
createCanvas();
const cxt = canvas.getContext("2d");
const floatList = new FloatList();
for (var i = 0; i < FLOAT_COUNT; i++) {
const float = new Float(
getRandom("x"),
getRandom("y"),
getRandom("s"),
getRandom("r"),
{ x: getRandom("fnx"), y: getRandom("fny"), r: getRandom("fnr") }
);
floatList.push(float);
}
function loop() {
cxt.clearRect(0, 0, canvas.width, canvas.height);
floatList.update();
floatList.draw(cxt);
// 启动透明度动画
updateCanvasOpacity();
// 启动下一帧
stop = requestAnimationFrame(loop);
}
loop();
}
// ======================================================
// 自适应窗口变化
// ======================================================
window.addEventListener("resize", () => {
if (!canvas) return;
// 重新设定画布尺寸
canvas.width = window.innerWidth;
canvas.height = window.innerHeight;
// 若有动画循环,强制触发一次重绘
if (typeof stop === "number") {
cancelAnimationFrame(stop);
}
// 重新启动动画循环
startFloat();
});
// ======================================================
// 滚动窗口变化
// ======================================================
function onSakuraScrollTop() {
if (!isAllowFloat || !canvas) return;
targetOpacity = window.scrollY < FLOAT_SCROLL_THRESHOLD ? 1 : 0;
}
// ======================================================
// 页面加载完成后执行
// ======================================================
window.addEventListener("DOMContentLoaded", () => {
decide();
onSakuraScrollTop();
window.addEventListener("scroll", onSakuraScrollTop);
});</script><link rel="stylesheet" href="/css/track.css"/><script src="/js/track.js"></script><div class="osu-container" id="osuContainer" style="display:none;opacity:0;"><div class="osu-wheel"><div class="track" data-created="2025-04-12T16:00:00.000Z" data-title="公告栏" data-description="<p>◉ 本公告栏内容具有时效性,建议定期查看来获得最新内容。<br>◉
阅读评论请注意其发布时间,以确保沟通交流为同一公告版本内容~</p><br><p>本博客从搭建完毕发布第一篇文章已经是 25 年 5 月的事情,中途由于切换主题和配置博客耽误了不少时间,直到25年9月左右才开始有继续更新。所以实际的建站时间至今不超过 4 个月,文章内容也不是很多。但有很多待发布的想法、教程、分享在筹备中,敬请期待~</p><br><p>已发布 | Published<br />
25-05-27 《圣地巡礼之〈命运石之门〉》 =&gt; 讲了站主去秋叶原玩打卡的经历,欢迎阅读~<br />
25-06-21 《路卡利欧全方位教程》 =&gt; 如果你玩《任天堂明星大乱斗》,同时又对路卡利欧感兴趣想学习,这是一个不错的参考~<br />
25-11-01 《旮旯杂谈之〈魔法使之夜〉》 =&gt; 简单回顾和分析了《魔法使之夜》的剧情、人物刻画,分享了自己的看法~<br /></p><br><p>更新中 | Updating<br />
25-11-?? 《旮旯杂谈之〈秽翼の尤斯缇娅〉》 =&gt; 简单梳理剧情以及分析其表达的内涵。<br />
25-11-?? 《十三机兵防卫圈通关感想》 =&gt; 以正时间线的方式梳理这部浪漫的科幻情书。<br /></p><br><p>文章发布预告 | Trailer<br />
??-??-?? 《Hexo 的安装教学系列》 =&gt; 整理并教学如何从 0 安装和部署 Hexo,并且添加主题美化和个性化设置。<br />
??-??-?? 《FLwolfy.ShokaX 日志》 =&gt; 为我魔改 ShokaX 源码的部分进行讲解和撰写简易文档。</p><br><p>祝愿和祈祷站主不鸽🐦吧~</p> ..." data-cover="https://imgs.flwolfy.site/img/post/announce/Cover.webp" data-link="/other/announce/"><div class="track-content" style="padding-right:0;"><div class="track-meta-container"><div class="meta"><span class="item" title="创建时间:2025-04-13 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-04-13T00:00:00+08:00">2025-04-13</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>1.1k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>1 分钟</span></span></div></div><div class="track-title"><a href="/other/announce/" itemprop="url" title="公告栏">公告栏</a></div><div class="track-description">⚠️本公告栏永远置顶,并且会不定期更新内容。里面信息具有时效性,如果有需要了解里面最新的内容,请定期查看以了解最新的资讯和通知。</div><div class="track-cats-container"><span><a href="/categories/other/" itemprop="url" title="其他"><i class="ic i-flag"></i>其他</a></span></div></div><div class="track-image"><img src="https://imgs.flwolfy.site/img/post/announce/Cover.webp" decoding="async" alt="公告栏"/></div><div class="track-meta-html"><div class="meta"><span class="item" title="创建时间:2025-04-13 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><span class="text">发表于</span><time itemprop="dateCreated datePublished" datetime="2025-04-13T00:00:00+08:00">2025-04-13</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span class="text">本文字数</span><span>1.1k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span class="text">阅读时长</span><span>1 分钟</span></span></div></div></div><div class="track" data-created="2025-05-26T16:00:00.000Z" data-title="《命运石之门》圣地巡礼" data-description="<p>◉ 大部分实景图片为本人及朋友(已授权)拍摄,未经允许请勿使用!<br>◉
动漫内部图片均为原片截图以及B站“圣地巡礼”专栏导览图,如果这侵犯了你的著作权,请立即联系我,我会删除。</p><br><p>今年5月去了一趟日本东京旅游,作为二次元圈内人,必须去一趟秋叶原买各种谷子。同时秋叶原作为大名鼎鼎的“石头门”取景地,本人作为石头门厨必须要进行一波圣地巡礼啦。跟我一起说:一切都是命运石之门的选择!</p><br><p>虽然秋叶原本身其实不大,但本人和朋友逛各家谷子店花了非常久的时间,基本上也是收获满满,不过圣地打卡也就反倒变成了买谷之余做的事情了哈哈。本人打卡的地方除了参考动漫中的地点,也有部分几个是根据游戏内出现的画面进行相同角度的拍摄。不过本人的拍摄技术有限,拍的不好见谅啦~</p><br><p>PS: 取景原图均来自《命运石之门》、《命运石之门:0》,其余实拍图均为本人实际到场拍摄。</p><br><p>这里是一切梦开始的地方,秋叶原车站真的很大(虽然感觉不如上海虹桥站哈哈),走出来那种一片二次元氛围扑面而来的感觉真的很爽~</p><br><p>这里是牧濑红莉栖的葬身之地,现实生活中这里是一个重要的买谷子的地方,不过有一说一这里的谷子比其他地方贵很多,而且品种基本都是一些当季潮漫,也就可能因为石头门比较特殊,所以有一些石头门的谷子还在售卖。</p><br><p>这张图是本人本次秋叶原之行最满意的拍摄图。不论是但是的天气还是时间都非常合适,正好对应原作动漫里桥上那种朦胧氛围。</p><br><p>这个斜坡前是冈部伦太郎为了拯救真有理不断循环的开端,这个场景虽然很好见到,不过由于这个桥现在使用率很高,很难找到时机等没人的时候拍摄。不过日本人都挺有礼貌的,我在拍摄的时候,有一些上班族宁可停下来等我拍完。</p><br><p>这也是动漫里一个非常重要的地方,是真有理和菲利斯打工的女仆咖啡厅。本人没有实际进去,但是从外面看去好像已经不是女仆咖啡厅了(有点可惜),不过招牌还在,打卡还是ok的~</p><br><p>这里动漫里应该是叫做“柳林神社”,是原作琉华子的家,实际比动漫里要小很多,而且一般时间都是不让人进去的。本人也只能在外面简单拍摄,不做过多打扰...</p><br><p>这个是天桥上面,就是当时牧濑红莉栖点醒冈部伦太郎去撤回 DMail 拯救真有理的地点 ..." data-cover="https://imgs.flwolfy.site/img/post/sg-visit/Cover.webp" data-link="/anime/pilgrimage/sg-visit/"><div class="track-content" style="padding-right:0;"><div class="track-meta-container"><div class="meta"><span class="item" title="创建时间:2025-05-27 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-05-27T00:00:00+08:00">2025-05-27</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>4.4k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>4 分钟</span></span></div></div><div class="track-title"><a href="/anime/pilgrimage/sg-visit/" itemprop="url" title="《命运石之门》圣地巡礼">《命运石之门》圣地巡礼</a></div><div class="track-description">难得去了一次秋叶原,想着把我最喜欢的动漫之一《命运石之门》里面的场景都去实地考察一下~</div><div class="track-cats-container"><span><a href="/categories/anime/pilgrimage/" itemprop="url" title="圣地巡礼"><i class="ic i-flag"></i>圣地巡礼</a></span></div></div><div class="track-image"><img src="https://imgs.flwolfy.site/img/post/sg-visit/Cover.webp" decoding="async" alt="《命运石之门》圣地巡礼"/></div><div class="track-meta-html"><div class="meta"><span class="item" title="创建时间:2025-05-27 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><span class="text">发表于</span><time itemprop="dateCreated datePublished" datetime="2025-05-27T00:00:00+08:00">2025-05-27</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span class="text">本文字数</span><span>4.4k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span class="text">阅读时长</span><span>4 分钟</span></span></div></div></div><div class="track" data-created="2025-06-20T16:00:00.000Z" data-title="路卡利欧全方位教程" data-description="<p>◉ 本指南旨在帮助准备练习《任天堂明星大乱斗—特别版》中路卡利欧的玩家了解路卡利欧的整体定位与玩法思路,并充当一个查阅百科的作用。该指南要求玩家对大乱斗中各类术语有一定了解。我将常见问题整理成清晰的结构,方便查阅与学习。<br>◉
本资料的内容整合参考国外大佬 NewBae 的路卡利欧教学与我自己对于路卡职业选手研究,并融合了我自身对路卡角色的实战经验。本文章内相关影像素材部分来自 Ultimate Frame Data 、 Smash Wiki 等网站。<br>◉
若有建议、疑问或补充,欢迎通过邮件联系我 FLwolfy,也欢迎各位加入任天堂明星大乱斗路卡利欧国内角色QQ群:1007101846。</p><br><p>路卡利欧在大乱斗5代并不算是优秀角色,人人都有早期击杀的时代让路卡利欧非常难以保留高波导并生存。不过路卡利欧还是有一些帧数相对优秀的的招式,并且由于波导的机制,大部分对手不敢让路卡利欧获得高波导,这导致对手在跟路卡利欧立回时总是容易凹或急从而露出破绽。路卡利欧玩家要做的是熟悉各种安全招和帧数,并以最大化收益来翻盘。</p><br><p>路卡利欧的地面招式在整个大乱斗环境中不算优秀,特别是在 DLC 出了之后(万恶的DLC)。所以路卡利欧的地面招式用起来需要谨慎。由于路卡利欧在地面具有优秀的移速,同对手立回并用地面招接近是不错的进攻手段。同时不少地面招式都是良好的连招起手,可以在立回阶段尝试摸起手。</p><br><p>路卡利欧的 Jab 虽然是 5帧 起手,理论上可以用来抢招,但判定小整体性能偏弱,不具备压制力或稳定性,因此在实战中不算实用,并不推荐作为常规的脱连手段使用。它更重要的作用在于作为 Jablock 连招的起手去获得大收益。</p><br><p>路卡利欧的 DA 动作是向前铲踢,有着不错的 7帧 启动帧数,是一个不错的追击突进距离和,因此可以在许多场合作为突进爆发技使用,用于打断节奏抑或是连招终结都是不错的选择。但是,DA 的动作结束后硬直较长,无法快速跟进,没有后续连招。若不安全打点(不穿盾)被盾住容易遭到却反,因此不能频繁滥用。</p><br><p>需要特别注意的有两点:DA 在近打点是可以穿盾的,较为安全,可以作为一种出其不意的接近手段;DA 的攻击判定前期是甜点判定,具备非常优秀的击飞能力。若能在自身中高波导时命中甜点, ..." data-cover="https://imgs.flwolfy.site/img/post/lucario-guide/Cover.webp" data-link="/game/guide/lucario-guide/"><div class="track-content" style="padding-right:0;"><div class="track-meta-container"><div class="meta"><span class="item" title="创建时间:2025-06-21 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-06-21T00:00:00+08:00">2025-06-21</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>11k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>10 分钟</span></span></div></div><div class="track-title"><a href="/game/guide/lucario-guide/" itemprop="url" title="路卡利欧全方位教程">路卡利欧全方位教程</a></div><div class="track-description">本指南面向《任天堂明星大乱斗—特别版》的路卡利欧玩家,旨在提供角色定位、玩法思路及实战技巧的全方位参考,内容整合自国外教学资料及实战经验,方便玩家查阅与学习。</div><div class="track-cats-container"><span><a href="/categories/game/guide/" itemprop="url" title="攻略"><i class="ic i-flag"></i>攻略</a></span></div></div><div class="track-image"><img src="https://imgs.flwolfy.site/img/post/lucario-guide/Cover.webp" decoding="async" alt="路卡利欧全方位教程"/></div><div class="track-meta-html"><div class="meta"><span class="item" title="创建时间:2025-06-21 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><span class="text">发表于</span><time itemprop="dateCreated datePublished" datetime="2025-06-21T00:00:00+08:00">2025-06-21</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span class="text">本文字数</span><span>11k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span class="text">阅读时长</span><span>10 分钟</span></span></div></div></div><div class="track" data-created="2025-10-31T16:00:00.000Z" data-title="旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事" data-description="<p>◉ 本篇感想含有剧透内容,请未通关《魔法使之夜》的读者谨慎观看!<br>◉
此感想纯作者主观感受,部分内容参考了 Bilibili 和 巴哈姆特 上的赏析文章,融合了我自身的观点。如果有任何观点引起你的反感,请无视~<br>◉
本篇文章大部分图片来自网络和游戏截图,若侵权,请告知我,我会立即处理。</p><br><p>《魔法使之夜》作为型月 TYPE-MOON 的代表作之一,以其独特的世界观和细腻的人物刻画吸引了大量玩家和读者(包括我)。本人在此之前没有玩过任何文字冒险类游戏,本作可以算是我的第一部 Galgame,整体游玩体验非常好。在游玩时,其浓厚且细腻的氛围与精致的演出表现真的让人沉浸其中——无论是剧本的叙事节奏、人物间那细微但又微微散发出来的情感,还是配乐与画面的配合,都展现出极高的完成度。可以说,《魔法使之夜》不仅是一款视觉小说,更像是一场由文字、声音与画面共同构成的艺术体验。</p><br><p>不过必须承认的是,《魔法使之夜》并不是一款所有人都适合的游戏,它的过于“日常感”的叙事,不突出的“主线剧情”,奇幻的型月世界观,以及缺少 Galgame 该有的恋爱元素,让它在文字冒险游戏中算是一个“特点不突出”的另类。不过,也许也正是因为这种“不突出”,让它整个游玩过程非常舒适。</p><br><p>在经历了长达 50小时 的深度游玩体验后(实际游玩时间不会那么长,本人由于是全语音党所以游玩时间比较长),我对《魔法使之夜》这部作品有了比较基本且细致的游玩体验。接下来,本文主要分为两个部分来赏析《魔法使之夜》这部作品:</p><br><p>希望通过这样的结构,能带领读者从不同角度理解这部作品的魅力所在。</p><br><p></p><br><p>《魔法使之夜》是一部气质独特的视觉小说作品,尽管它算是被归类于 Galgame ,但它完全不满足任何所谓“美少女恋爱游戏”的特征,它适合被当作一本小说来鉴赏。它的故事发生在1980年代末的日本——一个日后被历史反复回望的年代:经济高速膨胀,霓虹灯照亮通宵不眠的大街,金融资本奔涌如潮,年轻人奔向城市追逐奢华与未来。那是所谓的泡沫经济巅峰——房地产价格不断攀升、股市狂热、消费主义盛行,咖啡馆与百货大楼鳞次栉比,仿佛只要走进都市中心,就能触碰闪耀的明天。</p><br><p>正是在这样一个时代,我们随着本作男主 静希 ..." data-cover="https://imgs.flwolfy.site/img/post/wothn-review/Cover.webp" data-link="/game/review/wothn-review/"><div class="track-content" style="padding-right:0;"><div class="track-meta-container"><div class="meta"><span class="item" title="创建时间:2025-11-01 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><time itemprop="dateCreated datePublished" datetime="2025-11-01T00:00:00+08:00">2025-11-01</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span>12k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span>11 分钟</span></span></div></div><div class="track-title"><a href="/game/review/wothn-review/" itemprop="url" title="旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事">旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事</a></div><div class="track-description">本文对《魔法使之夜》故事进行了整理与分析,涵盖主要剧情、人物关系以及关键战斗事件,重点讨论了青子、橙子、有珠和草十郎的心理变化与信念冲突,同时对作品的社会背景和泡沫经济时期的时代特征进行了简要思考。</div><div class="track-cats-container"><span><a href="/categories/game/review/" itemprop="url" title="赏析"><i class="ic i-flag"></i>赏析</a></span></div></div><div class="track-image"><img src="https://imgs.flwolfy.site/img/post/wothn-review/Cover.webp" decoding="async" alt="旮旯杂谈之《魔法使之夜》,细腻平稳的奇幻故事"/></div><div class="track-meta-html"><div class="meta"><span class="item" title="创建时间:2025-11-01 00:00:00"><span class="icon"><i class="ic i-calendar"></i></span><span class="text">发表于</span><time itemprop="dateCreated datePublished" datetime="2025-11-01T00:00:00+08:00">2025-11-01</time></span><span class="item" title="本文字数"><span class="icon"><i class="ic i-pen"></i></span><span class="text">本文字数</span><span>12k</span><span class="text">字</span></span><span class="item" title="阅读时长"><span class="icon"><i class="ic i-clock"></i></span><span class="text">阅读时长</span><span>11 分钟</span></span></div></div></div></div><div class="track-detail"><div class="track-cover"><img src="" decoding="async" alt="Info Cover"/><h3 class="track-info-title">未命名</h3></div><div class="track-card"><div class="track-info-meta"></div><p class="track-info-description">123</p><a class="track-info-readmore" href="#">continue→</a></div></div><i class="i-ri-close-line absolute bottom-4 right-4 cursor-pointer text-8" id="osu-close"></i></div><script>(function(){
document.addEventListener('DOMContentLoaded', function(){
// --------------------------
// 1. 导航栏按钮
// --------------------------
const rightNav = document.getElementById('rightNav');
if (rightNav) {
const searchItem = rightNav.querySelector('.item.search');
if (searchItem) {
const wheelItem = document.createElement('li');
wheelItem.className = 'item wheel';
const icon = document.createElement('i');
icon.className = 'ic i-list-alt';
wheelItem.appendChild(icon);
searchItem.insertAdjacentElement('afterend', wheelItem);
}
}
// --------------------------
// 2. 动画函数
// --------------------------
const osuContainer = document.getElementById('osuContainer');
function toggleOsuContainer() {
if (!osuContainer) return;
if (osuContainer.style.display === 'block') {
hideOsuContainer();
} else {
osuContainer.style.display = 'block';
void osuContainer.offsetWidth;
osuContainer.style.opacity = '1';
osuContainer.style.transform = 'translate(-50%, -55%)';
}
}
function hideOsuContainer() {
if (!osuContainer) return;
osuContainer.style.opacity = '0';
osuContainer.style.transform = 'translate(-50%, -80%)';
osuContainer.addEventListener('transitionend', () => {
osuContainer.style.display = 'none';
}, { once: true });
}
// --------------------------
// 3. 绑定事件
// --------------------------
document.querySelector('li.item.wheel > i')?.addEventListener('click', toggleOsuContainer);
document.getElementById('osu-close')?.addEventListener('click', hideOsuContainer);
// --------------------------
// 4. 初始化函数
// --------------------------
initOsuWheel();
});
})();</script>
<script>
// ======================================================
// 创建全局 siteData 对象
// ======================================================
window.siteData = window.createReactiveObject({
categories: [{"name":"其他","count":1},{"name":"动漫","count":1},{"name":"游戏","count":2},{"name":"圣地巡礼","count":1},{"name":"攻略","count":1},{"name":"赏析","count":1}],
tags: [{"name":"公告","count":1},{"name":"攻略","count":2},{"name":"旅游","count":1},{"name":"秋叶原","count":1},{"name":"任斗","count":1},{"name":"宝可梦","count":1},{"name":"型月","count":1},{"name":"Gal","count":1},{"name":"杂谈","count":1}],
dates: {"2025-04-12":1,"2025-10-31":3,"2025-05-26":1,"2025-06-20":1},
});
</script>
</body></html>