광고 미리 로드는 Google에서 관리하는 GMA Next-Gen SDK의 광고 로드 기능으로, 광고 로드 및 캐싱을 대신 관리합니다. 광고 미리 로드를 사용하려면 광고 로드 방식을 변경해야 합니다. 광고 미리 로드를 사용하여 성능을 최적화하려면 맞춤 캐싱을 사용 중지하고 GMA Next-Gen SDK에 책임을 위임하세요.
광고 미리 로드는 수동 광고 로드에 비해 다음과 같은 이점을 제공합니다.
- 참조 관리: 로드된 광고를 보유하므로 광고를 표시할 준비가 될 때까지 참조를 유지할 필요가 없습니다.
- 자동 다시 로드: 캐시에서 광고를 가져올 때 새 광고를 자동으로 로드합니다.
- 관리형 재시도: 지수 백오프를 사용하여 실패한 요청을 자동으로 재시도합니다.
- 만료 처리: 광고가 만료되기 전에 (일반적으로 1시간 후) 자동으로 새로고침합니다.
- 캐시 최적화: 캐시 크기가 1보다 큰 경우 GMA Next-Gen SDK은 최적의 광고를 게재하기 위해 캐시 순서를 최적화합니다.
이 가이드에서는 광고 미리 로드 구성, 광고 미리 로드 가능 여부 확인, 미리 로드된 광고 표시 방법을 설명합니다.
기본 요건
튜토리얼을 진행하기 전에 다음 항목을 완료해야 합니다.
- GMA Next-Gen SDK 버전 0.14.0-alpha01 이상을 설치합니다.
- GMA Next-Gen SDK를 설정합니다.
- 선택사항: 예제 앱을 다운로드하고 실행합니다.
광고 미리 로드 시작
광고 미리 로드를 시작하려면 startPreload()를 호출합니다. 이 메서드는 앱 시작 시 한 번만 호출해야 합니다. startPreload()를 호출하면 GMA Next-Gen SDK가 자동으로 광고를 미리 로드하고 미리 로드된 구성에 대해 실패한 요청을 다시 시도합니다.
다음 예에서는 광고 미리 로드를 시작합니다.
Kotlin
private fun startPreloading(adUnitId: String) {
val 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);
}
미리 로드된 광고 가져오기 및 표시
광고 미리 로드를 사용하는 경우 GMA Next-Gen SDK는 캐시된 광고를 보유합니다.
광고를 게재하려면 pollAd()를 호출합니다.
GMA Next-Gen SDK는 사용 가능한 광고를 가져오고 백그라운드에서 다음 광고를 자동으로 미리 로드합니다.
광고를 게재할 준비가 될 때까지 이 메서드를 호출하지 마세요. 광고를 캐시에 유지하면 GMA Next-Gen SDK에서 만료된 광고를 자동으로 새로고침하고 캐시 최적화를 실행할 수 있습니다.
다음 예에서는 미리 로드된 광고를 가져와서 표시합니다.
Kotlin
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);
}
}
광고 미리 로드 사용 가능 여부 확인
광고 사용 가능 여부를 확인하려면 다음 중 하나를 선택하세요.
미리 로드된 광고 사용 가능 여부 가져오기
다음 예에서는 광고 사용 가능 여부를 확인합니다.
Kotlin
private fun isAdAvailable(adUnitId: String): Boolean {
return InterstitialAdPreloader.isAdAvailable(adUnitId)
}
자바
private boolean isAdAvailable(String adUnitId) {
return InterstitialAdPreloader.isAdAvailable(adUnitId);
}
미리 로드된 광고 사용 가능 여부 수신 대기
광고가 성공적으로 미리 로드되거나, 미리 로드에 실패하거나, 광고 캐시가 소진될 때 알림을 받으려면 미리 로드 이벤트를 등록하세요.
미리 로드 이벤트는 분석 목적으로 사용됩니다. 프리로드 이벤트 콜백 내에서 다음을 실행합니다.
startPreload()를 호출하지 마세요.- 광고가 즉시 표시되지 않는 한
pollAd()를 호출하지 마세요.
다음 예에서는 광고 이벤트를 등록합니다.
Kotlin
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")
// [Important] Don't call ad preloader start() or pollAd() from onAdsExhausted.
}
override fun onAdPreloaded(preloadId: String, responseInfo: ResponseInfo) {
Log.i(TAG, "Interstitial preload ad $preloadId is available")
}
}
val 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");
// [Important] Don't call ad preloader start() or pollAd() from onAdsExhausted.
}
@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);
}
광고 미리 로드 중지
세션에서 미리 로드 ID의 광고를 다시 표시할 필요가 없는 경우 광고 미리 로드를 중지할 수 있습니다. 특정 미리 로드 ID의 광고 미리 로드를 중지하려면 미리 로드 ID와 함께 destroy()를 호출합니다.
버퍼 크기 설정
버퍼 크기는 메모리에 보관되는 미리 로드된 광고 수를 제어합니다. 기본적으로 Google은 메모리 사용량과 광고 게재 지연 시간을 균형 있게 유지하도록 버퍼 크기를 최적화합니다. 다음 광고가 로드되기 전에 앱에 광고가 표시되는 경우 맞춤 버퍼 크기를 설정하여 메모리에 보관되는 광고 수를 늘릴 수 있습니다. 버퍼 크기는 최대 4로 설정하는 것이 좋습니다.
Kotlin
private fun setBufferSize(adUnitId: String) {
val adRequest = AdRequest.Builder(adUnitId).build()
val preloadConfig = PreloadConfiguration(adRequest, bufferSize = 3)
InterstitialAdPreloader.start(adUnitId, preloadConfig)
}
Java
private void setBufferSize(String adUnitId) {
AdRequest adRequest = new AdRequest.Builder(adUnitId).build();
PreloadConfiguration preloadConfig = new PreloadConfiguration(adRequest, 3);
InterstitialAdPreloader.start(adUnitId, preloadConfig);
}