【问题标题】:SCNNode parent-child relationship in SceneKit?SceneKit中的SCNNode父子关系?
【发布时间】:2017-06-28 14:13:42
【问题描述】:

从我以前的question 看来,我相信克隆SCNNode 是解决加载多个对象问题的方法。然而,我意识到有些不对劲。

我做了类似的事情

arrow = scnScene.rootNode.childNode(withName: "arrow", recursively:true)
arrow.rotation = SCNVector4(0, 0, 1, M_PI_2)
arrow.position = SCNVector3(x: 0, y: 0, z: -3);
let sign = SCNNode()
for i in 0..<10{
    let node = arrow.clone()
    node.position = SCNVector3(i+1,0,0)
    sign.addChildNode(node)
}
arrow.addChildNode(sign)

我希望显示一行箭头,但实际上有一列箭头(沿 x 轴平移但实际上影响 y 轴,似乎克隆节点的坐标系已更改)显示并且所有子对象都旋转 180 度.为什么?

在 Karl Sigiscar 告诉我使用 SCNReferenceNode 之前,我不确定我应该如何使用它,它能否实现我的目标?

更新:

我尝试过这样的 SCNReferenceNode:

    let scnScene = SCNScene()

    if let filePath = Bundle.main.path(forResource: "arrowsign", ofType: "dae", inDirectory: "art.scnassets") {
        // ReferenceNode path -> ReferenceNode URL
        let referenceURL = NSURL(fileURLWithPath: filePath)


        if #available(iOS 9.0, *) {
            arrow = SCNReferenceNode(url: referenceURL as URL!)!
            arrow.load()
            arrow.rotation = SCNVector4(0, 0, 1, -M_PI_2)
            arrow.position = SCNVector3(0,0,-5)

            // Create reference node
            for i in 0..<10{
                let referenceNode : SCNReferenceNode = SCNReferenceNode(url: referenceURL as URL)!
                referenceNode.load()
                referenceNode.position = SCNVector3(i+1, 0, 0);
                arrow.addChildNode(referenceNode)
            }
        }
    }
    scnScene.rootNode.addChildNode(arrow)

我没有旋转子节点,但是当我运行它时它们会自动旋转(-M_PI_2 度)。我确实在 x 轴上进行了平移,但实际上显示的是一列箭头,而不是一排箭头。这是子父节点的特性吗?

【问题讨论】:

    标签: ios swift3 scenekit


    【解决方案1】:

    使用 SCNReferenceNode 后,我发现如果将一个节点作为子节点添加到另一个节点,则子节点将设置为父节点的位置。比如有一个父节点在位置(3,4,5),那么它的所有子节点首先会位于(3,4,5)中(以后可以修改)。因此,如果您想要一行箭头,只需修改子节点的 x 并保持 y 和 z 值等于零。 如果父节点应用旋转,旋转也将应用到子节点。

    【讨论】:

      猜你喜欢
      • 2017-01-01
      • 2017-05-16
      • 2016-03-25
      • 1970-01-01
      • 2018-03-28
      • 2014-12-05
      • 2017-01-18
      • 2017-04-15
      • 2017-07-22
      相关资源
      最近更新 更多