ARKit会话的currentFrame始终为零

时间:2017-07-04 09:57:27

标签: ios augmented-reality arkit

我尝试从sympy的{​​{1}}属性进行相机转换。

为什么我一直将currentFrame.camera作为ARSession

1 个答案:

答案 0 :(得分:2)

我刚刚进行了一次快速测试,看到session.currentFrame在前几次通过渲染循环时是零。这个滞后变化,可能是两个或十几个。但最终currentFrame出现了。{/ p>

class ViewController: UIViewController, ARSCNViewDelegate, ARSessionDelegate, SCNSceneRendererDelegate {

override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(animated)

    // Create a session configuration
    let configuration = ARWorldTrackingSessionConfiguration()
    configuration.worldAlignment = .gravityAndHeading
    configuration.planeDetection = .horizontal

    sceneView.session.delegate = self

    // Run the view's session
    sceneView.session.run(configuration)
    print(#function, sceneView.session.currentFrame)

}

// MARK: - SCNSceneRendererDelegate
func renderer(_ renderer: SCNSceneRenderer, didRenderScene scene: SCNScene, atTime time: TimeInterval) {
    print(#function, sceneView.session.currentFrame)
}

// MARK: - ARSessionDelegate
func session(_ session: ARSession, didUpdate frame: ARFrame) {
    print(#function, sceneView.session.currentFrame)
}

给我们

renderer(_:didRenderScene:atTime:) nil
...
session(_:didUpdate:) Optional(<ARFrame: 0x1c42cff10 timestamp=6334.963644 capturedImage=0x1c0124d80 camera=0x1c41262c0 lightEstimate=0x1c4238640 | no anchors, 0 features>)
...
renderer(_:didRenderScene:atTime:) Optional(<ARFrame: 0x1c02c9c30 timestamp=6334.996948 capturedImage=0x1c0124b00 camera=0x1c0124920 lightEstimate=0x1c02251a0 | no anchors, 0 features>)