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


C# Bounds.IntersectRay方法代碼示例

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


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

示例1: ClampToBounds

 public static Vector3 ClampToBounds( this Vector3 v, Bounds bounds )
 {
     Vector3 clamp = v;
     Ray clampRay = new Ray( Vector2.zero, v );
     float dist;
     if( bounds.IntersectRay( clampRay, out dist ) ) {
         clamp = Vector3.ClampMagnitude( v, dist );
     }
     return clamp;
 }
開發者ID:rhys-vdw,項目名稱:birdy-hawk,代碼行數:10,代碼來源:Vector3Extensions.cs

示例2: Internal_RaycastRef

 internal bool Internal_RaycastRef(Ray ray, ref UIHotSpot.Hit hit)
 {
     Bounds bound = new Bounds(this.center, this.size);
     if (!bound.IntersectRay(ray, out hit.distance))
     {
         return false;
     }
     hit.point = ray.GetPoint(hit.distance);
     hit.normal = -ray.direction;
     return true;
 }
開發者ID:HexHash,項目名稱:LegacyRust,代碼行數:11,代碼來源:UIBoxHotSpot.cs

示例3: BoundsWithinPoints

    // BoundsWithinPoints                                                                                      //
    // Cchecks if passed bounds contains either point (return false)                                           //
    // Then Fires rays between both points to check if the bounds are contained within both rays (return true) //
    public static bool BoundsWithinPoints( Vector3 point_a, Vector3 point_b, Bounds bounds )
    {
        // If the start or end point are within the object, do nothing
        if( bounds.Contains( point_a ) || bounds.Contains( point_b ) )
        {
            return false;
        }

        // If the object is fully on both rays
        Ray ray_forward = new Ray( point_a, point_b - point_a );
        Ray ray_backward = new Ray( point_b, point_a - point_b );
        if( bounds.IntersectRay( ray_forward ) && bounds.IntersectRay( ray_backward ))
        {
            return true;
        }
        else
        {
            return false;
        }
    }
開發者ID:tomob95,項目名稱:Portfolio,代碼行數:23,代碼來源:TiCuttingUtilities.cs

示例4: HandleIntersectionRouting

        void HandleIntersectionRouting()
        {
            FastList<NodeLaneMarker> nodeMarkers;
            if (m_nodeMarkers.TryGetValue(m_selectedNode, out nodeMarkers))
            {
                Ray mouseRay = Camera.main.ScreenPointToRay(Input.mousePosition);
                NodeLaneMarker hoveredMarker = null;
                Bounds bounds = new Bounds(Vector3.zero, Vector3.one);
                for (int i = 0; i < nodeMarkers.m_size; i++)
                {
                    NodeLaneMarker marker = nodeMarkers.m_buffer[i];

                    if (!IsActive(marker))
                        continue;

                    bounds.center = marker.m_position;
                    if (bounds.IntersectRay(mouseRay))
                    {
                        hoveredMarker = marker;
                        marker.m_size = 2f;
                    }
                    else
                        marker.m_size = 1f;
                }

                if (hoveredMarker != null && Input.GetMouseButtonUp(0))
                {
                    if (m_selectedMarker == null)
                    {
                        m_selectedMarker = hoveredMarker;
                    }
                    else if (RoadManager.RemoveLaneConnection(m_selectedMarker.m_lane, hoveredMarker.m_lane))
                    {
                        m_selectedMarker.m_connections.Remove(hoveredMarker);
                    }
                    else if (RoadManager.AddLaneConnection(m_selectedMarker.m_lane, hoveredMarker.m_lane))
                    {
                        m_selectedMarker.m_connections.Add(hoveredMarker);
                    }
                }
            }

            if (Input.GetMouseButtonUp(1))
            {
                if (m_selectedMarker != null)
                    m_selectedMarker = null;
                else
                    m_selectedNode = 0;
            }
        }
開發者ID:Rovanion,項目名稱:csl-traffic,代碼行數:50,代碼來源:RoadCustomizerTool.cs

示例5: IsPickingParticle

	// Control --------------------------------------------------------------------------
	public bool IsPickingParticle(Ray ray)
	{
		if (IsParticle() == false)
			return false;

		if (m_WireObject == null)
			return false;

		List<Vector4>	listPos = m_WireObject.GetLastParticlePostions();
		foreach (Vector4 pos in listPos)
		{
			Bounds	bounds = new Bounds(new Vector3(pos.x, pos.y, pos.z), new Vector3(pos.w, pos.w, pos.w));
			if (bounds.IntersectRay(ray))
				return true;
		}

		return false;
	}
開發者ID:ziyihu,項目名稱:LordOfSinU3D,代碼行數:19,代碼來源:FxmInfoIndexing.cs

示例6: RaycastSide

		private PivotType RaycastSide(SuperCube aCube, Ray aRay) {
			aRay.origin    = aCube.transform.InverseTransformPoint(aRay.origin);
			aRay.direction = aCube.transform.InverseTransformDirection(aRay.direction);
			aRay.direction.Normalize();

			Vector3   size    = aCube.Extents / 2;
			PivotType side    = PivotType.None;
			float     closest = float.MaxValue;
			float     dist    = 0;

			Bounds bounds = new Bounds();
			bounds.center = Vector3.zero;
			bounds.extents = size;
			if (bounds.IntersectRay(aRay, out dist)) {
				side = PivotType.All;
				closest = dist + 0.1f;
			}

			if (CheckSide(aRay, new Vector3( 0, 0,-1), size.z, Mathf.Min(size.x, size.y), closest, out dist)) {
				closest = dist;
				side    = PivotType.Back;
			}
			if (CheckSide(aRay, new Vector3( 0, 0, 1), size.z, Mathf.Min(size.x, size.y), closest, out dist)) {
				closest = dist;
				side    = PivotType.Front;
			}
			if (CheckSide(aRay, new Vector3(-1, 0, 0), size.x, Mathf.Min(size.y, size.z), closest, out dist)) {
				closest = dist;
				side    = PivotType.Right;
			}
			if (CheckSide(aRay, new Vector3( 1, 0, 0), size.x, Mathf.Min(size.y, size.z), closest, out dist)) {
				closest = dist;
				side    = PivotType.Left;
			}
			if (CheckSide(aRay, new Vector3( 0,-1, 0), size.y, Mathf.Min(size.x, size.z), closest, out dist)) {
				closest = dist;
				side    = PivotType.Top;
			}
			if (CheckSide(aRay, new Vector3( 0, 1, 0), size.y, Mathf.Min(size.x, size.z), closest, out dist)) {
				closest = dist;
				side    = PivotType.Bottom;
			}

			return side;
		}
開發者ID:rhysb89,項目名稱:AdelaidePrototype,代碼行數:45,代碼來源:SuperCubeEditor.cs

示例7: ObjectRaycast

		/**
		 * Return the nearest hit object in scene.  Does not require a collider.
		 */
		public static GameObject ObjectRaycast(Ray ray, IEnumerable<GameObject> objects)
		{
			Renderer renderer;
			float distance = Mathf.Infinity;
			float best = Mathf.Infinity;
			GameObject obj = null;
			Bounds bounds = new Bounds(Vector3.zero, Vector3.one);

			pb_RaycastHit hit;

			foreach(GameObject go in objects)
			{
				Ray localRay = TransformRay(ray, go.transform);

				renderer = go.GetComponent<Renderer>();

				if( renderer != null )
				{
					if( renderer.bounds.IntersectRay(ray, out distance) )
					{
						MeshFilter mf = go.GetComponent<MeshFilter>();

						if( mf != null && mf.sharedMesh != null && MeshRaycast(mf.sharedMesh, localRay, out hit))
						{
							if(hit.distance < best)
							{
								best = hit.distance;
								obj = go;
							}
						}
					}
				}
				else
				{
					bounds.center = go.transform.position;

					if(bounds.IntersectRay(ray, out distance))
					{
						if( distance < best )
						{
							best = distance;
							obj = go;
						}
					}
				}
			}

			return obj;
		}
開發者ID:procore3d,項目名稱:giles,代碼行數:52,代碼來源:pb_HandleUtility.cs


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