Doanh thu từ quảng cáo ở cấp lượt hiển thị

Chọn nền tảng: Android iOS Unity

Khi một lượt hiển thị xảy ra, SDK quảng cáo trên thiết bị di động của Google sẽ cung cấp dữ liệu doanh thu từ quảng cáo liên quan đến lượt hiển thị đó. Bạn có thể sử dụng dữ liệu này để tính toán giá trị vòng đời của người dùng hoặc chuyển dữ liệu cho các hệ thống liên quan khác.

Hướng dẫn này nhằm giúp bạn triển khai tính năng thu thập dữ liệu về doanh thu từ quảng cáo ở cấp lượt hiển thị trong ứng dụng Android.

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

  • Nhập SDK Quảng cáo của Google trên thiết bị di động phiên bản 21.1.0 trở lên.

Mỗi định dạng quảng cáo đều có một OnPaidEventListener. Trong vòng đời của một sự kiện quảng cáo, SDK quảng cáo trên thiết bị di động của Google sẽ theo dõi các sự kiện hiển thị và gọi trình xử lý bằng giá trị nhận được.

Ví dụ sau đây xử lý các sự kiện có tính phí cho một quảng cáo có tặng thưởng:

Java

private void setOnPaidEventListener(RewardedAd ad) {
  ad.setOnPaidEventListener(
      new OnPaidEventListener() {
        @Override
        public void onPaidEvent(@NonNull AdValue adValue) {
          // Extract the impression-level ad revenue data.
          long valueMicros = adValue.getValueMicros();
          String currencyCode = adValue.getCurrencyCode();
          int precision = adValue.getPrecisionType();

          // Get the ad unit ID.
          String adUnitId = ad.getAdUnitId();

          // Extract ad response information.
          AdapterResponseInfo loadedAdapterResponseInfo =
              ad.getResponseInfo().getLoadedAdapterResponseInfo();
          if (loadedAdapterResponseInfo != null) {
            String adSourceName = loadedAdapterResponseInfo.getAdSourceName();
            String adSourceId = loadedAdapterResponseInfo.getAdSourceId();
            String adSourceInstanceName = loadedAdapterResponseInfo.getAdSourceInstanceName();
            String adSourceInstanceId = loadedAdapterResponseInfo.getAdSourceInstanceId();

            Bundle extras = ad.getResponseInfo().getResponseExtras();
            String mediationGroupName = extras.getString("mediation_group_name");
            String mediationABTestName = extras.getString("mediation_ab_test_name");
            String mediationABTestVariant = extras.getString("mediation_ab_test_variant");
          }
        }
      });
}

Kotlin

private fun setOnPaidEventListener(ad: RewardedAd) {
  ad.onPaidEventListener = OnPaidEventListener { adValue ->
    // Extract the impression-level ad revenue data.
    val valueMicros = adValue.valueMicros
    val currencyCode = adValue.currencyCode
    val precision = adValue.precisionType

    // Get the ad unit ID.
    val adUnitId = ad.adUnitId

    // Extract ad response information.
    val loadedAdapterResponseInfo = ad.responseInfo.loadedAdapterResponseInfo
    val adSourceName = loadedAdapterResponseInfo?.adSourceName
    val adSourceId = loadedAdapterResponseInfo?.adSourceId
    val adSourceInstanceName = loadedAdapterResponseInfo?.adSourceInstanceName
    val adSourceInstanceId = loadedAdapterResponseInfo?.adSourceInstanceId
    val extras = ad.responseInfo.responseExtras
    val mediationGroupName = extras.getString("mediation_group_name")
    val mediationABTestName = extras.getString("mediation_ab_test_name")
    val mediationABTestVariant = extras.getString("mediation_ab_test_variant")
  }
}

Xác định tên nguồn quảng cáo của sự kiện tuỳ chỉnh

Đối với các nguồn quảng cáo sự kiện tuỳ chỉnh, phương thức getAdSourceName() sẽ trả về tên nguồn quảng cáo Custom event. Nếu bạn sử dụng nhiều sự kiện tuỳ chỉnh, thì tên nguồn quảng cáo sẽ không đủ chi tiết để phân biệt giữa nhiều sự kiện tuỳ chỉnh. Để xác định vị trí của một sự kiện tuỳ chỉnh cụ thể, hãy làm như sau:

  1. Gọi phương thức getAdSourceName().
  2. Đặt một tên riêng biệt cho nguồn quảng cáo.

Ví dụ sau đây đặt một tên nguồn quảng cáo riêng biệt cho một sự kiện tuỳ chỉnh:

Java

private String getUniqueAdSourceName(@NonNull AdapterResponseInfo loadedAdapterResponseInfo) {

  String adSourceName = loadedAdapterResponseInfo.getAdSourceName();
  if (adSourceName.equals("Custom Event")) {
    if (loadedAdapterResponseInfo
        .getAdapterClassName()
        .equals("com.google.ads.mediation.sample.customevent.SampleCustomEvent")) {
      adSourceName = "Sample Ad Network (Custom Event)";
    }
  }
  return adSourceName;
}

Kotlin

private fun getUniqueAdSourceName(loadedAdapterResponseInfo: AdapterResponseInfo): String {

  var adSourceName = loadedAdapterResponseInfo.adSourceName
  if (adSourceName == "Custom Event") {
    if (
      loadedAdapterResponseInfo.adapterClassName ==
        "com.google.ads.mediation.sample.customevent.SampleCustomEvent"
    ) {
      adSourceName = "Sample Ad Network (Custom Event)"
    }
  }
  return adSourceName
}

Để biết thêm thông tin về nguồn quảng cáo giành chiến thắng, hãy xem bài viết Truy xuất thông tin về nội dung phản hồi quảng cáo.

Tích hợp với Đối tác phân bổ ứng dụng (AAP)

Để biết thông tin đầy đủ về cách chuyển dữ liệu doanh thu từ quảng cáo đến các nền tảng phân tích, hãy tham khảo hướng dẫn của đối tác:

Partner SDK
Adjust
AppsFlyer
Singular
Tenjin

Các phương pháp triển khai hay nhất

  • Thiết lập trình nghe ngay sau khi bạn tạo hoặc có quyền sử dụng đối tượng quảng cáo và ngay trước khi hiển thị quảng cáo. Điều này đảm bảo rằng bạn không bỏ lỡ bất kỳ lệnh gọi lại sự kiện có tính phí nào.
  • Gửi thông tin về doanh thu từ quảng cáo ở cấp lượt hiển thị đến máy chủ phân tích ưu tiên của bạn ngay tại thời điểm lệnh gọi lại sự kiện có tính phí được gọi. Điều này đảm bảo rằng bạn không vô tình bỏ qua bất kỳ lệnh gọi lại nào và tránh tạo ra sự chênh lệch về dữ liệu.

AdValue

AdValue là một lớp đại diện cho giá trị tiền tệ mà bạn nhận được từ một quảng cáo, bao gồm mã đơn vị tiền tệ của giá trị và loại mã chính xác được mã hoá như sau.

PrecisionType Mô tả
UNKNOWN Giá trị quảng cáo không xác định. Hệ thống sẽ trả về kết quả này khi bạn bật tính năng pingback LTV, nhưng không có đủ dữ liệu.
ESTIMATED Giá trị quảng cáo được ước tính từ dữ liệu tổng hợp.
PUBLISHER_PROVIDED Nhà xuất bản đã cung cấp giá trị quảng cáo (chẳng hạn như CPM thủ công) trong một nhóm dàn xếp.
PRECISE Giá trị chính xác mà bạn phải trả cho quảng cáo này.

Trong trường hợp sử dụng tính năng Dàn xếp của AdMob, AdMob sẽ tìm cách cung cấp giá trị ESTIMATED cho những nguồn quảng cáo được tối ưu hoá.

Đối với những nguồn quảng cáo không được tối ưu hoá, hoặc trong trường hợp không có đủ dữ liệu tổng hợp để báo cáo một giá trị ước tính có ý nghĩa, thì giá trị PUBLISHER_PROVIDED sẽ được trả về.

Lượt hiển thị thử nghiệm từ các nguồn quảng cáo đặt giá thầu

Sau khi sự kiện doanh thu từ quảng cáo ở cấp lượt hiển thị xảy ra cho một nguồn quảng cáo đặt giá thầu thông qua một yêu cầu kiểm thử, bạn chỉ nhận được các giá trị sau:

  • UNKNOWN: cho biết loại độ chính xác.
  • 0: cho biết giá trị quảng cáo.

Trước đây, bạn có thể thấy loại độ chính xác là một giá trị khác với UNKNOWN và giá trị quảng cáo lớn hơn 0.

Để biết thông tin chi tiết về cách gửi yêu cầu quảng cáo kiểm thử, hãy xem phần Bật thiết bị kiểm thử.