iOS Facebook sdk 接入指南(AEM)

聚合事件測量(Aggregated Event Measurement,簡稱AEM)

您可以使用聚合事件測量(AEM)來測量那些已選擇退出應用跟蹤的iOS 14.5+用戶的應用程序事件。您可以通過使用Facebook SDK for iOS來集成AEM。

使用Facebook SDK

步驟1:設置您的開發(fā)環(huán)境

按照“入門指南 - iOS”中的說明進行操作,直到第五步。當您到達第六步時,請返回本頁面并繼續(xù)進行第二步。

步驟2:支持iOS通用鏈接

通過滿足支持iOS通用鏈接的先決條件,來支持深度鏈接到您的移動應用。

步驟3:連接您的應用程序代理和場景代理

當您支持iOS通用鏈接時,使用以下方法來與AEM集成。

iOS v14.0.0及以后版本的Facebook SDK

為了確保您的應用能夠正確支持通過通用鏈接的應用廣告中的深度鏈接,請在您的應用程序代理中實現application(:continue:restorationHandler:),并從您的實現中調用ApplicationDelegate.shared.application(_:continue:)。您的代碼可能如下所示:

func application(_ application: UIApplication,
                   continue userActivity: NSUserActivity,
                   restorationHandler: @escaping ([UIUserActivityRestoring]?) -> Void
                 ) -> Bool
{
  ApplicationDelegate.shared.application(application, continue: userActivity)
  
  // 實現的其余部分...
  
  return true
}

如果您的應用選擇了場景,那么在scene(:continue:)和scene(:willConnectTo:options:)中添加以下代碼:

func scene(_ scene: UIScene,
             continue userActivity: NSUserActivity
           )
{
  ApplicationDelegate.shared.application(.shared, continue: userActivity)
  
  // 實現的其余部分...
}
  
  
func scene(_ scene: UIScene,
             willConnectTo session: UISceneSession,
             options connectionOptions: UIScene.ConnectionOptions
           )
{
  if let userActivity = connectionOptions.userActivities.first,
         userActivity.activityType == NSUserActivityTypeBrowsingWeb
  {
    ApplicationDelegate.shared.application(.shared, continue: userActivity)
  }
  
  // 實現的其余部分...
}  

iOS v13.2.0及更早版本的Facebook SDK

為了確保您的應用能夠正確支持通過通用鏈接的應用廣告中的深度鏈接,請在您的應用程序代理中實現application(:continue:restorationHandler:),并從您的實現中調用ApplicationDelegate.shared.application(_:open:options:)。您的代碼可能如下所示:

func application(_ application: UIApplication,
                   continue userActivity: NSUserActivity,
                   restorationHandler: @escaping ([UIUserActivityRestoring]?) -> Void
                ) -> Bool
{
  if userActivity.activityType == NSUserActivityTypeBrowsingWeb,
     let url = userActivity.webpageURL
  {
    ApplicationDelegate.shared.application(application, open: url, options: [:])
  }
  
  // 實現的其余部分...

  return true
}

如果您的應用選擇了場景,那么在scene(:continue:)和scene(:willConnectTo:options:)中添加以下代碼:

func scene(_ scene: UIScene,
             continue userActivity: NSUserActivity
           )
{
  if let url = userActivity.webpageURL,
     userActivity.activityType == NSUserActivityTypeBrowsingWeb
  {
    ApplicationDelegate.shared.application(.shared, open: url, options: [:])
  }
    
  // 實現的其余部分...
}
  
  
func scene(_ scene: UIScene,
             willConnectTo session: UISceneSession,
             options connectionOptions: UIScene.ConnectionOptions
          )
{
  if let userActivity = connectionOptions.userActivities.first,
     let url = userActivity.webpageURL,
     userActivity.activityType == NSUserActivityTypeBrowsingWeb
  {
    ApplicationDelegate.shared.application(.shared, open: url, options: [:])
  }

  // 實現的其余部分...
}

當您在移動應用中使用自定義URL以支持AEM時
將AppDelegate.swift方法中的代碼替換為以下代碼。這段代碼在您的應用啟動時初始化SDK,并將深度鏈接URL傳遞給SDK。即使是在冷啟動時打開應用,重新參與廣告中的深度鏈接URL也應該傳遞給iOS SDK。

如果您是程序化設置Facebook應用ID,請在SDK初始化前設置應用ID。
// AppDelegate.swift

import UIKit
import FBSDKCoreKit

@UIApplicationMain
class AppDelegate: UIResponder, UIApplicationDelegate
{    
  func application(_ application: UIApplication,
                   didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?
                   ) -> Bool
  {  
    // 如果您已在info.plist中配置了應用ID,則不需要設置應用ID
    Settings.shared.appID  = APP_ID    

    // 初始化iOS SDK
    ApplicationDelegate.shared.application
    (
      application,
      didFinishLaunchingWithOptions: launchOptions
    )

    return true
  }
  

  func application(_ app: UIApplication,
                   open url: URL,
                   options: [UIApplication.OpenURLOptionsKey : Any] = [:]
                   ) -> Bool
  {
    // 將深度鏈接URL傳遞給iOS SDK
    ApplicationDelegate.shared.application
    (
      app,
      open: url,
      sourceApplication: options[UIApplication.OpenURLOptionsKey.sourceApplication] as? String,
      annotation: options[UIApplication.OpenURLOptionsKey.annotation]
    )
  }  
}

iOS 13將打開URL的功能移動到了SceneDelegate。如果您使用的是iOS 13,請在您的SceneDelegate中添加以下方法:

// SceneDelegate.swift

import FBSDKCoreKit
  ...
func scene(_ scene: UIScene, 
           openURLContexts URLContexts: Set<UIOpenURLContext>
           )
{
  guard let url = URLContexts.first?.url else
  {
    return
  }

  // 將深度鏈接URL傳遞給iOS SDK
  ApplicationDelegate.shared.application
  (
    UIApplication.shared,
    open: url,
    sourceApplication: nil,
    annotation: [UIApplication.OpenURLOptionsKey.annotation]
  )
}

步驟3:添加應用事件

要添加您想要跟蹤的應用事件,請按照“入門指南 - iOS”中的說明從第七步開始操作。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容