首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Swift - UNUsernotification检查BadgeNumberIcon中的更改

Swift - UNUsernotification检查BadgeNumberIcon中的更改
EN

Stack Overflow用户
提问于 2017-09-18 22:31:46
回答 2查看 700关注 0票数 1

我想在标签中显示徽章号码的值。

到目前为止,我已经将所有内容都放到了我的viewWillAppear中。因此,每次加载控制器时,都会对变量进行赋值。代码如下:

代码语言:javascript
复制
var deliveredNotif = Int()

 override func viewWillAppear(_ animated: Bool) {
    super.viewWillAppear(true)
deliveredNotif = UIApplication.shared.applicationIconBadgeNumber
myBadgeLabel.text = "\(deliveredNotif)"
}

我的问题是:如果控制器是活动的,并且viewWillAppear已经被调用,我如何更新deliveredNotif?这意味着,如果我在控制器中,有没有办法触发一个函数,每当applicationIconBadgeNumber的值改变时,它就会更新deliveredNotif的值?

谢谢!

-UPDATE-我的解决方案我创建了一个常量变量:NSNumber iconBadgeNumber = var ()

在我的Appdelegate中,我有:

代码语言:javascript
复制
func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) {
    completionHandler([.alert, .badge])
    NotificationCenter.default.post(name: NSNotification.Name(rawValue: "applicationIconBadgeNumber"), object: nil)
    iconBadgeNumber = UIApplication.shared.applicationIconBadgeNumber + 1 as NSNumber
}

然后在我的控制器中:

代码语言:javascript
复制
override func viewDidLoad() {
    super.viewDidLoad()
 NotificationCenter.default.addObserver(self, selector: #selector(updateIconBadgeNumber), name: NSNotification.Name(rawValue: "applicationIconBadgeNumber"), object: nil)


}

@objc func updateIconBadgeNumber() {
    if iconBadgeNumber == 0 {
        print("zero")
    } else {
    print("there unread notification")
    }
}
EN

回答 2

Stack Overflow用户

发布于 2017-09-18 23:28:00

您可以将您的UIViewController设置为密钥路径applicationIconBadgeNumber的观察者:

首先注册远程通知。在您的didFinishLaunchingWithOptions函数中,添加:

代码语言:javascript
复制
    let center = UNUserNotificationCenter.current()
    center.requestAuthorization(options: [.alert, .badge, .sound]) { _, _ in
        DispatchQueue.main.async {
            application.registerForRemoteNotifications()
        }
    }

别忘了在文件的顶部添加:import UserNotifications

然后在你的viewDidLoad中添加:

代码语言:javascript
复制
UIApplication.shared.addObserver(self, forKeyPath: "applicationIconBadgeNumber", options: .new, context: nil)

然后,覆盖observeValue函数:

代码语言:javascript
复制
    override func observeValue(forKeyPath keyPath: String?,
                                        of object: Any?,
                                           change: [NSKeyValueChangeKey : Any]?,
                                          context: UnsafeMutableRawPointer?) {
        if keyPath == "applicationIconBadgeNumber" {
            deliveredNotif = UIApplication.shared.applicationIconBadgeNumber
            myBadgeLabel.text = "\(deliveredNotif)"
        }
    }
票数 2
EN

Stack Overflow用户

发布于 2017-09-18 23:11:35

您有3种不同的方法来通知对象某个值已更改:

  • 首先,您有通知中心,以便在您的值发生更改时通知观察者。查看这个post,你会在互联网上找到更多的信息,你也可以使用协议和委托,但是对于一个值的通知更新来说似乎有点繁琐。
  • 最后你应该看看这个post,它解释了键值观察的原理,我相信你已经听说过它了。

最后,这篇终极文章将向您解释何时应该使用每一条原则。

KVO vs NSNotification vs protocol/delegates?

在发布一个已经被多次回答的问题之前,你应该尝试进行更认真的调查。

希望这篇文章能对你有所帮助。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/46281910

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档