Quando um anúncio não é carregado, há sempre um
método delegado ou gerenciador de conclusão
a função , que fornece uma
objetoNSError
.
Para a GADBannerView
, o seguinte é chamado:
Swift
func bannerView(_ bannerView: GADBannerView, didFailToReceiveAdWithError error: Error)
Objective-C
- (void)bannerView:(nonnull GADBannerView *)bannerView didFailToReceiveAdWithError:(nonnull NSError *)error;
Veja um snippet de código que ilustra as informações disponíveis quando um anúncio não carregar:
Swift
func bannerView(_ bannerView: GADBannerView, didFailToReceiveAdWithError error: Error) { // Gets the domain from which the error came. let errorDomain = error.domain // Gets the error code. See // https://developers.google.com/admob/ios/api/reference/Enums/GADErrorCode // for a list of possible codes. let errorCode = error.code // Gets an error message. // For example "Account not approved yet". See // https://support.google.com/admob/answer/9905175 for explanations of // common errors. let errorMessage = error.localizedDescription // Gets additional response information about the request. See // https://developers.google.com/admob/ios/response-info for more information. let responseInfo = (error as NSError).userInfo[GADErrorUserInfoKeyResponseInfo] as? GADResponseInfo // Gets the underlyingError, if available. let underlyingError = (error as NSError).userInfo[NSUnderlyingErrorKey] as? Error if let responseInfo = responseInfo { print("Received error with domain: \(errorDomain), code: \(errorCode)," + "message: \(errorMessage), responseInfo: \(responseInfo)," + "underlyingError: \(underlyingError?.localizedDescription ?? "nil")") } }
Objective-C
- (void)bannerView:(GADBannerView *)bannerView didFailToReceiveAdWithError:(NSError *)error { // Gets the domain from which the error came. NSString *errorDomain = error.domain; // Gets the error code. See // https://developers.google.com/admob/ios/api/reference/Enums/GADErrorCode // for a list of possible codes. int errorCode = error.code; // Gets an error message. // For example "Account not approved yet". See // https://support.google.com/admob/answer/9905175 for explanations of // common errors. NSString *errorMessage = error.localizedDescription; // Gets additional response information about the request. See // https://developers.google.com/admob/ios/response-info for more // information. GADResponseInfo *responseInfo = error.userInfo[GADErrorUserInfoKeyResponseInfo]; // Gets the underlyingError, if available. NSError *underlyingError = error.userInfo[NSUnderlyingErrorKey]; NSLog(@"Received error with domain: %@, code: %ld, message: %@, " @"responseInfo: %@, underlyingError: %@", errorDomain, errorCode, errorMessage, responseInfo, underlyingError.localizedDescription); }
Essas informações podem ser usadas para determinar com mais precisão o que causou o anúncio
falhar.
Especificamente, para erros no domínio
GADErrorDomain
, o localizedDescription
podem ser consultadas nesta Central de Ajuda
artigo para ter mais detalhes
explicação e possíveis ações que podem ser tomadas para resolver o
problema.