SDK v20 출시 대비하기

20.0.0 버전에는 많은 브레이킹 체인지가 있을 예정입니다. 19.7.0 버전에서는 새로운 API가 다수 도입되고 20.0.0 버전에 대비하여 여러 클래스의 지원이 중단되거나 이름이 변경되었습니다. 이 가이드에서는 버전 19.7.0에서 도입된 주요 변경사항과 2021년 초에 예정된 버전 20.0.0의 변경사항을 중점적으로 설명합니다.

전체 화면 형식 API 업데이트

버전 20.0.0부터 전면 광고, 보상형 광고, 보상형 전면 광고, 앱 오프닝 광고 형식이 일관된 API 디자인을 따르도록 표준화됩니다.

모든 전체 화면 형식 API에서는 다음 원칙을 활용합니다.

  • 정적 로드 메서드
  • 유사한 로드 콜백 또는 핸들러 메커니즘
  • 프레젠테이션 콜백의 FullScreenContentCallback 클래스에 대한 의존성

기존 RewardedVideoAd API 삭제

최신 RewardedAd API는 2019년 3월에 처음 도입되었으며, 18개월 넘게 선호하는 보상형 API의 자리를 지켜 왔습니다. 한 번에 보상형 광고를 2개 이상 로드하는 기능을 비롯하여 기존 RewardedVideoAd API에 비해 더 많은 기능이 개선되었습니다.

SDK 버전 20.0.0에서 기존 RewardedVideoAd API가 삭제되었습니다.

스마트 배너가 지원 중단되고 적응형 배너로 대체됨

스마트 배너 광고가 지원 중단되고 적응형 배너 광고로 대체됩니다. 적응형 배너는 우수한 실적을 낼 뿐만 아니라 광고 너비를 더욱 유연하게 설정합니다. 전체 너비 배너를 계속 사용하려는 경우에도 다음과 같은 코드 스니펫에 표시된 대로 적응형 배너를 통해 계속 사용할 수 있습니다.

자바

public class MyActivity extends AppCompatActivity {
  ...
  private AdSize getFullWidthAdaptiveSize() {
    Display display = getWindowManager().getDefaultDisplay();
    DisplayMetrics outMetrics = new DisplayMetrics();
    display.getMetrics(outMetrics);

    float widthPixels = outMetrics.widthPixels;
    float density = outMetrics.density;

    int adWidth = (int) (widthPixels / density);
    return AdSize.getCurrentOrientationAnchoredAdaptiveBannerAdSize(this, adWidth);
  }
}

Kotlin

class MyActivity : AppCompatActivity() {
  ...
  private val adaptiveAdSize: AdSize
    get() {
      val display = windowManager.defaultDisplay
      val outMetrics = DisplayMetrics()
      display.getMetrics(outMetrics)

      val density = outMetrics.density

      var adWidthPixels = ad_view_container.width.toFloat()
      if (adWidthPixels == 0f) {
        adWidthPixels = outMetrics.widthPixels.toFloat()
      }

      val adWidth = (adWidthPixels / density).toInt()
      return AdSize.getCurrentOrientationAnchoredAdaptiveBannerAdSize(this, adWidth)
    }
}

애플리케이션 나가기 콜백 삭제

모든 광고 형식의 onAdLeftApplication 콜백이 삭제되었으며 ProcessLifecycleOwner로 대체됩니다. OS 수준 API를 사용하면 광고 상호작용으로 인해 앱을 나가는 것인지 여부와 관계없이 사용자가 내 앱을 나갈 때마다 알림을 받습니다.

onAdLeftApplication 콜백은 광고 클릭 핸들러 역할이 아니었으며, 이 콜백을 활용하여 클릭수를 보고하면 정확한 측정항목이 생성되지 않았습니다. 예를 들어 외부 브라우저를 실행한 AdChoices 아이콘에서 발생한 클릭은 콜백을 호출했으나 클릭수로 집계되지는 않았습니다.

클래스 이름 변경

아래 표에는 변경되었거나 삭제된 특정 클래스의 이름이 나와 있습니다. 요약하면 다음과 같습니다.

  • UnifiedNativeAd와 관련된 대부분의 클래스 이름이 NativeAd로 변경되었습니다.
  • MobileAds.Settings, NativeExpressAdView, NativeAppInstallAd, NativeContentAd, InstreamAd 클래스와 뷰가 삭제되었습니다.
  • Publisher 접두사를 포함하는 모든 클래스에서 해당 접두사가 AdManager 접두사로 대체되었습니다.
  • InterstitialAd 패키지 이름이 변경되었습니다.
19.5.0 클래스 20.0.0 클래스
com.google.android.gms.ads. com.google.android.gms.ads.
reward.RewardedVideoAd rewarded.RewardedAd
reward.RewardedVideoAdListener rewarded.RewardedAdLoadCallback 및 FullScreenContentCallback
reward.RewardItem rewarded.RewardItem
rewarded.RewardedAdCallback OnUserEarnedRewardListener
formats.UnifiedNativeAdView nativead.NativeAdView
formats.UnifiedNativeAd nativead.NativeAd
formats.UnifiedNativeAdAssetNames nativead.NativeAdAssetNames
formats.UnifiedNativeAd.OnUnifiedNativeAdLoadedListener nativead.NativeAd.OnNativeAdLoadedListener
formats.AdChoicesView nativead.AdChoicesView
formats.NativeAd.AdChoicesInfo nativead.NativeAd.AdChoicesInfo
formats.MediaView nativead.MediaView
formats.NativeAdViewHolder nativead.NativeAdViewHolder
formats.NativeAdOptions nativead.NativeAdOptions
formats.NativeCustomTemplateAd nativead.NativeCustomFormatAd
formats.NativeCustomTemplateAd.OnCustomTemplateAdLoadedListener nativead.NativeCustomFormatAd.OnCustomFormatAdLoadedListener
MobileAds.Settings 삭제됨
doubleclick.PublisherAdRequest admanager.AdManagerAdRequest
doubleclick.PublisherAdView admanager.AdManagerAdView
formats.PublisherAdViewOptions formats.AdManagerAdViewOptions
doubleclick.PublisherInterstitialAd admanager.AdManagerInterstitialAd
InterstitialAd interstitial.InterstitialAd
NativeExpressAdView 삭제됨
instream.InstreamAd 삭제됨
mediation.admob.AdMobExtras 삭제됨
Correlator 삭제됨
search.SearchAdRequest 삭제됨
Interface AdRequest.TagForUnderAgeOfConsent 삭제됨
Interface AdRequest.MaxAdContentRating 삭제됨
formats.NativeAppInstallAd native.NativeAd
formats.NativeAppInstallAdView native.NativeAdView
mediation.NativeAppInstallAdMapper mediation.UnifiedNativeAdMapper
formats.NativeContentAd native.NativeAd
formats.NativeContentAdView native.NativeAdView
mediation.NativeContentAdMapper mediation.UnifiedNativeAdMapper

삭제/대체된 메서드

아래 표에는 버전 20.0.0의 구체적인 변경사항이 나와 있습니다. 요약하면 다음과 같습니다.

  • 오래된 초기화 메서드가 MobileMobile 클래스에서 삭제되었습니다.
  • AdRequest.Builder() 클래스의 일부 메서드가 삭제되었거나 RequestConfiguration 클래스로 이동되었습니다.
  • RewardedAd 및 InterstitialAd API가 모든 전체 화면 형식에 부합하도록 업데이트되었습니다.
  • Correlator 기능이 삭제되었습니다.
클래스 v19.5.0 API v20.0.0 API 참고
AdSize getPortraitBannerAdSizeWithWidth() getPortraitAnchoredAdaptiveBannerAdSize()
getLandscapeBannerAdSizeWithWidth() getLandscapeAnchoredAdaptiveBannerAdSize()
getCurrentOrientationBannerAdSizeWithWidth() getCurrentOrientationAnchoredAdaptiveBannerAdSize()
MobileAds initialize(Context, String) MobileAds.initialize(Context, OnInitializationCompleteListener) 이제 AndroidManifest.xml에 앱 ID가 설정됩니다.
initialize(Context, String, MobileAds.Settings) initialize(Context, OnInitializationCompleteListener) Settings 클래스가 지원 중단되었습니다.
getRewardedVideoAdInstance() 삭제됨 RewardedAd API를 대신 사용하세요.
AdListener onAdFailedToLoad(int) onAdFailedToLoad(LoadAdError)
onAdLeftApplication() 삭제됨 전체 화면 광고 형식에서는 AdListener 대신 FullscreenContentCallback을 사용하며, FullscreenContentCallback에는 동일한 메서드가 없습니다. 해당 메서드는 AdListener에서 삭제되었습니다.
VideoController getAspectRatio() MediaContent.getAspectRatio()
AdRequest getGender() 삭제됨
getBirthday() 삭제됨
getNetworkExtras() 삭제됨
setManualImpressionsEnabled() 삭제됨
updateCorrelator() 삭제됨 광고 콘텐츠 필터링을 참고하세요.
AdRequest.Builder setBirthday() 삭제됨
setGender() 삭제됨
setIsDesignedForFamilies() 삭제됨 가이드를 참고하세요.
addTestDevice() RequestConfiguration.Builder.setTestDeviceIds() 테스트 광고 사용 설정을 참고하세요.
tagForChildDirectedTreatment() RequestConfiguration.Builder.setTagForChildDirectedTreatment() 광고 콘텐츠 필터링을 참고하세요.
setTagForUnderAgeOfConsent() RequestConfiguration.Builder.setTagForUnderAgeOfConsent()
setMaxAdContentRating() RequestConfiguration.Builder.setMaxAdContentRating()
AdView getMediationAdapterClassName() ResponseInfo.getMediationAdapterClassName() 이제 AdView 메서드 getResponseInfo()를 통해 ResponseInfo 객체를 사용할 수 있습니다.
NativeAdOptions setImageOrientation() setMediaAspectRatio()
getImageOrientation getMediaAspectRatio()
RewardedAd loadAd(AdRequest, RewardedAdLoadCallback) RewardedAd.load(Context, String, AdRequest, RewardedAdLoadCallback) 이제 RewardedAd에서 다른 전체 화면 형식과 동일한 정적 로드 방식을 사용합니다.
loadAd(PublisherAdRequest, RewardedAdLoadCallback) RewardedAd.load(Context, String, AdManagerAdRequest, RewardedAdLoadCallback)
isLoaded() 삭제됨 정적 로드 메서드의 콜백은 이미 로드된 광고를 제공합니다.
show(Activity, RewardedAdCallback) show(Activity, OnUserEarnedRewardListener) 이 show 메서드는 더 넓은 전체 화면 형식의 방식을 준수합니다.
RewardedAdLoadCallback onRewardedAdFailedToLoad(int) onAdFailedToLoad(LoadAdError)
onRewardedAdFailedToLoad(LoadAdError) onAdFailedToLoad(LoadAdError)
onRewardedAdLoaded() onAdLoaded(RewardedAd)
AppOpenAdLoadCallback onAppOpenAdFailedToLoad(int) onAdFailedToLoad(LoadAdError)
onAppOpenAdFailedToLoad(LoadAdError) onAdFailedToLoad(LoadAdError)
onAppOpenAdLoaded(AppOpenAd) onAdLoaded(AppOpenAd)
RewardedInterstitialAdLoadCallback onRewardedInterstitialAdFailedToLoad(int) onAdFailedToLoad(LoadAdError)
onRewardedInterstitialAdFailedToLoad(LoadAdError) onAdFailedToLoad(LoadAdError)
onRewardedInterstitialAdLoaded(RewardedInterstitialAd) onAdLoaded(RewardedInterstitialAd)
InterstitialAd new InterstitialAd() InterstitialAd.load(Context, String, AdRequest, InterstitialAdLoadCallback) 이제 InterstitialAd에서 다른 전체 화면 형식과 동일한 정적 로드 방식을 사용합니다.
setAdListener()
DynamicHeightSearchAdRequest getNetworkExtras() 삭제됨 NetworkExtras 클래스가 지원 중단되었습니다.
AdLoader forContentAd() 삭제됨
forAppInstallAd() 삭제됨
withCorrelator() 삭제됨
getMediationAdapterClassName() 삭제됨