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

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

ただいまの
回答率

87.78%

[swift/iOS]バックグランド状態からフォアグランド状態へ遷移させたい

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 1
  • VIEW 1,600

score 45

前提・実現したいこと

※少々実現したいことを修正しました。

アプリ起動時に定期実行処理(API呼び出し)を処理させて、
バックグラウンド時に遷移しても処理を続ける実装をしようとしています。
バックグラウンドに遷移後に、APIのレスポンスでNGが返ってきた場合に
フォアグラウンドに遷移させてアラートを表示したいのですが、
フォアグラウンドへの遷移の方法がわからないので教えていただきたいです。

※調べ方が悪くて欲しい情報にたどり着けていない可能性もありますが、教えて下さい。

該当のソースコード

import UIKit
import Firebase
//import FireBaseMessaging
import UserNotifications

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate {

    var window: UIWindow?
    var viewController: ViewController!
    var backgroundTaskID : UIBackgroundTaskIdentifier = UIBackgroundTaskIdentifier(rawValue: 100)

    var sDeviceToken : String!
    var bPost = false

    func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
        FirebaseApp.configure()

        //Messaging.messaging().delegate = self as MessagingDelegate

        if #available(iOS 10.0, *) {
            UNUserNotificationCenter.current().delegate = self as! UNUserNotificationCenterDelegate

            UNUserNotificationCenter.current().requestAuthorization(options: [.sound, .alert, .badge], completionHandler: {_, _ in })
            // プッシュ通知の登録
            application.registerForRemoteNotifications()
        } else {
            // iOS10未満のためプッシュ通知しない
        }
        return true
    }

    // プッシュ通知受信時、プッシュ通知タップ時
    func application(_ application: UIApplication, didReceiveRemoteNotification userInfo: [AnyHashable : Any], fetchCompletionHandler completionHandler: @escaping (UIBackgroundFetchResult) -> Void) {

        switch application.applicationState {
        case .inactive:     // バックグラウンド状態でプッシュ通知から起動したとき
            if (userInfo[AnyHashable("URL")] != nil) {
                // 画面遷移
                let sUrl = userInfo["URL"]
                //viewController.ReqesutURL(sUrl)
            }
            break
        case .active:       // アプリ起動時にプッシュ通知を受信したとき
            // バッジデクリメント
            DispatchQueue.main.async {
                UIApplication.shared.applicationIconBadgeNumber = UIApplication.shared.applicationIconBadgeNumber + 1
            }
            break
        case .background:   // バックグラウンド状態でプッシュ通知を受信したとき
            break
        default:
            break
        }
        // バッジデクリメント
        DispatchQueue.main.async {
            UIApplication.shared.applicationIconBadgeNumber = UIApplication.shared.applicationIconBadgeNumber - 1
        }
        completionHandler(UIBackgroundFetchResult.newData)
    }

    // デバイストークン取得時イベント
    func application(_ application: UIApplication, didRegisterForRemoteNotificationsWithDeviceToken deviceToken: Data) {

        InstanceID.instanceID().instanceID { (result, error) in
            if let error = error {
                print("Error fetching remote instance ID: \(error)")
            } else if let result = result {
                // 変更があれば、APIを使用して送信
                if (self.sDeviceToken != nil && self.sDeviceToken != result.token) {
                    self.sDeviceToken = result.token
                    //self.viewController.postAsync()
                    self.bPost = true
                } else {
                    self.sDeviceToken = result.token
                }
                print("DeviceToken: \(result.token)")
            }
        }
    }

    // バックグラウンド遷移直前に呼ばれる
    func applicationWillResignActive(_ application: UIApplication) {
        self.backgroundTaskID = application.beginBackgroundTask(){
            [weak self] in
            application.endBackgroundTask((self?.backgroundTaskID)!)
            self?.backgroundTaskID = UIBackgroundTaskIdentifier.invalid
        }
    }

    func applicationDidEnterBackground(_ application: UIApplication) {
        // Use this method to release shared resources, save user data, invalidate timers, and store enough application state information to restore your application to its current state in case it is terminated later.
        // If your application supports background execution, this method is called instead of applicationWillTerminate: when the user quits.
    }

    func applicationWillEnterForeground(_ application: UIApplication) {
        // Called as part of the transition from the background to the active state; here you can undo many of the changes made on entering the background.
    }

    // アプリがアクティブになるたびに呼ばれる
    func applicationDidBecomeActive(_ application: UIApplication) {
        application.endBackgroundTask(self.backgroundTaskID)
    }

    // アプリ終了時イベント
    func applicationWillTerminate(_ application: UIApplication) {
        // Called when the application is about to terminate. Save data if appropriate. See also applicationDidEnterBackground:.
    }
}
import UIKit

class ViewController: UIViewController {

    var timer = Timer()

    override func viewDidLoad() {
        super.viewDidLoad()

        dispAlert()
    }

    @objc func dispAlert()  {
        if self.timer.isValid {
            self.timer.invalidate()
        }
        self.timer = Timer.scheduledTimer(timeInterval: 15, target: self, selector: #selector(updating), userInfo: nil, repeats: true)

        let alert = UIAlertController(title: "テスト", message: "バックグラウンド", preferredStyle: .alert)
        let confirmAction: UIAlertAction = UIAlertAction(title: "アラート", style: .default, handler:nil)
        alert.addAction(confirmAction)
        self.present(alert, animated: true, completion: nil)
    }
}

補足情報(FW/ツールのバージョンなど)

MacOS HighSierra
Swift 3
Xcode 10.1

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • takabosoft

    2019/12/12 10:54

    そういうアプリを見たことがありますか?

    ローカル通知をして、それをユーザーにタップさせてアプリを起動させることはできると思いますが、それ以外の方法で勝手にフォアグラウンドに来るアプリは私はみたことがありません。

    むしろローカル通知をアラート代わりにするのがベストな気もします。

    キャンセル

  • entaro12345

    2019/12/12 11:51

    ないですね。
    定期的にAPI通信をして、APIのレスポンスでNGがあれば、フォアグラウンドにしてアラートしたかったのですが、やはり無理なのですかね?

    キャンセル

回答 2

checkベストアンサー

0

stackoverflowでも出来ないという回答がありましたので、リンクを張っておきます。

How to bring application to foreground in ios?
https://stackoverflow.com/questions/22930259/how-to-bring-application-to-foreground-in-ios

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/12/12 14:18

    ありがとうございます。
    ユーザーアクションが必要ということがわかりました。

    キャンセル

0

ユーザーのインターアクションなしで、フォアグランド状態へ遷移するのは不可能です。

解決方法は:

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/12/12 14:17

    ありがとうございます。
    やはり何かしらユーザーアクションがないと不可なのですね。

    キャンセル

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

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

関連した質問

同じタグがついた質問を見る