2017-11-02 14 views
0

私は計時用のストップウォッチアプリケーションを書いていますし、私はクロックが一定の時間間隔(午前20時00分のような - 6時)を超えているかどうかを確認する必要があり、その場合には、時間間隔に現在の経過時間を追加します私は後でデータベースに格納する変数です。どのように私はこれを達成するための任意のアイデアですか?これまではティック関数でチェックしようとしましたが、アプリがバックグラウンドになっている時間は追加されません。ストップウォッチのiOSスウィフト

import Foundation 
    import os.log 

/// The class protocol for a Stopwatch instance. 
protocol StopwatchDelegate: class { 
    func currentTimerUpdated(seconds: String, minutes: String, hours: String) 
    func timerHasStarted() 
    func timerHasStopped() 
    func timerWasReset() 
} 

/// A container for a stopwatch. 
class Stopwatch{ 

    //var currentTimerSession = [TimerSession] = [] 

    // ***************************************************************** 
    // MARK: - Stopwatch Properties 
    // ***************************************************************** 

    /// The middleman for communicating with the view controller. 
    weak var delegate: StopwatchDelegate? 

    /// The actual Timer for this stopwatch. 
    private(set) var timer: Timer? 

    /// The time at which the timer was started. 
    private(set) var timerStartTime: TimeInterval = 0 

    /// The Timer-time at which the last user *pause* occurred. 
    private(set) var timerSavedTime: TimeInterval = 0 

    private(set) var timerSession = false 

    // ***************************************************************** 
    // MARK: - Stopwatch Class Methods 
    // ***************************************************************** 
    /// Create a new Stopwatch by locating the middleman and starting the timer. 
    /// 
    /// - Parameter delegate: the middleman to communicate to the view controller. 
    /// - Returns: An instance to a ticking `Stopwatch`. 
    /// 
    init(delegate: StopwatchDelegate) { 
     os_log("Initilzing timer.", log: OSLog.default, type: .debug) 
     self.delegate = delegate 
    } 

    // ***************************************************************** 
    // MARK: - Stopwatch Timer Methods 
    // ***************************************************************** ***************************************************************** 

    /// Start the stopwatch's timer. 
    func startTimer() { 
     timer = Timer.scheduledTimer(timeInterval: 0.01, target: self, 
            selector: #selector(timerHasTicked(timer:)), 
            userInfo: nil, repeats: true) 
     RunLoop.current.add(timer!, forMode: RunLoopMode.commonModes) 

     /// Record the time at which we started this timer. 
     //checkForOngoingTimer() 
     timerStartTime = Date.timeIntervalSinceReferenceDate 

     timerOriginalStartTime = Date() 
     timerSession = true 


     delegate?.timerHasStarted() 
    } 

    /// Pause the Timer 
    func stopTimer() { 
     /// Save the Time delta of the current Timer. 
     let currentTime = Date.timeIntervalSinceReferenceDate 
     timerSavedTime += currentTime - timerStartTime 
     timer?.invalidate() 
     delegate?.timerHasStopped() 
    } 

    /// Reset the Timer and all of the laps. 
    func resetTimer() { 
     timerSavedTime = 0 
     timerStartTime = 0 
     timerSession = false 

     timer?.invalidate() 
     delegate?.timerWasReset() 
    } 

    /// Compute the new time values time values: 
    /// 
    /// - `minutes`: starts at 0 and increments to 59 
    /// - `seconds`: starts at 0 and increments to 59 
    /// - `hours`: starts at 0 and increments to 59 
    /// 
    /// - Parameter timer: The instance of the currently *running* Timer. 
    /// 
    @objc private func timerHasTicked(timer: Timer) { 

     /// Find the time delta between start time and now. 
     let currentTime = Date.timeIntervalSinceReferenceDate 
     let timerElapsedTime: TimeInterval = (currentTime - timerStartTime) + timerSavedTime 

     /// Convert elapsed time to minutes, seconds, and hours. 
     let minutes = Int(timerElapsedTime)/60 % 60 
     let seconds = Int(timerElapsedTime) % 60 
     let hours = Int(timerElapsedTime/3600) 

     let formatter = DateFormatter() 
     formatter.timeZone = TimeZone.current 
     formatter.dateFormat = "yyyy-MM-dd HH:mm" 
     timerOriginalStartTime = formatter.string(from: timerOriginalStartTime) 

     /// Let the delegate know the Time has been updated. 
     delegate?.currentTimerUpdated(seconds: String(format: "%02u", seconds), 
             minutes: String(format: "%02u", minutes), 
             hours: String(format: "%02u", hours)) 
    } 
    } 
+0

App Capabitiesで背景モードを有効にした後に試しましたか? –

答えて

2

あなたのタイマーはバックグラウンドで解雇しないので、行くための最良の方法はありますが、ストップウォッチを開始し、開始時刻を格納することで、その後、アプリがバックグラウンドになるとし、再び戻ってきます、開始時から現在のオフセットを計算することができます。

タイマーの停止をサポートする場合は、一時停止の開始時間と終了時間を追跡し、合計時間からその時間を差し引くことができます。

+0

私はそうすることを考えていましたが、問題はユーザーがタイマーを一時停止できるようにして、開始時間と終了時間をすべて保存する必要があるということです。どのように私はすべての異なる開始時間と終了時間を処理することができますか? –

+0

一時停止をサポートするには、ユーザーが一時停止を押す時間を記録します。その後、ユーザーがタイマーを再起動すると、 'interval =(currentTime - pauseTime)'を計算し、それを元の開始時刻に追加し、開始時刻として使用します。このメソッドでは、 'startTime'と' pauseTime'の2回だけ追跡する必要があります。 – vacawama

関連する問題