Version: 5.4 beta (switch to 5.3)
LanguageEnglish
  • C#
  • JS

Script language

Select your preferred scripting language. All code snippets will be displayed in this language.

NavMesh.SetAreaCost

Suggest a change

Success!

Thank you for helping us improve the quality of Unity Documentation. Although we cannot accept all submissions, we do read each suggested change from our users and will make updates where applicable.

Close

Sumbission failed

For some reason your suggested change could not be submitted. Please try again in a few minutes. And thank you for taking the time to help us improve the quality of Unity Documentation.

Close

Cancel

public static function SetAreaCost(areaIndex: int, cost: float): void;
public static void SetAreaCost(int areaIndex, float cost);

Parameters

areaIndex Index of the area to set.
cost New cost.

Description

Sets the cost for finding path over geometry of the area type on all agents.

This will replace any custom area costs on all agents, and set the default cost for new agents that are created after calling the function. The cost must be larger than 1.0.

You can use NavMesh.GetAreaFromName to find the area index based on the name of the NavMesh area type.

#pragma strict
// ToggleWaterCost.cs
public class ToggleWaterCost extends MonoBehaviour {
	function Update() {
		if (Input.anyKeyDown) {
			// Make water area 10x more costly to traverse.
			NavMesh.SetAreaCost(NavMesh.GetAreaFromName("water"), 10.0f);
		}
	}
}
// ToggleWaterCost.cs
using UnityEngine;
using System.Collections;
public class ToggleWaterCost : MonoBehaviour {
	void Update() {
		if (Input.anyKeyDown) {
			// Make water area 10x more costly to traverse.
			NavMesh.SetAreaCost(NavMesh.GetAreaFromName("water"), 10.0f);
		}
	}
}

See also:
Areas and Costs – to learn how to use different Area types.