Таймер CountDown не работал при навигации по контроллеру Swift? - PullRequest
1 голос
/ 07 апреля 2019

Обратный отсчет идет в фоновом режиме, когда я минимизирую таймер обратного отсчета в таймере приложения. но когда я перемещаюсь FirstViewController к SecondViewController и нажимаю кнопку возврата от SecondViewController, чтобы перейти к firstViewController, таймер не продолжает обратный отсчет. Я хочу, чтобы когда я вернулся к первому контроллеру просмотра, таймер все еще находился в обратном отсчете.

вот мой код

import UIKit

class FirstViewController: UIViewController {

        @IBOutlet weak var timerLabel: UILabel!

        var countdownTimer: Timer!
        var totalTime = 200


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

    func startTimer() {
        countdownTimer = Timer.scheduledTimer(timeInterval: 1, target: self, selector: #selector(updateTime), userInfo: nil, repeats: true)
    }

    @objc func updateTime() {

        timerLabel.text = "\(timeFormatted(totalTime))"

            if totalTime != 0 {
                totalTime -= 1
            } else {
                endTimer()
            }
        }
        func endTimer() {
            countdownTimer.invalidate()
        }

        func timeFormatted(_ totalSeconds: Int) -> String {
            let seconds: Int = totalSeconds % 60
            let minutes: Int = (totalSeconds / 60) % 60
            //     let hours: Int = totalSeconds / 3600
            return String(format: "%02d:%02d", minutes, seconds)
        }


        @IBAction func nextScreen(_ sender: UIButton) {

            let vc = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "SecondViewController")
            navigationController?.pushViewController(vc, animated: true)
        }

}

и вот мой код в AppDelegate, чтобы таймер все еще работал в фоновом режиме:

import UIKit

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?
    var backgroundUpdateTask: UIBackgroundTaskIdentifier = UIBackgroundTaskIdentifier(rawValue: 0)

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {

        return true
    }

    func applicationWillResignActive(_ application: UIApplication) {
        self.backgroundUpdateTask = UIApplication.shared.beginBackgroundTask(expirationHandler: {
            self.endBackgroundUpdateTask()
        })
    }

    func applicationDidEnterBackground(_ application: UIApplication) {
    }

    func applicationWillEnterForeground(_ application: UIApplication) {
        self.endBackgroundUpdateTask()
    }

    func endBackgroundUpdateTask() {
        UIApplication.shared.endBackgroundTask(self.backgroundUpdateTask)
        self.backgroundUpdateTask = UIBackgroundTaskIdentifier.invalid
    }


    func applicationDidBecomeActive(_ application: UIApplication) {
        application.applicationIconBadgeNumber = 0
    }
}

второй ViewController:

import UIKit

class SecondViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.
    }

    @IBAction func backToFirstScreen(_ sender: UIButton) {

        let vc = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "FirstViewController")
        navigationController?.pushViewController(vc, animated: true)
    }

}

это контроллер просмотра изображений в раскадровке Click To See Image

Ответы [ 2 ]

1 голос
/ 07 апреля 2019

Это потому, что вы не возвращаетесь к firstViewController!

Вы создаете новый экземпляр firstViewController и помещаете его в secondViewController.

Для возврата вы можете вызвать secondViewController:

@IBAction func backToFirstScreen(_ sender: UIButton) {

    self.navigationController?.popViewController(animated: true)
}
1 голос
/ 07 апреля 2019
@IBAction func backToFirstScreen(_ sender: UIButton) 
{
   navigationController?.popViewController(animated:true)
}

Вместо того, чтобы возвращаться назад, вы создаете еще один первый объект контроллера представления, который запускает еще один таймер.Это единственная проблема, которую я вижу в вашем коде

...