繁体   English   中英

已用计时器未启动

[英]Elapsed Timer not starting

我正在建立一个经过的计时器,而代码没有给出错误,则计时器无法启动。

我正在使用两个ViewController,一个叫做Stopwatch,它在Stopwatch()类下具有启动停止功能,然后是一个普通的ViewController,其中包含其余的控件。

主故事板 按钮和插座连接

查看控制器代码:

import UIKit

class ViewController: UIViewController {

let watch = Stopwatch()

@IBOutlet weak var elapsedTimeLabel: UILabel!

@IBAction func startButton(_ sender: Any) {
    Timer.scheduledTimer(timeInterval: 0.1, target: self, selector: #selector(self.updateElapsedTimeLabel), userInfo: nil, repeats: true)

    watch.start()
}

@IBAction func stopButton(_ sender: Any) {
    watch.stop()
}

@objc func updateElapsedTimeLabel (timer : Timer) {
    if watch.isRunning {
        let minutes = Int (watch.elapsedTime/60)
        let seconds = watch.elapsedTime.truncatingRemainder(dividingBy: 60)
        let tenOfSeconds = (watch.elapsedTime * 10).truncatingRemainder(dividingBy: 10)
        elapsedTimeLabel.text = String (format: "%02d:%02d:%02d", minutes, seconds, tenOfSeconds)
    } else {
        timer.invalidate()
    }
}

override func viewDidLoad() {
    super.viewDidLoad()
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
}

override var prefersStatusBarHidden: Bool {
    return true
}
}

秒表视图控制器代码:

import Foundation

class Stopwatch {

private var startTime : Date?

var elapsedTime: TimeInterval {
    if let startTime = self.startTime {
        return -startTime.timeIntervalSinceNow
    } else {
        return 0
    }
}
var isRunning: Bool {
    return startTime != nil
}

func start() {
    startTime = Date()
}

func stop() {
    startTime = nil
}
}

调试窗口中什么都没有,所以不确定是什么问题,我一遍又一遍地重新连接了按钮,事实并非如此。 如上所述,我在代码中也没有得到其他错误。

任何人都可以阐明这一点。 也许我使用了错误的#selector或我在执行updateElapsedTimeLabel分钟,秒,tenOfSeconds计算错误。 不确定。 感谢您的浏览。

如果在Option上单击secondstenOfSeconds您会发现一个类型为TimeInterval (即Double ),另一个类型为Double 因此,您的%02d格式说明符是错误的。 在C语言中,格式说明符和参数之间的不匹配是未定义的行为。 Swift并未说明如何处理,但我想它将忽略该参数。

要解决此问题,请将最后2个组件的格式说明符更改为%02.f

let minutes = Int(watch.elapsedTime/60)
let seconds = watch.elapsedTime.truncatingRemainder(dividingBy: 60)
let tenOfSeconds = (watch.elapsedTime * 100).truncatingRemainder(dividingBy: 100) // fixed the math here
elapsedTimeLabel.text = String(format: "%02d:%02.f:%02.f", minutes, seconds, tenOfSeconds)

但是,为什么不使用DateFormatter来简化您的生活:

class ViewController: UIViewController {
    private let formatter: DateFormatter = {
        let formatter = DateFormatter()
        formatter.dateFormat = "mm:ss:SS"
        return formatter
    }()

    @objc func updateElapsedTimeLabel (timer : Timer) {
        if watch.isRunning {
            elapsedTimeLabel.text = formatter.string(from: Date(timeIntervalSince1970: watch.elapsedTime))
        } else {
            timer.invalidate()
        }
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM