Natywne nakładki reklamowe

Rozpocznij

Natywne nakładki reklamowe są wyświetlane użytkownikom za pomocą komponentów interfejsu, które są natywne dla platformy. Te reklamy są wyświetlane jako nakładka na aplikację. Działają podobnie jak banery reklamowe, ale można dostosować ich wygląd.

Natywne nakładki reklamowe obsługują zapośredniczenie i reklamy wideo. Jest to główna zaleta natywnych nakładek reklamowych w porównaniu z reklamami natywnymi.

Z tego przewodnika dowiesz się, jak zaimplementować natywne nakładki reklamowe w aplikacji Unity, oraz poznasz ważne kwestie, które należy wziąć pod uwagę.

Wymagania wstępne

Zanim przejdziesz dalej, wykonaj te czynności:

Zawsze testuj za pomocą reklam testowych

Poniższy przykładowy kod zawiera identyfikator jednostki reklamowej, którego możesz użyć do wysyłania żądań reklam testowych. Został on specjalnie skonfigurowany tak, aby na każde żądanie zwracać reklamy testowe, a nie reklamy produkcyjne, dzięki czemu można go bezpiecznie używać.

Gdy zarejestrujesz aplikację w interfejsie Ad Managera i utworzysz własne identyfikatory jednostek reklamowych do użycia w aplikacji, podczas programowania wyraźnie skonfiguruj urządzenie jako urządzenie testowe.

/21775744923/example/native

Wczytywanie natywnej nakładki reklamowej

Wczytywanie natywnej nakładki reklamowej odbywa się za pomocą statycznej metody Load() w klasie NativeOverlayAd. Wczytany obiekt NativeOverlayAd jest podawany jako parametr w procedurze obsługi zakończenia.

Poniższy kod używa NativeOverlayAd do wczytywania reklamy:




// This ad unit is configured to always serve test ads.
private string _adUnitId = "/21775744923/example/native";



private NativeOverlayAd _nativeOverlayAd;

/// <summary>
/// Loads the ad.
/// </summary>
public void LoadAd()
{
    // Clean up the old ad before loading a new one.
    if (_nativeOverlayAd != null)
    {
        DestroyAd();
    }

    Debug.Log("Loading native overlay ad.");

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

    // Optional: Define native ad options.
    var options = new NativeAdOptions
    {
        AdChoicesPosition = AdChoicesPlacement.TopRightCorner,
        MediaAspectRatio = NativeMediaAspectRatio.Any,
    };

    // Send the request to load the ad.
    NativeOverlayAd.Load(_adUnitId, adRequest, options,
        (NativeOverlayAd ad, LoadAdError error) =>
    {
        if (error != null)
        {
            Debug.LogError("Native Overlay ad failed to load an ad " +
                           " with error: " + error);
            return;
        }

        // The ad should always be non-null if the error is null, but
        // double-check to avoid a crash.
        if (ad == null)
        {
            Debug.LogError("Unexpected error: Native Overlay ad load event " +
                           " fired with null ad and null error.");
            return;
        }

        // The operation completed successfully.
        Debug.Log("Native Overlay ad loaded with response : " +
                   ad.GetResponseInfo());
        _nativeOverlayAd = ad;

        // Register to ad events to extend functionality.
        RegisterEventHandlers(ad);
    });
}

Renderowanie i stylizowanie natywnej nakładki reklamowej

Natywne nakładki reklamowe są renderowane za pomocą NativeTemplateStyle. Ta klasa definiuje pola, które umożliwiają dostosowanie wyglądu reklamy.

TemplateID to wymagany ciąg znaków, który określa szablon natywny używany do renderowania natywnej nakładki reklamowej. Aby wybrać odpowiedni szablon natywny dla reklamy, użyj stałej NativeTemplateID.

Poniższy kod renderuje natywną nakładkę reklamową za pomocą szablonu średniego i stylu niestandardowego.

/// <summary>
/// Renders the ad.
/// </summary>
public void RenderAd()
{
    if (_nativeOverlayAd != null)
    {
        Debug.Log("Rendering Native Overlay ad.");

        // Define a native template style with a custom style.
        var style = new NativeTemplateStyle
        {
            TemplateID = NativeTemplateID.Medium,
            MainBackgroundColor = Color.red,
            CallToActionText = new NativeTemplateTextStyles
            {
                BackgroundColor = Color.green,
                FontColor = Color.white,
                FontSize = 9,
                Style = NativeTemplateFontStyle.Bold
            }
        };

        // Renders a native overlay ad at the default size
        // and anchored to the bottom of the screne.
        _nativeOverlayAd.RenderTemplate(style, AdPosition.Bottom);
    }
}

Wyświetlanie i ukrywanie natywnej nakładki reklamowej

Poniższy kod pokazuje, jak wyświetlić wczytaną natywną nakładkę reklamową.

/// <summary>
/// Shows the ad.
/// </summary>
public void ShowAd()
{
    if (_nativeOverlayAd != null)
    {
        Debug.Log("Showing Native Overlay ad.");
        _nativeOverlayAd.Show();
    }
}

Ukrywanie natywnej nakładki reklamowej

Poniższy kod pokazuje, jak ukryć natywną nakładkę reklamową.

/// <summary>
/// Hides the ad.
/// </summary>
public void HideAd()
{
    if (_nativeOverlayAd != null)
    {
        Debug.Log("Hiding Native Overlay ad.");
        _nativeOverlayAd.Hide();
    }
}

Niszczenie natywnej nakładki reklamowej

Gdy skończysz korzystać z natywnej nakładki reklamowej, wywołaj metodę Destroy(), aby zwolnić zasoby.

/// <summary>
/// Destroys the native overlay ad.
/// </summary>
public void DestroyAd()
{
    if (_nativeOverlayAd != null)
    {
        Debug.Log("Destroying native overlay ad.");
        _nativeOverlayAd.Destroy();
        _nativeOverlayAd = null;
    }
}