How to share information between Screens and Entities is a very common problem. There are a lot of ways to solve this problem, but each has its downsides. While this problem may seem trivial, this article will talk about the preferred way to share object references between Screens (the owner) and Entities (contained objects that need the information).
Let's imagine you are creating a multi-player game where the players work together to defeat groups of enemies. Based off of this simple description of a game we can identify a few things:
The Screen will have a PositionedObjectList<Player>
The Screen will have a PositionedObjectList<Enemy>
Each enemy will need to know about the PositionedObjectList<Player> so that it can make decisions about where to move and where/when to attack.
Naturally you will want to make the two PositionedObjectLists (for Player and Entity types) in Glue in your Screen. This means that the Screen has access to the two PositionedObjectLists. For proper encapsulation, the logic for the Enemy AI should exist in the Enemy code (as opposed to the Screen code). However, the Enemy's AI logic will need access to the PositionedObjectList<Player> that exists in the Screen.
At a high level the steps required to share the information are:
Create a public PositionedObjectList<Player> property in the Enemy custom code (not through Glue)
Assign this property in the Screen class whenever a new Enemy is created
Use this property in your AI logic in Enemy.cs
Open your Enemy.cs file and add the following code at class scope:
That was easy!
Locate where you create your Enemy instances and add the following code:
You may have a method like AiActivity in your Enemy.cs file. If so, it would look like this: