###やりたいこと
Deep LinkのCustome URL Schemeでアプリを立ち上げ、
そのURLの内容に合わせてビューの表示内容を変える
やったこと
Deep Linkの設定は済ませており、room://xxx@yyyという形式のDeepLinkを設定しています。
①アプリ起動中にDeepLinkを押す
②アプリをタスクキルした状態でDeepLinkを押す
の2つの方法でDeepLinkの実験をしました。
問題点
①に関しては
scene(_ scene: UIScene, openURLContexts URLContexts: Set<UIOpenURLContext>)
のdelegateメソッドで受け取ることができ、期待通りの動作をしました。
②に関しては
scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions)
のメソッドで処理するらしいのですが、
Appleのリファレンス(下記URL)を見て実装しているものの、うまくDeepLinkのURLを受けて取れていないようです。
Supporting Universal Links in Your App
###該当部分のコード
Swift
1func scene(_ scene: UIScene, willConnectTo session: UISceneSession, options connectionOptions: UIScene.ConnectionOptions) { 2 3 // Custom URL SchemeのURLを取得 4 if let urlContext = connectionOptions.urlContexts.first { 5 let url = urlContext.url 6 7 // StoryboardからViewControllerをロードする 8 let storyboard = UIStoryboard(name: "Main", bundle: nil) 9 let vc = storyboard.instantiateViewController(withIdentifier: "doorvc") as! DoorViewController 10 vc.modalPresentationStyle = .fullScreen 11 vc.arg = url.host 12 13 // ViewControlelrを表示する 14 window?.rootViewController?.present(vc, animated: true, completion: nil) 15 return 16 } 17}
実行時の挙動
②を実際に実行した時はDoorViewControllerが表示されないです。
恐らくif文の中に入っていないと思われます。
恐らく、、、というのは、確認の方法が分からないからです。
①は普通にコンソール上でprint文デバッグで確認できますが、
②は一度タスクキルをするため、Xcode上でコンソールを表示することが出来ず、
どういう挙動をしているのかが全く分からず、手詰まりの状態です。
環境
Xcode 13.2
MacOS 11.5.1
Swift
DeepLinkのURL(room://xxx@yyy)の取得の仕方、
もしくはタスクキルして再度アプリを起動した時にコンソールを確認する方法でもいいので、
わかる方がいらっしゃいましたら助けて頂けると幸いです。
よろしくお願いします。
補足(やる必要のないこと)
Universal Linksは①②双方の方法で実装&動作確認済みです。
Custome URL Schemeを使ってアプリを起動させた時のURL取得方法を
教えて頂けると幸いです m(_ _)m
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。