Viewer Structure
Overview
The viewer structure manages a dynamic list of viewers (usually Players) on an entity or any other object. It either provides methods to add or remove viewer or utilizes the Bindables API for BindableList<Player>
and then listens when value gets added or removed to/from that list.
This structure enables selective updates and mainly visibility control
Example
Entities utilize the viewer structure for visibility control.
Every entity provides addViewer
and removeViewer
methods. When you add a player as viewer to an entity, the player will see the entity. If you remove the player, the player will no longer see the entity and won't be able to interact with it.
Other dockyard apis that utilizes the viewer structure are: