wuxianshengcong/Library/PackageCache/com.unity.ai.navigation@1.1.5/Documentation~/NavMeshLink.md
2025-01-02 14:50:41 +08:00

2.8 KiB
Raw Blame History

NavMeshLink

NavMesh Link creates a navigable link between two locations that use NavMeshes.

This link can be from point to point or it can span a gap, in which case the Agent uses the nearest location along the entry edge to cross the link.

You must use a NavMesh Link to connect different NavMesh Surfaces.

To use the NavMesh Link component, navigate to GameObject > AI > NavMesh Link.

NavMeshLink example

Parameters

Property Description
Agent Type Specify the Agent type that can use the link.
Start Point Specify the start point of the link, relative to the GameObject. Defined by XYZ coordinates.
End Point Specify the end point of the link, relative to the GameObject. Defined by XYZ coordinates.
Align Transform To Points Clicking this button moves the GameObject at the links center point and aligns the transforms forward axis with the end point.
Cost Modifier When the cost modifier value is non-negative the cost of moving over the NavMeshLink is equivalent to the cost modifier value times the Euclidean distance between NavMeshLink end points.
Bidirectional With this checkbox selected, NavMesh Agents traverse the NavMesh Link both ways (from the start point to the end point, and from the end point back to the start point).
When this checkbox is cleared, the NavMesh Link only functions one-way (from the start point to the end point only).
Area Type The area type of the NavMesh Link (this affects pathfinding costs).
- Walkable (this is the default option)
- Not Walkable
- Jump

Connecting multiple NavMesh Surfaces together

Connecting surfaces example

If you want an Agent to move between multiple NavMesh Surfaces in a Scene, they must be connected using a NavMesh Link.

In the example Scene above, the blue and red NavMeshes are defined in different NavMesh Surfaces, with a NavMesh link connecting them.

Note that when connecting NavMesh Surfaces:

  • You can connect NavMesh Surfaces using multiple NavMesh Links.

  • Both the NavMesh Surfaces and the NavMesh Link must have same Agent type.

  • The NavMesh Links start and end point must only be on one NavMesh Surface - be careful if you have multiple NavMeshes at the same location.

  • If you are loading a second NavMesh Surface and you have unconnected NavMesh Links in the first Scene, check that they do not connect to any unwanted NavMesh Surfaces.