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

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

ただいまの
回答率

89.19%

(swift3) アクション付きローカル通知の実装について

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 3,118

dottext

score 39

前提・実現したいこと

ローカル通知にボタンを配置したい。

この図のようなものをつくりたい。
(参照 http://dev.classmethod.jp/references/ios8-notification-action/)

ロック画面でスライドした時に現れるボタンの編集がしたい。

発生している問題・エラーメッセージ


現状ですと上記のようにロック画面でのアクションがclearのみになっている。
ここに現れるボタンの編集がしたい。

(参照サイト http://qiita.com/mshrwtnb/items/3135e931eedc97479bb5)


このようなアクション通知は実装できています。

言語:swift 
User Notifications Frameworkを使って実装したいが、やり方がわからない。

試したこと

AppDelegate.swift

func applicationDidEnterBackground(_ application: UIApplication) {

        enum ActionIdentifier: String {
            case attend
            case absent
        }

        let attend = UNNotificationAction(identifier: ActionIdentifier.attend.rawValue,
                                          title: "出席", options: [])

        let absent = UNNotificationAction(identifier: ActionIdentifier.absent.rawValue,
                                          title: "欠席",
                                          options: [])


        let category = UNNotificationCategory(identifier: "message", actions: [attend, absent], intentIdentifiers: [], options: [])


        UNUserNotificationCenter.current().setNotificationCategories([category])



        let content = UNMutableNotificationContent()
        content.title = "出席確認"
        content.body = "今日のイベントに参加しますか?"
        content.sound = UNNotificationSound.default()

        // categoryIdentifierを設定
        content.categoryIdentifier = "message"

        // 5秒後
        let trigger = UNTimeIntervalNotificationTrigger(timeInterval: 5, repeats: false)
        let request = UNNotificationRequest(identifier: "FiveSecond",
                                            content: content,
                                            trigger: trigger)

        UNUserNotificationCenter.current().add(request, withCompletionHandler: nil)

        @available(iOS 10.0, *)
        func userNotificationCenter(_ center: UNUserNotificationCenter,
                                    didReceive response: UNNotificationResponse,
                                    withCompletionHandler completionHandler: () -> Void) {

            switch response.actionIdentifier {
            case ActionIdentifier.attend.rawValue:
                debugPrint("出席します")
            case ActionIdentifier.absent.rawValue:
                debugPrint("欠席します")
            default:
                ()
            }

            completionHandler()
        }

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

以下のサイトを参考にしてみてください。

<Swift>iOS 10 User Notifications Framework実装まとめ

通知を受けた時にロック画面では以下の様な見え方になりました。
s

確認したコード

★ AppDelegate.swift

import UIKit
import UserNotifications

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?


    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {


        if #available(iOS 10.0, *) {
            // iOS 10
            let center = UNUserNotificationCenter.current()
            center.requestAuthorization(options: [.badge, .sound, .alert], completionHandler: { (granted, error) in
                if error != nil {
                    return
                }

                if granted {
                    debugPrint("通知許可")
                } else {
                    debugPrint("通知拒否")
                }
            })

        } else {
            // iOS 9
            let settings = UIUserNotificationSettings(types: [.badge, .sound, .alert], categories: nil)
            UIApplication.shared.registerUserNotificationSettings(settings)
        }
        return true
    }
}

★ ViewController.swift

import UIKit
import UserNotifications

enum ActionIdentifier: String {
    case attend
    case absent
}

class ViewController: UIViewController, UNUserNotificationCenterDelegate {

    override func viewDidLoad() {
        super.viewDidLoad()

    }

    @IBOutlet weak var a: UIButton!

    @IBAction func g(_ sender: AnyObject) {

        let attend = UNNotificationAction(identifier: ActionIdentifier.attend.rawValue,
                                          title: "出席", options: [])

        let absent = UNNotificationAction(identifier: ActionIdentifier.absent.rawValue,
                                          title: "欠席",
                                          options: [])


        let category = UNNotificationCategory(identifier: "message", actions: [attend, absent], intentIdentifiers:  [], options: [])

        UNUserNotificationCenter.current().setNotificationCategories([category])
        UNUserNotificationCenter.current().delegate = self


        let content = UNMutableNotificationContent()
        content.title = "出席確認"
        content.body = "今日のイベントに参加しますか?"
        content.sound = UNNotificationSound.default()

        // categoryIdentifierを設定
        content.categoryIdentifier = "message"

        // 5秒後
        let trigger = UNTimeIntervalNotificationTrigger(timeInterval: 5, repeats: false)
        let request = UNNotificationRequest(identifier: "FiveSecond",
                                            content: content,
                                            trigger: trigger)

        UNUserNotificationCenter.current().add(request, withCompletionHandler: nil)
    }


    @available(iOS 10.0, *)
    func userNotificationCenter(_ center: UNUserNotificationCenter,
                                didReceive response: UNNotificationResponse,
                                withCompletionHandler completionHandler: @escaping () -> Swift.Void) {

        switch response.actionIdentifier {
        case ActionIdentifier.attend.rawValue:
            debugPrint("出席します")
        case ActionIdentifier.absent.rawValue:
            debugPrint("欠席します")
        default:
            ()
        }

        completionHandler()
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()

    }
}

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/10/22 17:20

    回答ありがとうございます。早く回答を頂き嬉しく思います。

    回答いただいたようなアクション通知は実装できました。
    しかし、ロック画面におけるスライド操作によって表れるボタンは編集されていません。
    実装方法をお知りであればご教授願いたいです。

    キャンセル

  • 2016/10/22 17:40 編集

    iOS8の Notification Action が iOS10の UNNotificationActionに置き換わっていると思うので同じ事ができていると思いますよ。

    iOS8ではボタンが見えてそのまま更に横にスワイプすると削除されるのではなかったでしたっけ?なので見え方が変わっただけと思います。

    キャンセル

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

  • ただいまの回答率 89.19%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる