Cuando un anuncio no se carga, siempre hay un
de devolución de llamada o un controlador de finalización
al que se llama que proporciona un
objetoNSError
.
En el caso de a GADBannerView
, se llama a lo siguiente:
Swift
func bannerView(_ bannerView: GADBannerView, didFailToReceiveAdWithError error: Error)
Objective‑C
- (void)bannerView:(nonnull GADBannerView *)bannerView didFailToReceiveAdWithError:(nonnull NSError *)error;
A continuación, presentamos un fragmento de código que ilustra la información disponible cuando no se puede cargar un anuncio:
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); }
Esta información se puede usar para determinar con mayor precisión qué causó la falla de la carga de anuncios.
En particular, para los errores del dominio GADErrorDomain
, localizedDescription
se puede buscar en este artículo del Centro de ayuda a fin de obtener una explicación más detallada y posibles acciones que se pueden tomar para resolver el problema.