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


C# QuadTree.GenerateZones方法代码示例

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


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

示例1: GenerateZones

    // Procedurally generate QuadTrees
    // Make a maximum of "max_depth" levels of depth
    public void GenerateZones(int depth, int max_depth)
    {
        Debug.Log("Generate Zones, depth = " + depth + ", max = " + max_depth + " " + boundary.ToString());
        // Reached max depth
        if (depth > max_depth) return;

        // If there's no place for 4 rooms, exit
        if (boundary.half.x * 2.0f < DungeonGenerator.ROOM_MIN_SIZE*2) return;
        if (boundary.half.y * 2.0f < DungeonGenerator.ROOM_MIN_SIZE*2) return;

        // Try to make a slice capable of generating 4 more rooms
        // If we can't manage to make it in "10" tries, exit
        XY slice = new XY();
        bool new_slice = RandomSlice(1,10,ref slice);
        if (new_slice == false) return;

        // Place QuadTree children
        AABB aabb1 = new AABB();
        XY size = new XY(slice.x - boundary.Left (), boundary.Top() - slice.y);
        aabb1.center = new XY(slice.x - size.x/2.0f, slice.y + size.y/2.0f);
        aabb1.half = new XY(size.x/2.0f,size.y/2.0f);
        if (aabb1.half.x*2.0f >= DungeonGenerator.ROOM_MIN_SIZE && aabb1.half.y*2.0f >= DungeonGenerator.ROOM_MIN_SIZE)
        {
            Debug.Log("Creating north west quadtree");
            northWest = new QuadTree(aabb1);
            northWest.GenerateZones(depth+1,max_depth);
        }

        AABB aabb2 = new AABB();
        size = new XY(boundary.Right() - slice.x, boundary.Top() - slice.y);
        aabb2.center = new XY(slice.x + size.x/2.0f, slice.y + size.y/2.0f);
        aabb2.half = new XY(size.x/2.0f,size.y/2.0f);
        if (aabb2.half.x*2.0f >= DungeonGenerator.ROOM_MIN_SIZE && aabb2.half.y*2.0f >= DungeonGenerator.ROOM_MIN_SIZE)
        {
            Debug.Log("Creating north east quadtree");
            northEast = new QuadTree(aabb2);
            northEast.GenerateZones(depth+1,max_depth);
        }

        AABB aabb3 = new AABB();
        size = new XY(slice.x - boundary.Left (), slice.y - boundary.Bottom());
        aabb3.center = new XY(slice.x - size.x/2.0f, slice.y - size.y/2.0f);
        aabb3.half = new XY(size.x/2.0f,size.y/2.0f);
        if (aabb3.half.x*2 >= DungeonGenerator.ROOM_MIN_SIZE && aabb3.half.y*2 >= DungeonGenerator.ROOM_MIN_SIZE)
        {
            Debug.Log("Creating south west quadtree");
            southWest = new QuadTree(aabb3);
            southWest.GenerateZones(depth+1,max_depth);
        }

        AABB aabb4 = new AABB();
        size = new XY(boundary.Right() - slice.x, slice.y - boundary.Bottom());
        aabb4.center = new XY(slice.x + size.x/2.0f, slice.y - size.y/2.0f);
        aabb4.half = new XY(size.x/2.0f,size.y/2.0f);
        if (aabb4.half.x*2 >= DungeonGenerator.ROOM_MIN_SIZE && aabb4.half.y*2 >= DungeonGenerator.ROOM_MIN_SIZE)
        {
            Debug.Log("Creating south east quadtree");
            southEast = new QuadTree(aabb4);
            southEast.GenerateZones(depth+1,max_depth);
        }
    }
开发者ID:gtco,项目名称:FutileBase,代码行数:63,代码来源:QuadTree.cs

示例2: GenerateZones

    // Procedurally generate QuadTrees
    // Make a maximum of "max_depth" levels of depth
    public void GenerateZones(int depth, int max_depth)
    {
        // Reached max depth
        if (depth > max_depth) return;

        // No place for 4 rooms? return
        if (boundary.half.x < roomRealMinSize) return;
        if (boundary.half.y < roomRealMinSize) return;

        // Random possibilty of not generating zone
        int r = Random.Range(0,100);
        if (r < dungeon.CHANCE_STOP && depth > 1) return;

        // Try to make a slice with space for 4 rooms
        // Retry "N=SLICE_TRIES" times
        XY slice = new XY();
        bool new_slice = RandomSlice(1,dungeon.SLICE_TRIES,ref slice);
        if (new_slice == false) return;

        // Generate children QuadTrees
        // NORTHWEST
        AABB aabb1 = new AABB();
        XY size = new XY(slice.x - boundary.Left (), boundary.Top() - slice.y);
        aabb1.center = new XY(slice.x - size.x/2.0f, slice.y + size.y/2.0f);
        aabb1.half = new XY(size.x/2.0f,size.y/2.0f);
        northWest = new QuadTree(aabb1);
        northWest.parent = this;
        northWest.GenerateZones(depth+1,max_depth);
        // NORTHEAST
        AABB aabb2 = new AABB();
        size = new XY(boundary.Right() - slice.x, boundary.Top() - slice.y);
        aabb2.center = new XY(slice.x + size.x/2.0f, slice.y + size.y/2.0f);
        aabb2.half = new XY(size.x/2.0f,size.y/2.0f);
        northEast = new QuadTree(aabb2);
        northEast.parent = this;
        northEast.GenerateZones(depth+1,max_depth);
        // SOUTHWEST
        AABB aabb3 = new AABB();
        size = new XY(slice.x - boundary.Left (), slice.y - boundary.Bottom());
        aabb3.center = new XY(slice.x - size.x/2.0f, slice.y - size.y/2.0f);
        aabb3.half = new XY(size.x/2.0f,size.y/2.0f);
        southWest = new QuadTree(aabb3);
        southWest.parent = this;
        southWest.GenerateZones(depth+1,max_depth);
        // SOUTEAST
        AABB aabb4 = new AABB();
        size = new XY(boundary.Right() - slice.x, slice.y - boundary.Bottom());
        aabb4.center = new XY(slice.x + size.x/2.0f, slice.y - size.y/2.0f);
        aabb4.half = new XY(size.x/2.0f,size.y/2.0f);
        southEast = new QuadTree(aabb4);
        southEast.parent = this;
        southEast.GenerateZones(depth+1,max_depth);
    }
开发者ID:JordanAupetit,项目名称:ProjectDungeon,代码行数:55,代码来源:QuadTree.cs


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