Error CS1503 Cannot convert from "UnityEngine.Vector3" to "float"

  • I was told i was passing the wrong type of parameter into SetDestination but i looked though the unity api but I couldn’t find anything.

Collider colliders = Physics.OverlapSphere(transform.position, Sight);
foreach (Collider nearbyObjects in colliders)
{
if(nearbyObjects.tag == WorkerTag)
{
myNavMeshAgent.SetDestination(nearbyObjects);
}
}


- and i can't find anything one online about it

You’re trying to pass in the collider but it’s expecting a Vector3 representing a position in space.

myNavMeshAgent.SetDestination(nearbyObjects.transform.position);

Thanks and added a part that when one alien sees the player others with in a 20f distance come and help

Just a note about this:

The compiler doesn’t care singular or plural, but when you are iterating, generally use singular for the iterator and plural for the thing being iterated.

So …

Collider[] nearbyObjects = Physics.OverlapSphere(transform.position, Sight);
foreach (Collider nearbyObject in nearbyObjects)
{
    // do stuff with nearbyObject, NOT with nearbyObjects
}

Even better, never use the word “object…” Saying “object” is equivalent to saying thingamajig and completely useless as a name.

Use worker or enemy or agent or dude or anything like that… even something as ambiguous as “nearbyWorkers” is helpful because if you ever see something called a “Wall” come up in nearbyWorkers then you know something is wrong and you can fix it.

The sanity you save may be your own.

3 Likes

i did nearbyobjects cause i was going to add more tags that it looks for

        Collider[] colliders = Physics.OverlapSphere(transform.position, Sight);
        foreach (Collider nearbyObject in colliders)
        {
            if(nearbyObject.tag == WorkerTag)
            {
               myNavMeshAgent.SetDestination(nearbyObjects.transform.position);
            }
            if(nearbyObject.tag == OtherTag)
            {
              //do thing
            }
        }

If you’re choosing a word that is generic it’s a good sign that you don’t actually need the word. In the case of your code you could just call it nearby.

Although if I were writing the code I’d just call it collider since the code is accessing one of a collection of type Collider not of type GameObject. That can be important once your code is long enough you can no longer see the type on screen and aren’t using an IDE that shows the type next to the variable name like JetBrains Rider.

1 Like