Google Mobile Ads SDK で、MRAID v2 の既存のサポートを基盤として構築された MRAID v3 のベータ版サポートが開始されました。これにより、広告主様はアド マネージャーのパブリッシャーに MRAID v3 クリエイティブを配信できるようになります。このガイドでは、MRAID v3 仕様で不明確で解釈の余地があった MRAID の実装の詳細を明確にします。対象読者は MRAID v3 クリエイティブの作成者です。
前提条件
パブリッシャーは次の条件を満たしている必要があります。
- MRAID v3 の場合は Google Mobile Ads SDK for iOS 7.30.0 以降
- MRAID v2 の場合は Google Mobile Ads SDK for iOS 7.4.0 以降
役立つ入門ガイド
MRAID について詳しくは、IAB MRAID のページをご覧ください。また、MRAID v3 の定義ドキュメント(以下で説明するすべてのパラメータの詳細が記載されています)と、MRAID v3 に関する IAB のブログ投稿もダウンロードできます。
MRAID v3(ベータ版)の実装の詳細
視認性 - exposureChange イベント
このイベントはサポートされています。非推奨の viewableChange
イベントではなく、新しい exposureChange
イベントのリスナーを使用することをおすすめします。メソッド mraid.isViewable()
も非推奨になりました。ただし、下位互換性を維持するため、これらの非推奨メソッドは引き続きサポートされます。
exposureChange
イベント定義は、広告ビューが変更されるたびにディスパッチされます。SDK には、イベントが大量に生成されるのを防ぐためのポーリング メカニズムがあります。初期状態は、広告がリスナーを登録した後に非同期で送信されます。コールバックには、0.0
から 100.0
の間の浮動小数点数である exposed_percentage
パラメータが含まれます。
使用例については、MRAID v3 仕様をご覧ください。
MRAID の検出と初期化、MRAID_ENV 属性
この SDK は、MRAID v3 仕様で定義されている初期化プロトコルに準拠しています。
MRAID_ENV
オブジェクトでは、SDK は IDFA
、limitAdTracking
、アプリ ID、COPPA(これらは省略可)を送信しません。MRAID バージョン、SDK 名、SDK バージョンなど、必要なすべての変数が MRAID_ENV
オブジェクトで提供されます。
聴認性の測定
音声が聞こえるかどうか、音量が変更されたタイミングを特定するための新しいイベント(audioVolumeChange
)が導入されました。
audioVolumeChange
イベントには、volume_percentage
という 1 つのパラメータがあります。値は最大音声再生音量の割合です。0.0
~100.0
の間の浮動小数点数(再生が許可されていない場合は 0.0
)、または音量を特定できない場合は null
です。
使用例については、MRAID v3 仕様をご覧ください。
mraid.getLocation()
mraid.getLocation()
はサポートされていないため、常に -1
を返します。
mraid.unload()
このメソッドはいつでも呼び出すことができ、SDK は広告を閉じ、リソースを割り当て解除し、ウェブビューを削除するか、別のドキュメントまたは新しい広告に置き換えることで対応します。
クリエイティブが unload()
を呼び出すと、ネイティブ レイヤはクリエイティブ タイプに応じて次のように応答します。
タイプ | unload() の動作 |
---|---|
バナー | 現在の広告と同じリクエスト パラメータを使用して新しい広告リクエストを行います。 |
インタースティシャル | インタースティシャルを閉じます。 |
VPAID(Video Player Ad Interface Definition)
Google Mobile Ads SDK は VPAID をサポートしていません。mraid.supports('vpaid')
は false を返します。
mraid.useCustomClose()
mraid.useCustomClose()
は、フォーマットとクリエイティブのタイプによってはサポートされない場合があります。
MRAID v2 の実装の詳細
mraid.getVersion()
mraid.getVersion()
は、クリエイティブが読み込まれるまで 2.0
を返しません。mraid.getState()
が loading
を返す間は、MRAID バージョンをチェックしないでください。
mraid.resize()
mraid.resize()
が呼び出されると、元のバナーがバナーのスクリーンショット画像に置き換えられます。サイズ変更された広告が元の広告スペースをカバーしていない場合、このことが顕著になります。
サイズ変更された広告も、元のバナーのフレームには従いません。バナーがスクロール ビューに配置されている場合、サイズ変更された広告はバナーとともにスクロールしません。
mraid.setResizeProperties()
mraid.setResizeProperties()
のすべての呼び出しには、必須プロパティの完全なリストが含まれている必要があります。サイズ変更プロパティが無効な場合、デフォルトに戻され、有効なパラメータで mraid.setResizeProperties()
が再度呼び出されるまで、mraid.resize()
の後続の呼び出しはすべて失敗します。
mraid.getMaxSize()
mraid.getMaxSize()
は、サイズ変更された広告の最大サイズを決定する場合にのみ使用してください。エキスパンド広告のサイズを決定するには、mraid.getScreenSize()
を使用します。
mraid.setOrientationProperties()
allowOrientationChange
プロパティが true
に設定された状態で mraid.setOrientationProperties()
を呼び出すと、forceOrientation
プロパティを設定しても何も行われません。向きを強制的に設定するクリエイティブは、allowOrientationChange
を false
に設定する必要があります。
mraid.isViewable()
ビューが本来表示されるはずの広告を覆っている場合でも、mraid.isViewable()
は true
を返します。アプリのコンテンツで表示中の広告を覆わないようにしてください。
mraid.getCurrentPosition()
2 つの部分からなるエキスパンド広告が展開状態にある場合、最初の部分で mraid.getCurrentPosition()
を呼び出すと、画面のサイズが返されます。
mraid.supports()
SDK バージョン 7.11.0 以降では、mraid.supports("storePicture")
と mraid.supports("calendar")
は常に false
を返します。MRAID v2 仕様に準拠して、クリエイティブはこれらのメソッドが利用できないケースに対応できる必要があります。
mraid.storePicture()
MRAID クリエイティブが mraid.storePicture()
を呼び出すと、アプリは画像を保存する権限を自動的にリクエストします。