当前位置: 首页>>代码示例>>C#>>正文


C# QuadTree.Insert方法代码示例

本文整理汇总了C#中QuadTree.Insert方法的典型用法代码示例。如果您正苦于以下问题:C# QuadTree.Insert方法的具体用法?C# QuadTree.Insert怎么用?C# QuadTree.Insert使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在QuadTree的用法示例。


在下文中一共展示了QuadTree.Insert方法的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: Search_AreaWithOnePoint_ReturnsOnePoint

        public void Search_AreaWithOnePoint_ReturnsOnePoint()
        {
            var center = new Point(0, 0);
            var boundary = new Boundary(center, 1, 1);
            var quad = new QuadTree<Point>(boundary);

            // insert one point in the second quadrant
            var point = new Point(-0.75, +0.75);
            quad.Insert(point);

            // then insert one point in each remaining quadrant
            var points = new List<Point>
            {
                new Point(+0.75, +0.75), // first quadrant
                new Point(-0.75, -0.75), // third quadrant
                new Point(+0.75, -0.75) // fourth quadrant
            };

            points.ForEach(p => quad.Insert(p));

            // search second quadrant
            var searchArea = new Boundary(new Point(-0.5, 0.5), 0.5, 0.5);

            var results = quad.Search(searchArea);

            Assert.IsTrue(results.Count == 1);
            Assert.IsTrue(results.Contains(point));
        }
开发者ID:clapis,项目名称:roamler,代码行数:28,代码来源:PointQuadTreeTests.cs

示例2: Insert_WithinBoundary_ReturnsTrue

        public void Insert_WithinBoundary_ReturnsTrue()
        {
            var center = new Point(0, 0);
            var boundary = new Boundary(center, 1, 1);
            var quad = new QuadTree<Point>(boundary);

            Assert.IsTrue(quad.Insert(new Point(0, 0)));
            Assert.IsTrue(quad.Insert(new Point(-0.5, 0.5)));
        }
开发者ID:clapis,项目名称:roamler,代码行数:9,代码来源:PointQuadTreeTests.cs

示例3: Insert_OutOfBoundary_ReturnsFalse

        public void Insert_OutOfBoundary_ReturnsFalse()
        {
            var center = new Point(0, 0);
            var boundary = new Boundary(center, 1, 1);
            var quad = new QuadTree<Point>(boundary);

            Assert.IsFalse(quad.Insert(new Point(2, 0)));
            Assert.IsFalse(quad.Insert(new Point(0, 2)));
        }
开发者ID:clapis,项目名称:roamler,代码行数:9,代码来源:PointQuadTreeTests.cs

示例4: Test1000ItemsWithQuery

        public void Test1000ItemsWithQuery()
        {
            Random rand = new Random ();
            var bounds = new RectangleF (0f,0f,100f,100f);
            QuadTree<RectangleF> tree = new QuadTree<RectangleF>(bounds) {
                GetRect = r => r
            };

            //add 10 items, assert no subnodes.
            for (int i = 0; i < 1000; i++)
            {
                var rect = new RectangleF ( rand.Next (0, 80), rand.Next (0, 80), rand.Next (1, 10), rand.Next (1, 10));
                tree.Insert (rect);
            }

            //insert a rect at 25, 25, 5, 5, and query for it.

            var searchRect = new RectangleF (25f, 25f, 5f, 5f);
            tree.Insert (searchRect);

            //now try and find it.

            bool found = false;
            int count = 0;
            foreach (var rect in tree.Query (new RectangleF (20f, 20f, 10f, 10f)))
            {
                count++;
                Console.WriteLine (rect);
                if (rect == searchRect)
                {
                    found = true;
                    break;
                }
            }

            Console.WriteLine ("count: " + count);

            Assert.That (found, Is.True);
        }
开发者ID:bennidhamma,项目名称:SimpleQuadTree,代码行数:39,代码来源:Tests.cs

示例5: TestSubdivision

        public void TestSubdivision()
        {
            Random rand = new Random ();
            var bounds = new RectangleF (0f,0f,100f,100f);
            QuadTree<RectangleF> tree = new QuadTree<RectangleF>(bounds) {
                GetRect = r => r
            };

            //add 10 items, assert no subnodes.
            for (int i = 0; i < 10; i++)
            {
                var rect = new RectangleF ( rand.Next (0, 80), rand.Next (0, 80), rand.Next (1, 10), rand.Next (1, 10));
                tree.Insert (rect);
            }

            Assert.That (tree.Nodes.Count (), Is.EqualTo (1));

            //add 11th item, assert there are subnodes.

            var lastRect = new RectangleF (rand.Next (0, 80), rand.Next (0, 80), rand.Next (1, 10), rand.Next (1, 10));
            tree.Insert (lastRect);

            Assert.That (tree.Nodes.Count (), Is.EqualTo (5));
        }
开发者ID:bennidhamma,项目名称:SimpleQuadTree,代码行数:24,代码来源:Tests.cs

示例6: BuildIndex

        public ISpatialIndex BuildIndex(IQueryable<ISpatialDocument> documents)
        {
            if (!documents.Any()) return new EmptySpatialIndex();

            var mercator = new Boundary(new Point(0, 0), 180, 90);
            var quadTree = new QuadTree<SpatialDocument>(mercator);

            foreach (var doc in documents)
            {
                quadTree.Insert(new SpatialDocument(doc));
            }

            var index = new SpatialIndex(quadTree);

            return index;
        }
开发者ID:clapis,项目名称:roamler,代码行数:16,代码来源:SpatialIndexBuilder.cs

示例7: initializeWorld

    // For now, just generates rectangular buildings
    // width/height in ... pixels?
    private void initializeWorld(float mapWidth, float mapHeight, int numBuildings)
    {
        worldWidth = mapWidth;
        worldHeight = mapHeight;

        agentTree = new QuadTree<Agent>(agentTreeSplit, agentDepthLimit, 0, 0, worldWidth, worldHeight);
        buildingTree = new QuadTree<Rect>(buildingTreeSplit, buildingDepthLimit, 0, 0, worldWidth, worldHeight);

        // Probably get something closer to a city by carving streets out
        //   rather than trying to fill with boxes.
        float streetWidth = Mathf.Max(minimumStreetWidth, Mathf.Floor(worldWidth * 0.01f));

        // But for current testing, just making some random rectangles.
        for(int i=0; i<numBuildings; i++)
        {
            float xDim = Random.Range(3.0f*streetWidth, 10.0f*streetWidth);
            float yDim = Random.Range(3.0f*streetWidth, 10.0f*streetWidth);

            float xPos = Random.Range(0.0f, worldWidth-xDim);
            float yPos = Random.Range(0.0f, worldHeight-yDim);

            // For now just letting these be redundant
            Quad tempQuad = new Quad(xPos, yPos, xPos+xDim, yPos+yDim);
            Rect tempRect = new Rect(xPos, yPos, xDim, 		yDim);

            buildingTree.Insert(tempRect, ref tempQuad);
            structures.Add(tempRect);
        }
    }
开发者ID:futurechris,项目名称:zombai,代码行数:31,代码来源:WorldMap.cs

示例8: InitQuadTree

 /// <summary>
 /// Направи нов QuadTree и пополни го со сите објекти кои моментално постојат во играта.
 /// Се повикува при секој повик на OnUpdate
 /// </summary>
 /// <param name="gameObjects"></param>
 private void InitQuadTree(IList<IGameObject> gameObjects)
 {
     quadtree = new QuadTree<IGameObject>(new RectangleF(0, 0, (float)Game.VirtualGameWidth + 0.1f,
         (float)Game.VirtualGameHeight + 0.1f));
     foreach (IGameObject obj in gameObjects)
         quadtree.Insert(obj);
 }
开发者ID:TanjaStojanovska,项目名称:VP_Arkanoid_Game,代码行数:12,代码来源:ArkanoidGamePlayState.cs

示例9: Search_Area_ReturnsAreaPoints

        public void Search_Area_ReturnsAreaPoints()
        {
            var center = new Point(0, 0);
            var boundary = new Boundary(center, 1, 1);
            var quad = new QuadTree<Point>(boundary);

            var firstQuadrant = new Boundary(new Point(+0.5, +0.5), 0.5, 0.5);
            var secondQuadrant = new Boundary(new Point(-0.5, +0.5), 0.5, 0.5);
            var thirdQuadrant = new Boundary(new Point(-0.5, -0.5), 0.5, 0.5);
            var fourthQuadrant = new Boundary(new Point(+0.5, -0.5), 0.5, 0.5);

            var pointsPerQuadrant = 10;
            var generator = new RandomGenerator();

            // insert points in the third quadrant
            var pointsInThirdQuadrant = generator.GeneratePointsWithin(thirdQuadrant, pointsPerQuadrant);
            pointsInThirdQuadrant.ForEach(p => quad.Insert(p));

            // insert points in other quadrants
            var pointsInOtherQuadrants = new List<Point>();
            pointsInOtherQuadrants.AddRange(generator.GeneratePointsWithin(firstQuadrant, pointsPerQuadrant));
            pointsInOtherQuadrants.AddRange(generator.GeneratePointsWithin(secondQuadrant, pointsPerQuadrant));
            pointsInOtherQuadrants.AddRange(generator.GeneratePointsWithin(fourthQuadrant, pointsPerQuadrant));
            pointsInOtherQuadrants.ForEach(p => quad.Insert(p));

            // search third quadrant
            var results = quad.Search(thirdQuadrant);

            // assert all result points are in third quadrant
            Assert.IsTrue(results.Count == pointsPerQuadrant);
            results.ForEach(p => Assert.IsTrue(thirdQuadrant.Contains(p)));
        }
开发者ID:clapis,项目名称:roamler,代码行数:32,代码来源:PointQuadTreeTests.cs

示例10: TestIncreaseCapacityDuringInsertion

    public void TestIncreaseCapacityDuringInsertion() {
      QuadTree<TestItem> quadTree = new QuadTree<TestItem>(
        new BoundingRectangle(-100.0f, -100.0f, 100.0f, 100.0f)
      );
      quadTree.MaxItemsPerNode = 2;

      TestItem[] items = new TestItem[] {
        new TestItem(new BoundingRectangle(-10.0f, -10.0f, 10.0f, 10.0f)),
        new TestItem(new BoundingRectangle(-20.0f, -20.0f, 20.0f, 20.0f)),
        new TestItem(new BoundingRectangle(-30.0f, -30.0f, 30.0f, 30.0f)),
        new TestItem(new BoundingRectangle(-40.0f, -40.0f, 40.0f, 40.0f))
      };
      foreach(TestItem item in items) {
        quadTree.Insert(item);
      }
    }
开发者ID:pr0gramm3r1,项目名称:AngryTanks,代码行数:16,代码来源:QuadTree.Test.cs

示例11: CreateEnvironment

        private void CreateEnvironment()
        {
            treeCollision = new QuadTree<Tree>(new RectangleF(new Vector2(0, 0), new Vector2(512 * scaleHorizontal, 512 * scaleHorizontal)));
            for (int i = 0; i < treeAmount; i++)
            {
                var x = G.r.Next((int)(512 * scaleHorizontal));
                var z = G.r.Next((int)(512 * scaleHorizontal));
                var height = CheckHeightCollision(new Vector3(x, 0, z));
                while (height > treemaxy || height < treeminy)
                {
                    x = G.r.Next((int)(512 * scaleHorizontal));
                    z = G.r.Next((int)(512 * scaleHorizontal));
                    height = CheckHeightCollision(new Vector3(x, 0, z));
                }
                var tree = new Tree(this, new Vector3(x, height - 8, z));
                treeCollision.Insert(tree);
                plantsandshit.Add(tree);
            }

            for (int i = 0; i < flowerAmount; i++)
            {
                var x = G.r.Next((int)(512 * scaleHorizontal));
                var z = G.r.Next((int)(512 * scaleHorizontal));
                var height = CheckHeightCollision(new Vector3(x, 0, z));
                while (height > flowermaxy || height < flowerminy)
                {
                    x = G.r.Next((int)(512 * scaleHorizontal));
                    z = G.r.Next((int)(512 * scaleHorizontal));
                    height = CheckHeightCollision(new Vector3(x, 0, z));
                }
                var flower = new Flower(this, new Vector3(x, height, z));
                plantsandshit.Add(flower);
            }

            player = new Player(this, new Vector2(3, 8), new Vector3(512, 0, 512));
            entities.Add(player);

            for (int i = 0; i < birdCount; i++)
            {
                var x = G.r.Next((int)(512 * scaleHorizontal));
                var z = G.r.Next((int)(512 * scaleHorizontal));
                var bird = G.g.bf.CreateBird(this, new Vector3(x, 32, z));
                entities.Add(bird);
            }
        }
开发者ID:Frib,项目名称:LD24,代码行数:45,代码来源:Island.cs

示例12: Search_PointAtBoundaryCenter_IsReturnedOnlyOnce

        public void Search_PointAtBoundaryCenter_IsReturnedOnlyOnce()
        {
            var center = new Point(0, 0);
            var boundary = new Boundary(center, 1, 1);
            var quad = new QuadTree<Point>(boundary);

            // insert a point in each  quadrant
            var points = new List<Point>
            {
                new Point(+0.75, +0.75),
                new Point(-0.75, +0.75),
                new Point(-0.75, -0.75),
                new Point(+0.75, -0.75)
            };

            points.ForEach(p => quad.Insert(p));

            // insert an additional point at the center
            var point = new Point(0, 0);
            quad.Insert(point);

            // search center
            var searchArea = new Boundary(center, 0.5, 0.5);
            var results = quad.Search(searchArea);

            Assert.IsTrue(results.Count == 1);
            Assert.IsTrue(results.Contains(point));
        }
开发者ID:clapis,项目名称:roamler,代码行数:28,代码来源:PointQuadTreeTests.cs

示例13: Search_PartialBoundary_ReturnResults

        public void Search_PartialBoundary_ReturnResults()
        {
            var center = new Point(0, 0);
            var boundary = new Boundary(center, 1, 1);
            var quad = new QuadTree<Point>(boundary);

            var point = new Point(0.75, 0.75);
            var searchArea = new Boundary(new Point(1, 1), 1, 1);

            Assert.IsTrue(boundary.Contains(point));
            Assert.IsTrue(searchArea.Contains(point));

            quad.Insert(point);

            var results = quad.Search(searchArea);

            Assert.IsTrue(results.Count == 1);
            Assert.IsTrue(results.Contains(point));
        }
开发者ID:clapis,项目名称:roamler,代码行数:19,代码来源:PointQuadTreeTests.cs

示例14: TestInsertSplitting

    public void TestInsertSplitting() {
      QuadTree<TestItem> quadTree = new QuadTree<TestItem>(
        new BoundingRectangle(-100.0f, -100.0f, 100.0f, 100.0f)
      );
      quadTree.MaxItemsPerNode = 6;

      TestItem[] items = new TestItem[] {
        // Unsplittable node to test FirstSplittableItemIndex
        new TestItem(new BoundingRectangle(-10.0f, -10.0f, 10.0f, 10.0f)),
        // Four corners
        new TestItem(new BoundingRectangle(-90.0f, -90.0f, -10.0f, -10.0f)),
        new TestItem(new BoundingRectangle(10.0f, -90.0f, 90.0f, -10.0f)),
        new TestItem(new BoundingRectangle(-90.0f, 10.0f, -10.0f, 90.0f)),
        new TestItem(new BoundingRectangle(10.0f, 10.0f, 90.0f, 90.0f)),
        // Unsplittable node to test split skipping
        new TestItem(new BoundingRectangle(-15.0f, -15.0f, 15.0f, 15.0f)),
        // Causes the node to split
        new TestItem(new BoundingRectangle(-90.0f, -90.0f, 90.0f, 90.0f)),
        // To test insertion into child nodes
        new TestItem(new BoundingRectangle(-5.0f, -5.0f, 5.0f, 5.0f)),
        new TestItem(new BoundingRectangle(-90.0f, -90.0f, -85.0f, -85.0f)),
        new TestItem(new BoundingRectangle(85.0f, -90.0f, 90.0f, -85.0f)),
        new TestItem(new BoundingRectangle(-90.0f, 85.0f, -85.0f, 90.0f)),
        new TestItem(new BoundingRectangle(85.0f, 85.0f, 90.0f, 90.0f))
      };
      foreach(TestItem item in items) {
        quadTree.Insert(item);
      }

      // Remember the current bounding rectangle lookups for the items which
      // should be situated in other quad-tree nodes by now
      int lookupCount2 = items[2].BoundRectangleLookups;
      int lookupCount3 = items[3].BoundRectangleLookups;
      int lookupCount4 = items[4].BoundRectangleLookups;

      // Perform the query
      List<TestItem> result = new List<TestItem>();
      quadTree.Query(new BoundingRectangle(-80.0f, -80.0f, -20.0f, -20.0f), result);

      // Make sure that the quad-tree didn't check the items that should have
      // been placed into other nodes
      Assert.AreEqual(lookupCount2, items[2].BoundRectangleLookups);
      Assert.AreEqual(lookupCount3, items[3].BoundRectangleLookups);
      Assert.AreEqual(lookupCount4, items[4].BoundRectangleLookups);

      // Make sure the query results are correct
      Assert.AreEqual(2, result.Count);
      Assert.Contains(items[1], result);
      Assert.Contains(items[6], result);
    }
开发者ID:pr0gramm3r1,项目名称:AngryTanks,代码行数:50,代码来源:QuadTree.Test.cs

示例15: TestIncreaseCapacityDuringSplit

    public void TestIncreaseCapacityDuringSplit() {
      QuadTree<TestItem> quadTree = new QuadTree<TestItem>(
        new BoundingRectangle(-100.0f, -100.0f, 100.0f, 100.0f)
      );
      quadTree.MaxItemsPerNode = 5;

      TestItem[] items = new TestItem[] {
        new TestItem(new BoundingRectangle(-60.0f, -60.0f, -40.0f, -40.0f)),
        new TestItem(new BoundingRectangle(-70.0f, -70.0f, -30.0f, -30.0f)),
        new TestItem(new BoundingRectangle(-80.0f, -80.0f, -20.0f, -20.0f)),
        new TestItem(new BoundingRectangle(-90.0f, -90.0f, -10.0f, -10.0f)),

        new TestItem(new BoundingRectangle(-160.0f, -160.0f, -140.0f, -140.0f)),
        new TestItem(new BoundingRectangle(-170.0f, -170.0f, -130.0f, -130.0f)),
        new TestItem(new BoundingRectangle(-180.0f, -180.0f, -120.0f, -120.0f)),
        new TestItem(new BoundingRectangle(-190.0f, -190.0f, -110.0f, -110.0f))
      };
      foreach(TestItem item in items) {
        quadTree.Insert(item);
      }
    }
开发者ID:pr0gramm3r1,项目名称:AngryTanks,代码行数:21,代码来源:QuadTree.Test.cs


注:本文中的QuadTree.Insert方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。