Entitas学习三 —— Entitas 基本思想

2024-02-14 01:18
文章标签 学习 基本 思想 entitas

本文主要是介绍Entitas学习三 —— Entitas 基本思想,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. Entitas的主要思路

如果你熟悉ECS的话,可以很容易就理解这个框架,不熟悉也没关系,我们一起来熟悉。

Entitas的思路比较明确——谁发生了改变,我就对谁感兴趣。

比如角色的血量,如果它没有变化,那么,System是不会对其进行操作的(当然,你想操作也行)。只有血量发生了变化,它才会被关注。

当然了,像监测血量变化这种事情,我们用消息订阅就能完成,只不过Entitas把这件事情做到了极致。

而且,通过GetTrigger和Filter这两个函数,我们可以轻松地定位我们所需要的那些实体,确实很神奇,也很方便。

2.大实体

其实,Entitas的这种模式,会把一个实体变得很大,按照我目前所理解的情况来看(入门阶段),实体的种类是非常少的。

比如框架默认就只设定了两种实体——GameEntity和InputEntity——游戏实体和输入实体。

而实体的进一步划分,比如英雄、怪物、子弹等,都是由组件来实现——即GameEntity同时包含了这些角色所需要的组建,但不同类型的角色激活不同类型的组建。然后通过GameMatcher来筛选实体类型。

可以粗暴地理解为,你激活了哪些组件,你就属于哪种类型,至于实体,这个概念已经被弱化了。

其实也很好理解,这就是所谓的组合。

只不过,这样会导致GameEntity拥有特别多的属性(组件),显然这是一个比较庞大的类。

3.零散的组件

很显然,随着游戏开发的进行,我们的组件会越来越多,我们必须花点心思去管理这些文件,不然就要陷入混乱了。

我的想法是,把类型相近的组件类都放在一个文件里,这样就不至于出现一大堆类文件。

4.优点

这框架的优点蛮多的,由于我的HelloWorld篇幅有限,我对Entitas的理解也不够深入,没法和大家准确地描述它的所有优点,只能列举我目前所了解到的优点:

  • 代码结构清晰。只要严格按照框架来写代码,基本上不会出现乱七八糟的东西
  • 极其方便地管理实体状态。Entitas这种模式,天生就带着“状态机”的功能,只要你某个属性变化了我就做出相应的处理,我不用管你是怎么变化的。各种状态的切换都十分方便。
  • 扩展性强。组件这种模式,本来耦合度就很低,一切都是组件的组合而已,后期的扩展也变得十分方便。
  • 自带缓存功能。Entitas是有缓存功能的,被销毁的实体并不会真正地消失,而是待在缓存里,等待下一次的使用。

5.缺点

当然了,不管什么框架,一定有它的缺点,我在这里也稍微列举一些我所了解到的缺点:

  • 上手难度高。从HelloWorld中就能了解到,要熟悉这个框架,需要花费一定的精力,特别是对于新手而言,会一脸懵逼。
  • 实体庞大。如我之前所说,由于所有组件的处理代码都放在一个类里,会造成这个类特别庞大,当然,这倒也不会引起太大的问题。
  • 组件非常多,不好管理。这个问题,可能并不是这个框架的锅。
  • 自动生成代码并不那么美好。如果你的代码刚好编译出错,但是你又需要生成实体代码后才能解决报错的问题,这时候就陷入死循环了——你需要生成代码后才能解决编译报错,但生成代码却需要先解决编译报错的问题。当然,这个官方有解决方案,只是,我仍然觉得很麻烦。
  • 国内资料少。额,这确实也算是一个缺点吧。
  • 不适合小项目。因为框架限定了写代码的方式,写小游戏反而不那么顺手。

6.唠叨一下

所以,关于Entitas的介绍,就到此为止咯。

如果你对这个框架感兴趣的话,一定要到GitHub上面看看wiki,它比我讲解的要好太多了!

至于我本人,对Entitas的研究也告一段落,以后有机会再把它用到我的实际项目中吧。

写本系列文章时,我对Entitas的了解仍然处于初级阶段,如果有哪些描述不当的,欢迎指正。

这篇关于Entitas学习三 —— Entitas 基本思想的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/707143

相关文章

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

Unity新手入门学习殿堂级知识详细讲解(图文)

《Unity新手入门学习殿堂级知识详细讲解(图文)》Unity是一款跨平台游戏引擎,支持2D/3D及VR/AR开发,核心功能模块包括图形、音频、物理等,通过可视化编辑器与脚本扩展实现开发,项目结构含A... 目录入门概述什么是 UnityUnity引擎基础认知编辑器核心操作Unity 编辑器项目模式分类工程

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

Python学习笔记之getattr和hasattr用法示例详解

《Python学习笔记之getattr和hasattr用法示例详解》在Python中,hasattr()、getattr()和setattr()是一组内置函数,用于对对象的属性进行操作和查询,这篇文章... 目录1.getattr用法详解1.1 基本作用1.2 示例1.3 原理2.hasattr用法详解2.

DNS查询的利器! linux的dig命令基本用法详解

《DNS查询的利器!linux的dig命令基本用法详解》dig命令可以查询各种类型DNS记录信息,下面我们将通过实际示例和dig命令常用参数来详细说明如何使用dig实用程序... dig(Domain Information Groper)是一款功能强大的 linux 命令行实用程序,通过查询名称服务器并输

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁