swift – SceneKit SCNSceneRendererDelegate – 未调用渲染器函数

swift – SceneKit SCNSceneRendererDelegate – 未调用渲染器函数,第1张

概述我最近问了一个有一个非常明显答案的 question.我还在研究同一个项目并遇到另一个问题.我需要实现每帧逻辑,并且SCNSceneRendererDelegate协议在iOS上工作得很好,但在OSX上,渲染器函数没有触发.我创建了一个示例项目来说明我的问题.它由storyboard中的Scene Kit视图和ViewController类中的以下代码组成: import Cocoaimport 我最近问了一个有一个非常明显答案的 question.我还在研究同一个项目并遇到另一个问题.我需要实现每帧逻辑,并且SCNSceneRendererDelegate协议在iOS上工作得很好,但在OSX上,渲染器函数没有触发.我创建了一个示例项目来说明我的问题.它由storyboard中的Scene Kit视图和VIEwController类中的以下代码组成:
import Cocoaimport SceneKitclass VIEwController: NSVIEwController,SCNSceneRendererDelegate {    @IBOutlet weak var sceneVIEw: SCNVIEw!    let cubeNode = SCNNode()    overrIDe func vIEwDIDLoad() {        super.vIEwDIDLoad()        let scene = SCNScene()        let sphere = SCNSphere(radius: 0.1)        sphere.firstMaterial!.diffuse.contents = NScolor.yellowcolor()        let sphereNode = SCNNode(geometry: sphere)        scene.rootNode.addChildNode(sphereNode)        let cube = SCNBox(wIDth: 0.2,height: 0.2,length: 0.2,chamferRadius: 0)        cube.firstMaterial!.diffuse.contents = NScolor.greencolor()        cubeNode.geometry = cube        cubeNode.position = SCNVector3(1,0)        scene.rootNode.addChildNode(cubeNode)        let cameraNode = SCNNode()        cameraNode.camera = SCNCamera()        cameraNode.position = SCNVector3(2,1,2)        let constraint = SCNLookAtConstraint(target: cubeNode)        cameraNode.constraints = [constraint]        scene.rootNode.addChildNode(cameraNode)        sceneVIEw.scene = scene        sceneVIEw.backgroundcolor = NScolor(red: 0.5,green: 0,blue: 0.3,Alpha: 1)        sceneVIEw.allowsCameraControl = true        sceneVIEw.delegate = self        sceneVIEw.playing = true    }    func renderer(renderer: SCNSceneRenderer,updateAtTime time: NSTimeInterval) {        cubeNode.position.x += 0.1    }}

我想要的只是基本上每帧移动立方体.但没有任何反应.奇怪的是,当我将sceneVIEw.allowsCameraControl设置为true时,每当我在屏幕上单击或拖动时都会调用渲染器函数(这是有意义的,因为它需要根据摄像机角度更新视图).但我希望每一帧都能调用它.

是否有错误我没看到或者这是我的Xcode中的错误?

编辑:
我已经尝试按照下面的答案中的说明,现在有VIEwController的以下代码:

import Cocoaimport SceneKitclass VIEwController: NSVIEwController {    @IBOutlet weak var sceneVIEw: SCNVIEw!    let scene = MyScene(create: true)    overrIDe func vIEwDIDLoad() {        super.vIEwDIDLoad()        sceneVIEw.scene = scene        sceneVIEw.backgroundcolor = NScolor(red: 0.5,Alpha: 1)        sceneVIEw.allowsCameraControl = true        sceneVIEw.delegate = scene        sceneVIEw.playing = true    }}

和MyScene课程:

import Foundationimport SceneKitfinal class MyScene: SCNScene,SCNSceneRendererDelegate {    let cubeNode = SCNNode()    convenIEnce init(create: Bool) {        self.init()        let sphere = SCNSphere(radius: 0.1)        sphere.firstMaterial!.diffuse.contents = NScolor.yellowcolor()        let sphereNode = SCNNode(geometry: sphere)        rootNode.addChildNode(sphereNode)        let cube = SCNBox(wIDth: 0.2,0)        rootNode.addChildNode(cubeNode)        let cameraNode = SCNNode()        cameraNode.camera = SCNCamera()        cameraNode.position = SCNVector3(2,2)        let constraint = SCNLookAtConstraint(target: cubeNode)        cameraNode.constraints = [constraint]        rootNode.addChildNode(cameraNode)    }    @objc func renderer(aRenderer: SCNSceneRenderer,updateAtTime time: NSTimeInterval) {        cubeNode.position.x += 0.01    }}

但是,它仍然无法正常工作.我究竟做错了什么?

编辑:设置sceneVIEw.loops = true修复了描述的问题

我怀疑答案取决于Querent所说的“每一帧”. Querent应该澄清这一点,但无论如何我都会尝试回答,因为我就是这样.

最简单的解释可能是“无论如何都会呈现的每一帧”,但这似乎不太可能是所期望的,除非该多维数据集旨在作为渲染器的一种活动监视器,这似乎也不可能;有更好的方法.

Querent可能想要的是在视图的playing属性为YES时重复渲染.如果是这种情况,那么答案就像将视图的loops属性设置为YES一样简单.这最近为我解决了一个问题,我希望在键盘按键被按下时进行渲染. (我注意到将播放设置为YES会导致对我的代表进行一次调用.)

总结

以上是内存溢出为你收集整理的swift – SceneKit SCNSceneRendererDelegate – 未调用渲染器函数全部内容,希望文章能够帮你解决swift – SceneKit SCNSceneRendererDelegate – 未调用渲染器函数所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1046333.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-24
下一篇 2022-05-24

发表评论

登录后才能评论

评论列表(0条)

保存