Demo: http://msfasr.com/WebGAL_Demo_Page/
Bilibili 演示视频: https://www.bilibili.com/video/BV1nh411n7vt/
https://github.com/MakinoharaShoko/WebGAL/releases/
如果下载速度过慢,请尝试通过蓝奏云网盘下载(链接已过期,3.5版本请在 Release 下载): https://www.lanzouw.com/iRcdzvj3c8d
现在,你可以直接运行WebGAL-win.exe即可开始调试你的视觉小说。如果遇到杀毒软件拦截或防火墙拦截等情况,请放行以允许该程序运行。
WebGAL理论上可以在任何浏览器上运行,但是由于浏览器的限制跨域访问机制,本地 JavaScript 脚本可能无法在浏览器上运行,因此,你需要在本地建立一个http服务器。你可以选择任何你喜爱的的http服务器,并通过本地http服务器访问index.html来开始游戏。如果你没有本地http服务器,你可以使用Node.js简单地搭建一个。
我在WebGAL发行版的根目录放置了一个app.js作为 Node.js 服务器脚本,在你安装了 Node.js 后,只需要通过以下命令:
npm install express
npm install open
node app.js
即可开始调试你的游戏。
现在,你应该已经运行起来了一个调试服务器,接下来让我来教你如何编写你自己的剧本
你应该能够发现,在解压后的文件夹下,有一个 WebGAL 文件夹,在 WebGAL 文件夹下,有一个 game 文件夹,那就是你的游戏资源应该存放的地方。
你的所有游戏剧本、图片、立绘都应该在放解压后目录的 WebGAL/game 文件夹下,目录对应的资源说明如下:
文件夹 | 存放的资源 |
---|---|
background | 用于存放背景图片、标题页背景 |
figure | 用于存放人物立绘 |
scene | 用于存放用户剧本 |
bgm | 用于存放背景音乐 |
vocal | 用于存放配音文件 |
在/game 文件夹下,有一个文件config.txt,你可以在这个文件中填写你游戏的相关信息:
Game_name:WebGAL;//你的游戏名称
Game_key:0f33fdGr;//一串识别码,你应该尽可能随机地输入一串不容易与别人重复的字符,长度最好在6-10字符之间,否则可能会引发bug
Title_img:Title2.png;//标题的图片名称,图片放在/background 文件夹
Title_bgm:夏影.mp3;//标题的背景音乐,音乐文件应该放在/bgm文件夹
首先,程序会从初始脚本start.txt
开始运行,在后续的脚本编写中,我会告诉你如何跳转章节或设置分支选项。
编写剧本的方式非常简单,且与自然语言几乎无异。
首先,使用记事本或VS Code 、sublime 等文本编辑器,打开游戏资源目录下 scene 文件夹中的 start.txt,然后你就可以开始编写你的第一条对话了。
编写人物对话的方法非常简单,你只需要输入:
注意,每条对话的冒号、分号应当为英文字符!
人物:对话;
示例:
雪之下雪乃:请用茶;
由比滨:啊,谢谢;
小町:谢谢雪乃姐!;
一色:谢谢学姐。;
在每条对话/剧本后,使用分号作为结束。(如果不写分号有时候也行,但是作者还是建议加上分号以防止bug)。
如果你的多条对话没有改变人物名称,你可以使用连续对话,而可以省略人物名称,再在你需要的时候使用:
雪之下雪乃:你到得真早;
对不起,等很久了吗?;//此时,对话的人物名称仍然是“雪之下雪乃”。
比企谷八幡:刚到而已;
在许多游戏中,会以黑屏显示一些文字,用来引入主题或表现人物的心理活动。你可以使用 intro 命令来演出独白:
intro:回忆不需要适合的剧本,,反正一说出口,,都成了戏言。;
独白的分拆以英文逗号(,)来分割,也就是说,每一个英文逗号代表一个换行。在实际演出中,上面的文字会变成:
回忆不需要适合的剧本,
反正一说出口,
都成了戏言。
具体的情况还请在游戏中自行试验。
要让 WebGAL 能够读取背景图片和人物立绘,你的背景图片应该被放在background文件夹内,而立绘图片则应该放在figure文件夹中。
接下来,你可以通过以下简单的语句来改变当前显示的背景图片和人物立绘:
changeBG:testBG03.jpg;//改变背景
changeP:testFigure02.png;//改变人物立绘
changeBG:none;//关闭背景
changeP:none;//关闭人物立绘
你有可能会发现,在你改变背景图片或人物立绘后,你需要再点击一下鼠标才能显示下一条对话,如果你希望在改变背景图片/立绘后立即执行下一条语句的内容,请使用:
changeBG_next:testBG03.jpg;
changeP_next:testFigure02.png;//改变人物立绘
一色:谢谢学姐!;
如果你这样做,那么在背景图片/立绘替换后,程序会立刻执行下一条语句。
很多游戏可以在文本框的左下角放置小头像,以下是在本引擎中使用的语法:
miniAvatar:minipic_test.png;//在左下角显示minipic_test.png
miniAvatar:none;//关闭这个小头像
现在,你可以在页面的三个不同位置放置不同的立绘,只需要在放置立绘的语句处加上你要放置的位置就可以了,示例如下:
changeP_left:testFigure03.png;
changeP:testFigure04.png;
changeP_right:testFigure03.png;
以上三行分别对应着左、中、右三个不同的位置。三个不同位置的立绘是相互独立的,所以如果你需要清除立绘,必须分别独立清除:
changeP_left:none;
changeP:none;
changeP_right:none;
如果你想要在立绘改变后立刻执行下一条语句,操作方法与之前一样,即在命令后加上 _next
:
changeP_left_next:testFigure03.png;
changeP_next:testFigure04.png;
changeP_right_next:testFigure03.png;
注意命令的书写顺序,如果你这样写(先写next后写位置),那么将是无效的:
changeP_next_left:testFigure03.png;
changeP_next_right:testFigure03.png;
在 Galgame 中,跳转章节、场景与分支选择是不可或缺的,因此,本游戏模组也支持场景跳转与分支选择。
你可以将你的剧本拆分成多个 txt 文档,并使用一个简单的语句来切换当前运行的剧本。
假如你现在写了两个章节的剧本,分别是 Chapter-1.txt 与 Chapter-2.txt ,在Chapter-1.txt 运行结束后,你希望跳转到 Chapter-2.txt 对应的场景,请使用以下语句:
语句:
changeScene:Chapter-2.txt;
示例:
(Chapter-1.txt)
......
......
changeScene:Chapter-2.txt;
接下来执行的就是Chapter-2.txt的内容了。
......
......
(Chapter-2.txt)
通过执行这条命令,你将切换游戏场景,并使接下来的剧情发展按照新的场景剧本运行。新的剧本会在下一次鼠标点击后运行。
如果你的剧本存在分支选项,你希望通过选择不同的选项进入不同的章节,请使用以下语句:
choose:{叫住她:Chapter-2.txt,回家:Chapter-3.txt};
你只需要将选项的文本与选择选项后要进入的剧本名称一一对应起来,就可以实现分支选择的功能了。
引入背景音乐的方法极其简单,你只需要将背景音乐放置在 /bgm 目录下,然后便可以简单地在需要的时候令其播放:
bgm:夏影.mp3;
众所周知,Galgame 最吸引人的地方往往在于其有优秀的配音。在此版本中,你可以为对话引入配音了,将你的配音放入vocal文件夹,然后在对话的前面,人物名称的后面加入 vocal-语音文件名,
即可引入,语法示例如下:
比企谷八幡:vocal-V3.ogg,刚到而已;
在连续对话时,语音的引入方式也是一样的:
雪之下雪乃:vocal-V1.ogg,你到得真早;
vocal-V2.ogg,对不起,等很久了吗?;
如果你想要创建一个分支,但是却觉得为此新建一个TXT文件太麻烦,你可以尝试使用以下方式在同一文件内实现创建分支和跳转语句。
注意:如果你的分支很长,我不建议你使用这种方式,因为一个TXT的行数不适宜太长,否则可能会导致加载慢、响应迟钝等性能问题。
......
jump_label:label_1;
//以下这些行会被忽略:
......
......
......
//然后,你需要创建label:
label:label_1;
然后,程序会在这里继续执行。;
......
......
简而言之, jump_label 类似于 goto 语句,能够立刻让你的剧本跳到场景(TXT文件)中的任意一个位置,而这个位置需要你用label创建。
如果把jump_label 比作任意门,那么这个任意门的终点就是 label 所在的位置。
WebGAL:让我们来测试分支跳转到label!;
choose_label:{测试1:label_1,测试2:label_2};
label:label_1;
现在应该是1号分支;
jump_label:end;
label:label_2;
现在应该是2号分支;
jump_label:end;
label:end;
现在是统一的结束;
注意,在每个分支的结尾,你应该用 jump_label 来跳转到你希望的位置。由于程序是线性执行的,所以如果你没有在分支的结束跳转,那么程序会继续往下运行,比如说:
WebGAL:让我们来测试分支跳转到label!;
choose_label:{测试1:label_1,测试2:label_2};
label:label_1;
现在应该是1号分支;
label:label_2;
现在应该是2号分支;
现在是统一的结束;
在这个剧本中,如果你选择了分支2,那么一切看起来好像没有问题。但是如果你选择了分支1,你会惊讶地发现,在分支1执行完后,竟然分支2又执行了一遍。那是因为程序按顺序继续执行下一行了,而你没有指定在分支结束后跳到哪里。
注意:这是一个测试功能,可能会发生未知异常
注意:在你弄清楚如何使用label,如何在label内部跳转场景之前,请不要轻易使用变量系统,这可能会令你感到迷惑!
varSet:a:1,b:1;//声明两个变量,a的值为1,b的值为1
varUp:a:2,b:3;//a的值提升2,b的值提升3
varDrop:a:1,b:3;//a的值降低1,b的值降低3
jump_varReach:a:3,label1;//当a>=3时,跳转到label1
jump_varBelow:a:3,label2;//当a<3时,跳转到label2
label:label1;
......
......
jump_label:end;
label:label2;
......
......
jump_label:end;
label:end;
......
......