이 페이지에서는 최신 버전과 이전 버전의 이전에 대해 설명합니다.
v22에서 v23으로 이전
최소 Android API 수준은 21입니다.
Google 모바일 광고 SDK 버전 23.0.0부터는 모든 앱이 Android API 수준 21 이상을 실행해야 합니다. API 수준을 조정하려면 앱 수준 build.gradle
파일에서 minSdkVersion
값을 21 이상으로 변경하세요.
슈퍼클래스에서 상속된 AdManagerAdRequest.Builder
메서드를 체이닝할 수 있습니다.
버전 23.0.0에서는 상위 요소에서 상속받은 AdManagerAdRequest.Builder
메서드를 연결하여 단일 호출을 사용하여 AdManagerAdRequest
를 빌드할 수 있습니다.
자바
AdManagerAdRequest request = new AdManagerAdRequest.Builder() .addCustomTargeting("age", "25") // AdManagerAdRequest.Builder method. .setContentUrl("https://www.example.com") // Method inherited from parent. .build(); // Builds an AdManagerAdRequest.
Kotlin
var request = AdManagerAdRequest.Builder() .addCustomTargeting("age", "25") // AdManagerAdRequest.Builder method. .setContentUrl("https://www.example.com") // Method inherited from parent. .build() // Builds an AdManagerAdRequest.
지원 중단된 메서드가 삭제/대체됨
v22.0.0 API | v23.0.0 API |
---|---|
AdRequest.Builder.addTestDevice() | RequestConfiguration.Builder.setTestDeviceIds() |
AdRequest.Builder.tagForChildDirectedTreatment() | RequestConfiguration.Builder.setTagForChildDirectedTreatment() |
AdRequest.Builder.setIsDesignedForFamilies() | RequestConfiguration.Builder.setMaxAdContentRating() |
AdFormat.UNKNOWN | 교체 불가 |
AdLoader.Builder.forUnifiedNativeAd() | AdLoader.Builder.forNativeAd() |
AdLoader.Builder.forCustomTemplateAd() | AdLoader.Builder.forCustomFormatAd() |
AdLoader.Builder.withNativeAdOptions(com.google.android.gms.ads.formats .NativeAdOptions)
|
AdLoader.Builder.withNativeAdOptions(com.google.android.gms.ads.nativead .NativeAdOptions)
|
void MobileAds.setSameAppKeyEnabled() | boolean MobileAds.putPublisherFirstPartyIdEnabled() |
v21에서 v22로 이전
MobileAds.getVersion()을 사용하여 Google 모바일 광고 SDK 버전 다운로드
MobileAds.getVersionString()
메서드는 버전 22.0.0에서 삭제되고 MobileAds.getVersion()
으로 대체됩니다.
새 메서드는 예상 외부 버전 번호를 반환합니다(예: 22.0.0
). 이 변경사항에 대한 자세한 내용은 새 Google 모바일 광고 SDK getVersion() 메서드 사용을 참고하세요.
지원 중단된 NativeCustomFormatAd.getVideoMediaView() 삭제
버전 21에서 Google 모바일 광고 SDK는 네이티브 맞춤 광고 형식의
미디어 애셋을 가져올 수 있는
NativeCustomFormatAd.getVideoMediaView()
메서드를 제공했습니다.
버전 22부터는 자체 MediaView
를 만들고, 미디어 콘텐츠를 설정하고, MediaContent.getVideoController()
를 사용하여 동영상을 관리할 수 있습니다.
v22
// Called when a custom native ad loads. @Override public void onCustomFormatAdLoaded(NativeCustomFormatAd ad) { // Assumes you have a FrameLayout in your view hierarchy with the id media_placeholder. FrameLayout mediaPlaceholder = (FrameLayout) findViewById(R.id.media_placeholder); MediaContent mediaContent = ad.getMediaContent(); if (mediaContent != null && mediaContent.hasVideoContent()) { // Create a MediaView and set its media content. MediaView mediaView = new MediaView(mediaPlaceholder.getContext()); mediaView.setMediaContent(mediaContent); mediaPlaceholder.addView(mediaView); } }
v21
// Called when a custom native ad loads. @Override public void onCustomFormatAdLoaded(NativeCustomFormatAd ad) { // Assumes you have a FrameLayout in your view hierarchy with the id media_placeholder. FrameLayout mediaPlaceholder = (FrameLayout) findViewById(R.id.media_placeholder); VideoController videoController = ad.getVideoController(); if (videoController.hasVideoContent()) { // Add the media view provided by the native ad. mediaPlaceholder.addView(ad.getVideoMediaView()); } }
자세한 내용은 맞춤 네이티브 광고 가이드를 참고하세요.
삭제 또는 대체된 메서드
아래 표에는 버전 22.0.0의 구체적인 변경사항이 나와 있습니다.
v21.0.0 | v22.0.0 |
---|---|
MobileAds.getVersionString() | MobileAds.getVersion() |
NativeCustomFormatAd.getVideoMediaView() | NativeCustomFormatAd.getMediaContent() |
NativeCustomFormatAd.getVideoController() | NativeCustomFormatAd.getMediaContent().getVideoController() |
AdRequest.Builder.setAdInfo() | AdRequest.Builder.setAdString() |
MediationRewardedVideoAdAdapter | 어댑터 |
MediationRewardedVideoAdListener | |
com.google.android.gms.ads.mediation.VersionInfo | com.google.android.gms.ads.VersionInfo |
com.google.android.gms.ads.doubleclick.AppEventListener | com.google.android.gms.ads.admanager.AppEventListener |
v20에서 v21로 이전
minSdkVersion을 19 이상으로 업데이트
Google 모바일 광고 SDK 버전 21.0.0부터는 모든 앱이 Android API 수준 19 이상을 실행해야 합니다. API 수준을 조정하려면 앱의 빌드 파일에서 minSdkVersion
값을 19 이상으로 변경하세요.
엄격한 null 허용 여부 적용
엄격한 null 허용 여부 적용에 대비하기 위해 이전에 null 허용 여부를 명시적으로 정의하지 않았던 모든 API에 @NonNull
주석이 추가됩니다.
이 변경으로 인해 null 안전 위반이 있고 이전에 null
값을 안전한 방식으로 처리하지 않은 경우 Kotlin 앱 및 Java 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를 이용해 서드 파티 광고 네트워크에 정보를 제공해야 합니다.
맞춤 이벤트 인터페이스 지원 중단
맞춤 이벤트를 사용하면미디에이션 을 사용하는 게시자가 Ad Manager의 지원되는 광고 소스가 아닌 폭포식 구조 광고 소스를 설정할 수 있습니다.
모든 맞춤 이벤트 인터페이스가 지원 중단되고 Adapter
클래스 및 MediationAdLoadCallback
인터페이스로 대체됩니다.
아래 표에는 버전 21.0.0부터 각 맞춤 이벤트 인터페이스에 사용해야 하는 해당 클래스 또는 인터페이스가 나와 있습니다.
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의 자리를 지켜 왔습니다. 한 번에 보상형 광고를 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 |
nativead.NativeCustomFormatAd |
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의 구체적인 변경사항이 나와 있습니다. 요약:
- 오래된 초기화 메서드가 MobileAds 클래스에서 삭제되었습니다.
AdRequest.Builder()
클래스의 일부 메서드가 삭제되었거나RequestConfiguration
클래스로 이동되었습니다.- RewardedAd 및 InterstitialAd API가 모든 전체 화면 형식에 부합하도록 업데이트되었습니다.
- Correlator 기능이 삭제되었습니다.
클래스 | v19.5.0 API | v20.0.0 API | 참고 |
---|---|---|---|
AdSize | getPortraitBanner |
getPortraitAnchored |
|
getLandscapeBanner |
getLandscapeAnchored |
||
getCurrentOrientation |
getCurrentOrientationAnchored |
||
MobileAds | initialize(Context, String) | MobileAds.initialize(Context, OnInitializationComplete |
이제 AndroidManifest.xml에 앱 ID가 설정됩니다. |
initialize(Context, String, MobileAds.Settings) | initialize(Context, OnInitializationComplete |
Settings 클래스가 지원 중단되었습니다. | |
getRewardedVideo |
삭제됨 | RewardedAd API를 대신 사용하세요. | |
AdListener | onAdFailedToLoad(int) | onAd |
|
onAdLeftApplication() | 삭제됨 | 전체 화면 광고 형식에서는 AdListener 대신 FullscreenContentCallback을 사용하며, FullscreenContentCallback에는 동등한 메서드가 없습니다. 해당 메서드는 AdListener에서 삭제되었습니다. | |
VideoController | getAspectRatio() | MediaContent.getAspectRatio() | |
PublisherAdRequest | getGender() | 삭제됨 | |
getBirthday() | 삭제됨 | ||
getNetworkExtras() | 삭제됨 | ||
setManualImpressions |
삭제됨 | ||
updateCorrelator() | 삭제됨 | 광고 콘텐츠 필터링을 참고하세요. | |
PublisherAdRequest.Builder | setBirthday() | 삭제됨 | |
setGender() | 삭제됨 | ||
setIsDesignedForFamilies() | 삭제됨 | 가이드를 참고하세요. | |
addTestDevice() | RequestConfiguration |
테스트 광고 사용 설정을 참고하세요. | |
tagForChildDirectedTreatment() | RequestConfiguration |
광고 콘텐츠 필터링을 참고하세요. | |
setTagFor |
RequestConfiguration |
||
setMaxAdContentRating() | RequestConfiguration |
||
AdView | getMediationAdapter |
ResponseInfo |
이제 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 | onRewardedAd |
onAd |
|
onRewardedAd |
onAd |
||
onRewardedAdLoaded() | onAdLoaded(RewardedAd) | ||
AppOpenAdLoadCallback | onAppOpenAd |
onAd |
|
onAppOpenAd |
onAd |
||
onAppOpenAd |
onAdLoaded(AppOpenAd) | ||
RewardedInterstitialAdLoad |
onRewardedInterstitialAd |
onAd |
|
onRewardedInterstitialAd |
onAd |
||
onRewardedInterstitialAd |
onAd |
||
PublisherInterstitialAd | new PublisherInterstitialAd() | InterstitialAd.load(Context, String, AdRequest, InterstitialAdLoadCallback) | 이제 InterstitialAd에서 다른 전체 화면 형식과 동일한 정적 로드 방식을 사용합니다. |
setAdListener() | |||
DynamicHeightSearchAd |
getNetworkExtras() | 삭제됨 | NetworkExtras 클래스가 지원 중단되었습니다. |
AdLoader | forContentAd() | 삭제됨 | |
forAppInstallAd() | 삭제됨 | ||
withCorrelator() | 삭제됨 | ||
getMediationAdapter |
삭제됨 |