Version: 2017.3
public static RaycastHit2D BoxCast (Vector2 origin, Vector2 size, float angle, Vector2 direction, float distance= Mathf.Infinity, int layerMask= DefaultRaycastLayers, float minDepth= -Mathf.Infinity, float maxDepth= Mathf.Infinity);

参数

origin 盒体在 2D 空间中的起点。
size 盒体的大小。
angle 盒体的角度(以度为单位)。
direction 表示盒体方向的向量。
distance 盒体的最大投射距离。
layerMask 过滤器,用于仅在特定层上检测碰撞体。
minDepth 仅包括 Z 坐标(深度)大于或等于该值的对象。
maxDepth 仅包括 Z 坐标(深度)小于或等于该值的对象。

返回

RaycastHit2D 返回的投射数量。

描述

向场景中的碰撞体投射盒体,返回与盒体接触的第一个碰撞体。

从概念上说,BoxCast 就像朝特定方向拖动一个盒体穿过场景一样。在该过程中,可以检测并报告与盒体接触的任何对象。

函数返回一个 RaycastHit2D 对象,该对象引用了盒体命中的碰撞体 (如果未命中任何对象,则结果的碰撞体属性将为 NULL)。layerMask 可用于 仅在特定层上有选择地检测对象 (例如,这让您能够仅将检测应用于敌人角色)。

返回的 RaycastHit2D 将返回盒体将与碰撞体接触的 点和法线。此外,它还返回当盒体接触该点时 盒体的质心。

BoxCast 有一个 size 选项。该选项定义了盒体的大小。发射的盒体 将穿过世界。盒体越大,命中的 GameObject 越多。

BoxCast 还有一个 angle 选项。发射的穿过游戏中元素的盒体 可以旋转。这意味着,可能很难观察到 BoxCast 与 GameObject 之间的碰撞。

BoxCast.direction 变量用于确定盒体在游戏中的移动方式。这是一个控制水平和垂直方向的 2D 变量。

Distance 控制盒体从 origin 开始行进的距离。它可能会与 多个或 0 个 Collider 进行交互。在这些情况下,最接近的 Collider2D 提供 在 RaycastHit2D 变量中设置的值。如果未命中任何 Collider2D,则返回 NULL。

另请参阅:LayerMask 类、RaycastHit2D 类、BoxCastAllBoxCastNonAllocDefaultRaycastLayersIgnoreRaycastLayerraycastsHitTriggers


public static int BoxCast (Vector2 origin, Vector2 size, float angle, Vector2 direction, ContactFilter2D contactFilter, RaycastHit2D[] results, float distance= Mathf.Infinity);

参数

origin 盒体在 2D 空间中的起点。
size 盒体的大小。
angle 盒体的角度(以度为单位)。
direction 表示盒体方向的向量。
distance 盒体的最大投射距离。
results 用于接收结果的数组。该数组的大小决定可返回的结果的最大数量。
contactFilter 接触筛选器,用于以不同方式筛选结果,例如按层遮罩、Z 深度或法线角度。

返回

int 返回放置在 results 数组中的结果数。

描述

向场景中的碰撞体投射盒体,并返回与盒体接触的所有碰撞体。

从概念上说,BoxCast 就像朝特定方向拖动一个盒体穿过场景一样。在该过程中,可以检测并报告与盒体接触的任何对象。

该函数返回找到的接触点数,并将这些接触点放入 results 数组。也可以通过 contactFilter 对结果进行过滤。

另请参阅:ContactFilter2DRaycastHit2D