Skip to content

Entities

polyrain edited this page Aug 1, 2021 · 1 revision

First see Entity Component System.

An entity without components doesn't do much, but has some important functionality:

  • Entities have a position in the world, which is measured in metres. This is used for rendering and physics.
  • Entities have a scale which determines its size. This is used for rendering and physics.
  • Entities have an event system to communicate between components and entities. See Event System.

Entity lifecycle

The entity lifecycle can be seen in the figure below.

Note that create() is not called when the entity is instantiated through new Entity(), but when the entity is added into the world. This means we know that an entity doesn't do anything while we are still adding components to it, or before we've placed it in the game.

Entities can also be disabled or enabled during gameplay. While an entity is disabled, it won't draw on the screen or run any updates. This is very useful when an entity isn't needed right now but will be later, since it won't have to be created twice. You can also create entities ahead of time but leave them disabled until they're necessary.

Using Entities

To make an entity, just instantiate one and use addComponent() to add components to it. You can also use getComponent() to access the components on an entity. The entity then has to be registered with the Entity Service to be created.

public static void spawnPlayer()
  // Create entity
  Entity player = new Entity()
    .addComponent(new TextureRenderComponent("images/player.png"))
    .addComponent(new PlayerMovementComponent())
    .addComponent(new InventoryComponent())
    .addComponent(new CombatComponent());

  // Access components
  player.getComponent(PlayerMovementComponent.class).setSpeed(3f);

  // Create in the world
  ServiceLocator.getEntityService().register(player);
}

Table of Contents

Home

Design Document

Design Document

Design Document

Game Engine

Getting Started

Entities and Components

Item Drops from Entities

Service Locator

Loading Resources

Logging

Unit Testing

Debug Terminal

Input Handling

UI

Animations

Audio

AI

Physics

Game Screens and Areas

Terrain

Map Generation

Concurrency & Threading

Settings

Troubleshooting

MacOS Setup Guide

Clone this wiki locally