场景(Scene)与节点(Node)

简介

先设想有那么一瞬间你自己不再是一名游戏开发者了,而是一名大厨!
你的装备换成了一套大厨的制服。不要考虑制作游戏的事情,你现在的职责是为你的顾客创建新的可口的食谱。

那么,大厨是怎样创建食谱的呢?食谱分为两部分:首先是食材;然后是工序。这样,任何人都可以根据食谱烹调并品尝到你华丽的创作。

Godot中制作游戏与这个过程非常相似。Godot引擎就像一个厨房,在这个厨房里,节点就像装满新鲜食材的冰箱。

节点有很多种类型,显示图片的、播放声音的、显示三维模型的,等等。总共有几十个。

节点

让我们从基础谈起。节点是创建游戏的最基础的元素,它具有以下一些特征:

  • 名称
  • 可编辑的属性
  • 能接收回调,以便处理每帧(Frame)相关效果
  • 可以被扩展,以便拥有更多功能
  • 可以被添加为其它节点的子节点

最后一点非常重要:节点能让其它节点作为子节点。这样组合出来,就变成了我们常说的状。

Godot中这种树状组织能力创建了一种强大的项目管理工具。由于不同的节点有不同的功能,通过组合它们就足以创建更复杂的功能。

这样讲你肯定还没有什么感觉,但Godot所有的知识点都与上面这些特征有关,你现在只要记住有节点这么个概念,并且节点能按树状组合就好了。

场景

有了节点的概念后,下一步就是要给你解释什么是场景了。

场景就是由一组按树状层级结构组织的节点组成。它有下列属性:

  • 一个场景只有一个根节点
  • 场景可以被保存到硬盘上并被加载回来
  • 场景可被实例化 (稍后会有更多描述)
  • 运行一款游戏意味着在运行一个场景
  • 一个项目中可以有多个场景,但启动时必须指定其中一个用于初始加载的场景

Godot编辑器其实就是一个场景编辑器。它有丰富的用于编辑二维和三维场景的相关工具,这些工具都是围绕编辑节点和场景的概念的。

创建项目

光讲理论很无聊了吧,那让我们来点实践性的:用编辑器来做个“Hello world”。

当没有启动具体项目时,Godot会打开项目管理器,用于帮助开发者管理项目。

点"New Project"创建新项目,这个时候需要选择项目路径并指定项目名称:

编辑器

创建好新项目后,下一步就是打开它,这样就启动了Godot编辑器。编辑器的效果大致是这样:

上面提过,在Godot中制作游戏就像到了厨房,先打开冰箱,然后添加一些新鲜的节点到项目中。让我们开始“Hello World”吧,点击"New Node"按钮:

打开“Create Node”对话框,界面显示了一长列可用节点吧:

先选择“Label”节点,可以在上方快速搜索:

最后,创建标签!“Create”按钮被点击后,会发生很多事情:

首先,场景变成2D编辑器,因为Label是个二维节点,Label会出现Viewpoint左上角、被选中状态。

同时,该节点出现在Scene树编辑器,标签属性则出现在Inspector。

下面,我们来修改该标签的“Text”属性,改成"Hello, World!":

好了,这样就可以运行场景了!点击顶部栏的播放场景的按钮或按F6:

哎呀...

提示场景需要保存了才能运行;保存场景,文件名比如叫做 hello.scn:

该场景只允许保存在该项目中。项目的根 "res://" 代表资源路径。

保存场景后再点“运行场景”,“Hello, World!”这个demo应该就开始执行了:

搞定!

.. _doc_scenes_and_nodes-configuring_the_project:

配置项目

项目中,如果有多个场景,必须指定一个主场景 - 在运行时初始被载入的。

这些设置都被保存在engine.cfg中,这是一种win.ini这样的纯文本格式,编辑起来很简单。因为项目设置项很多,所以可以通过“项目设置”对话框来直观操作。

通过菜单Scene -> Project Settings可以访问该对话框。

该窗口被打开时,要选择主场景,很简单,切换到application/main_scene属性,选择'hello.scn'即可。

完成设置后,点“运行按钮”或F5键会开始运行该项目。

再打开项目设置对话框,其中显示了很多可用选项及默认值。如果默认值没问题的话就不需要动它。

当其中一项值被改动,其名称左侧会出现一个标记,代表该值将会保存到engine.cfg文件中。

其实还可以添加自定义配置选项并在运行时被读入
:ref:Globals <class_Globals> 单例对象中.

未完待续...

下一节会涉及多个场景及多个节点!

原文:http://docs.godotengine.org/en/latest/tutorials/step_by_step/scenes_and_nodes.html

[译]Godot系列教程一 - 场景与节点的更多相关文章

  1. [译]Godot系列教程三 - 场景实例化(续)

    场景实例化(续) 要点 场景实例化带来很多便利的用法,总体来说有: 将场景细分,更便于管理 相对于某些引擎中的Prefab组件更灵活,并且在许多方面更强大 是一种设计更复杂的游戏流程甚至UI的方式 这 ...

  2. [译]Godot系列教程二 - 场景实例化(Instancing)

    场景实例化(Instancing) 原理阐述 创建一个场景并将节点扔到里面对于小项目是适用的,但随着项目不断发展,用到越来越多的节点,整个项目很快就会演化成难以管理的状态. 为了解决这个问题,Godo ...

  3. [译]Godot系列教程五 - 制作Godot编辑器插件

    制作插件 下文仅针对2.1版本. 关于插件 插件是为编辑器扩展出更多有用工具的重要方式.它可以完全用GDScript和标准场景开发,甚至都不需重新加载编辑器就可生效.不像模块,你无需创建C++代码.也 ...

  4. [译]Godot系列教程四 - 编写脚本

    编写脚本(Scripting) 简介 关于无需编程即可创建视频游戏的那些工具的谈论有很多.不用学习编程知识对很多独立开发者来说就是一个梦想.这种需求 - 游戏开发者.甚至在很多公司内部,希望对游戏流程 ...

  5. [译]Godot系列教程六 - 简单的二维游戏

    Pong Godot自带的Demo中有大量更复杂的示例,但这款叫"Pong"的游戏可以对2D游戏的基本特性做一个介绍. 静态资源 本文所用到的一些资源文件:http://files ...

  6. HTML5游戏开发系列教程7(译)

    原文地址:http://www.script-tutorials.com/html5-game-development-lesson-7/ 今天我们将完成我们第一个完整的游戏--打砖块.这次教程中,将 ...

  7. HTML5游戏开发系列教程6(译)

    原文地址:http://www.script-tutorials.com/html5-game-development-lesson-6/ 这是我们最新一篇HTML5游戏开发系列文章.我们将继续使用c ...

  8. HTML5游戏开发系列教程5(译)

    原文地址:http://www.script-tutorials.com/html5-game-development-lesson-5/ 最终我决定准备下一篇游戏开发系列的文章,我们将继续使用can ...

  9. HTML5游戏开发系列教程4(译)

    原文地址:http://www.script-tutorials.com/html5-game-development-lesson-4/ 这篇文章是我们继续使用canvas来进行HTML5游戏开发系 ...

随机推荐

  1. 同步博客到CSDN

    经过一些朋友的多次邀请,现同步博客到CSDN,地址:http://blog.csdn.net/knightswarrior.

  2. golang reflect

    golang reflect go语言中reflect反射机制.详细原文:地址 接口值到反射对象 package main import ( "fmt" "reflect ...

  3. [ASP.NET MVC 小牛之路]15 - Model Binding

    Model Binding(模型绑定)是 MVC 框架根据 HTTP 请求数据创建 .NET 对象的一个过程.我们之前所有示例中传递给 Action 方法参数的对象都是在 Model Binding ...

  4. 页面loading效果

    当网页太大,打开太慢的时候,为了增加良好的用户体验(不让用户眼巴巴的等,心中暗骂c,这么慢),我们需要加一个等待动画. 只需把以下代码加入页面中即可,图片可以根据自己的需求更换,更换图片之后需要改变l ...

  5. alert()与console.log()的区别

    [1]alert() [1.1]有阻塞作用,不点击确定,后续代码无法继续执行 [1.2]alert()只能输出string,如果alert输出的是对象会自动调用toString()方法 e.g. al ...

  6. floating IP 原理分析 - 每天5分钟玩转 OpenStack(107)

    上一节我们通过 Web UI 创建为 cirros-vm3 分配了浮动 IP,今天将分析其工作原理. 首先查看 router 的 interface 配置: 可以看到,floating IP 已经配置 ...

  7. Neutron Vlan Network 原理- 每天5分钟玩转 OpenStack(92)

    前面我们陆续学习了 Neutron local network,flat network 和 DHCP 服务,从本节将开始讨论 vlan network. vlan network 是带 tag 的网 ...

  8. 引用类型-Array类型

    ECMAScript数组的每一项可以保存任何类型的数据,并且数组的大小是可以动态调整的. 创建数组的基本方式有两种,第一种是使用Array构造函数 var colors = new Array(); ...

  9. Android图片选择器

    1.概述 应公司项目需求,要做一个图片选择器,网上搜索了一些源码,我在别人的基础上进行了修改,另外页面也进行了重整,我的是先加载图片文件夹列表,然后再进入选择图片.            参考博客地址 ...

  10. C#:Md5和Sha1两种加密方式

    1.新建控制台应用程序 2.新建类 EncryptHelper.cs public static class EncryptHelper { /// <summary> /// 基于Md5 ...