Raycast System is a set of a few classes which help setup basic structure for detecting special interest objects in 3D world, mainly for purposes of some kind of interaction system.
In Raycast System there are two types of objects differing in behavior and purpose:
- Raycasted objects are objects which are detected in Raycast System. They might contain logic to necessary for the interaction, but they shouldn't call it on their own. Their main purpose is to be detected by raycaster and then used by its controller logic
- Raycaster is the subject of the system. It detects the raycasted objects in order to call logic on them
Configuration of the game to support and use Raycast System consists of two parts: (1) raycasted objects configuration and (2) raycaster configuration.
- Layer - preparing a special layer for detected objects is not mandatory and raycasted objects might be on Default layer as well. However it is a good practice to create a separate layer for purposes of being detected as raycasted or interactive objects.
- Raycast Collider - every raycasted object needs a collider to be detected. After setting a desired layer (chosen in point 1) on colliders game object, component RaycastCollider must be added. Raycast collider represents one collider of the object, as the object might use multiple colliders.
- Raycast Target - another component which must be added to raycasted object. The RaycastTarget component represents the raycasted object and it's logic. It should be added to game object where all other logic related scripts are to fully benefit from TryGetComponent method. Preferably it should be added to ancestor of Raycast Colliders. Raycast target can be inherited from, for example to contain cached logic component, to make referencing it easier instead of using TryGetComponent
- Raycast Controller - every raycasting subject in Raycast System (for example Player) needs RaycastController component in order to detect raycast targets. The component might be added to any game object of the subject however it's prefered to put it in Head game object of FPP player or MainCamera game object for other perspectives. If raycast controller is needed for other objects such as NPCs, it's also possible to add it to them.
- Ray Provider - a strategy for providing a ray to raycast controller. There are a few predefined ray providers for the most common raycast controller usages, but RayProvider class can be inherited and adjusted to personal needs of the project. So, far there are 3 predefined ray providers in Ray Providers directory:
- MainCameraForwardRayProvider - returns ray from MainCamera in the MainCamera direction
- TransformForwardRayProvider - returns forward looking ray from game object its attached to
- RayFromMouseProvider - returns ray going from camera (by default MainCamera) in the direction specified by mouse pointer position. There are both Input Manager and Input System variants
 
- Other fields - lastly other raycast controller fields should be configured. This applies specially Raycasted Layers which represents layers detected by the raycast controller. The field must contain both: (1) layers of raycasted objects specified earlier and (2) layers that block the view/access to raycasted objects
This package can use Naughty Attributes package to view read only fields that shouldn't be edited in inspector. To setup it correctly you need to install the package and define NAUGHTY_ATTRIBUTES symbol.