如何在Swift中设置游戏循环

时间:2014-06-08 06:44:06

标签: ios swift

要在Objective-C中设置游戏循环,我了解到我应该设置一个CADisplayLink

updater = [CADisplayLink displayLinkWithTarget:self selector:@selector(gameLoop) ];
[updater setFrameInterval: 1];
[updater addToRunLoop: [NSRunLoop currentRunLoop] forMode: NSRunLoopCommonModes];

我如何在Swift中执行此操作?

我曾试图谷歌这个,但我找不到任何这方面的例子。

3 个答案:

答案 0 :(得分:24)

通过一些调整,几乎只是从Objective-C到Swift的直接翻译。

import QuartzCore
var updater = CADisplayLink(target: self, selector: Selector("gameLoop"))
updater.frameInterval = 1
updater.addToRunLoop(NSRunLoop.currentRunLoop(), forMode: NSRunLoopCommonModes)

答案 1 :(得分:7)

Swift 3.x版本的Brian Tracy' answer

let updater = CADisplayLink(target: self, selector: #selector(self.gameLoop))
updater.preferredFramesPerSecond = 60
updater.add(to: RunLoop.current, forMode: RunLoopMode.commonModes)

除了Swift 3的语法更改之外,还要注意iOS 10 API从frameInterval(仍然有效,但产生不推荐的警告)更改为preferredFramesPerSecond

答案 2 :(得分:5)

这是我的GameLoop课程(Swift 3)

import UIKit

class GameLoop : NSObject {

    var doSomething: () -> ()!
    var displayLink : CADisplayLink!

    init(doSomething: @escaping () -> ()) {
        self.doSomething = doSomething
        super.init()
        start()
    }

    // you could overwrite this too
    func handleTimer() {
        doSomething()
    }

    func start() {
        displayLink = CADisplayLink(target: self, selector: #selector(handleTimer))
        /*
        * If set to zero, the
        * display link will fire at the native cadence of the display hardware.
        * The display link will make a best-effort attempt at issuing callbacks
        * at the requested rate.
        */
        displayLink.preferredFramesPerSecond = 0
        displayLink.add(to: .main, forMode: .commonModes)
    }

    func stop() {
        displayLink.invalidate()
        displayLink.remove(from: .main, forMode: .commonModes)
        displayLink = nil
    }
}

如果您要在后台GCD队列上更新某些内容并希望将这些更改提取到主队列(和runloop),则应使用Dispatch Source for Data