SDK 이전

컬렉션을 사용해 정리하기 내 환경설정을 기준으로 콘텐츠를 저장하고 분류하세요.

이 페이지에서는 현재 및 이전 버전의 이전에 대해 설명합니다.

v20에서 v21로 이전

minSdkVersion을 버전 19 이상으로 업데이트

Google 모바일 광고 SDK 버전 21.0.0부터는 모든 앱이 Android API 수준 19 이상을 실행해야 합니다. API 수준을 조정하려면 앱의 빌드 파일에서 minSdkVersion 값을 19 이상으로 변경하세요.

엄격한 null 허용 여부 적용

엄격한 null 허용 여부 적용에 대비하기 위해 이전에 null 허용 여부를 명시적으로 정의하지 않았던 모든 API에 @NonNull 주석이 추가됩니다.

이 변경으로 인해 null 안전 위반이 있고 이전에 null 값을 안전한 방식으로 처리하지 않은 경우 Kotlin 앱 및 자바 null 검사 프레임워크를 사용하는 앱이 손상될 수 있습니다 (Null 안전에 관한 Kotlin 문서 참고).

addNetworkExtras() 메서드 삭제

추가 매개변수를 특정 광고 네트워크 어댑터에 NetworkExtras 인스턴스로 전달하는 addNetworkExtras() 메서드는 SDK 20.3.0에서 지원 중단되었으며 버전 21.0.0에서 삭제될 예정입니다. 대신 동일한 AdRequest.Builder 클래스의 addNetworkExtrasBundle() 메서드를 사용하세요.

위치 메서드 삭제

버전 21.0.0에서 다음 위치 메서드가 삭제됩니다.

  • 미디에이션 타겟팅을 위해 사용자의 위치를 설정하는 setLocation(Location location) 메서드(AdRequest.Builder 클래스)
  • 이전에 setLocation(Location location) 메서드에 전달되었던 사용자의 위치 타겟팅 정보를 반환하는 getLocation() 메서드(AdRequest 클래스)
  • AdRequest로 정의된 경우 사용자의 위치를 반환하는 getLocation() 메서드(MediationAdConfiguration 클래스)

Google에서는 광고 타겟팅을 위해 위치 데이터를 사용하지 않습니다. 필요한 경우 타사 API를 사용하여 타사 광고 네트워크에 정보를 제공해야 합니다.

맞춤 이벤트 인터페이스 지원 중단

맞춤 이벤트를 사용하면 AdMob미디에이션을 사용하는 게시자가AdMob에서 지원하는 광고 네트워크가 아닌 광고 네트워크에 대한 폭포식 구조 미디에이션을 추가할 수 있습니다.

모든 맞춤 이벤트 인터페이스가 지원 중단되고 Adapter 클래스 및 MediationAdLoadCallback 인터페이스로 대체됩니다.

아래 표에는 버전 21.0.0부터 각 맞춤 이벤트 인터페이스에 사용해야 하는 해당 클래스 또는 인터페이스가 나와 있습니다.

v20.0.0 인터페이스 v21.0.0 클래스/ 인터페이스
맞춤 이벤트 어댑터
맞춤 이벤트 배너
맞춤 이벤트 전면 광고
맞춤 이벤트 네이티브
맞춤 이벤트 배너 리스너 어댑터, MediationAdLoadCallback
맞춤 이벤트 전면 광고 리스너
맞춤 이벤트 리스너
맞춤 이벤트 네이티브 리스너

v19에서 v20으로 이전

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

전체 화면 형식 API 업데이트

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

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

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

기존 RewardedVideoAd API 삭제

최신 RewardedAd API는 2019년 3월에 처음 도입되었으며 18개월 이상 기본 보상형 API로 사용되었습니다. 한 번에 보상형 광고를 두 개 이상 로드하는 기능을 비롯하여 기존 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.
보상.보상형 동영상 광고 보상형 광고 보상형 광고
보상.보상형 동영상 광고 리스너 Rewarded.RewardedAdLoadCallback 및 FullScreenContentCallback
보상 상품. 보상형 광고 리워드 항목
보상형 광고 콜백 OnUserEarnedRewardListener
형식.UnifiedNativeAdView nativead.NativeAdView
형식.UnifiedNativeAd nativead.NativeAd
형식.UnifiedNativeAdAssetNames nativead.NativeAdAssetNames
Format.UnifiedNativeAd.OnUnifiedNativeAdLoadedListener nativead.NativeAd.OnNativeAdLoadedListener
형식.AdChoicesView nativead.AdChoicesView
형식.NativeAd.AdChoices정보 nativead.NativeAd.AdChoicesInfo
형식.MediaView nativead.MediaView
형식.NativeAdViewHolder nativead.NativeAdViewHolder
형식.NativeAdOptions nativead.NativeAdOptions
Format.NativeCustomTemplateAd nativead.NativeCustomFormatAd
Format.NativeCustomTemplateAd.OnCustomTemplateAdLoadedListener nativead.NativeCustomFormatAd.OnCustomFormatAdLoadedListener
MobileAds.Settings 삭제됨
doubleclick.PublisherXXXXXXXX admanager.AdManagerValueTrack
doubleclick.PublisherAdView admanager.AdManagerAdView
Format.PublisherAdViewOptions 형식.AdManagerAdViewOptions
doubleclick.Publisher전면 광고 admanager.AdManager전면 광고
전면 광고 전면 광고.전면 광고
NativeExpressAdView 삭제됨
instream.InstreamAd 삭제됨
미디에이션.admob.AdMob추가 삭제됨
상관자 삭제됨
검색 검색 검색 삭제됨
pagetype.TagForunderAgeOfConsent 인터페이스 삭제됨
pagetype.MaxAdContentRating 인터페이스 삭제됨
Format.NativeAppInstallAd native.NativeAd
Format.NativeAppInstallAdView native.NativeAdView
미디에이션.NativeAppInstallAdMapper 미디에이션.통합NativeAdMapper
형식.네이티브 콘텐츠 광고 native.NativeAd
Format.NativeContentAdView native.NativeAdView
미디에이션.네이티브 콘텐츠 광고 매퍼 미디에이션.통합NativeAdMapper

삭제/대체된 메서드

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

  • MobileAds 클래스에서 오래된 초기화 메서드가 삭제되었습니다.
  • AdRequest.Builder() 클래스의 일부 메서드가 삭제되었거나 RequestConfiguration 클래스로 이동했습니다.
  • RewardedAd 및 전면 광고 API가 모든 전체 화면 형식에 맞게 업데이트되었습니다.
  • 상관자 기능이 삭제되었습니다.
클래스 v19.5.0 API v20.0.0 API 메모
광고 크기 get세로 배너AdSizeWithWidth() get세로 앵커 광고적응형 배너 광고 크기()
get 풍경 배너AdSizeWithWidth() get 풍경앵커AdaptiveBannerAdSize()
getCurrentOrientationBannerAdSizeWithWidth() getCurrentOrientationAnchoredAdaptiveBannerAdSize()
모바일 광고 initialize(Context, String) MobileAds.initialize(Context, OnInitializationComplete리스너) 이제 AndroidManifest.xml에 앱 ID가 설정됩니다.
initialize(Context, String, MobileAds.Settings) initialize(Context, OnInitializationComplete리스너) Settings 클래스는 지원 중단되었습니다.
getRewardedVideoAdInstance() 삭제됨 대신 RewardedAd API를 사용하세요.
광고 리스너 onAdFailedToLoad(int) onAdFailedToLoad(LoadAdError)
onAdLeftApplication() 삭제됨 전체 화면 광고 형식은 AdListener 대신 FullscreenContentCallback을 사용하며, FullscreenContentCallback에는 동일한 메서드가 없습니다. AdListener에서 메서드가 삭제되었습니다.
동영상 컨트롤러 getAspectRatio() MediaContent.getAspectRatio()
AdRequest getGender() 삭제됨
getBirthday() 삭제됨
getNetworkExtras() 삭제됨
setManualImpression사용 설정됨 삭제됨
UpdateCorrelator() 삭제됨 광고 콘텐츠 필터링을 참고하세요.
AdRequest.Builder setBirthday() 삭제됨
setGender() 삭제됨
setIsDesignForFamilies() 삭제됨 가이드를 참고하세요.
addTestDevice() RequestConfiguration.Builder.setTestDeviceIds() 테스트 광고 사용 설정을 참고하세요.
tagForChildDirectedTreatment() RequestConfiguration.Builder.setTagForChildDirectedTreatment() 광고 콘텐츠 필터링을 참고하세요.
setTagForunderAgeOfConsent() RequestConfiguration.Builder.setTagForUnderAgeOfConsent()
setMaxAdContentRating() RequestConfiguration.Builder.setMaxAdContentRating()
GCLID getMediationAdapterClassName() ResponseInfo.getMediationAdapterClassName() 이제 AdView 메서드 getResponseInfo()를 통해 ResponseInfo 객체를 사용할 수 있습니다.
NativeAdOptions setImageOrientation() setMediaAspectRatio()
getImageOrientation getMediaAspectRatio()
보상형 광고 loadAd(GCLID, RewardedAdLoadCallback) RewardedAd.load(Context, String, pagetype, RewardedAdLoadCallback) 이제 보상형 광고는 다른 전체 화면 형식과 동일한 정적 로드 방식을 사용합니다.
loadAd(Publisher검색주소창, RewardedAdLoadCallback) RewardedAd.load(Context, String, AdManagerKML, RewardedAdLoadCallback)
isLoaded() 삭제됨 정적 로드 메서드의 콜백은 이미 로드된 광고를 제공합니다.
show(Activity, RewardedAdCallback) show(Activity, OnUserEarnedRewardListener) 이 표시 방법은 더 광범위한 전체 화면 형식 접근 방식을 따릅니다.
보상형 광고 로드 콜백 onRewardedAdFailedToLoad(int) onAdFailedToLoad(LoadAdError)
onRewardedAdFailedToLoad(LoadAdError) onAdFailedToLoad(LoadAdError)
onRewardedAdLoaded() onAdLoaded(RewardedAd)
AppOpenAdLoadCallback onAppOpenAdFailedToLoad(int) onAdFailedToLoad(LoadAdError)
onAppOpenAdFailedToLoad(LoadAdError) onAdFailedToLoad(LoadAdError)
onAppOpenAd로드됨(AppOpenAd) onAdLoaded(AppOpenAd)
Rewarded전면 광고 로드콜백 onRewarded전면 광고실패한 로드(int) onAdFailedToLoad(LoadAdError)
onRewarded전면 광고실패 시 로드(LoadAdError) onAdFailedToLoad(LoadAdError)
onRewarded전면 광고로드됨(보상형 전면 광고) onAd로드됨(보상형 전면 광고)
InterstitialAd 새 InterstitialAd() VPAIDAd.load(컨텍스트, 문자열, 검색주소창, 전면 광고 로드 콜백) 이제 전면 광고에서는 다른 전체 화면 형식과 동일한 정적 로드 방식을 사용합니다.
setAdListener()
DynamicHeightSearchAd요청 getNetworkExtras() 삭제됨 NetworkExtras 클래스가 지원 중단되었습니다.
forContentAd() 삭제됨
forAppInstallAd() 삭제됨
withCorrelator() 삭제됨
getMediationAdapterClassName() 삭제됨