计时器倒计时6小时,到时间后停止计时,再按一次按钮再开始6小时

问题描述

我需要一个计时器来倒计时6个小时。

。到达时间后必须重置

。必须在按下按钮时将其激活。

。它必须在应用打开或关闭时继续运行。

我有一个倒计时计时器,到另一个日期,还有另一个倒计时计时器,仅在应用程序处于活动状态时有效。

我该如何制作一个6小时的计时器?

倒数计时器⬇︎

var timeCount: NSDate?
var timer = Timer()

timer = Timer.scheduledTimer(timeInterval: 1,target: self,selector: #selector(countdown),userInfo: nil,repeats: true)

@objc func countdown()
{
let endTime = "08-10-2020 18:00:00"
let formatter = DateFormatter()
formatter.dateFormat = "dd-MM-yyyy HH:mm:ss"
timeCount = (formatter.date(from: endTime))! as NSDate

let currentDate = Date()
let calendar = Calendar.current

let diffDateComponents = calendar.dateComponents([.hour,.minute,.second],from: currentDate,to: timeCount! as Date)

let countdown = "\(diffDateComponents.hour ?? 0):\(diffDateComponents.minute ?? 0):\(diffDateComponents.second ?? 0)"

let hourS = diffDateComponents.hour!
let minuteS = diffDateComponents.minute!
let secondS = diffDateComponents.second!

print(countdown)

if countdown == "0:0:0"
{
   button.setTitle("PRESS",for: .normal)
   button.backgroundColor = .green
   timer.invalidate()
}
else
{
   button.setTitle("PRESS WHEN TIME RUNS OUT" + "\n\(String(format: "%02d:%02d:%02d",hourS,minuteS,secondS))",for: .normal)
   button.backgroundColor = .red
}
}

仅在应用程序处于活动状态时倒计时⬇︎

var timer = Timer()
var hours = 06
var minutes = 00
var secs = 00


timer = Timer.scheduledTimer(timeInterval: 1,repeats: true)

@objc func countdown()
{
    secs = secs-1
    if (secs<0)
    {
        secs = 59
        minutes=minutes-1
        if (minutes<0)
        {
            minutes = 59
            hours = hours-1
            if (hours<0)
            {
                hours = 0
                minutes = 0
                secs = 0
                
                timer.invalidate()
            }
        }
    }

var hourp: String
var minutesp: String
var secp: String
    
if(hours<10)
{
hourp = "0" + String(describing: hours)
}
else
{
hourp = String(describing: hours)
}
if(minutes<10)
{
minutesp = "0" + String(describing: minutes)
}
else
{
minutesp = String(describing: minutes)
}
if(secs<10)
{
secp = "0" + String(describing: secs)
}
else
{
secp = String(describing: secs)
}
let timing = hourp + ":" + minutesp + ":" + secp
    
print(timing)

if hours == 0 && minutes == 0 && secs == 0
{
button.setTitle("PRESS",for: .normal)
button.backgroundColor = .green
else
{
button.setTitle("PRESS WHEN TIME RUNS OUT" + "\n\(timing)",for: .normal)
button.backgroundColor = .red
}

}

解决方法

您可以获取时间并在按下按钮时保存时间,然后可以在viewdiload中花费时间进行比较

就是这样;

首先为当前时间创建2个变量,另一个用于比较

var currentTime = Date()
var compareTime = Date().addingTimeInterval(21600) //6 hours is 21600 second

现在,我们需要节省点击按钮的时间;

UserDefaults.standard.set(currentTime,forKey: "time")

现在我们需要比较这些时间;

override func viewDidLoad() {
    super.viewDidLoad()
    var time = UserDefaults.standard.object(forKey: "time")
        if let newTime = time as? Date {
        if let difference = Calendar.current.dateComponents([.hour],from: newTime,to: compareTime).hour {
            if difference > 6 {
              //make whatever you want if 6 hours is finish
            }
               }
            }
    }
,

这就是我最终要做的事情,它才能按预期工作。

感谢@BurakKöse的回答,指导我朝正确的方向前进。

import UIKit
import Foundation

var timer = Timer()
var currentTime = Date()
var compareTime = Date().addingTimeInterval(-21600)


func setupButtonTitle()
{
 if UserDefaults.standard.object(forKey: "count6") == nil
    {
        button.setTitle("PRESS",for: .normal)
        button.backgroundColor = .green
    }
    else
    {
        button.setTitle("PRESS" + "\nIN " + "\(startTimer()))",for: .normal)
    }
  button.addTarget(self,action: #selector(buttonTap),for: .touchUpInside)
}


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

@objc func sixHourCountdown()
{
    let timeStarted = UserDefaults.standard.object(forKey: "count6")
    
    let timeStart = timeStarted as! Date
    let diffComponents = Calendar.current.dateComponents([.hour,.minute,.second],from: compareTime,to: timeStart)
    let hour = diffComponents.hour!
    let minute = diffComponents.minute!
    let second = diffComponents.second!
    let timeRemaining = String(format: "%02d:%02d:%02d",hour,minute,second)

    compareTime += 1
    
    if hour == 0 && minute == 0 && second == 0 || timeStart < compareTime
    {
        button.setTitle("PRESS",for: .normal)
        button.backgroundColor = .green
        timer.invalidate()
    }
    else
    {
        button.setTitle("PRESS IN" + "\n\(timeRemaining)",for: .normal)
    }
}


@objc func buttonTap()
{
    if button.currentTitle != "PRESS"
    {
        button.backgroundColor = .red
        DispatchQueue.main.asyncAfter(deadline: .now() + .seconds(2),execute:
        {
         button.backgroundColor = .yellow
        })
    }
    if button.currentTitle == "PRESS" && button.backgroundColor == .green
    {
        UserDefaults.standard.set(currentTime,forKey: "count6")

        let otherVC = OTHERVC()
        self.navigationController?.pushViewController(otherVC,animated: true)
    }
}


override func viewDidLoad() {
    super.viewDidLoad()


setupButtonTitle()

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...