17
18

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

AndroidAdvent Calendar 2014

Day 19

ネイティブアドのすゝめ(Android)

Posted at

家族とMacとネット環境さえあれば、どこでも生きていける@neirazaです。
今年の10月からサイバーエージェントのアドテク本部AdTech NativeUnitてとこで、iOSおよびAndroid向けの各広告プロダクトのSDKをつくってます。

Android Studioのbetaがついに取れましたね。広告SDKを利用される方が、どんどんAndroid Studioに移行してくださると、仕事でも完全に移行できるのになーなんて、思ったりしてます。

最近、ネイティブアドのお仕事をしており、良い機会なので色々とまとめてみました。

さて、今回の内容ですが前半部分はネイティブアドのすゝめ(iOS)で一部扱った内容なので、既にご覧になった方は申し訳ないですが、読み飛ばしちゃってください。

ネイティブアドの概要

@neiraza的な解釈

「媒体に自然と表示し見せる、広告自体の呼び出し元となる枠」
ネイティブアドにとって重要なのは、
それ単体で価値のある枠で、その枠をタップした先に利用者が求める答えがある、その答えこそが広告だった。
たぶん、そんな状態なんだと思います。

僕は今のところ、ネイティブアドと言われる広告を入れた日本のアプリしか見たことがないのですが、
これが成功する、カッコイイ、ネイティブアドだぜ!ってのは無いように思えます。
ずっと以前からネイティブアドと呼ばれずに存在していたタイプの広告に名前がついたくらいの状況かなと思ってます。

何か面白い案とか、ないすかね。

ちなみに僕は最初、ネイティブアドってネイティブ技術(モバイルの)でつくる広告だと思ってましたが、普通にJSでタグ埋め埋めな広告とかも指すので、結構範囲は広いです。

業界標準的なやつ

業界標準的な取りまとめは米国のオンライン広告の業界団体IAB一般社団法人 インターネット広告推進協議会(JIAA)などのサイトで、抑えたほうが良いと思います。

特にTHE ADVERTISING PLAYBOOKは一度、目を通した上で日本の商慣習、現状などを見ていったほうが良いと思います。

ネイティブアドに触ってみよう

MoPub Inc.が公開しているmopub-android-sdkを適当に解説しつつ、動かしてみます。
MoPub?って人もいるかと思いますが、Twitterが昨年9月に4億ドルぐらいで買収したモバイル広告ネットワークをやっている会社です。

動かしてみよう

ソースはmopub-android-sdkです。

画面起動後に、NativeAd(TableView Manager)をタップする。
(下記画像を参照のこと)

device-2014-11-26-133650.png

すると下みたいな表示が出てきます。
こいつはUITableView内の2行目だけをネイティブアドに差し替える実装をしています。ソースはこちら

device-2014-11-26-133722.png

Twitterでよくこんな感じの広告みますよね。

device-2014-11-26-133730.png

実装をみてみよう

さて、スーパーざっくり解説を始めます。

NativeListViewFragmentが、ListViewを表示している画面です。
このListviewにsetAdapterするアダプターを工夫しています。
それが、MoPubAdAdapterです。

広告以外の通常行は、ArrayAdapterにandroid.R.layout.simple_list_item_1をぶっこんでいます。
そのArrayAdapterを引数にMoPubAdAdapterのインスタンスを生成します。

mAdAdapter = new MoPubAdAdapter(getActivity(), adapter);

このインスタンスに対し、MoPubNativeAdRendererを登録します。

MoPubNativeAdRendererに対し、native_ad_list_itemを設定しておくことで広告表示のレイアウトの準備完了です。

あとはListViewにセットしたMoPubAdAdapterが、通常のデータソースの挙動と同じく呼ばれるたびに、広告行か否かを判定し、広告行の場合はこのアダプター内の独自処理を呼び、そうでない場合はArrayAdapterの処理を明示的に呼び出す形で成立しています。

この辺の考え方は、HeaderViewListAdapterなどに近いと思います。
iOSに比べると、Androidらしい作りになっていると思います。

実装を読んだ感想

サンプルにはNativeGalleryFragmentというものもありますが、なGallery(Deprecated since API level 16)のことではなく、ViewPager(android.support.v4.view.ViewPager)のサンプルです。

しかし、MoPubAdAdapterはBaseAdapterをベースにしているため、ListView以外の下記Viewに対するAdapterとしても使えると思います。広告を出したいかどうかは別として。

動作は試していません

さいごに

2015年もネイティブアドに振り回されながら 「儲かるネイティブアド」「作っていて/利用していてネイティブアド」 とかを見つけて、もっと楽しくお仕事が楽しくできたらなーと思っています。

エンジニアのネイティブ広告のアドテク社交場ってどこかあれば、おしえてください(T ^ T)

17
18
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
17
18

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?