添加计时器以更新UIView背景色

时间:2018-10-25 03:50:45

标签: ios swift uiview nstimer uibackgroundcolor

各位程序员,我是新来的,需要一些有关使用计时器更新UIView背景的帮助。是否可以在特定的小时范围内设置计时器?我希望能够在一天中什么时候背景会改变颜色的位置使用它。另外,即使用户未使用该应用程序,我也可以将其更新到哪里?我希望我的应用程序能够拥有非常好的UI和用户体验,而不必停留在应用程序上。我一直在研究计时器,但是它们使用的是秒,这就是为什么我会好奇是否可以使用小时。预先谢谢你!

2 个答案:

答案 0 :(得分:0)

我认为您有两个不同的任务:

  1. 根据当前时间选择适当的视图样式。 (我认为这很简单,只需使用NSDate在viewWillAppearwillMoveToWindow中获取本地时间即可。)
  2. 通过更改时间来更新活动视图。

要解决第二个任务,可以使用计时器。只需使用计时器检查时间即可,因为您可以将计时器安排到您应更改样式的最近时间:

let timer = Timer(fire: Date(timeIntervalSinceNow: 1000.0), interval: 60.0 * 60.0, repeats:true) { (sender) in
            //check current time and update view's background;
            //or send notification about time
        }
RunLoop.current.add(timer, forMode: .common)

为了使您的代码更好,请创建一些可以封装计时器创建和posting notification的有关时间更改的类。

UPD
我认为您应该从头开始。首先,阅读有关UIViewControllerUIViewNotificationCenterTimer的信息。另外,您还应该阅读event-driven architecture。之后,您将查看您的应用程序并决定可以在哪里添加colorUpdate函数。
如果您在不了解应用程序的情况下需要完整的解决方案,则可以找人为您创建解决方案(在Freelance或Upwork上或在其他可以找到外包商的地方)。

P.S。
将colorUpdate函数添加到NotificationCenter是一个坏主意,您可以将此方法添加到Notification的处理程序中。

答案 1 :(得分:0)

Swift 4的工作代码。

对于这个简单的事情,无需使用计时器或任何其他可以用UserDefaults完成的代码

通过viewWillAppear方法添加它。

import UIKit

class MainVC: UIViewController {

    override func viewWillAppear(_ animated: Bool) {

        if let Last_Update_Date = kUserDefults_("last_update_date") as? Date{

            print(Date().minutes(from: Last_Update_Date)) // Time Different in minutes

            if Date().minutes(from: Last_Update_Date) > 60{
                // update view's background
                self.view.backgroundColor = UIColor.red
                // update date in UserDefaults
                kUserDefults(Date() as AnyObject, key: "last_update_date")
            }
        }else{

            kUserDefults(Date() as AnyObject, key: "last_update_date")
        }
    }
}

将价值存储在 UserDefaults

func kUserDefults(_ value : AnyObject, key : String ){
    let defults = UserDefaults.standard
    defults.setValue(value, forKey: key)
    defults.synchronize()
}

UserDefaults

检索值
func kUserDefults_( _ key : String) -> AnyObject? {
    let defults = UserDefaults.standard
    return defults.value(forKey: key ) as AnyObject?
}

日期 extension

extension Date {
    /// Returns the amount of minutes from another date
    func minutes(from date: Date) -> Int {
        return Calendar.current.dateComponents([.minute], from: date, to: self).minute ?? 0
    }
}