# Amazon Publisher Services - Ad Generation Integration [Android]
Amazon Publisher ServicesとAd Generation SDKをAndroidで連携するためのマニュアルとなります。
# サービスご利用にあたって
本連携については、Amazon Publisher Servicesの登録がお済みのうえ、行って頂くようお願いいたします。
Amazon Publisher Servicesのドキュメント等、公式サイトよりご確認お願いいたいます。
# 対応バージョン
- Android 4.4+ (API Level 19)
- Amazon Publisher Services SDK v9.10.2
注意
- 広告のリフレッシュ(ローテーション)を行う場合はAmazon Publisher Servicesの機能を用いて実装してください。
- Ad Generationのローテーション及び、連携SDKのアドネットワークのローテーション設定はOFFにしてください。
- Amazon Publisher Services(DTB SDK)とAmazon Mobile Ad Network SDKの併用はサポート対象外となります。
# Ad Generation管理画面での広告枠設定
- 対象枠でカスタムタグを作成する。
- カスタムタグ認証情報として「Amazon Header Bidding」を選択する。
- アドネットワーク名を入力する。こちらは表示にのみ使用されます。
- Key/CPMをデフォルト値から変更したい場合は変更します。
# Amazon Publisher Services SDKの導入
# Gradleを使用する (推奨)
Build.Gradle
ファイルを開き、 repositories
と dependencies
に以下を追記してください。
repositories {
...
mavenCentral()
}
dependencies {
...
implementation ("com.amazon.android:aps-sdk:9.10.2")
}
# 手動でインストールする
- [File] > [New] > [New Module] の順にクリックし、ポップアップダイアログボックスで[Import .JAR/.AAR Package] をクリックします。
- 新しいダイアログボックスが開くので、
aps-sdk.aar
またはDTBAndroidSDKx.x.aar
をインポートします。 - [File] > [Project Structure] > [app] > [Dependencies] と進み、対象のaar ファイルを依存関係として追加します。
# アクセス権限とActivityのマニフェストへの追加
- 次のアクセス権限をマニフェストに追加します。
INTERNET / ACCESS_WIFI_STATE / ACCESS_NETWORK_STATE は必須です。
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
- 位置情報ターゲティングをする場合は下記を追加してください
<uses-permission android:name = "android.permission.ACCESS_COARSE_LOCATION" />
<uses-permission android:name = "android.permission.ACCESS_FINE_LOCATION" />
# Ad Generation SDKの導入
- Ad Generation AndroidSDKバナー導入マニュアルの[1. プロジェクトにSDKを追加する]から[3. Google Play Servicesを設定する]をご参照ください。
# ProGuard
ProGuardの設定ファイルに以下を追加してください。
-keep class com.amazon.device.ads.** { *; }
# Amazon Publisher Services SDK(DTB SDK)の初期設定
# バナー広告
# DTBAdRequestの生成と広告リクエスト
DTB SDKが生成するbid情報(DTBAdResponse)の有効期間は10分となります。
# Ad Generationの呼び出し
DTBAdResponseパラメーターの付与以外は通常のAd Genrationの広告リクエストと同様です。
# オートリフレッシュ(ローテーション)の実装
- 広告のオートリフレッシュ(ローテーション)はAd Generationの機能を使わずにDTB SDKの
DTBAdRequest
(DTBAdLoader
)に設定してください。
Ad Generationのローテーション及び、連携SDKのアドネットワークのローテーション設定はOFFにしてください。
- 自動更新を必ず停止してください。停止の推奨場所はActivityのonStop()およびonDestroy()です。実装によってはonPause()も推奨場所になります。自動更新処理を不適切に使用するとインプレッション数に矛盾が生じる恐れがあります。
注意
- 広告の自動更新処理を停止し、DTBAdLoaderで使用されているリソースを解放することは、重要です。広告の自動更新処理は、明示的に停止しない限り続行されます。その場合、想定外の挙動になり、またインプレッション数が少なくなります。
- loadAdを呼び出す前に自動更新のプロパティを設定します。loadAdを1回呼び出す際、DTBAdLoaderのインスタンスを1つだけ使用してください。また、stop()が呼び出さるとインスタンスを再使用することはできません。
onSuccess
やonFailure
コールバック等で、Viewの上に重ねてViewを生成しないでください。新しいViewを作る場合、以前のViewをクリアするようにしてください。- オートリフレッシュは60秒がデフォルト値であり、20秒未満で設定した場合、自動的に60秒に上書きされます。
DTBAdRequest
クラスのsetAutoRefresh
メソッドを利用せず、インスタンスの再生成などで独自にローテーションをおこなうことはお控えください- 独自にローテーションをおこなうことが避けられない場合は、Amazon Publisher Services SDKに対してローテーションのための再リクエストであることを通知する実装が別途必要となりますので、弊社へお問い合わせ、またはAmazon社へお問い合わせください。
# テストモード
テストモードを有効にするには、以下のコードを広告リクエストより前に実行してください。
注意
テスト広告は属性の資格がないため、本番ではテストコードを忘れずに削除してください。
# 通信の検証
通信の検証を行う場合は、下記の公式サイトを参考に検証を行ってください。
Sending Artifacts to APS for Verification (opens new window)
Mobile Integration Self-Check Guide (opens new window)