Auf dieser Seite finden Sie eine Anleitung zum Initialisieren von GMA Next-Gen SDK.
Hinweis
Wenn Sie GMA Next-Gen SDK verwenden möchten, müssen Sie entweder ohne Vermittlung integrieren oder AdMob als Vermittlungsplattform nutzen. Die anderen Vermittlungsplattformen sind nicht mit GMA Next-Gen SDK kompatibel.
Build für GMA Next-Gen SDK konfigurieren
In den folgenden Abschnitten wird beschrieben, wie Sie GMA Next-Gen SDK konfigurieren.
GMA Next-Gen SDK-Abhängigkeit einbeziehen
Für GMA Next-Gen SDK ist eine andere Gradle-Abhängigkeit erforderlich. Entfernen Sie in der Build-Datei auf App-Ebene den Verweis auf die Google Mobile Ads SDK-Abhängigkeit und fügen Sie das neue Artefakt ein.
| Gradle-Abhängigkeiten | |
|---|---|
| Google Mobile Ads SDK |
Kotlindependencies { // ... implementation("com.google.android.gms:play-services-ads:25.3.0") } Groovydependencies { // ... implementation 'com.google.android.gms:play-services-ads:25.3.0' } |
| GMA Next-Gen SDK |
Kotlindependencies { // ... // Comment out/remove play-services-ads. // implementation("com.google.android.gms:play-services-ads:25.3.0") implementation("com.google.android.libraries.ads.mobile.sdk:ads-mobile-sdk:1.1.1") } Groovydependencies { // ... // Comment out/remove play-services-ads. // implementation 'com.google.android.gms:play-services-ads:25.3.0' implementation 'com.google.android.libraries.ads.mobile.sdk:ads-mobile-sdk:1.1.1' } |
com.google.android.gms-Module in Vermittlungsintegrationen ausschließen
Mediationsadapter sind weiterhin von Google Mobile Ads SDK abhängig. GMA Next-Gen SDK enthält jedoch alle Klassen, die von Vermittlungsadaptern benötigt werden. Um Kompilierungsfehler im Zusammenhang mit doppelten Symbolen zu vermeiden, müssen Sie verhindern, dass Google Mobile Ads SDK von Vermittlungsadaptern als Abhängigkeit abgerufen wird.
Schließen Sie in der Build-Datei auf App-Ebene die Module play-services-ads und play-services-ads-lite global aus allen Abhängigkeiten aus.
Kotlin
configurations.configureEach { exclude(group = "com.google.android.gms", module = "play-services-ads") exclude(group = "com.google.android.gms", module = "play-services-ads-lite") }
Groovy
configurations.configureEach { exclude group: "com.google.android.gms", module: "play-services-ads" exclude group: "com.google.android.gms", module: "play-services-ads-lite" }
Mindest- und Ziel-Android-API‑Level festlegen
GMA Next-Gen SDK erfordert ein Android-Mindest-API-Level von 24 und ein Android-Kompilierungs-API-Level von 34. Passen Sie die Werte für minSdk und compileSdk in der Build-Datei auf App-Ebene auf mindestens 24 bzw. 34 an.
GMA Next-Gen SDK initialisieren
GMA Next-Gen SDK muss initialisiert werden, bevor Anzeigen geladen werden. Das ist eine Änderung gegenüber Google Mobile Ads SDK, wo die Initialisierung optional, aber empfohlen ist. Aktualisieren Sie Ihren Code, wenn Sie das SDK bisher nicht initialisiert haben, bevor Sie Anzeigen geladen haben.
In diesem Abschnitt werden die Unterschiede bei der Implementierung der SDK-Initialisierung zwischen Google Mobile Ads SDK und GMA Next-Gen SDK beschrieben.
AdMob-App-ID festlegen
In den folgenden Beispielen wird die AdMob-App-ID in Google Mobile Ads SDK und GMA Next-Gen SDK festgelegt:
| Google Mobile Ads SDK |
Für die Integration ist ein <manifest> <application> <!-- Sample AdMob app ID: ca-app-pub-3940256099942544~3347511713 --> <meta-data android:name="com.google.android.gms.ads.APPLICATION_ID" android:value="SAMPLE_APP_ID"/> </application> </manifest> |
| GMA Next-Gen SDK |
Geben Sie Ihre AdMob-App-ID programmatisch als Teil der SDK-Initialisierung an. Kotlin// Initialize the Google Mobile Ads SDK. val initConfig = InitializationConfig.Builder("SAMPLE_APP_ID").build() MobileAds.initialize(this@MainActivity, initConfig) {} Java// Initialize GMA Next-Gen SDK. InitializationConfig initConfig = new InitializationConfig.Builder("SAMPLE_APP_ID").build(); MobileAds.initialize(this, initConfig, initializationStatus -> {}); |
Implementierungsänderungen prüfen
In den folgenden Beispielen werden Google Mobile Ads SDK und GMA Next-Gen SDK initialisiert:
| Google Mobile Ads SDK |
Rufen Sie Kotlinimport com.google.android.gms.ads.MobileAds import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val backgroundScope = CoroutineScope(Dispatchers.IO) backgroundScope.launch { // Initialize the Google Mobile Ads SDK on a background thread. MobileAds.initialize(this@MainActivity) {} } } } Javaimport com.google.android.gms.ads.MobileAds; import com.google.android.gms.ads.initialization.InitializationStatus; import com.google.android.gms.ads.initialization.OnInitializationCompleteListener; public class MainActivity extends AppCompatActivity { protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); new Thread( () -> { // Initialize the Google Mobile Ads SDK on a background thread. MobileAds.initialize(this, initializationStatus -> {}); }) .start(); } } |
| GMA Next-Gen SDK |
Rufen Sie Kotlinimport com.google.android.libraries.ads.mobile.sdk.MobileAds import com.google.android.libraries.ads.mobile.sdk.initialization.InitializationConfig import kotlinx.coroutines.CoroutineScope import kotlinx.coroutines.Dispatchers import kotlinx.coroutines.launch class MainActivity : AppCompatActivity() { override fun onCreate(savedInstanceState: Bundle?) { super.onCreate(savedInstanceState) setContentView(R.layout.activity_main) val backgroundScope = CoroutineScope(Dispatchers.IO) backgroundScope.launch { // Initialize GMA Next-Gen SDK on a background thread. MobileAds.initialize( this@MainActivity, // Sample AdMob app ID: ca-app-pub-3940256099942544~3347511713 InitializationConfig.Builder("SAMPLE_APP_ID").build() ) { // Adapter initialization is complete. } // SDK initialization is complete. If you don't want to wait for bidding adapters to finish // initializing, start loading ads now. } } } Javaimport com.google.android.libraries.ads.mobile.sdk.MobileAds; import com.google.android.libraries.ads.mobile.sdk.initialization.InitializationConfig; public class MainActivity extends AppCompatActivity { protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); new Thread( () -> { // Initialize GMA Next-Gen SDK on a background thread. MobileAds.initialize( this, // Sample AdMob app ID: ca-app-pub-3940256099942544~3347511713 new InitializationConfig.Builder("SAMPLE_APP_ID") .build(), initializationStatus -> { // Adapter initialization is complete. }); // SDK initialization is complete. If you don't want to wait for bidding adapters to // finish initializing, start loading ads now. }) .start(); } } |