Os objetos AdResult
fornecem um mecanismo para detectar tentativas de carregamento de um anúncio com falha.
Se ocorrer uma falha, o método AdResult
is_successful()
vai retornar falso.
Nessas situações, a invocação do método AdResult
ad_error()
vai retornar um
objeto AdError
com informações relacionadas ao erro.
Este é um snippet de código que ilustra as informações disponíveis quando um anúncio não é carregado:
firebase::Future<firebase::gma::AdResult> load_ad_future =
ad_view->LoadAd(request);
// In a game loop, monitor the load ad status
if (load_ad_future.status() == firebase::kFutureStatusComplete) {
const firebase::gma::AdResult* ad_result = load_ad_future.result();
if (!ad_result.is_successful()) {
// There was an error loading the ad.
const AdError& ad_error = ad_result.ad_error();
firebase::gma::AdErrorCode code = ad_error.code();
std::string domain = ad_error.domain();
std::string message = ad_error.message();
const firebase::gma::ResponseInfo response_info = ad_error.response_info();
printf("Received error with domain: %s, code: %d, message: %s and response info: %s\n”,
domain.c_str(), message.c_str(), response_info.ToString().c_str());
}
}
Essas informações podem ser usadas para determinar com mais precisão o que causou a falha no carregamento
do anúncio. Em particular, para erros no domínio com.google.admob
no
iOS e com.google.android.gms.ads
no Android, a mensagem pode ser pesquisada neste
artigo da Central de Ajuda para uma explicação mais detalhada e possíveis ações que podem ser tomadas para resolver o
problema.