質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

1127閲覧

検証用としてボタンタップ時にLocalNotificationを送りたいが送信されない

hodoru3sei

総合スコア284

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2020/06/29 13:08

困っていること

LocalNotificationがうまく送信されるか試すためにボタンを配置してLocalNotificationを送っているのですが、うまく送られずに困っています。

現状

プッシュ通知を作成しているコードは以下です

Swift

1class ViewController: UIViewController, UNUserNotificationCenterDelegate { 2 3 override func viewDidLoad() { 4 super.viewDidLoad() 5 let center = UNUserNotificationCenter.current() 6 center.requestAuthorization(options: [.alert, .badge, .sound]) {(granted, error) in 7 if granted { 8 print("許可する") 9 } else { 10 print("許可しない") 11 } 12 } 13 } 14 15 @IBAction func onTap(_ sender: Any) { 16 sendLocalNotification() 17 } 18 19 private func sendLocalNotification(){ 20 // タイトル、本文、サウンド設定の保持 21 let content = UNMutableNotificationContent() 22 content.title = "title" 23 content.body = "message" 24 content.sound = UNNotificationSound.default 25 26 // 現在日時 27 let date = Date() 28 29 // 年月日時分秒をそれぞれ個別に取得 30 let calendar = Calendar.current 31 32 // 年月日時分秒をそれぞれまとめて取得 33 let comps = calendar.dateComponents([.year, .month, .day, .hour, .minute, .second], from: date) 34 35 let trigger: UNNotificationTrigger = UNCalendarNotificationTrigger(dateMatching: comps, repeats: false) 36 37 // 識別子とともに通知の表示内容とトリガーをrequestに内包 38 let request = UNNotificationRequest(identifier: "LocalNotification", content: content, trigger: trigger) 39 40 // UNUserNotificationCenterにrequestを加える 41 let center = UNUserNotificationCenter.current() 42 center.delegate = self 43 center.add(request) { (error) in 44 if let error = error { 45 print(error.localizedDescription) 46 } 47 } 48 } 49 50} 51 52

フォアグラウンドで受け取るためにAppDelegateにも処理を書いています

Swift

1extension AppDelegate: UNUserNotificationCenterDelegate{ 2 func userNotificationCenter(_ center: UNUserNotificationCenter, willPresent notification: UNNotification, withCompletionHandler completionHandler: @escaping (UNNotificationPresentationOptions) -> Void) { 3 // アプリ起動中でもアラートと音で通知 4 completionHandler([.alert, .sound]) 5 } 6}

何か足りていない処理があったりするのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

Triggerの条件と、Delegateの設定に誤りがあるのではないでしょうか。
以下の様に変更したら、通知が表示されませんでしょうか。"★"マークをつけた箇所をご確認願います。

※"UNCalendarNotificationTrigger"を利用した際の条件が、具体的にどう問題があるかは未検証となります。ご了承ください。

Swift

1class ViewController: UIViewController, UNUserNotificationCenterDelegate { 2 3 override func viewDidLoad() { 4 super.viewDidLoad() 5 let center = UNUserNotificationCenter.current() 6 center.requestAuthorization(options: [.alert, .badge, .sound]) {(granted, error) in 7 if granted { 8 print("許可する") 9 } else { 10 print("許可しない") 11 } 12 } 13 } 14 15 @IBAction func onTap(_ sender: Any) { 16 sendLocalNotification() 17 } 18 19 private func sendLocalNotification(){ 20 // タイトル、本文、サウンド設定の保持 21 let content = UNMutableNotificationContent() 22 content.title = "title" 23 content.body = "message" 24 content.sound = UNNotificationSound.default 25 26 // 現在日時 27 let date = Date() 28 29 // 年月日時分秒をそれぞれ個別に取得 30 let calendar = Calendar.current 31 32 // 年月日時分秒をそれぞれまとめて取得 33 let comps = calendar.dateComponents([.year, .month, .day, .hour, .minute, .second], from: date) 34 35 // ★2秒後に通知するように変更 36 // let trigger: UNNotificationTrigger = UNCalendarNotificationTrigger(dateMatching: comps, repeats: false) 37 let trigger = UNTimeIntervalNotificationTrigger(timeInterval: 2, repeats: false) 38 39 // 識別子とともに通知の表示内容とトリガーをrequestに内包 40 let request = UNNotificationRequest(identifier: "LocalNotification", content: content, trigger: trigger) 41 42 // UNUserNotificationCenterにrequestを加える 43 let center = UNUserNotificationCenter.current() 44 // ★delegate対象を、AppDelegateに変更 45 // center.delegate = self 46 center.delegate = UIApplication.shared.delegate as! AppDelegate 47 center.add(request) { (error) in 48 if let error = error { 49 print(error.localizedDescription) 50 } 51 } 52 } 53 54}

スクショ

投稿2020/06/29 14:34

tsuki01

総合スコア1751

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問