Version: 2017.2
Network Manager 回调
Network Messages

NetworkBehaviour 回调

When using the Network Manager, a player is added by default when a client connects to the server. Players are represented by designated GameObjects (See Unity documentation on Player GameObjects to learn more). The player GameObject exists on both the Server and the Client instances.

Different callbacks are received depending on your game’s connection state. These can be set in the Network Manager HUD.

Three connection states are available:

  • Host: To set your game up in Host mode, select LAN Host(H).

  • Client: To set your game up in Client mode, select LAN Client(C) and enter the server IP into the text field or use the API function StartClient(). Note that your server IP must be in the same local network - or you can type “localhost” if you are connecting to the same machine.

  • Server: To set your game up in Server mode, select LAN Server Only(S).

During run time, the Network Manager HUD’s controls are also available in the Network Manager HUD component’s Inspector window. Click Runtime Controls to access these.

The callbacks in this section are defined in the NetworkBehaviour class and are called only on the player GameObject. To learn more about setting up game states, see Using the Network Manager: Game state management.

Some callbacks require you to have multiple instances of the game running (for example, two Standalone instances, or one Standalone and one in the Editor). These instances can be on the same machine or on different machines, as long as those machines are connected through a local network. This also works in the same way for MatchMaker, but with MatchMaker your machines can also be connected via the Internet.

See also:

Player callbacks on Server

To get these callbacks you need to have two instances of the game, one running in Server mode and the other running in Client mode. These callbacks are only called on the player GameObject on the Server instance.

Launch the Server mode instance first, then start the Client instance to get the callbacks:

  • OnStartServer

  • OnRebuildObservers

  • (Start() function is called)

Player callbacks on Client

To get these callbacks you need to have two instances of the game, one running in Server mode and the other running in Client mode. These callbacks are only called on the player GameObject on the Client instance.

Launch the Server mode instance first, then start the Client instance to get the callbacks:

  • OnStartClient

  • OnStartLocalPlayer

  • OnStartAuthority

  • (Start() function is called)

Player callbacks on Host

To get these callbacks you need to have one instance of the game running in Host mode, either in the Editor or as a Standalone build. These callbacks are only called on the Player GameObject:

  • OnStartServer

  • OnStartClient

  • OnRebuildObservers

  • OnStartAuthority

  • OnStartLocalPlayer

  • (Start() function is called)

  • OnSetLocalVisibility

NetworkBehaviour: OnNetworkDestroy

To get the OnNetworkDestroy callback you need to have three Standalone instances of the game, one running in Server mode and two running in Client mode.

Follow the instructions below to get the OnNetworkDestroy callback:

  1. Start Server instance

  2. Start Client instance

  3. Start a second Client instance

  4. When both Client instances have automatically connected to the Server instance, stop one Client instance

  5. OnNetworkDestroy is then called on the remaining Client instance, but not on the Server instance

Network Manager 回调
Network Messages
Copyright © 2023 Unity Technologies
优美缔软件(上海)有限公司 版权所有
"Unity"、Unity 徽标及其他 Unity 商标是 Unity Technologies 或其附属机构在美国及其他地区的商标或注册商标。其他名称或品牌是其各自所有者的商标。
公安部备案号:
31010902002961