跳到主要内容

检测环境中的平面(C/C++)

概要

本章节给出了关键开发步骤,完整代码可以参考示例代码

约束与限制

检测环境平面能力支持部分Phone、部分Tablet设备。请参考硬件要求判断设备是否支持运动跟踪及平面识别特性(ARENGINE_FEATURE_TYPE_SLAM)。

引入AR Engine

开发者可参考管理AR会话章节的引入AR Engine

创建ARSession

开发者可以参考管理AR会话创建ARSession。

创建平面对象列表

  1. 创建一个平面对象列表planeList,用于存放AR Engine运行过程中检测到的所有平面。

    AREngine_ARTrackableList *planeList = nullptr;
    HMS_AREngine_ARTrackableList_Create(arSession, &planeList);
  2. 设置可跟踪对象类型为ARENGINE_TRACKABLE_PLANE。

    AREngine_ARTrackableType planeTrackedType = ARENGINE_TRACKABLE_PLANE;

识别当前环境中的平面

调用HMS_AREngine_ARSession_GetAllTrackables函数,检测当前环境中的所有平面,并将结果存放在planeList中。

HMS_AREngine_ARSession_GetAllTrackables(arSession, planeTrackedType, planeList);

获取平面数量

调用HMS_AREngine_ARTrackableList_GetSize函数获取平面数量,结果存放在planeListSize中。

int32_t planeListSize = 0;
HMS_AREngine_ARTrackableList_GetSize(arSession, planeList, &planeListSize);

在应用环境中,可能存在0个、1个或多个平面。

当planeListSize等于0时,表示当前环境中不存在平面。

当planeListSize等于1时,表示当前环境中仅存在1个平面。

当planeListSize大于1时,表示当前环境中存在多个平面。

获取平面实例

当存在1个或多个平面时,可以依次遍历planeList获取所有平面对象。

for (int i = 0; i < planeListSize; ++i) {
// 遍历所有平面对象,根据您的应用进行处理。
}

对于第i个平面,创建并获取可跟踪对象,并将其转化为平面对象AREngine_ARPlane

AREngine_ARTrackable *arTrackable = nullptr;
HMS_AREngine_ARTrackableList_AcquireItem(arSession, planeList, i, &arTrackable);
AREngine_ARPlane *arPlane = reinterpret_cast<AREngine_ARPlane*>(arTrackable);

AR Engine中,任何物体都被定义为可跟踪对象AREngine_ARTrackable。平面也是一种可跟踪对象,开发者可以通过类型转换reinterpret_cast将可跟踪对象AREngine_ARTrackable转化为平面对象AREngine_ARPlane

销毁平面对象列表

HMS_AREngine_ARTrackableList_Destroy(planeList);