Cómo integrar la API de WebView para anuncios

Las APIs de WebView para anuncios ponen los indicadores de la app a disposición de las etiquetas en tu WebView, lo que ayuda a mejorar la monetización de los publicadores que proporcionaron el contenido y a proteger a los anunciantes del spam.

Cómo funciona

La comunicación con el SDK de anuncios de Google para dispositivos móviles solo se produce en respuesta a eventos de anuncios activados por cualquiera de los siguientes elementos:

El SDK agrega controladores de mensajes al objeto WebView registrado para escuchar estos eventos de anuncios. Para comprender mejor cómo funciona, consulta el código fuente de la página de prueba.

Requisitos previos

  • SDK de anuncios de Google para dispositivos móviles versión 20.6.0 o posterior.
  • Nivel de API de Android 21 o posterior

  • Agrega la siguiente etiqueta <meta-data> en tu archivo AndroidManifest.xml para omitir la verificación del APPLICATION_ID. Si omites este paso y no proporcionas la etiqueta <meta-data>, el SDK de anuncios de Google para dispositivos móviles arrojará un IllegalStateException cuando se inicie la app.

    <!-- Bypass APPLICATION_ID check for web view APIs for ads -->
     <meta-data
         android:name="com.google.android.gms.ads.INTEGRATION_MANAGER"
         android:value="webview"/>
    

Registra la vista web

Llama a registerWebView() en el subproceso principal para establecer una conexión con los controladores de JavaScript en el código de AdSense o la etiqueta de Google Publisher dentro de cada instancia de WebView. Esto debe hacerse lo antes posible, por ejemplo, en el método onCreate() de tu MainActivity.

Kotlin

import android.webkit.CookieManager
import android.webkit.WebView
import com.google.android.gms.ads.MobileAds

class MainActivity : AppCompatActivity() {
  lateinit var webView: WebView

  override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)
    webView = findViewById(R.id.webview)

    // Let the web view accept third-party cookies.
    CookieManager.getInstance().setAcceptThirdPartyCookies(webView, true)
    // Let the web view use JavaScript.
    webView.settings.javaScriptEnabled = true
    // Let the web view access local storage.
    webView.settings.domStorageEnabled = true
    // Let HTML videos play automatically.
    webView.settings.mediaPlaybackRequiresUserGesture = false

    // Register the web view.
    MobileAds.registerWebView(webView)
  }
}

Java

import android.webkit.CookieManager;
import android.webkit.WebView;
import com.google.android.gms.ads.MobileAds;

public class MainActivity extends AppCompatActivity {
  private WebView webView;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    webView = findViewById(R.id.webview);

    // Let the web view accept third-party cookies.
    CookieManager.getInstance().setAcceptThirdPartyCookies(webView, true);
    // Let the web view use JavaScript.
    webView.getSettings().setJavaScriptEnabled(true);
    // Let the web view access local storage.
    webView.getSettings().setDomStorageEnabled(true);
    // Let HTML videos play automatically.
    webView.getSettings().setMediaPlaybackRequiresUserGesture(false);

    // Register the web view.
    MobileAds.registerWebView(webView);
  }
}

Cómo probar tu integración

Antes de usar tu propia URL, te recomendamos que cargues la siguiente URL para probar la integración:

https://google.github.io/webview-ads/test/#api-for-ads-tests

La URL de prueba muestra barras de estado verdes para indicar que la integración se realizó correctamente si se cumplen las siguientes condiciones:

  • WebView conectado al SDK de anuncios de Google para dispositivos móviles

Próximos pasos

  • Obtén el consentimiento en WebView. Las APIs de WebView para anuncios no propagan el consentimiento recopilado en el contexto de la app para dispositivos móviles con los marcos de trabajo de cumplimiento de MTC v2.0 de IAB o CCPA de IAB a las etiquetas de tus vistas web. Si te interesa implementar un solo flujo de consentimiento como propietario del WebView y su contenido web correspondiente que se monetiza, trabaja con tu plataforma de administración de consentimiento para recopilar el consentimiento en el contexto del WebView.