mirror of
https://github.com/MirrorNetworking/Mirror.git
synced 2024-11-18 11:00:32 +00:00
93 lines
3.0 KiB
Markdown
93 lines
3.0 KiB
Markdown
|
# Converting a Single-Player Game to Mirror
|
|||
|
|
|||
|
This document describes steps to converting a single player game to a multiplayer game, using Mirror. The process described here is a simplified, higher level version of the actual process for a real game; it doesn’t always work exactly like this, but it provides a basic recipe for the process.
|
|||
|
|
|||
|
## NetworkManager set-up
|
|||
|
|
|||
|
- Add a new GameObject and rename it “NetworkManager”.
|
|||
|
- Add the NetworkManager component to the “NetworkManager” GameObject.
|
|||
|
- Add the NetworkManagerHUD component to the GameObject. This provides the default UI for managing the network game state.
|
|||
|
|
|||
|
See Using the NetworkManager.
|
|||
|
|
|||
|
## Player Prefab Setup
|
|||
|
|
|||
|
- Find the Prefab for the player GameObject in the game, or create a Prefab from the player GameObject
|
|||
|
- Add the NetworkIdentity component to the player Prefab
|
|||
|
- Check the LocalPlayerAuthority box on the NetworkIdentity
|
|||
|
- Set the `playerPrefab` in the NetworkManager’s Spawn Info section to the player Prefab
|
|||
|
- Remove the player GameObject instance from the Scene if it exists in the Scene
|
|||
|
|
|||
|
See Player Objects for more information.
|
|||
|
|
|||
|
## Player Movement
|
|||
|
|
|||
|
- Add a NetworkTransform component to the player Prefab
|
|||
|
- Update input and control scripts to respect `isLocalPlayer`
|
|||
|
- Fix Camera to use spawned player and `isLocalPlayer`
|
|||
|
|
|||
|
For example, this script only processes input for the local player:
|
|||
|
|
|||
|
```
|
|||
|
using UnityEngine;
|
|||
|
using Mirror;
|
|||
|
|
|||
|
public class Controls : NetworkBehaviour
|
|||
|
{
|
|||
|
void Update()
|
|||
|
{
|
|||
|
if (!isLocalPlayer)
|
|||
|
{
|
|||
|
// exit from update if this is not the local player
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
// handle player input for movement
|
|||
|
}
|
|||
|
}
|
|||
|
```
|
|||
|
|
|||
|
## Basic Player Game State
|
|||
|
|
|||
|
- Make scripts that contain important data into NetworkBehaviours instead of MonoBehaviours
|
|||
|
- Make important member variables into SyncVars
|
|||
|
|
|||
|
See State Synchronization.
|
|||
|
|
|||
|
## Networked Actions
|
|||
|
|
|||
|
- Make scripts that perform important actions into NetworkBehaviours instead of MonoBehaviours
|
|||
|
- Update functions that perform important player actions to be commands
|
|||
|
|
|||
|
See Networked Actions.
|
|||
|
|
|||
|
## Non-player GameObjects
|
|||
|
|
|||
|
Fix non-player prefabs such as enemies:
|
|||
|
|
|||
|
- Add the NetworkIdentify component
|
|||
|
- Add the NetworkTransform component
|
|||
|
- Register spawnable Prefabs with the NetworkManager
|
|||
|
- Update scripts with game state and actions
|
|||
|
|
|||
|
## Spawners
|
|||
|
|
|||
|
- Potentially change spawner scripts to be NetworkBehaviours
|
|||
|
- Modify spawners to only run on the server (use isServer property or the `OnStartServer()` function)
|
|||
|
- Call `NetworkServer.Spawn()` for created GameObjects
|
|||
|
|
|||
|
## Spawn Positions for Players
|
|||
|
|
|||
|
- Add a new GameObject and place it at player’s start location
|
|||
|
- Add the NetworkStartPosition component to the new GameObject
|
|||
|
|
|||
|
## Lobby
|
|||
|
|
|||
|
- Create Lobby Scene
|
|||
|
- Add a new GameObject to the Scene and rename it to “NetworkLobbyManager”.
|
|||
|
- Add the NetworkLobbyManager component to the new GameObject.
|
|||
|
- Configure the Manager:
|
|||
|
- Scenes
|
|||
|
- Prefabs
|
|||
|
- Spawners
|