本指南的適用對象為想透過 AdMob 透過 iOS 應用程式營利,但未使用 Firebase 的發布商。如果您打算在應用程式中加入 Firebase 或考慮使用 Firebase,請改為參閱本指南的 AdMob 和 Firebase 版本。
將 Google Mobile Ads SDK 整合至應用程式,是顯示廣告和賺取收益的第一步。整合 SDK 後,您就可以執行一或多個支援的廣告格式。
必要條件
- 使用 Xcode 13.2.1 或更高版本
- 指定 iOS 10.0 以上版本
- 建議您:建立 AdMob 帳戶並註冊應用程式。
匯入 Mobile Ads SDK
CocoaPods (偏好)
將 SDK 匯入 iOS 專案最簡單的方法就是使用 CocoaPods。開啟專案的 Podfile,然後將這一行新增至應用程式的目標:
pod 'Google-Mobile-Ads-SDK'
然後透過指令列執行:
pod install --repo-update
如果您是第一次使用 CocoaPods,請參閱其官方說明文件,瞭解如何建立及使用 Podfile。
Swift 套件管理員
從 9.0.0 版開始,Google Mobile Ads SDK 支援 Swift Package Manager。請按照下列步驟匯入 Swift 套件。
在 Xcode 中依序前往 [File] (檔案) > [Add Packages...] (新增套件),以安裝 Google Mobile Ads Swift Package。
在畫面顯示的提示中,搜尋 Google Mobile Ads Swift Package GitHub 存放區:
https://github.com/googleads/swift-package-manager-google-mobile-ads.git
選取您要使用的 Google 行動廣告 Swift Package 版本。 如要進行新專案,建議您使用使用下一個主要版本。
完成後,Xcode 就會開始解析您的套件依附元件,並在背景下載。如要進一步瞭解如何新增套件依附元件,請參閱 Apple 的文章。
手動下載
直接下載及解壓縮 SDK 架構,然後將下列架構匯入 Xcode 專案:
GoogleAppMeasurement.xcframework
GoogleAppMeasurementIdentitySupport.xcframework
GoogleMobileAds.xcframework
GoogleUtilities.xcframework
nanopb.xcframework
PromisesObjC.xcframework
UserMessagingPlatform.xcframework
請在專案的建構設定中將
-ObjC
連接器標記新增至「Other Linker Flags」(其他連結器標記)::
更新您的 Info.plist
更新應用程式的 Info.plist
檔案以新增兩個金鑰:
包含AdMob app ID found in the AdMob UI字串值的
GADApplicationIdentifier
金鑰。具有 Google (
cstr6suwn9.skadnetwork
) 的SKAdNetworkIdentifier
值的SKAdNetworkItems
鍵,以及已向 Google 提供這些值的第三方買家。
完整程式碼片段
<key>GADApplicationIdentifier</key> <string>ca-app-pub-3940256099942544~1458002511</string> <key>SKAdNetworkItems</key> <array> <dict> <key>SKAdNetworkIdentifier</key> <string>cstr6suwn9.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>4fzdc2evr5.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>4pfyvq9l8r.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>2fnua5tdw4.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>ydx93a7ass.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>5a6flpkh64.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>p78axxw29g.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>v72qych5uu.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>ludvb6z3bs.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>cp8zw746q7.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>c6k4g5qg8m.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>s39g8k73mm.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>3qy4746246.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>3sh42y64q3.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>f38h382jlk.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>hs6bdukanm.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>prcb7njmu6.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>v4nxqhlyqp.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>wzmmz9fp6w.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>yclnxrl5pm.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>t38b2kh725.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>7ug5zh24hu.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>9rd848q2bz.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>y5ghdn5j9k.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>n6fk4nfna4.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>v9wttpbfk9.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>n38lu8286q.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>47vhws6wlr.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>kbd757ywx3.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>9t245vhmpl.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>a2p9lx4jpn.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>22mmun2rn5.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>4468km3ulz.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>2u9pt9hc89.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>8s468mfl3y.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>av6w8kgt66.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>klf5c3l5u5.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>ppxm28t8ap.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>424m5254lk.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>ecpz2srf59.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>uw77j35x4d.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>mlmmfzh3r3.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>578prtvx9j.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>4dzt52r2t5.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>gta9lk7p23.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>e5fvkxwrpn.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>8c4e2ghe7u.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>zq492l623r.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>3rd42ekr43.skadnetwork</string> </dict> <dict> <key>SKAdNetworkIdentifier</key> <string>3qcr597p9d.skadnetwork</string> </dict> </array>
如果您尚未建立 AdMob 帳戶並註冊應用程式,現在就是很好的好時機。
初始化 Mobile Ads SDK
載入廣告前,請針對 GADMobileAds.sharedInstance
呼叫 startWithCompletionHandler:
方法,該方法會初始化 SDK,並在初始化完成後 (或 30 秒逾時後) 回呼完成處理常式。這項操作只需要執行一次,最好在應用程式啟動時執行。請盡早呼叫 startWithCompletionHandler:
。
以下範例說明如何在 AppDelegate
中呼叫 startWithCompletionHandler:
方法:
AppDelegate.m 範例 (摘錄)
Swift
import GoogleMobileAds @UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool { GADMobileAds.sharedInstance().start(completionHandler: nil) return true } }
Objective-C
@import GoogleMobileAds; @implementation AppDelegate - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { [GADMobileAds.sharedInstance startWithCompletionHandler:nil]; return YES; } @end
如果您使用的是中介服務,建議等到呼叫完成程序再呼叫廣告,這樣才能確保所有中介服務轉接程式都已初始化。
選取廣告格式
已匯入並初始化 Mobile Ads SDK,且您已準備好導入廣告。 AdMob 提供多種不同廣告格式,讓您選擇最適合應用程式使用者體驗的廣告格式。
橫幅
顯示在裝置螢幕頂端或底部的矩形廣告。 橫幅廣告會在使用者與應用程式互動時顯示,而且可在一段時間後自動重新整理。如果是行動廣告新手,建議從這裡著手。
插頁式
這類全螢幕廣告會覆蓋應用程式介面,直到使用者關閉為止。 在應用程式執行流程中的自然暫停階段 (例如遊戲關卡之間或工作完成後),它們都最適合使用。
原生
自訂廣告,能與應用程式的外觀和風格一致。您可以決定廣告的位置與位置,讓版面配置與應用程式的設計更加一致。
已獲得獎勵
獎勵使用者觀看短片,以及與可試玩廣告及問卷調查互動的廣告。適合透過免費遊戲使用者營利;
導入獎勵廣告 | 導入獎勵廣告 (新版 API) |