배너 광고

배너 보기는 화면 안의 한 지점을 차지하는 직사각형 이미지 또는 텍스트 광고입니다. 사용자가 앱과 상호작용하는 동안 화면에 표시되며 새로고침할 수 있습니다. 일정 시간이 지나면 자동으로 설정될 수 있습니다 모바일이 처음인 경우 시작하기에 좋은 출발점입니다 우수사례

이 가이드에서는 배너 뷰를 Unity 앱에 통합하는 방법을 설명합니다. 또한 코드 스니펫과 안내에 관한 추가 정보를 제공하며 추가 리소스로 연결되는 링크를 제공합니다

기본 요건

항상 테스트 광고로 테스트

다음 샘플 코드에는 요청에 사용할 수 있는 광고 단위 ID가 포함되어 있습니다. 테스트 광고 테스트 광고를 반환하도록 특별히 구성된 경우 만들기 때문에 안전하게 사용할 수 있습니다.

하지만 AdMob 웹 인터페이스에서 자체 광고 단위를 만들었습니다 앱에서 사용할 ID를 확인하고 기기를 테스트로 명시적으로 구성 기기에서 있습니다.

Android

ca-app-pub-3940256099942544/6300978111

iOS

ca-app-pub-3940256099942544/2934735716

모바일 광고 SDK 초기화

광고를 로드하기 전에 앱에서 다음을 호출하여 모바일 광고 SDK를 초기화하도록 합니다. MobileAds.Initialize() 이 작업은 앱 실행 시 한 번만 처리하면 됩니다.

using GoogleMobileAds;
using GoogleMobileAds.Api;

public class GoogleMobileAdsDemoScript : MonoBehaviour
{
    public void Start()
    {
        // Initialize the Google Mobile Ads SDK.
        MobileAds.Initialize((InitializationStatus initStatus) =>
        {
            // This callback is called once the MobileAds SDK is initialized.
        });
    }
}

미디에이션을 사용하는 경우 콜백이 발생할 때까지 기다린 후 이렇게 하면 모든 미디에이션 어댑터가 초기화됩니다.

BannerView 예

아래의 샘플 코드에는 배너 보기를 사용하는 방법이 자세히 나와 있습니다. 이 예에서 여러분은 배너 보기의 인스턴스를 만들고, AdRequest: 배너 뷰에 광고를 로드합니다. 그런 다음 수명 주기 이벤트를 처리하여 기능을 확장합니다.

배너 뷰 만들기

배너 보기 사용의 첫 번째 단계는 배너 보기의 인스턴스를 만드는 것입니다. GameObject에 연결된 C# 스크립트에서 실행됩니다.


  // These ad units are configured to always serve test ads.
#if UNITY_ANDROID
  private string _adUnitId = "ca-app-pub-3940256099942544/6300978111";
#elif UNITY_IPHONE
  private string _adUnitId = "ca-app-pub-3940256099942544/2934735716";
#else
  private string _adUnitId = "unused";
#endif

  BannerView _bannerView;

  /// <summary>
  /// Creates a 320x50 banner view at top of the screen.
  /// </summary>
  public void CreateBannerView()
  {
      Debug.Log("Creating banner view");

      // If we already have a banner, destroy the old one.
      if (_bannerView != null)
      {
          DestroyAd();
      }

      // Create a 320x50 banner at top of the screen
      _bannerView = new BannerView(_adUnitId, AdSize.Banner, AdPosition.Top);
  }

BannerView의 생성자에는 다음이 포함됩니다. 매개변수:

  • adUnitId: BannerView에서 광고를 로드해야 합니다.
  • AdSize: 사용할 광고 크기입니다. 배너 크기를 참고하세요. 참조하세요.
  • AdPosition: 배너 뷰를 배치할 위치입니다. 이 AdPosition enum은 유효한 광고 게재순위 값을 나열합니다.

플랫폼에 따라 광고 단위가 어떻게 사용되는지 확인하세요. iOS에서 광고를 요청하기 위한 iOS 광고 단위와 요청을 수행합니다.

(선택사항) 맞춤 위치로 배너 보기 만들기

BannerView의 위치를 더 세밀하게 제어하기 위해 AdPosition 값에서 제공하는 것보다 화면에 배치되는 경우 생성자를 사용합니다. 는 다음과 같습니다.

// Create a 320x50 banner views at coordinate (0,50) on screen.
_bannerView = new BannerView(_adUnitId, AdSize.Banner, 0, 50);

BannerView의 왼쪽 상단은 다음과 같습니다. 생성자에 전달된 x 및 y 값에 배치됩니다. 여기서 왼쪽 상단으로 이동합니다.

(선택사항) 맞춤 크기로 배너 보기 만들기

AdSize 상수를 사용하는 것 외에 맞춤 크기를 지정할 수도 있습니다. :

// Use the AdSize argument to set a custom size for the ad.
AdSize adSize = new AdSize(250, 250);
_bannerView = new BannerView(_adUnitId, adSize, AdPosition.Bottom);

배너 광고 로드

광고를 로드하려면 AdRequest를 만들어 LoadAd() 메서드

/// <summary>
/// Creates the banner view and loads a banner ad.
/// </summary>
public void LoadAd()
{
    // create an instance of a banner view first.
    if(_bannerView == null)
    {
        CreateBannerView();
    }

    // create our request used to load the ad.
    var adRequest = new AdRequest();

    // send the request to load the ad.
    Debug.Log("Loading banner ad.");
    _bannerView.LoadAd(adRequest);
}

배너 보기 이벤트 수신

광고의 작동 방식을 맞춤설정하려면 로드, 열기, 닫기 등 광고의 수명 주기 이 음악을 들으려면 대리자를 등록하세요.

/// <summary>
/// listen to events the banner view may raise.
/// </summary>
private void ListenToAdEvents()
{
    // Raised when an ad is loaded into the banner view.
    _bannerView.OnBannerAdLoaded += () =>
    {
        Debug.Log("Banner view loaded an ad with response : "
            + _bannerView.GetResponseInfo());
    };
    // Raised when an ad fails to load into the banner view.
    _bannerView.OnBannerAdLoadFailed += (LoadAdError error) =>
    {
        Debug.LogError("Banner view failed to load an ad with error : "
            + error);
    };
    // Raised when the ad is estimated to have earned money.
    _bannerView.OnAdPaid += (AdValue adValue) =>
    {
        Debug.Log(String.Format("Banner view paid {0} {1}.",
            adValue.Value,
            adValue.CurrencyCode));
    };
    // Raised when an impression is recorded for an ad.
    _bannerView.OnAdImpressionRecorded += () =>
    {
        Debug.Log("Banner view recorded an impression.");
    };
    // Raised when a click is recorded for an ad.
    _bannerView.OnAdClicked += () =>
    {
        Debug.Log("Banner view was clicked.");
    };
    // Raised when an ad opened full screen content.
    _bannerView.OnAdFullScreenContentOpened += () =>
    {
        Debug.Log("Banner view full screen content opened.");
    };
    // Raised when the ad closed full screen content.
    _bannerView.OnAdFullScreenContentClosed += () =>
    {
        Debug.Log("Banner view full screen content closed.");
    };
}

배너 뷰 폐기

배너 보기 사용을 마치면 Destroy()를 호출하여 리소스를 배포합니다

/// <summary>
/// Destroys the banner view.
/// </summary>
public void DestroyAd()
{
    if (_bannerView != null)
    {
        Debug.Log("Destroying banner view.");
        _bannerView.Destroy();
        _bannerView = null;
    }
}

작업이 끝났습니다. 이제 앱에서 배너 광고를 게재할 수 있습니다.

아래 표에는 표준 배너 크기가 나와 있습니다.

크기(dp(너비x높이)) 설명 가용성 AdSize 상수
320x50 표준 배너 휴대전화 및 태블릿 BANNER
320x100 대형 배너 휴대전화 및 태블릿 LARGE_BANNER
300x250 IAB 중형 직사각형 휴대전화 및 태블릿 MEDIUM_RECTANGLE
468x60 IAB 원본 크기 배너 태블릿 FULL_BANNER
728x90 IAB 리더보드 태블릿 LEADERBOARD
제공된 너비 x 적응형 높이 적응형 배너 휴대전화 및 태블릿 해당 사항 없음
화면 너비 x 32|50|90 스마트 배너 휴대전화 및 태블릿 SMART_BANNER
적응형 배너에 대해 자세히 알아보세요. 스마트 배너를 대체하기 위해 제공됩니다.

추가 리소스