Quảng cáo xen kẽ

Quảng cáo xen kẽ là quảng cáo toàn màn hình, che phủ giao diện của ứng dụng lưu trữ. Quảng cáo này thường xuất hiện tại các điểm chuyển tiếp tự nhiên trong luồng thực thi của ứng dụng, chẳng hạn như trong thời gian tạm dừng giữa các cấp độ trong trò chơi. Khi một ứng dụng hiển thị quảng cáo xen kẽ, người dùng có lựa chọn nhấn vào quảng cáo và tiếp tục hoặc đóng ứng dụng và quay lại ứng dụng.

Hướng dẫn này giải thích cách tích hợp quảng cáo xen kẽ vào ứng dụng Unity.

Điều kiện tiên quyết

Luôn thử nghiệm bằng quảng cáo thử nghiệm

Mã mẫu sau đây chứa một mã đơn vị quảng cáo mà bạn có thể sử dụng để yêu cầu quảng cáo thử nghiệm. Mã này được định cấu hình đặc biệt để trả về quảng cáo thử nghiệm thay vì quảng cáo thực tế cho mọi yêu cầu, giúp đảm bảo an toàn khi sử dụng.

Tuy nhiên, sau khi đăng ký một ứng dụng trong Giao diện web Ad Manager và tạo đơn vị quảng cáo của riêng bạn Mã nhận dạng để sử dụng trong ứng dụng của bạn, hãy định cấu hình thiết bị của bạn làm quá trình kiểm tra một cách rõ ràng thiết bị trong khoảng thời gian phát triển ứng dụng.

/6499/example/interstitial

Chạy SDK quảng cáo trên thiết bị di động

Trước khi tải quảng cáo, hãy để ứng dụng của bạn chạy SDK quảng cáo trên thiết bị di động bằng cách gọi MobileAds.Initialize(). Bạn chỉ cần thực hiện việc này một lần, tốt nhất là khi bắt đầu chạy ứng dụng.

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.
        });
    }
}

Nếu bạn đang sử dụng tính năng dàn xếp, hãy đợi cho đến khi lệnh gọi lại xảy ra trước khi tải quảng cáo dưới dạng điều này sẽ đảm bảo rằng tất cả các bộ chuyển đổi dàn xếp đều được khởi chạy.

Triển khai

Các bước chính để tích hợp quảng cáo xen kẽ là:

  1. Tải quảng cáo xen kẽ
  2. Hiển thị quảng cáo xen kẽ
  3. Theo dõi các sự kiện của quảng cáo xen kẽ
  4. Dọn dẹp quảng cáo xen kẽ
  5. Tải trước quảng cáo xen kẽ tiếp theo

Tải quảng cáo xen kẽ

Bạn có thể tải một quảng cáo xen kẽ bằng cách sử dụng phương thức Load() tĩnh trên Lớp InterstitialAd. Phương thức tải yêu cầu một mã đơn vị quảng cáo, AdManagerAdRequest và một trình xử lý hoàn thành. được gọi khi tải quảng cáo thành công hoặc không thành công. Các URL đã tải Đối tượng AdManagerInterstitialAd được cung cấp dưới dạng một thông số trong trình xử lý hoàn thành. Ví dụ bên dưới cho thấy cách tải một AdManagerInterstitialAd.


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

  private InterstitialAd _interstitialAd;

  /// <summary>
  /// Loads the interstitial ad.
  /// </summary>
  public void LoadInterstitialAd()
  {
      // Clean up the old ad before loading a new one.
      if (_interstitialAd != null)
      {
            _interstitialAd.Destroy();
            _interstitialAd = null;
      }

      Debug.Log("Loading the interstitial ad.");

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

      // send the request to load the ad.
      AdManagerInterstitialAd.Load(_adUnitId, adRequest,
          (InterstitialAd ad, LoadAdError error) =>
          {
              // if error is not null, the load request failed.
              if (error != null || ad == null)
              {
                  Debug.LogError("interstitial ad failed to load an ad " +
                                 "with error : " + error);
                  return;
              }

              Debug.Log("Interstitial ad loaded with response : "
                        + ad.GetResponseInfo());

              _interstitialAd = ad;
          });
  }

Hiển thị quảng cáo xen kẽ

Để hiển thị một quảng cáo xen kẽ đã tải, hãy gọi phương thức Show() trên Thực thể AdManagerInterstitialAd. Quảng cáo có thể được hiển thị một lần mỗi tải. Hãy sử dụng phương thức CanShowAd() để xác minh rằng quảng cáo đã sẵn sàng hiển thị.

/// <summary>
/// Shows the interstitial ad.
/// </summary>
public void ShowInterstitialAd()
{
    if (_interstitialAd != null && _interstitialAd.CanShowAd())
    {
        Debug.Log("Showing interstitial ad.");
        _interstitialAd.Show();
    }
    else
    {
        Debug.LogError("Interstitial ad is not ready yet.");
    }
}

Theo dõi các sự kiện của quảng cáo xen kẽ

Để tuỳ chỉnh thêm hành vi của quảng cáo, bạn có thể kết hợp với một số các sự kiện trong vòng đời của quảng cáo. Theo dõi những sự kiện này bằng cách đăng ký người được uỷ quyền như minh hoạ dưới đây.

private void RegisterEventHandlers(InterstitialAd interstitialAd)
{
    // Raised when the ad is estimated to have earned money.
    interstitialAd.OnAdPaid += (AdValue adValue) =>
    {
        Debug.Log(String.Format("Interstitial ad paid {0} {1}.",
            adValue.Value,
            adValue.CurrencyCode));
    };
    // Raised when an impression is recorded for an ad.
    interstitialAd.OnAdImpressionRecorded += () =>
    {
        Debug.Log("Interstitial ad recorded an impression.");
    };
    // Raised when a click is recorded for an ad.
    interstitialAd.OnAdClicked += () =>
    {
        Debug.Log("Interstitial ad was clicked.");
    };
    // Raised when an ad opened full screen content.
    interstitialAd.OnAdFullScreenContentOpened += () =>
    {
        Debug.Log("Interstitial ad full screen content opened.");
    };
    // Raised when the ad closed full screen content.
    interstitialAd.OnAdFullScreenContentClosed += () =>
    {
        Debug.Log("Interstitial ad full screen content closed.");
    };
    // Raised when the ad failed to open full screen content.
    interstitialAd.OnAdFullScreenContentFailed += (AdError error) =>
    {
        Debug.LogError("Interstitial ad failed to open full screen content " +
                       "with error : " + error);
    };
}

Dọn dẹp quảng cáo xen kẽ

Khi bạn đã hoàn tất với AdManagerInterstitialAd, hãy hãy nhớ gọi phương thức Destroy() trước khi xoá thông tin tham chiếu đến phương thức đó:

_interstitialAd.Destroy();

Thao tác này sẽ thông báo cho trình bổ trợ rằng đối tượng không còn được sử dụng nữa và bộ nhớ mà đối tượng đó không còn được sử dụng. chiếm lại có thể được xác nhận lại. Nếu không gọi được phương thức này, bộ nhớ sẽ bị rò rỉ.

Tải trước quảng cáo xen kẽ tiếp theo

Quảng cáo xen kẽ là đối tượng dùng một lần. Điều này có nghĩa là khi một quảng cáo xen kẽ sẽ hiển thị thì sẽ không dùng lại đối tượng này được. Để yêu cầu một quảng cáo xen kẽ khác, hãy tạo một đối tượng AdManagerInterstitialAd mới.

Để chuẩn bị quảng cáo xen kẽ cho cơ hội hiển thị tiếp theo, hãy tải trước quảng cáo xen kẽ sau khi OnAdFullScreenContentClosed hoặc OnAdFullScreenContentFailed sự kiện quảng cáo đã được tạo.

private void RegisterReloadHandler(InterstitialAd interstitialAd)
{
    // Raised when the ad closed full screen content.
    interstitialAd.OnAdFullScreenContentClosed += ()
    {
        Debug.Log("Interstitial Ad full screen content closed.");

        // Reload the ad so that we can show another as soon as possible.
        LoadInterstitialAd();
    };
    // Raised when the ad failed to open full screen content.
    interstitialAd.OnAdFullScreenContentFailed += (AdError error) =>
    {
        Debug.LogError("Interstitial ad failed to open full screen content " +
                       "with error : " + error);

        // Reload the ad so that we can show another as soon as possible.
        LoadInterstitialAd();
    };
}

Sự kiện ứng dụng

Sự kiện ứng dụng cho phép bạn tạo những quảng cáo có thể gửi tin nhắn đến mã ứng dụng của sự kiện đó. Ứng dụng thì có thể hành động dựa trên các tin nhắn này.

Bạn có thể theo dõi các sự kiện ứng dụng cụ thể của Ad Manager bằng cách sử dụng AppEvent. Các sự kiện này có thể xảy ra bất kỳ lúc nào trong vòng đời của quảng cáo, ngay cả trước khi tải được gọi.

namespace GoogleMobileAds.Api.AdManager;

/// The App event message sent from the ad.
public class AppEvent
{
    // Name of the app event.
    string Name;
    // Argument passed from the app event.
    string Value;
}

OnAppEventReceived sẽ tăng khi một sự kiện ứng dụng xảy ra trong một quảng cáo. Dưới đây là một ví dụ về cách xử lý sự kiện này trong mã của bạn:

_interstitialAd.OnAppEventReceived += (AppEvent args) =>
{
    Debug.Log($"Received app event from the ad: {args.Name}, {args.Value}.");
};

Dưới đây là ví dụ minh hoạ cách thay đổi màu nền của ứng dụng tuỳ thuộc vào sự kiện ứng dụng kèm theo tên màu:

_interstitialAd.OnAppEventReceived += (AppEvent args) =>
{
  if (args.Name == "color")
  {
    Color color;
    if (ColorUtility.TryParseColor(arg.Value, out color))
    {
      gameObject.GetComponent<Renderer>().material.color = color;
    }
  }
};

Đây là mẫu quảng cáo tương ứng sẽ gửi sự kiện ứng dụng màu:

<html>
<head>
  <script src="//www.gstatic.com/afma/api/v1/google_mobile_app_ads.js"></script>
  <script>
    document.addEventListener("DOMContentLoaded", function() {
      // Send a color=green event when ad loads.
      admob.events.dispatchAppEvent("color", "green");

      document.getElementById("ad").addEventListener("click", function() {
        // Send a color=blue event when ad is clicked.
        admob.events.dispatchAppEvent("color", "blue");
      });
    });
  </script>
  <style>
    #ad {
      width: 320px;
      height: 50px;
      top: 0px;
      left: 0px;
      font-size: 24pt;
      font-weight: bold;
      position: absolute;
      background: black;
      color: white;
      text-align: center;
    }
  </style>
</head>
<body>
  <div id="ad">Carpe diem!</div>
</body>
</html>

Các phương pháp hay nhất

Xác định xem quảng cáo xen kẽ có phải là loại quảng cáo phù hợp cho ứng dụng của bạn hay không.
Quảng cáo xen kẽ hoạt động hiệu quả nhất trong những ứng dụng có các điểm chuyển tiếp tự nhiên. Kết thúc một thao tác trong ứng dụng, chẳng hạn như chia sẻ hình ảnh hoặc hoàn tất trò chơi của bạn, tạo ra một điểm như vậy. Hãy đảm bảo bạn cân nhắc tại thời điểm nào trong quy trình của ứng dụng để hiển thị quảng cáo xen kẽ hiệu quả nhất và khả năng người dùng sẽ phản hồi.
Tạm dừng hành động khi hiển thị quảng cáo xen kẽ.
Có một số loại quảng cáo xen kẽ, chẳng hạn như quảng cáo văn bản, hình ảnh hoặc video. Điều quan trọng là phải đảm bảo rằng khi ứng dụng của bạn hiển thị quảng cáo xen kẽ cũng sẽ tạm ngừng việc sử dụng một số tài nguyên để cho phép quảng cáo hãy tận dụng chúng. Ví dụ: khi bạn thực hiện lệnh gọi để hiển thị quảng cáo xen kẽ, hãy nhớ tạm dừng mọi đầu ra âm thanh mà ứng dụng của bạn đang tạo. Bạn có thể tiếp tục phát âm thanh trong sự kiện OnAdFullScreenContentClosed(), Có thể được gọi khi người dùng đã tương tác xong với quảng cáo. Ngang bằng hãy cân nhắc tạm dừng mọi công việc tính toán cường độ cao, chẳng hạn như vòng lặp trò chơi trong khi quảng cáo đang hiển thị. Điều này đảm bảo rằng người dùng không gặp phải tình trạng hình ảnh chậm hoặc không phản hồi hay video bị giật.
Đừng hiển thị quá nhiều quảng cáo cho người dùng.
Mặc dù có vẻ như bạn sẽ tăng tần suất hiển thị quảng cáo xen kẽ trong ứng dụng của mình giống như cách tuyệt vời để tăng doanh thu, nhưng nó cũng có thể làm giảm trải nghiệm người dùng và tỷ lệ nhấp thấp hơn. Hãy đảm bảo rằng người dùng không thường xuyên bị gián đoạn khiến họ không còn hứng thú khi sử dụng ứng dụng của bạn.

Tài nguyên khác