ios - SceneKit 相机约束行为问题

标签 ios swift scenekit

目前正在使用 swift 在 scenekit 中开发游戏,我正在尝试实现相机约束以充分利用 scenekit 必须提供的一切。我非常接近得到我想要的东西,但我缺少一件而且似乎无法弄清楚。以下问题的视频。

This video用我写的代码显示我的相机跟随我的船。方向和角度都很好,并且惯性很好。我使用以下代码实现了这一点:

func renderer(_ renderer: SCNSceneRenderer, updateAtTime time: TimeInterval) {
    updateCameraPosition()
}

func updateCameraPosition () {
    let currentPosition = player.node.presentation.position
    let newVector = getNewCameraVector(currentPosition: currentPosition, t: 0.03 )

    cameraNode.runAction( SCNAction.move(to: newVector, duration: 0.2) )

    prevCameraPosition = currentPosition
}

func getNewCameraVector (currentPosition:SCNVector3, t: Float) -> SCNVector3 {
    let x = (1 - t) * prevCameraPosition.x + t * currentPosition.x
    let y = cameraZoom
    let z = ((1 - t) * prevCameraPosition.z + t * currentPosition.z) + cameraZPos!

    return SCNVector3(x,y,z)
}

This video显示相机跟随我的船有限制。它似乎只是在 x,z 轴上旋转。所以我真的很想让它像我写的代码一样在 x、z 轴上来回移动……或类似的东西。这些约束取自 WWDC 2017 scenekit fox 演示,我已经像这样实现了它们:

    // look at "lookAtTarget"
    let lookAtConstraint = SCNLookAtConstraint(target: player.node)
    lookAtConstraint.influenceFactor = 0.07
    lookAtConstraint.isGimbalLockEnabled = true

    // distance constraints
    let distanceConstraint = SCNDistanceConstraint(target: player.node)
    let distance = CGFloat(simd_length(cameraNode.simdPosition))
    distanceConstraint.minimumDistance = distance
    distanceConstraint.maximumDistance = distance

    // configure a constraint to maintain a constant altitude relative to the character
    //let desiredAltitude = abs(cameraNode.simdWorldPosition.y)
    //weak var weakSelf = self

    let keepAltitude = SCNTransformConstraint.positionConstraint(inWorldSpace: true, with: {(_ node: SCNNode, _ position: SCNVector3) -> SCNVector3 in
        return SCNVector3(0, self.cameraZoom, self.cameraZoom)
    })

    let accelerationConstraint = SCNAccelerationConstraint()
    accelerationConstraint.maximumLinearVelocity = 1500.0
    accelerationConstraint.maximumLinearAcceleration = 50.0
    accelerationConstraint.damping = 0.05

    cameraNode.constraints = [distanceConstraint, keepAltitude, accelerationConstraint, lookAtConstraint]

如果有人知道我如何实现这一目标,我很乐意听到!没有关于这些新约束的任何文档,所以我只是在猜测何时启用它们。

最佳答案

回答我自己的问题,希望对其他人有所帮助。我终于能够复制具有以下约束的相机代码:

func setupCamera () {
    cameraNode.camera = SCNCamera()
    cameraZPos = cameraZoom / 2 // cameraZoom == 100

    if let cam = cameraNode.camera {
        cam.zFar = cameraZFar
    }

    let replicatorConstraint = SCNReplicatorConstraint(target: player.node)
    replicatorConstraint.positionOffset = SCNVector3(0,cameraZoom,cameraZPos!)
    replicatorConstraint.replicatesOrientation = false

    let lookAtConstraint = SCNLookAtConstraint(target: player.node)
    lookAtConstraint.influenceFactor = 0.07
    lookAtConstraint.isGimbalLockEnabled = true

    let accelerationConstraint = SCNAccelerationConstraint()
    accelerationConstraint.maximumLinearAcceleration = 300.0

    cameraNode.constraints = [replicatorConstraint, lookAtConstraint, accelerationConstraint]
}

如果您有任何问题,请评论这个答案,我很乐意分享我学到的东西!

关于ios - SceneKit 相机约束行为问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51524534/

相关文章:

macos - SceneKit 平滑相机移动

ios - 在 UILocalNotification 触发后修改它的最佳方法是什么?

ios - 如何使用 KIF 框架使 UIDatePicker 自动化以选择过去的日期

ios 在数据加载和隐藏原型(prototype)单元格时触发 TableView 中的事件指示器

ios - 想要使用 Scenekit 更改节点的 y 值

ios - 无法在 SK3DNode 上方显示 Sprite

在模拟器中从 5 切换到 4.3 时,iOS 应用程序完全错位

ios - Swift - UIPickerView 崩溃应用程序没有错误

Swift 按字符串 double 排序结构数组

ios - 创建一个可以快速交互的不可见 View