Wayback Machinekoobas.hobune.stream
May JUN Jul
Previous capture 12 Next capture
2021 2022 2023
1 capture
12 Jun 22 - 12 Jun 22
sparklines
Close Help
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
  • Asset Store
  • Get Unity

UNITY ACCOUNT

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account
  • Blog
  • Forums
  • Answers
  • Evangelists
  • User Groups
  • Beta Program
  • Advisory Panel

Navigation

  • Home
  • Products
  • Solutions
  • Made with Unity
  • Learning
  • Support & Services
  • Community
    • Blog
    • Forums
    • Answers
    • Evangelists
    • User Groups
    • Beta Program
    • Advisory Panel

Unity account

You need a Unity Account to shop in the Online and Asset Stores, participate in the Unity Community and manage your license portfolio. Login Create account

Language

  • Chinese
  • Spanish
  • Japanese
  • Korean
  • Portuguese
  • Ask a question
  • Spaces
    • Default
    • Help Room
    • META
    • Moderators
    • Topics
    • Questions
    • Users
    • Badges
  • Home /
avatar image
0
Question by $$anonymous$$ · Jan 05, 2018 at 10:23 PM · c#positioncollidersboundsprocedural generation

Procedural object generation, objects overlap each other

Hey there,

I'm posting my code here because I've got to dead end and after rewriting my code twice, I think I'm missing something, so I came for help.

Basically, you call a method which generates the amount of objects (viruses) at the start of the game, but somehow when I want to position them not to overlap each other, the calculation doesn't work.

You call this method like this: GL.InstantiateVirus(int quantity, string Virus) I call this method 3 times with 3 different viruses but it doesn't seem to work. Could someone take a look at it what's wrong with my calculation?

Thank you in advance!

 public class GenerateLevel : MonoBehaviour {
     public List<StartVirus> VirusList;
     public List<StartVirus> VirusListAll;
     // Use this for initialization
     void Start () {
         VirusList = new List<StartVirus> ();
         VirusListAll = new List<StartVirus> ();
     }
     
     // Update is called once per frame
     void Update () {
         
     }
 
     public void InstantiateVirus(int quantity, string virus) {
         //Store the positions as Vector3 as ranges where X = width, Y = height, Z = Distance from camera
         //from 0-1. 0 is bottom left of camera, 1 is top right of the camera.
         VirusList.Clear();
 
         for (int i = 0; i < quantity; i++) {
             StartVirus _virus = new StartVirus();
 
             _virus.Pos = new Vector3(Random.Range(1f,100f) / 100f, Random.Range(1f,100f) / 100f, Globals.cameraHeight);
             _virus.Virus = Resources.Load ("Virus " + virus.ToString ()) as GameObject;
             _virus.Bounds = _virus.Virus.GetComponent<BoxCollider>().size / 100f;
             Debug.Log(_virus.Bounds);
 
             //Check if there's no previous position which _virus wants to take
             bool positionGood = false;
 
             while (!positionGood) {
                 for (int j = 0; j < VirusListAll.Count; j++) {
                     StartVirus _checkVirus = VirusListAll[j];
 
                     if (_checkVirus.Pos.x - _checkVirus.Bounds.x > _virus.Pos.x + _virus.Bounds.x &&
                         _checkVirus.Pos.x + _checkVirus.Bounds.x < _virus.Pos.x - _virus.Bounds.x &&
                         _checkVirus.Pos.z - _checkVirus.Bounds.z > _virus.Pos.z + _virus.Bounds.z &&
                         _checkVirus.Pos.z + _checkVirus.Bounds.z < _virus.Pos.z - _virus.Bounds.z) {
                         continue;
                     } else {
                         _virus.Pos = new Vector3(Random.Range(1f,100f) / 100f, Random.Range(1f,100f) / 100f, Globals.cameraHeight);
                         Debug.Log("Generated New Position");
                         break;
                     }
                 }
                 positionGood = true;
             }
             Debug.Log(_virus.Virus);
             VirusList.Add (_virus);
             VirusListAll.Add(_virus);
         }
 
         for (int i = 0; i < quantity; i++) {
             GameObject _go = Instantiate (VirusList[i].Virus, Camera.main.ViewportToWorldPoint (VirusList [i].Pos), Quaternion.identity) as GameObject;
             _go.name = virus.ToString ();
         }
     }
 
     [System.Serializable]
     public class StartVirus {
         [SerializeField]
         private Vector3 pos;
         public Vector3 Pos { get { return pos; } set { this.pos = value; } }
         [SerializeField]
         private Vector3 bounds;
         public Vector3 Bounds { get { return bounds; } set { this.bounds = value; } }
         [SerializeField]
         private GameObject virus;
         public GameObject Virus { get { return virus; } set { this.virus = value; } }
 
     }
 }

Comment
Add comment · Show 3
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users
avatar image ShadyProductions · Jan 05, 2018 at 10:40 PM 0
Share

Ins$$anonymous$$d of checking bounds, just add all random positions to a list, and when you generate another random position check the list if it exists already?

avatar image $$anonymous$$ ShadyProductions · Jan 05, 2018 at 10:54 PM 0
Share

If I would just do that there would be a possibility of overlapping, since you don't check whether that position already exists or not.

avatar image ShadyProductions $$anonymous$$ · Jan 05, 2018 at 11:11 PM 0
Share

Wouldn't this work? (make sure to change thee x, y ,z randoms as u want):

     private List<Vector3> positions = new List<Vector3>();
     private Vector3 GetUniqueRandomPosition(float $$anonymous$$Range, float maxRange)
     {
         var random = new Vector3(UnityEngine.Random.Range($$anonymous$$Range, maxRange), UnityEngine.Random.Range($$anonymous$$Range, maxRange), UnityEngine.Random.Range($$anonymous$$Range, maxRange));
         while (positions.Contains(random))
         {
             random = new Vector3(UnityEngine.Random.Range($$anonymous$$Range, maxRange), UnityEngine.Random.Range($$anonymous$$Range, maxRange), UnityEngine.Random.Range($$anonymous$$Range, maxRange));
         }
         positions.Add(random);
         return random;
     }

1 Reply

· Add your reply
  • Sort: 
avatar image
1
Best Answer

Answer by Lysander · Jan 05, 2018 at 11:20 PM

Make a single-element array for collision data, then use OverlapBoxNonAlloc or OverlapSphereNonAlloc, which is not only tremendously efficient for exactly this kind of situation, but would avoid pretty much all of the effort you're expending here and trim it down to a single function call. If you use the layermask to ONLY return colliders that are of a certain layer (put viruses on one layer), then returning a single collider result means generate a new random position and try again.

Comment
Add comment · Share
10 |3000 characters needed characters left characters exceeded
▼
  • Viewable by all users
  • Viewable by moderators
  • Viewable by moderators and the original poster
  • Advanced visibility
Viewable by all users

Your answer

Hint: You can notify a user about this post by typing @username

Up to 2 attachments (including images) can be used with a maximum of 524.3 kB each and 1.0 MB total.

Follow this Question

Answers Answers and Comments

430 People are following this question.

avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image avatar image

Related Questions

Bounds vs BoxCollider producing different sizes when provided same values? 2 Answers

How Does OnTriggerEnter() Work? 0 Answers

Multiple Cars not working 1 Answer

Distribute terrain in zones 3 Answers

when changing size of gameobject bounds do not change 1 Answer


Enterprise
Social Q&A

Social
Subscribe on YouTube social-youtube Follow on LinkedIn social-linkedin Follow on Twitter social-twitter Follow on Facebook social-facebook Follow on Instagram social-instagram

Footer

  • Purchase
    • Products
    • Subscription
    • Asset Store
    • Unity Gear
    • Resellers
  • Education
    • Students
    • Educators
    • Certification
    • Learn
    • Center of Excellence
  • Download
    • Unity
    • Beta Program
  • Unity Labs
    • Labs
    • Publications
  • Resources
    • Learn platform
    • Community
    • Documentation
    • Unity QA
    • FAQ
    • Services Status
    • Connect
  • About Unity
    • About Us
    • Blog
    • Events
    • Careers
    • Contact
    • Press
    • Partners
    • Affiliates
    • Security
Copyright © 2020 Unity Technologies
  • Legal
  • Privacy Policy
  • Cookies
  • Do Not Sell My Personal Information
  • Cookies Settings
"Unity", Unity logos, and other Unity trademarks are trademarks or registered trademarks of Unity Technologies or its affiliates in the U.S. and elsewhere (more info here). Other names or brands are trademarks of their respective owners.
  • Anonymous
  • Sign in
  • Create
  • Ask a question
  • Spaces
  • Default
  • Help Room
  • META
  • Moderators
  • Explore
  • Topics
  • Questions
  • Users
  • Badges