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


C# OctreeNode.Split方法代码示例

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


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

示例1: Test

        void Test(OctreeNode<Voxel> node, IEnumerable<Triangle> triangles)
        {
            if (node.Level > maxLevel) return;

            var result = triangles.Where(t => t.Intersects(node.AABB)).ToList();
            if (result.Any())
            {
                if (node.Level == maxLevel)
                {
                    node.Fill();
                }
                else
                {

                    if (node.Children == null)
                    {
                        node.Split();
                    }
                    Parallel.ForEach(node.Children, child => Test(child, result));
                }

            }
        }
开发者ID:veggielane,项目名称:OctreeTest,代码行数:23,代码来源:Window.cs

示例2: Test2

        void Test2(OctreeNode<Voxel> node, Func<OctreeNode<Voxel>, bool> func)
        {
            if (node.Level > maxLevel) return;

            if (func(node))
            {
                if (node.Level == maxLevel)
                {
                    node.Fill();
                }
                else
                {

                    if (node.Children == null)
                    {
                        node.Split();
                    }
                    Parallel.ForEach(node.Children, child => Test2(child, func));
                }
            }

            //else
            //{
            //    var result = triangles.Where(t => func(node)).ToList();
            //    if (result.Any())
            //    {
            //        if (node.Children == null)
            //        {
            //            node.Split();
            //        }
            //        Parallel.ForEach(node.Children, child => Test2(child, result, func));
            //    }
            //}
        }
开发者ID:veggielane,项目名称:OctreeTest,代码行数:34,代码来源:Window.cs

示例3: Intersect

 void Intersect(OctreeNode<Voxel> node, Triangle tri)
 {
     if(node.Level > maxLevel) return;
     if (tri.Intersects(node.AABB))
     {
         if (node.Level == maxLevel)
         {
             node.Fill();
         }
         else
         {
             if (node.Children == null)
             {
                 node.Split();
             }
             foreach (var child in node.Children)
             {
                 Intersect(child,tri);
             }
         }
     }
 }
开发者ID:veggielane,项目名称:OctreeTest,代码行数:22,代码来源:Window.cs


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