アーキテクチャ
このセクションでは、Interest Management アドオンで利用可能な主なコンポーネントについて説明します。
上の図は、コンポーネント間の関係を高レベルの視点から示し、それらの使用方法を示しています。
インタレストシェイプ
- 評価時にターゲットプレイヤーのインタレストに追加され、インタレストセルに変換されるインタレストのエリア/ボリュームを定義します(詳細は下記参照)。
- シェイプはインタレストプロバイダーとプレイヤーインタレストビューにリンクされています。
- 利用可能な基本的なシェイプは3つです:
InterestSphere
InterestBox
InterestCone
- カスタムシェイプは、
InterestShape
クラスを継承することで実装できます。
インタレストプロバイダー
- 世界の特定のオブジェクトに関連するインタレストを提供します。通常、そのオブジェクトの周囲のエリアです。
- 基本の
InterestProvider
は以下を実装しています:InterestShape
参照のリスト。- デフォルトではフィルタリングルールはなく、評価時にすべてのプレイヤーに対してインタレストが処理されます。
- カスタムプロバイダーは、
InterestProvider
クラスを継承し、bool IsPlayerInterested()
メソッドをオーバーライドすることで実装されます。 - グローバルプロバイダー(
IsGlobal
を有効にする)は、自動的にGlobalInterestManager
に登録され、すべてのプレイヤーに対して評価されます。 - プロバイダーのネストは、
Child Providers
をリンクすることでサポートされています。
以下の画像は、カスタムの InterestByDistance
プロバイダーを示しています。このプロバイダーは、プレイヤーがオブジェクトから300m(プロパティ VisibilityDistance
)以内にいる場合にリンクされた InterestBox
シェイプのインタレストを追加します。
以下の画像は、距離と視野角に基づいてプレイヤーにインタレストを提供するシーンオブジェクトの別の例を示しています。
PlayerInterestManager
andPlayerInterestView
are onAgent
object and provide base interest from player perspective - the cone view.Tower
objects have a component derived fromInterestProvider
which implements filtering rules.- One tower is in player's view within a specific angle and distance => its interest area (
Tower's Interest
- defined by that tower) is added to the player's interest and all objects in that area will be replicated. - The other tower outside of player's view is not included and objects in that area won't be replicated.
Player Interest View
- Special type of interest provider (derived from
InterestProvider
class) that is reserved for players - Input Authority must be valid. - Provides current position of the player and his view/camera. These information are essential for filtering which player is interested in which
InterestProvider
. - There might be more views per player spawned at the same time, but only one can be active - registered in
PlayerInterestManager.InterestView
. - This component is typically added to the player character prefab and represents his default view, for example cones that match camera frustum.
- Automatically registered to
GlobalInterestManager
and available for filtering.
Following image shows PlayerInterestView
on player prefab with references to near and far cones (interest shapes), which cover camera frustum (near cone) and increased visibility towards center of the screen (far cone):
Following image explains usage of PlayerInterestView
:
- In the first case the
Player Interest Manager
points to leftPlayer Interest View
. The player uses interest defined by that view. - In the second case the
Player Interest Manager
switched active interest view (PlayerInterestManager.InterestView
property) to the right one and started using interest of that view. - This makes features like spectator or switching between multiple characters (one active at a time) very easy to implement from interest management perspective.
Player Interest Manager
- Main component that drives evaluation of interest for a specific player - Input Authority must be valid.
- There is always exactly one
PlayerInterestManager
instance per player. - Holds reference to active
PlayerInterestView
. - Automatically registered to
GlobalInterestManager
and available for filtering. - Provides runtime information in inspector and scene view (gizmos).
- This component is typically on the same object as
PlayerInterestView
. - In more advanced cases this component can be added to a special player object - different from character object(s).
PlayerInterestView
which resides on character object is then registered dynamically from code at runtime.
Global Interest Manager
- Global manager (singleton) which resides on NetworkRunner.
- Stores references and provides access to Player Interest Managers, Player Interest Views and global Interest Providers.
Interest Cells
The player's interest is built by combination of common geometric shapes - sphere, box, cone. However Fusion's interest system works internally with a 3D grid of Interest Cells.
Converting interest shapes to cells produces a side effect - the actual area replicated to client is always bigger than area defined by shapes.
Let's compare area covered by cone shapes (representing first person view) and resulting interest cells:
You can see that the area replicated to a client (green boxes) is much bigger than what was designed with cones.
This difference can be reduced by lowering cell size of Fusion's interest system.
In first case (Cell Size = 32m) the resulting volume synchronized equals to 917 504 m3. In second case (Cell Size = 16m) the resulting volume synchronized equals to 327 680 m3 which is 65% less and may have some impact on network traffic. On the other side, CPU must process more cells.
Performance
Generally it is hard to tell what settings and shapes should be used, this must be fine tuned specifically for each game to get best results.
Following factors come into play:
- CPU budget.
- Overall map size.
- Density of networked objects.
- Environment design - objects blocking player's view.
- Number of global interest providers.
- Player count.
- ...
Lowering cell size better reflects designed shapes and generally reduces network traffic (replicated less objects outside the player's view), but requires more CPU power.
The Interest Management however provides ways to optimize that:
- Interest cells evaluated for an Interest Shape are automatically cached and reused if the shape properties remain static (position, radius, ...). Full evaluation is executed on demand.
- Player Interest Manager supports interlaced evaluation by overriding
bool CanUpdatePlayerInterest()
. This can be used to defer evaluation until the player moves by X, rotates by Y or to split execution with other subsystems between even/odd ticks. - When the scene design is complete, it can be post-processed to optimize specific areas with well defined visibility. However this process requires more effort.