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 WKWebView, 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 WKWebView 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

  • Versión 9.6.0 o posterior del SDK de anuncios de Google para dispositivos móviles
  • Actualiza el archivo Info.plist con la siguiente clave y valor de cadena. Esto omite una verificación que el SDK de anuncios de Google para dispositivos móviles realiza para un valor de GADApplicationIdentifier que se aplica a los desarrolladores que implementan anuncios fuera de una vista web. Si no realizas este paso y no proporcionas un GADApplicationIdentifier, el SDK de anuncios de Google para dispositivos móviles arrojará un GADInvalidInitializationException cuando se inicie la app.

    <!-- Indicate Google Mobile Ads SDK usage is only for web view APIs for ads -->
    <key>GADIntegrationManager</key>
    <string>webview</string>
    

Registra la vista web

Llama a register(_:) 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 WKWebView. Esto debe hacerse lo antes posible, por ejemplo, en el método viewDidLoad de tu controlador de vistas.

Swift

import WebKit

class ViewController: UIViewController {

  var webView: WKWebView!

  override func viewDidLoad() {
    super.viewDidLoad()

    // Initialize a WKWebViewConfiguration object.
    let webViewConfiguration = WKWebViewConfiguration()
    // Let HTML videos with a "playsinline" attribute play inline.
    webViewConfiguration.allowsInlineMediaPlayback = true
    // Let HTML videos with an "autoplay" attribute play automatically.
    webViewConfiguration.mediaTypesRequiringUserActionForPlayback = []

    // Initialize the WKWebView with your WKWebViewConfiguration object.
    webView = WKWebView(frame: view.frame, configuration: webViewConfiguration)
    view.addSubview(webView)

    // Register the web view.
    MobileAds.shared.register(webView)
  }
}

Objective-C

@import WebKit;

#import "ViewController.h"

@interface ViewController ()

@property(nonatomic, strong) WKWebView *webView;

@end

@implementation ViewController

- (void)viewDidLoad {
  [super viewDidLoad];

  // Initialize a WKWebViewConfiguration object.
  WKWebViewConfiguration *webViewConfiguration = [[WKWebViewConfiguration alloc] init];
  // Let HTML videos with a "playsinline" attribute play inline.
  webViewConfiguration.allowsInlineMediaPlayback = YES;
  // Let HTML videos with an "autoplay" attribute play automatically.
  webViewConfiguration.mediaTypesRequiringUserActionForPlayback = WKAudiovisualMediaTypeNone;

  // Initialize the WKWebView with your WKWebViewConfiguration object.
  self.webView = [[WKWebView alloc] initWithFrame:self.view.frame configuration:webViewConfiguration];
  [self.view addSubview:self.webView];

  // Register the web view.
  [GADMobileAds.sharedInstance registerWebView:self.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:

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

Próximos pasos

  • Obtén el consentimiento en WKWebView. 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 WKWebView 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 WKWebView.