重叠检测设置 (SDK for Cocos Creator)

最終更新: 2023年3月14日

这里将说明如何从输入的座标中获取模型的重叠检测。
说明以追加到已执行“载入SDK”的项目为前提。

概述

为了获取重叠检测,在Cubism SDK中使用名为Raycast的组件。

要设置Raycast,请执行以下三项。

  1. 附加一个运行Raycast的组件
  2. 指定用于重叠检测的图形网格
  3. 从CubismRaycaster.raycast获取检测结果

附加一个运行Raycast的组件

将进行重叠检测、名为[CubismRaycaster]的组件附加到作为模型根的Node上。

指定用于重叠检测的图形网格

在[模型]/Drawables/下,置入了管理每个绘制的图形网格的Node。
Node的名称是该参数的ID。

将[CubismRaycastable]附加到被视为此Node的重叠检测范围的那个。

从CubismRaycastable中,您可以选择附加网格的重叠检测范围。

  • Bounding Box:将围绕该网格的矩形作为重叠检测。它相比Triangles负载更轻。
  • Triangles:将该网格的形状作为重叠检测。如果要准确判断范围,请设置此项。

从CubismRaycaster.raycast获取检测结果

最后使用附加到模型根上的CubismRaycaster的Raycast(),获得重叠检测结果。

创建一个名为“CubismHitTest”的TypeScript脚本,添加如下代码并将其附加到模型的根。

import { _decorator, Component, Node, input, Input, EventTouch, Camera } from 'cc';
import CubismRaycaster from '../../Framework/Raycasting/CubismRaycaster';
import CubismRaycastHit from '../../Framework/Raycasting/CubismRaycastHit';
const { ccclass, property } = _decorator;

@ccclass('CubismHitTest')
export class CubismHitTest extends Component {
  @property({ type: Camera, visible: true })
  public _camera: Camera = new Camera;

  protected start() {
    input.on(Input.EventType.TOUCH_START,this.onTouchStart,this);
  }

  public onTouchStart(event: EventTouch) {
    const raycaster = this.getComponent(CubismRaycaster);

    if (raycaster == null) {
      return;
    }

    // Get up to 4 results of collision detection.
    const results = new Array<CubismRaycastHit>(4);

    // Cast ray from pointer position.
    const ray = this._camera.screenPointToRay(event.getLocationX(), event.getLocationY());
    const hitCount = raycaster.raycast2(ray, results);

    // Show results.
    let resultsText = hitCount.toString();
    for (var i = 0; i < hitCount; i++)
    {
      resultsText += "\n" + results[i].drawable?.name;
    }

    console.log(resultsText);
  }
}

这样就完成了设置。

在这种状态下,如果在执行过程中于Game视图中单击附加了CubismRaycastable的网格,则会将重叠检测的结果输出到Console视图。

执行示例

D_PSD_16<CubismDrawable>
D_PSD_15<CubismDrawable>
D_PSD_14<CubismDrawable>
D_PSD_07<CubismDrawable>
请问这篇文章对您有帮助吗?
关于本报道,敬请提出您的意见及要求。