Предварительная загрузка рекламы — это процесс загрузки и кэширования, управляемый SDK, который устраняет необходимость ручной загрузки и кэширования рекламы. Этот процесс позволяет показывать рекламу по мере необходимости, без необходимости вручную загружать рекламу или обрабатывать обратные вызовы загрузки рекламы.
В этом руководстве описывается настройка предзагруженной рекламы, проверка доступности предзагруженной рекламы, а также получение и отображение предзагруженной рекламы.
Предпосылки
Прежде чем продолжить обучение, вам необходимо выполнить следующие пункты:
- Установите Google Mobile Ads SDK (бета) версии 0.14.0-alpha01 или выше.
- Заполните руководство по началу работы .
- Дополнительно: загрузите и запустите пример приложения .
Начать предварительную загрузку рекламы
Чтобы начать предварительную загрузку, вызовите startPreload() . SDK Google Mobile Ads автоматически повторяет неудачные запросы объявлений для предварительно загруженных конфигураций.
Следующий пример запускает предварительную загрузку рекламы:
Котлин
private fun startPreloading(adUnitID: String) {
val adRequest: AdRequest = AdRequest.Builder(adUnitID).build()
val preloadConfig = PreloadConfiguration(adRequest)
InterstitialAdPreloader.start(adUnitID, preloadConfig)
}
Ява
private void startPreloading(String adUnitId) {
AdRequest adRequest = new AdRequest.Builder(adUnitId).build();
PreloadConfiguration preloadConfig = new PreloadConfiguration(adRequest);
InterstitialAdPreloader.start(adUnitId, preloadConfig);
}
Необязательно: измените предварительную загрузку рекламы
Чтобы изменить предварительно загружаемую рекламу, вызовите destroy() , а затем снова вызовите startPreload() с измененной конфигурацией.
Необязательно: остановить предварительную загрузку рекламы
Чтобы остановить предварительную загрузку рекламы, вызовите destroy() с идентификатором предварительной загрузки.
Необязательно: задайте размер буфера.
Размер буфера управляет количеством предзагруженных рекламных объявлений, хранящихся в памяти. Если ваше приложение отображает рекламу быстрее, чем загружаются новые объявления, увеличьте размер буфера. Если вас беспокоит расход памяти, уменьшите размер буфера, например, до 2 .
Котлин
private fun setBufferSize(adUnitID: String) {
val adRequest: AdRequest = AdRequest.Builder(adUnitID).build()
val preloadConfig = PreloadConfiguration(adRequest, bufferSize = 3)
InterstitialAdPreloader.start(adUnitID, preloadConfig)
}
Ява
private void setBufferSize(String adUnitId) {
AdRequest adRequest = new AdRequest.Builder(adUnitId).build();
PreloadConfiguration preloadConfig = new PreloadConfiguration(adRequest, 3);
InterstitialAdPreloader.start(adUnitId, preloadConfig);
}
Необязательно: получать уведомления о предварительной загрузке
Реализуйте PreloadCallback для получения уведомлений о событиях предварительной загрузки рекламы. Для отладки и ведения журнала эти события предоставляют объект с информацией об ответе.
Котлин
private fun startPreloadingWithCallback(adUnitID: String) {
val preloadCallback =
// [Important] Don't call ad preloader start() or pollAd() within the PreloadCallback.
object : PreloadCallback {
override fun onAdFailedToPreload(preloadId: String, adError: LoadAdError) {
Log.i(
TAG,
("Interstitial preload ad $preloadId failed to load with error: ${adError.message}"),
)
// [Optional] Get the error response info for additional details.
// val responseInfo = adError.responseInfo
}
override fun onAdsExhausted(preloadId: String) {
Log.i(TAG, "Interstitial preload ad $preloadId is not available")
}
override fun onAdPreloaded(preloadId: String, responseInfo: ResponseInfo) {
Log.i(TAG, "Interstitial preload ad $preloadId is available")
}
}
val adRequest: AdRequest = AdRequest.Builder(adUnitID).build()
val preloadConfig = PreloadConfiguration(adRequest)
InterstitialAdPreloader.start(adUnitID, preloadConfig, preloadCallback)
}
Ява
private void startPreloadingWithCallback(String adUnitId) {
PreloadCallback preloadCallback =
// [Important] Don't call ad preloader start() or pollAd() within the PreloadCallback.
new PreloadCallback() {
@Override
public void onAdFailedToPreload(String preloadId, LoadAdError adError) {
Log.e(
TAG,
String.format(
"Interstitial preload ad %s failed to load with error: %s",
preloadId, adError.getMessage()));
// [Optional] Get the error response info for additional details.
// ResponseInfo responseInfo = adError.getResponseInfo();
}
@Override
public void onAdsExhausted(String preloadId) {
Log.i(TAG, "Interstitial preload ad " + preloadId + " is not available");
}
@Override
public void onAdPreloaded(String preloadId, ResponseInfo responseInfo) {
Log.i(TAG, "Interstitial preload ad " + preloadId + " is available");
}
};
AdRequest adRequest = new AdRequest.Builder(adUnitId).build();
PreloadConfiguration preloadConfig = new PreloadConfiguration(adRequest);
InterstitialAdPreloader.start(adUnitId, preloadConfig, preloadCallback);
}
Получить и показать предзагруженную рекламу
Реклама становится доступной для показа после вызова метода onAdsAvailable() . Доступ к рекламе непрерывно по мере её показа и завершения. После получения объявления отслеживайте события жизненного цикла объявления и показывайте его.
В следующем примере показана предварительно загруженная реклама:
Котлин
private fun pollAndShowAd(activity: Activity, adUnitID: String) {
// Polling returns the next available ad and loads another ad in the background.
val ad = InterstitialAdPreloader.pollAd(adUnitID)
// Interact with the ad object as needed.
ad?.apply {
Log.d(TAG, "Interstitial ad response info: ${this.getResponseInfo()}")
this.adEventCallback =
object : InterstitialAdEventCallback {
override fun onAdImpression() {
Log.d(TAG, "Interstitial ad recorded an impression.")
}
override fun onAdPaid(value: AdValue) {
Log.d(TAG, "Interstitial ad onPaidEvent: ${value.valueMicros} ${value.currencyCode}")
}
}
// Show the ad.
ad.show(activity)
}
}
Ява
private void pollAndShowAd(Activity activity, String adUnitId) {
// Polling returns the next available ad and loads another ad in the background.
final InterstitialAd ad = InterstitialAdPreloader.pollAd(adUnitId);
// Interact with the ad object as needed.
if (ad != null) {
Log.d(TAG, "Interstitial ad response info: " + ad.getResponseInfo());
ad.setAdEventCallback(
new InterstitialAdEventCallback() {
@Override
public void onAdImpression() {
Log.d(TAG, "Interstitial ad recorded an impression.");
}
@Override
public void onAdPaid(AdValue value) {
Log.d(
TAG,
"Interstitial ad onPaidEvent: "
+ value.getValueMicros()
+ " "
+ value.getCurrencyCode());
}
});
// Show the ad.
ad.show(activity);
}
}
Необязательно: проверьте наличие предварительно загруженной рекламы.
Чтобы узнать, доступны ли объявления, вызовите isAdAvailable :
Котлин
private fun isAdAvailable(adUnitID: String): Boolean {
return InterstitialAdPreloader.isAdAvailable(adUnitID)
}
Ява
private boolean isAdAvailable(String adUnitId) {
return InterstitialAdPreloader.isAdAvailable(adUnitId);
}