Formatos de anúncios nativos personalizados e Open Measurement de tipo de display

Se você planeja usar o Open Measurement com formatos de anúncios nativos personalizados que não contêm um recurso de vídeo, você será responsável por chamar as APIs Open Measurement. A medição aberta para formatos de anúncios nativos personalizados de tipo de display é compatível apenas com a versão 7.43.0 e mais recentes. Se você estiver usando formatos de anúncios nativos personalizados com um recurso de vídeo, não precisará seguir este guia, porque o SDK dos anúncios para dispositivos móveis do Google rastreia a visibilidade do recurso de vídeo para você.

Pré-requisitos

Carregar um anúncio

O processo para carregar um anúncio é o mesmo, quer você use o Open Measurement. Nesse caso, usaremos um ViewController simples para demonstrar o carregamento de um GADNativeCustomTemplateAd:

@interface OpenMeasurementNativeCustomTemplateAdViewController ()
    <GADNativeCustomTemplateAdLoaderDelegate> {
  IBOutlet UIView *_parentView;
  GADAdLoader *_adLoader;
  GADNativeCustomTemplateAd *_customTemplateAd;
  MySimpleNativeAdView *_simpleNativeAdView;
}

@end

@implementation OpenMeasurementNativeCustomTemplateAdViewController

- (void) viewDidLoad {
  [super viewDidLoad];

  _adLoader = [[GADAdLoader alloc] initWithAdUnitID:@"your ad unit ID"
                                 rootViewController:self
                                            adTypes:@[ kGADAdLoaderAdTypeNativeCustomTemplate ]
                                            options:nil];
  _adLoader.delegate = self;
  [self loadAd];
}

- (void) loadAd {
  GAMRequest *request = [GAMRequest request];
  [_adLoader loadRequest:request];
}
...
@end

Registre sua visualização e comece a medir

Para mostrar um GADNativeCustomTemplateAd, é necessário registrar sua visualização de anúncio personalizada com o GADNativeTemplateAd usando a propriedade displayAdMeasurement.view.

Também é necessário informar explicitamente ao SDK para começar a medir seu anúncio. Para fazer isso, chame o método startWithError: na propriedade displayAdMeasurement do GADNativeCustomTemplateAd. startWithError: precisa ser chamado na linha de execução principal. As chamadas subsequentes não terão efeito.

@implementation OpenMeasurementNativeCustomTemplateAdViewController
...
#pragma mark - GADNativeCustomTemplateAdLoaderDelegate

- (void) adLoader:(GADAdLoader *) adLoader
    didReceiveNativeCustomTemplateAd:(GADNativeCustomTemplateAd *)nativeCustomTemplateAd {
  NSLog(@"Received custom native ad: %@", nativeCustomTemplateAd);

  _customTemplateAd = nativeCustomTemplateAd;

  // Put the custom native ad on screen.
  _simpleNativeAdView =
    [[NSBundle mainBundle] loadNibNamed:@"SimpleCustomNativeAdView"
                                  owner:nil
                                options:nil]
    .firstObject;
  [_parentView addSubview:_simpleNativeAdView];
  [_simpleNativeAdView populateWithCustomNativeAd:_customTemplateAd];


  // Set the top-level native ad view on the GADNativeCustomTemplateAd so the
  // Google Mobile Ads SDK can track viewability for that view.
  _customTemplateAd.displayAdMeasurement.view = _simpleNativeAdView;
  // Begin measuring your impressions and clicks.
  NSError *error = nil;
  [_customTemplateAd.displayAdMeasurement startWithError:&error];

  if (error) {
    NSLog(@"Failed to start the display measurement.");
  }
}
...
@end

Isso é tudo. Depois de lançar o app, você vai começar a receber dados de medição. No entanto, seus dados não serão certificados até que você passe pelo processo de certificação do IAB.