8

Is it possible to show some kind of a local notification from an app, even if the app isn't running(also not in background)?

For example a daily reminder or something like that. I know that it is possible with push-notifications, but it doesn't fit for my app.

Christian
  • 22,585
  • 9
  • 80
  • 106

3 Answers3

19

You can easily schedule local notifications, and they will be presented at the scheduled date and time regardless of the app's state.

First you need to get permission from the user to present notifications, like this:

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
    application.registerUserNotificationSettings(UIUserNotificationSettings(forTypes: UIUserNotificationType.Sound|UIUserNotificationType.Alert | UIUserNotificationType.Badge, categories: nil))
    return true
}

Then you create the notification like this:

var localNotification:UILocalNotification = UILocalNotification()
localNotification.alertAction = "This is"
localNotification.alertBody = "A notification"
localNotification.fireDate = NSDate(timeIntervalSinceNow: 15)
UIApplication.sharedApplication().scheduleLocalNotification(localNotification)

Have a look at the Local and Remote Notification Programming Guide.

Emil
  • 7,220
  • 17
  • 76
  • 135
  • This is an awesome answer and resolved my problem. Works like a charm. – Christian Jan 01 '15 at 17:35
  • [UILocalNotification](https://developer.apple.com/documentation/uikit/uilocalnotification) has been deprecated. Take a look at [this Swift 3 example](https://stackoverflow.com/a/45247943/4754881) for local notifications with [UNUserNotificationCenter](https://developer.apple.com/documentation/usernotifications/unusernotificationcenter). – Derek Soike Jul 21 '17 at 23:13
0

In AppDelegate, use this function instead

func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool {
    let settings = UIUserNotificationSettings(forTypes: [.Alert, .Badge, .Sound], categories: nil)
    application.registerUserNotificationSettings(settings)
    return true;
}
Berkay92
  • 552
  • 6
  • 21
0

Most of the solutions outlined above have all been deprecated. Use this UNUserNotification APIs instead

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

func registerForLocalNotification() {
       UNUserNotificationCenter.current()
           .requestAuthorization(options: [.alert, .sound, .badge]) { [weak self] granted, _ in
               print("Permission: \(granted)")
           }
   }