ARKit从入门到精通(7)-ARCamera介绍

  • 转载请注明出处:ARKit从入门到精通(7)-ARCamera介绍

  • ARCamera是一个相机,它是连接虚拟场景与现实场景之间的枢纽。在ARKit中,它是捕捉现实图像的相机,在SceneKit中它又是3D虚拟世界中的相机。(一般第一人称3D游戏,主角其实就是一个3D相机,我们电脑屏幕看到的画面就是这个相机捕捉的画面)

    • 一般我们无需去创建一个相机,因为当我们初始化一个AR试图时,他会为我们默认创建一个相机,而且这个相机就是摄像头的位置,同时也是3D世界中的原点所在(x=0,y=0,z=0)
      • ARCamera的API一般我们无需关心,因为ARKit会默认帮助我们配置好
  • API介绍

@interface ARCamera : NSObject <NSCopying>

/**
 4x4矩阵表示相机位置,同ARAnchor
 */
@property (nonatomic, readonly) matrix_float4x4 transform;

/**
相机方向(旋转)的矢量欧拉角
分别是x/y/z
 */
@property (nonatomic, readonly) vector_float3 eulerAngles;

/**
 相机追踪状态(在下方会有枚举值介绍)
 */
@property (nonatomic, readonly) ARTrackingState trackingState NS_REFINED_FOR_SWIFT;

/**
追踪运动类型
 */
@property (nonatomic, readonly) ARTrackingStateReason trackingStateReason NS_REFINED_FOR_SWIFT;

/**
相机曲率(笔者有点费解,反复揣摩应该是与焦距相关参数)
3x3矩阵
 fx 0   px
 0  fy  py
 0  0   1
 */
@property (nonatomic, readonly) matrix_float3x3 intrinsics;

/**
摄像头分辨率
 */
@property (nonatomic, readonly) CGSize imageResolution;

/**
投影矩阵
*/
@property (nonatomic, readonly) matrix_float4x4 projectionMatrix;

/**
创建相机投影矩阵
 */
- (matrix_float4x4)projectionMatrixWithViewportSize:(CGSize)viewportSize orientation:(UIInterfaceOrientation)orientation zNear:(CGFloat)zNear zFar:(CGFloat)zFar;

@end

//相机追踪状态枚举
typedef NS_ENUM(NSInteger, ARTrackingState) {

    /** 不被允许 */
    ARTrackingStateNotAvailable,

    /** 最小 */
    ARTrackingStateLimited,

    /** 正常. */
    ARTrackingStateNormal,
} NS_REFINED_FOR_SWIFT;

/**
 追踪运动类型
 */
API_AVAILABLE(ios(11.0)) API_UNAVAILABLE(macos, watchos, tvos)
typedef NS_ENUM(NSInteger, ARTrackingStateReason) {
    /** 无. */
    ARTrackingStateReasonNone,

    /** 运动. */
    ARTrackingStateReasonExcessiveMotion,

    /** 脸部捕捉. */
    ARTrackingStateReasonInsufficientFeatures,
} NS_REFINED_FOR_SWIFT;
  • 0
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
EasyAR 并不直接提供语音识别功能,但是你可以使用 Unity 的插件 SpeechRecognizer 实现安卓平台上的语音识别,并将识别结果与 EasyAR 中的 AR 应用进行交互。 以下是一个简单的示例代码,演示如何将语音识别结果与 EasyAR 中的 AR 应用进行交互: ```csharp using UnityEngine; using System.Collections; using UnityEngine.Android; using EasyAR; public class SpeechRecognition : MonoBehaviour { // EasyAR ARCamera 对象 public ARCamera arCamera; // 关键字 public string keyword = "hello"; // 识别结果 private string result = ""; void Start() { // 请求录音权限 #if UNITY_ANDROID if (!Permission.HasUserAuthorizedPermission(Permission.Microphone)) { Permission.RequestUserPermission(Permission.Microphone); } #endif // 创建 SpeechRecognizer 对象 AndroidJavaObject recognizer = new AndroidJavaObject("com.unity3d.player.UnitySpeechRecognizer"); // 开始识别 recognizer.Call("start", keyword); // 获取识别结果 result = recognizer.Call<string>("getResult"); } void Update() { // 如果识别结果为 "hello",则在 EasyAR 中显示一个 Cube if (result == "hello") { var obj = Instantiate(Resources.Load<GameObject>("Cube")); obj.transform.parent = arCamera.transform; obj.transform.localPosition = new Vector3(0, 0, 500); result = ""; } } void OnGUI() { // 显示识别结果 GUILayout.Label("Result: " + result); } } ``` 在上面的代码中,我们首先请求录音权限,然后创建 SpeechRecognizer 对象,并使用关键字 "hello" 开始识别。在 Update 函数中,如果识别结果为 "hello",则在 EasyAR 中显示一个 Cube。最后,我们获取识别结果,并在界面上显示出来。 需要注意的是,SpeechRecognizer 插件只能在 Android 平台上使用,而且需要在 AndroidManifest.xml 文件中添加相应的权限声明。 希望这个简单的示例能够帮助你实现 EasyAR 中的语音识别。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值