Register Game Object Components in Game Subsystems? (Component-based Game Object design)
Posted
by
topright
on Game Development
See other posts from Game Development
or by topright
Published on 2010-10-17T16:59:21Z
Indexed on
2011/03/11
16:19 UTC
Read the original article
Hit count: 332
I'm creating a component-based game object system. Some tips:
GameObject
is simply a list ofComponents
.- There are
GameSubsystems
. For example, rendering, physics etc. EachGameSubsystem
contains pointers to some ofComponents
.GameSubsystem
is a very powerful and flexible abstraction: it represents any slice (or aspect) of the game world.
There is a need in a mechanism of registering Components
in GameSubsystems
(when GameObject
is created and composed). There are 4 approaches:
- 1: Chain of responsibility pattern. Every
Component
is offered to everyGameSubsystem
.GameSubsystem
makes a decision whichComponents
to register (and how to organize them). For example, GameSubsystemRender can register Renderable Components.
pro. Components
know nothing about how they are used. Low coupling. A. We can add new GameSubsystem
. For example, let's add GameSubsystemTitles that registers all ComponentTitle and guarantees that every title is unique and provides interface to quering objects by title. Of course, ComponentTitle should not be rewrited or inherited in this case. B. We can reorganize existing GameSubsystems
. For example, GameSubsystemAudio, GameSubsystemRender, GameSubsystemParticleEmmiter can be merged into GameSubsystemSpatial (to place all audio, emmiter, render Components
in the same hierarchy and use parent-relative transforms).
con. Every-to-every check. Very innefficient.
con. Subsystems
know about Components
.
- 2: Each
Subsystem
searches forComponents
of specific types.
pro. Better performance than in Approach 1
.
con. Subsystems
still know about Components
.
- 3:
Component
registers itself inGameSubsystem(s)
. We know at compile-time that there is a GameSubsystemRenderer, so let's ComponentImageRender will call something like GameSubsystemRenderer::register(ComponentRenderBase*).
pro. Performance. No unnecessary checks as in Approach 1
.
con. Components
are badly coupled with GameSubsystems
.
- 4: Mediator pattern.
GameState
(that containsGameSubsystems
) can implement registerComponent(Component*).
pro. Components
and GameSubystems
know nothing about each other.
con. In C++ it would look like ugly and slow typeid-switch.
Questions:
Which approach is better and mostly used in component-based design? What Practice says? Any suggestions about implementation of Approach 4
?
Thank you.
© Game Development or respective owner