當前位置: 首頁>>代碼示例>>C#>>正文


C# Bounds.Encapsulate方法代碼示例

本文整理匯總了C#中UnityEngine.Bounds.Encapsulate方法的典型用法代碼示例。如果您正苦於以下問題:C# Bounds.Encapsulate方法的具體用法?C# Bounds.Encapsulate怎麽用?C# Bounds.Encapsulate使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在UnityEngine.Bounds的用法示例。


在下文中一共展示了Bounds.Encapsulate方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: GetBoundWithChildren

        /// <summary>
        /// Gets the rendering bounds of the transform.
        /// </summary>
        /// <param name="transform">The game object to get the bounding box for.</param>
        /// <param name="pBound">The bounding box reference that will </param>
        /// <param name="encapsulate">Used to determine if the first bounding box to be 
        /// calculated should be encapsulated into the <see cref="pBound"/> argument.</param>
        /// <returns>Returns true if at least one bounding box was calculated.</returns>
        public static bool GetBoundWithChildren(Transform transform, ref Bounds pBound, ref bool encapsulate)
        {
            var didOne = false;

            // get 'this' bound
            if (transform.gameObject.renderer != null)
            {
                var bound = transform.gameObject.renderer.bounds;
                if (encapsulate)
                {
                    pBound.Encapsulate(bound.min);
                    pBound.Encapsulate(bound.max);
                }
                else
                {
                    pBound.min = bound.min; 
                    pBound.max = bound.max; 
                    encapsulate = true;
                }

                didOne = true;
            }

            // union with bound(s) of any/all children
            foreach (Transform child in transform)
            {
                if (GetBoundWithChildren(child, ref pBound, ref encapsulate))
                {
                    didOne = true;
                }
            }

            return didOne;
        }
開發者ID:Skybladev2,項目名稱:TacticalRPG,代碼行數:42,代碼來源:Helpers.cs

示例2: DrawSkeleton

 public static void DrawSkeleton(Transform reference, Dictionary<Transform, bool> actualBones, AvatarSetupTool.BoneWrapper[] bones)
 {
   if ((Object) reference == (Object) null || actualBones == null)
     return;
   AvatarSkeletonDrawer.sPoseError = false;
   Bounds bounds = new Bounds();
   Renderer[] componentsInChildren = reference.root.GetComponentsInChildren<Renderer>();
   if (componentsInChildren != null)
   {
     foreach (Renderer renderer in componentsInChildren)
     {
       bounds.Encapsulate(renderer.bounds.min);
       bounds.Encapsulate(renderer.bounds.max);
     }
   }
   Quaternion orientation = Quaternion.identity;
   if (bones != null)
     orientation = AvatarSetupTool.AvatarComputeOrientation(bones);
   AvatarSkeletonDrawer.DrawSkeletonSubTree(actualBones, bones, orientation, reference, bounds);
   Camera current = Camera.current;
   if (!AvatarSkeletonDrawer.sPoseError || !((Object) current != (Object) null))
     return;
   GUIStyle style = new GUIStyle(GUI.skin.label);
   style.normal.textColor = Color.red;
   style.wordWrap = false;
   style.alignment = TextAnchor.MiddleLeft;
   style.fontSize = 20;
   GUIContent content = new GUIContent("Character is not in T pose");
   Rect rect = GUILayoutUtility.GetRect(content, style);
   rect.x = 30f;
   rect.y = 30f;
   Handles.BeginGUI();
   GUI.Label(rect, content, style);
   Handles.EndGUI();
 }
開發者ID:BlakeTriana,項目名稱:unity-decompiled,代碼行數:35,代碼來源:AvatarSkeletonDrawer.cs

示例3: AddBreastColliders

 private void AddBreastColliders()
 {
     if ((this.middleSpine != null) && (this.pelvis != null))
     {
         Bounds bounds = this.Clip(this.GetBreastBounds(this.pelvis), this.pelvis, this.middleSpine, false);
         BoxCollider collider = this.pelvis.gameObject.AddComponent<BoxCollider>();
         collider.center = bounds.center;
         collider.size = bounds.size;
         bounds = this.Clip(this.GetBreastBounds(this.middleSpine), this.middleSpine, this.middleSpine, true);
         collider = this.middleSpine.gameObject.AddComponent<BoxCollider>();
         collider.center = bounds.center;
         collider.size = bounds.size;
     }
     else
     {
         Bounds bounds2 = new Bounds();
         bounds2.Encapsulate(this.pelvis.InverseTransformPoint(this.leftHips.position));
         bounds2.Encapsulate(this.pelvis.InverseTransformPoint(this.rightHips.position));
         bounds2.Encapsulate(this.pelvis.InverseTransformPoint(this.leftArm.position));
         bounds2.Encapsulate(this.pelvis.InverseTransformPoint(this.rightArm.position));
         Vector3 size = bounds2.size;
         size[SmallestComponent(bounds2.size)] = size[LargestComponent(bounds2.size)] / 2f;
         BoxCollider collider2 = this.pelvis.gameObject.AddComponent<BoxCollider>();
         collider2.center = bounds2.center;
         collider2.size = size;
     }
 }
開發者ID:CarlosHBC,項目名稱:UnityDecompiled,代碼行數:27,代碼來源:RagdollBuilder.cs

示例4: GetBoundWithChildren

    static bool GetBoundWithChildren( Transform parent, ref Bounds pBound, ref bool initBound )
    {
        Bounds bound = new Bounds();
        bool didOne = false;

        if( parent.gameObject.renderer != null )
        {
            bound = parent.gameObject.renderer.bounds;
            if( initBound )
            {
                pBound.Encapsulate( bound.min );
                pBound.Encapsulate( bound.max );
            }
            else
            {
                pBound.min = new Vector3( bound.min.x, bound.min.y, bound.min.z );
                pBound.max = new Vector3( bound.max.x, bound.max.y, bound.max.z );
                initBound = true;
            }
            didOne = true;
        }

        foreach( Transform child in parent )
        {
            if( GetBoundWithChildren( child, ref pBound, ref initBound ))
                didOne = true;
        }

        return didOne;
    }
開發者ID:pchernev,項目名稱:Zombayo,代碼行數:30,代碼來源:GetBBox.cs

示例5: GetPartColliderBoundsInBasis

        public static Bounds GetPartColliderBoundsInBasis(this Part part, Matrix4x4 worldToBasisMatrix, int excessiveVerts = 2500)
        {
            Transform[] transforms = part.FindModelComponents<Transform>();
            Bounds bounds = new Bounds();
            for (int i = 0; i < transforms.Length; i++)
            {
                Transform t = transforms[i];

                MeshCollider mc = t.GetComponent<MeshCollider>();
                Mesh m;
                Matrix4x4 matrix = worldToBasisMatrix * t.localToWorldMatrix;

                if (mc == null)
                {
                    BoxCollider bc = t.GetComponent<BoxCollider>();
                    if (bc != null)
                    {
                        bounds.Encapsulate(matrix.MultiplyPoint3x4(bc.bounds.min));
                        bounds.Encapsulate(matrix.MultiplyPoint3x4(bc.bounds.max));
                    }
                    continue;
                }
                else
                    m = mc.sharedMesh;

                if (m == null)
                    continue;

                bounds.Encapsulate(matrix.MultiplyPoint3x4(m.bounds.min));
                bounds.Encapsulate(matrix.MultiplyPoint3x4(m.bounds.max));

            }
            return bounds;
        }
開發者ID:khr15714n,項目名稱:Ferram-Aerospace-Research,代碼行數:34,代碼來源:PartGeometryExtensions.cs

示例6: EditPageBounds

        void EditPageBounds()
        {
            Page t = target as Page;
            Vector3 pos = t.transform.position;

            Vector3[] verts = new Vector3[4];
            verts[0] = new Vector3(pos.x + t.pageBounds.min.x, pos.y + t.pageBounds.min.y, 0);
            verts[1] = new Vector3(pos.x + t.pageBounds.min.x, pos.y + t.pageBounds.max.y, 0);
            verts[2] = new Vector3(pos.x + t.pageBounds.max.x, pos.y + t.pageBounds.max.y, 0);
            verts[3] = new Vector3(pos.x + t.pageBounds.max.x, pos.y + t.pageBounds.min.y, 0);

            Handles.DrawSolidRectangleWithOutline(verts, new Color(1,1,1,0.2f), new Color(0,0,0,1));

            for(int i = 0; i < 4; ++i)
            {
                Vector3 vert = verts[i];
                Vector3 newPos = Handles.FreeMoveHandle(vert,
                                                        Quaternion.identity,
                                                        HandleUtility.GetHandleSize(pos) * 0.1f,
                                                        Vector3.zero,
                                                        Handles.CubeCap);
                newPos.z = 0;
                verts[i] = newPos;

                if (vert != newPos)
                {
                    switch(i)
                    {
                    case 0:
                        verts[1].x = newPos.x;
                        verts[3].y = newPos.y;
                        break;
                    case 1:
                        verts[0].x = newPos.x;
                        verts[2].y = newPos.y;
                        break;
                    case 2:
                        verts[3].x = newPos.x;
                        verts[1].y = newPos.y;
                        break;
                    case 3:
                        verts[2].x = newPos.x;
                        verts[0].y = newPos.y;
                        break;
                    }
                    break;
                }
            }

            Bounds newBounds = new Bounds(verts[0], Vector3.zero);
            newBounds.Encapsulate(verts[1]);
            newBounds.Encapsulate(verts[2]);
            newBounds.Encapsulate(verts[3]);

            t.transform.position = newBounds.center;
            newBounds.center = Vector3.zero;

            t.pageBounds = newBounds;
        }
開發者ID:Toast3y,項目名稱:Trials-Of-The-Dolphin-King,代碼行數:59,代碼來源:PageEditor.cs

示例7: Voxelize

	public void Voxelize (Transform root)
	{
		var meshFilters = root.GetComponentsInChildren<MeshFilter>();
		
		var objectBounds = new List<BoundHierarchy>();
		foreach (var filter in meshFilters)
		{
			var mesh = filter.sharedMesh;
			var vertices = mesh.vertices;
			var tris = mesh.triangles;
			var triangleBounds = new List<BoundHierarchy>();
			for(int i = 0; i < tris.Length; i += 3)
			{
				var vert1 = vertices[tris[i + 0]];
				var vert2 = vertices[tris[i + 1]];
				var vert3 = vertices[tris[i + 2]];
				vert1 = filter.transform.TransformPoint(vert1);
				vert2 = filter.transform.TransformPoint(vert2);
				vert3 = filter.transform.TransformPoint(vert3);
				
				var u = vert2 - vert3;
				var v = vert3 - vert1;
				var triNormal = Vector3.Cross(u, v);
				triNormal = triNormal.normalized;
				
				var triBounds = new Bounds(vert1, Vector3.zero);
				triBounds.Encapsulate(vert2);
				triBounds.Encapsulate(vert3);
				
				var tri = new Triangle {
					vertA = vert1,
					vertB = vert2,
					vertC = vert3,
					normal = triNormal,
					bound = triBounds,
				};
				
				triangleBounds.Add(new BoundHierarchy() { 
					bound = triBounds, 
					subBounds = null, 
					triList = tri 
				});
			}
			
			objectBounds.Add(new BoundHierarchy() { 
				bound = filter.GetComponent<Renderer>().bounds,  
				subBounds = triangleBounds.ToArray() 
			});
		}
		
		var rootNode = new BoundHierarchy() { 
			bound = _bounds, 
			subBounds = objectBounds.ToArray() 
		};
		
		GenerateBlockArray ();
		GenerateVoxelData (rootNode);
	}
開發者ID:ArieLeo,項目名稱:unity-voxelizer,代碼行數:58,代碼來源:Voxeliser.cs

示例8: GetBounds

 public static Bounds GetBounds(this GameObject obj)
 {
     var renderers = obj.GetComponentsInChildren<Renderer>();
     var bounds = new Bounds(renderers.Length > 0 ? renderers.First().bounds.center : obj.transform.position,
         Vector3.zero);
     renderers.ToList().ForEach(r => bounds.Encapsulate(r.bounds));
     obj.GetComponentsInChildren<Collider>().ForEach(
         c =>
             bounds.Encapsulate(new Bounds(obj.transform.TransformPoint(c.bounds.center),
                 obj.transform.TransformPoint(c.bounds.size))));
     return bounds;
 }
開發者ID:fatiguedartist,項目名稱:Sisyphus,代碼行數:12,代碼來源:RDGameObjectExtensions.cs

示例9: GetMapBoundingBox

    // --------------
    private Rect GetMapBoundingBox()
    {
        Matrix4x4	mat = this.GetMapTargetMatrix();

        Bounds		box = new Bounds(
            mat.MultiplyPoint3x4(new Vector3(0,	0, 0)), Vector3.zero);

        box.Encapsulate(mat.MultiplyPoint3x4(new Vector3(this.mapWidth,	0,				0)));
        box.Encapsulate(mat.MultiplyPoint3x4(new Vector3(0,				this.mapHeight,	0)));
        box.Encapsulate(mat.MultiplyPoint3x4(new Vector3(this.mapWidth,	this.mapHeight,	0)));

        return new Rect(box.min.x, box.min.y, box.size.x, box.size.y);
    }
開發者ID:perrysham,項目名稱:2DDemo,代碼行數:14,代碼來源:DemoMapCS.cs

示例10: GetBounds

    public static Bounds GetBounds(List<Vector3> vals)
    {
        Bounds b = new Bounds(Vector3.zero, Vector3.zero);

        if ( vals != null && vals.Count > 0 )
        {
            b.Encapsulate(vals[0]);

            for ( int i = 1; i < vals.Count; i++ )
                b.Encapsulate(vals[i]);
        }

        return b;
    }
開發者ID:mobeid,項目名稱:NP_SIMULATOR,代碼行數:14,代碼來源:MegaCacheUtils.cs

示例11: BoundsUnion

//============================ Bounds Functions ============================\
	
	// Creates bounds that encapsulate of the two Bounds passed in.
	public static Bounds BoundsUnion( Bounds b0, Bounds b1 ) {
		// If the size of one of the bounds is Vector3.zero, ignore that one
		if ( b0.size==Vector3.zero && b1.size!=Vector3.zero ) {
			return( b1 );
		} else if ( b0.size!=Vector3.zero && b1.size==Vector3.zero ) {
			return( b0 );
		} else if ( b0.size==Vector3.zero && b1.size==Vector3.zero ) {
			return( b0 );
		}
		// Stretch b0 to include the b1.min and b1.max
		b0.Encapsulate(b1.min);
		b0.Encapsulate(b1.max);
		return( b0 );
	}
開發者ID:ITIGameDesign,項目名稱:QuickSnap,代碼行數:17,代碼來源:Utils.cs

示例12: BoundsColliders

	public static Bounds BoundsColliders(GameObject obj) {
		var bounds = new Bounds(obj.transform.position, Vector3.zero);

		var colliders = obj.GetComponentsInChildren<Collider2D>();
		foreach(var c in colliders) {
			var blocal =BoundsOf(c);
			var t = c.transform;
			var max = t.TransformPoint(blocal.max);
			bounds.Encapsulate(max);
			var min = t.TransformPoint(blocal.min);
			bounds.Encapsulate(min);
		}

		return bounds;
	}
開發者ID:josejaime14,項目名稱:ocdc_ggj16,代碼行數:15,代碼來源:CameraFollow.cs

示例13: calculateWorldBounds

	public static Bounds calculateWorldBounds(GameObject go)
	{
		if (null == go) { return new Bounds(Vector3.zero, Vector3.zero); }

		Vector2 min = new Vector2(float.MaxValue, float.MaxValue);
		Vector2 max = new Vector2(float.MinValue, float.MinValue);
		Vector3 v;

		RectTransform[] rts = go.GetComponentsInChildren<RectTransform>();
		if (rts.Length == 0) return new Bounds(go.transform.position, Vector3.zero);

		for (int i = 0, imax = rts.Length; i < imax; ++i)
		{
			RectTransform t = rts[i];
			if (!t.gameObject.activeSelf) { continue; }

			Vector3[] corners = new Vector3[4];
			t.GetWorldCorners(corners);

			for (int j = 0; j < 4; ++j)
			{
				v = corners[j];
				if (v.x > max.x) max.x = v.x;
				if (v.y > max.y) max.y = v.y;

				if (v.x < min.x) min.x = v.x;
				if (v.y < min.y) min.y = v.y;
			}
		}

		Bounds b = new Bounds(min, Vector3.zero);
		b.Encapsulate(max);

		return b;
	}
開發者ID:oathx,項目名稱:Six,代碼行數:35,代碼來源:UGUIMath.cs

示例14: Start

 private void Start()
 {
     if (this.template != null)
     {
         int num = 0;
         Bounds bounds = new Bounds();
         for (int i = 0; i < this.maxRows; i++)
         {
             for (int j = 0; j < this.maxColumns; j++)
             {
                 GameObject obj2 = NGUITools.AddChild(base.gameObject, this.template);
                 obj2.transform.localPosition = new Vector3(this.padding + ((j + 0.5f) * this.spacing), -this.padding - ((i + 0.5f) * this.spacing), 0f);
                 UIStorageSlot component = obj2.GetComponent<UIStorageSlot>();
                 if (component != null)
                 {
                     component.storage = this;
                     component.slot = num;
                 }
                 bounds.Encapsulate(new Vector3((this.padding * 2f) + ((j + 1) * this.spacing), (-this.padding * 2f) - ((i + 1) * this.spacing), 0f));
                 if (++num >= this.maxItemCount)
                 {
                     if (this.background != null)
                     {
                         this.background.transform.localScale = bounds.size;
                     }
                     return;
                 }
             }
         }
         if (this.background != null)
         {
             this.background.transform.localScale = bounds.size;
         }
     }
 }
開發者ID:Lessica,項目名稱:Something-of-SHIPWAR-GAMES,代碼行數:35,代碼來源:UIItemStorage.cs

示例15: Awake

 void Awake()
 {
     propBounds = new Bounds( transform.position, Vector3.zero );
     foreach( var c in GetComponents<Collider>() ) {
         propBounds.Encapsulate( c.bounds );
     }
 }
開發者ID:johnsietsma,項目名稱:eons,代碼行數:7,代碼來源:GazePickPoint.cs


注:本文中的UnityEngine.Bounds.Encapsulate方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。