Documentation ¶
Overview ¶
Package pt 实体与组件原型,用于创建实体。
Index ¶
Constants ¶
This section is empty.
Variables ¶
View Source
var (
ErrPt = fmt.Errorf("%w: pt", exception.ErrCore) // 原型错误
)
Functions ¶
func As ¶
func As[T comparable](entity ec.Entity) (T, bool)
As 从实体提取一些需要的组件接口,复合在一起直接使用。
示例:
type IA interface { MethodA() } ... type IB interface { MethodB() } ... type CompositeAB struct { IA `ec:"A"` // 指定组件名 IB `ec:",CompB"` // 指定组件原型名 } ... entity.AddComponent("A", compA) entity.AddComponent("B", compB) ... v, ok := As[CompositeAB](entity) if ok { v.MethodA() v.MethodB() }
注意:
1.内部逻辑有使用反射,为了提高性能,可以使用一次后存储转换结果重复使用。 2.实体更新组件后,需要重新提取。 3.需要使用tag标记组件名或组件原型名,若没有标记,将会尝试使用字段名作为组件名去查找。
func Cast ¶
func Cast[T comparable](entity ec.Entity) T
Cast 从实体提取一些需要的组件接口,复合在一起直接使用,提取失败会panic。
示例:
type IA interface { MethodA() } ... type IB interface { MethodB() } ... type CompositeAB struct { IA `ec:"A"` // 指定组件名 IB `ec:",CompB"` // 指定组件原型名 } ... entity.AddComponent("A", compA) entity.AddComponent("B", compB) ... Cast[CompositeAB](entity).MethodA() Cast[CompositeAB](entity).MethodB()
注意:
1.内部逻辑有使用反射,为了提高性能,可以使用一次后存储转换结果重复使用。 2.实体更新组件后,需要重新提取。 3.需要使用tag标记组件名或组件原型名,若没有标记,将会尝试使用字段名作为组件名去查找。
Types ¶
type ComponentAttribute ¶
type ComponentAttribute struct { Instance any // 组件实例(必填) Name string // 组件名称 NonRemovable bool // 是否不可删除 Extra generic.SliceMap[string, any] // 自定义属性 }
ComponentAttribute 组件原型属性
func ComponentWith ¶
func ComponentWith(inst any, name string, nonRemovable bool, extra ...map[string]any) ComponentAttribute
ComponentWith 创建组件原型属性,用于注册实体原型时自定义相关属性
type ComponentLib ¶
type ComponentLib interface { // Declare 声明组件原型(可以重复声明) Declare(comp any) ec.ComponentPT // Undeclare 取消声明组件原型 Undeclare(prototype string) // Get 获取组件原型 Get(prototype string) (ec.ComponentPT, bool) // Range 遍历所有已注册的组件原型 Range(fun generic.Func1[ec.ComponentPT, bool]) // ReversedRange 反向遍历所有已注册的组件原型 ReversedRange(fun generic.Func1[ec.ComponentPT, bool]) }
ComponentLib 组件原型库
type Composite ¶
type Composite[T comparable] struct { // contains filtered or unexported fields }
Composite 组件复合器,直接使用As()或Cast()时,无法检测提取后实体是否又更新组件,使用复合器可以解决此问题。
示例:
type IA interface { MethodA() } ... type IB interface { MethodB() } ... type CompositeAB struct { IA `ec:"A"` // 指定组件名 IB `ec:",CompB"` // 指定组件原型名 } ... entity.AddComponent("A", compA) entity.AddComponent("B", compB) ... cx := Compose[CompositeAB](entity) if v, ok := cx.As(); ok { v.MethodA() v.MethodB() } cx.Cast().MethodA() cx.Cast().MethodB()
type EntityAttribute ¶
type EntityAttribute struct { Prototype string // 实体原型名称(必填) Instance any // 实体实例 Scope *ec.Scope // 可访问作用域 ComponentAwakeOnFirstTouch *bool // 开启组件被首次访问时,检测并调用Awake() ComponentUniqueID *bool // 开启组件唯一Id Extra generic.SliceMap[string, any] // 自定义属性 }
EntityAttribute 实体原型属性
func EntityWith ¶
func EntityWith(prototype string, inst any, scope *ec.Scope, componentAwakeOnFirstTouch, componentUniqueID *bool, extra ...map[string]any) EntityAttribute
EntityWith 创建实体原型属性,用于注册实体原型时自定义相关属性
type EntityLib ¶
type EntityLib interface { EntityPTProvider // GetComponentLib 获取组件原型库 GetComponentLib() ComponentLib // Declare 声明实体原型 Declare(prototype any, comps ...any) ec.EntityPT // Redeclare 重声明实体原型 Redeclare(prototype any, comps ...any) ec.EntityPT // Undeclare 取消声明实体原型 Undeclare(prototype string) // Get 获取实体原型 Get(prototype string) (ec.EntityPT, bool) // Range 遍历所有已注册的实体原型 Range(fun generic.Func1[ec.EntityPT, bool]) // ReversedRange 反向遍历所有已注册的实体原型 ReversedRange(fun generic.Func1[ec.EntityPT, bool]) }
EntityLib 实体原型库
type EntityPTProvider ¶
type EntityPTProvider interface { // GetEntityLib 获取实体原型库 GetEntityLib() EntityLib }
EntityPTProvider 实体原型提供者
Click to show internal directories.
Click to hide internal directories.