【Fungus入门】10分钟快速构建Unity中的万能对话系统 / 叙事系统 / 剧情系统
我真的很久没有写过一个完整的攻略了(笑),咸鱼了很久之后还是想来写一个好玩的。这次主要是梳理一下Unity的小众插件Fungus的核心功能,并且快速掌握其使用方法。
官方文档:http://fungusdocs.snozbot.com/
视频教程:https://www.youtube.com/watch?v=9zqUx0xZBv4
那么首先Fungus是什么呢?Fungus提供了一个交互式的界面,快速构建一个对话系统,甚至是文字游戏(AVG)的核心组件。
Fungus在Unity 3D项目中,主要是做剧情讲述部分,故我主要是阐述Fungus怎么做好一个剧情阐述。
一,怎么创建一个叙述?场景开始时的故事阐述
首先我们打开一个Unity项目,当然我手上是有一个项目的,目前正在参加Imagine Cup 2018.
首先我们在Tools里找到Fungus。事先我们需要在Unity的Assets Store里安装这个插件。
创建一个Flowchart。这样我们可以发现左边的树里已经多了一项Flowchart。
接下来我们打开Fungus的Flowchart窗口。
然后会出现一个这样的界面:
接下来我们点一下这个Block,为它改名为“StartStory”,然后将触发条件设为“GameStart”。
接下来为这个Block添加一些内容。
我们选择“+”,然后选择narrative里的say,添加一个新的叙述。
如果需要多段叙述,可以继续添加不同的块。
到现在我们都没有看见一行代码,是不是非常简洁?
二,对话系统开放!Character与Menu
一直到刚才我讲的都是单线叙事,现在我引入一个概念:Character。
接下来我们建立一个叫做boy的人物。
我们可以为人物指定一个Portrait(肖像),实现类似下图的效果:
如图操作:
现在有了一个Character之后,我们的对话就可以指定角色来区分了。
当然还有一个加快速度的剧情添加办法:Narrative > Conversation。
然后将剧情以这样的方式添加:[character] [portrait] [position] [hide] [<<< | >>>]: [Dialogue text]
示例:
john bored left: Oh, so that's how you use the Conversation command.sherlock eyeroll right: Yes, well done John.You catch on quickly don't you?hide john "offscreen left": I sure do.-- This is a comment, it doesn't appear in the conversationjohn angry middle: Wait, what!left: There's no need to be rude Sherlock!bored: Not like that would stop you.sherlock excited: AHA! So that's how you do a conversation from Lua!Fascinating.john <<<: Yes, riveting.john hide:sherlock hide:
接下来就能顺利展开剧情了。
接下来是一个重要功能:Menu。Menu可以为我们做出剧情走向,即根据选择跳转到不同的Block。
首先我们做一个简单的对话选择支:答题系统。
首先我们在Block后创建四个Menu:
然后再新建几个新的Block,将Menu的target指向新的Block。
这样就可以实现一个对话分支了。
请看答题系统的Fungus实现:
最后就可以形成一个对话树结构。
三,触发式对话
当然我们知道,一个正常的人物对话其实应该是触发式展开的。比如说你走近一个人,就开始自动对话,或者是按下键,就自动对话。
这里提供一个简单的触发式解决办法,当然这不是唯一的解决办法:
1,首先我们给人物加一个Collider,Box Collider即可。
这里最好让Collider不碰到任何其他物体。
同时注意,我们还要创建另一个Collider来保证人物不被穿过。这个时候可以用Sphere Collider。
2,我们勾选触发器,isTrigger选项。
然后在这个人物这里新建一个C#脚本,编辑触发器函数:
这里的Message类似一个信号,当我们触发了这个Collider之后,广播了一个信号,我暂且取名为majorTask1.
同时我们将block的触发条件设置为”Message Received“。
这样我们就可以设置成触发式对话了。
=================================
这是我们正在开发的独立游戏:《无尽音海》音乐跑酷+探索城市。目前正在开发阶段。
【Fungus入门】10分钟快速构建Unity中的万能对话系统 / 叙事系统 / 剧情系统的更多相关文章
- 【Istio实际操作篇】Istio入门,10分钟快速安装
@ 目录 前言 本文说明 请大家务必查看 环境准备 详细版 入门:搭建步骤 Istio软件包下载 下载Istio 卸载 简洁版 安装 卸载 学习不走弯路,gz号「yeTechLog」 前言 上一篇讲了 ...
- UWP开发入门(十九)——10分钟学会在VS2015中使用Git
写程序必然需要版本控制,哪怕是个人项目也是必须的.我们在开发UWP APP的时候,VS2015默认提供了对微软TFS和Git的支持.考虑到现在Git很火,作为微软系的程序员也不得不学一点防身,以免被开 ...
- 带你十分钟快速构建好 SpringBoot + SSM 框架
目前最主流的 java web 框架应该是 SSM,而 SSM 框架由于更轻便与灵活目前受到了许多人的青睐.而 SpringBoot 的轻量化,简化项目配置, 没有 XML 配置要求等优点现在也得到了 ...
- Unity中的万能对象池
本文为博主原创文章,欢迎转载.请保留博主链接http://blog.csdn.net/andrewfan Unity编程标准导引-3.4 Unity中的万能对象池 本节通过一个简单的射击子弹的示例来介 ...
- Hexo快速构建个人小站-Fulid主题下添加Valine评论系统(三)
Hexo目录: Hexo快速构建个人小站-Hexo初始化和将项目托管在Github(一) Hexo快速构建个人小站-自定义域名和自定义主题(二) 背景交代: 前面两章完成了Hexo的初始化和部分自定义 ...
- 10分钟快速入门Redis
Redis安装 来源:https://github.com/jaywcjlove/handbook 官方编译安装 $ wget http://download.redis.io/releases/re ...
- ShareSDK入门指南:Android 10分钟快速集成
ShareSDK 官方已提供Android 快速集成教程,以官方教程为参考,本文重点指导大家在集成中遇到的问题. Android 快速集成官方教程:http://wiki.mob.com/Androi ...
- vuex2 10分钟快速入门
因为太简单了,我直接就贴代码了~ #建立store.js import Vue from 'vue'; import Vuex from 'vuex'; Vue.use(Vuex) export de ...
- 10分钟快速入门vue.js
Vue.js是一个轻巧.高性能.可组件化的MVVM库,一套用于构建用户界面的渐进式框架,上手简单,兼容强大. 官方文档:https://cn.vuejs.org/v2/guide/ 下面我们就直接来使 ...
随机推荐
- [BZOJ1000] A+B Problem
Description Calculate a+b Input Two integer a,b (0<=a,b<=10) Output Output a+b Sample Input 1 ...
- 关于html中图片上传预览的实现
本地图片预览 第一种方法 <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type& ...
- 开发中使用Gson的实例(时间格式错误解决方法)
...... // 通过GSON解析,使用4个实体类来接受(TotalResponse.TradeRateResponse.TradeRatess.TbTradeRates) GsonBuilder ...
- onmouse事件
常用的鼠标事件:onmouseenter,onmouseleave,onmouseover,onmouseout,onmouseup,onmousedown,onmousewheel,onmousem ...
- MyBatis的三层级联和二层缓存
我们这里说的三层级联和二级缓存其实也是MyBatis映射器的知识点,只是因为比较难理解,所以单独拿出来讲解,下面是三层级联的内容: 我们知道,在数据库中包含着一对一,一对多 ...
- CentOS配置本地yum源
如果CentOS服务器处在内网环境中时,如果缺少依赖手动安装那么会非常麻烦,要花费很多时间来寻找rpm包,现在如果搭建本地的yum源,就非常方便了,使用yum源首先需要一个CentOS安装镜像,去官网 ...
- JS离开页面 弹窗
function bindDOMEvents() { $(document).keydown(function (e) { var key = e.which || e.keyCode; if (ke ...
- Linux中查看进程树
pstree -p 查看当前的shell的进程和执行shell脚本的子进程的方法:echo $$
- 【深度学习】用PaddlePaddle进行车牌识别(二)
上节我们讲了第一部分,如何用生成简易的车牌,这节课中我们会用PaddlePaddle来识别生成的车牌. 数据读取 在上一节生成车牌时,我们可以分别生成训练数据和测试数据,方法如下(完整代码在这里): ...
- 测试框架Mocha
NodeJS里最常用的测试框架估计就是mocha了.它支持多种node的assert libs, 同时支持异步和同步的测试,同时支持多种方式导出结果,也支持直接在browser上跑Javascript ...