0%

Programmingプログラミングナレッジ

Posted:2016.07.21

admobの広告をアプリ内に表示させる

せっかく作ったアプリはリリース後に収益につなげていきたいですよね。アプリの有料化以外にもアプリ内に広告を表示させて収益を得る方法もあります。その中でもメジャーな「Admob」というサービスを利用して広告を表示する方法をまとめていきます。

 

ハイブリットアプリのプラットフォームであるCordovaには数多くのプラグインが用意されていますが、今回はAdmob広告の表示に「cordova-admob-pro」というプラグインを使います。

 

Admobアカウント登録と広告ユニット作成

まずは次のページよりAdmobのアカウント登録を行います。
googleのアドワーズ、もしくはアドセンスのアカウントがあれば簡単に早くアカウントが作成できます。

 

https://www.google.co.jp/admob/

 

アカウントが作成できたら、広告ユニット(広告バナーが表示される部分)の作成を行います。【新しいアプリを収益化】のボタンから画面の手順に沿って広告ユニットを作成します。広告の表示方法はバナー(画面の一部に表示)もしくはインタースティシャル(画面全体に大きく表示)から選択できます。

 

広告ユニットが作成されると広告ユニットの詳細情報に、ca-app-pub-****から始まる「広告ユニットID」が表示されています。アプリのプラグイン設定時にこのIDを使用します。

 

Admob用プラグインの設定

1.コマンドでプラグインをインストール

次のCordovaコマンドで、cordova-admob-proのプラグインをインストールします。

 

$ cordova plugin add cordova-plugin-admobpro

 

2.index.jsに下記のコードを追記します

Admobの広告を表示させるjavascriptのコードになります。先ほど作成した広告ユニットIDを設定します。

 

AdMob.createBanner({
  adId:'ca-app-pub-**********広告ユニットIDが入ります**********',
  position:AdMob.AD_POSITION.BOTTOM_CENTER,
  overlap: true,
  autoShow:true
});

 

Cordovaが完全に読み込まれたタイミングでないとプラグインが利用できないため、onDeviceReady()の関数内にAdmobの広告を表示させるコードを挿入します。

 

【index.js】※一部抜粋

var app = {

    initialize: function() {
        this.bindEvents();
    },
    
    bindEvents: function() {
        document.addEventListener('deviceready', this.onDeviceReady, false);
    },

    onDeviceReady: function() {
        app.receivedEvent('deviceready');

        //Admobの広告バナー表示コード
        AdMob.createBanner({
          adId:'ca-app-pub-**********広告ユニットIDが入ります**********',
          position:AdMob.AD_POSITION.BOTTOM_CENTER,
          overlap: true,
          autoShow:true
        });
  
    },
    
    receivedEvent: function(id) {
        var parentElement = document.getElementById(id);
        var listeningElement = parentElement.querySelector('.listening');
        var receivedElement = parentElement.querySelector('.received');

        listeningElement.setAttribute('style', 'display:none;');
        receivedElement.setAttribute('style', 'display:block;');

        console.log('Received Event: ' + id);
    }
};

app.initialize();

 

アプリをビルドして実機で確認すると広告バナーが表示されているのが確認できます。

 

また、リリース前の動作テストには下記のサンプル広告コードを使用します。

 

// Admobサンプル広告バナーコード
AdMob.createBanner({
 adId:'ca-app-pub-3940256099942544/6300978111',
 position:AdMob.AD_POSITION.BOTTOM_CENTER,
 overlap: true,
 autoShow:true
});

 

テストに本番用コードを使用するとアカウント停止の恐れもあるので必ずサンプル広告のコードを使うようにします。

 

Admob利用時の注意点

Cordovaの初期index.htmlファイルに含まれている、devicereadyのステータスを示す部分である下記のコードがあります。

 

<div class="app">
    <h1>Apache Cordova</h1>
    <div id="deviceready" class="blink">
      <p class="event listening">Connecting too Device</p>
    <p class="event received">Device is Ready</p>
  </div>
</div>

 

これを削除してしまうと、なぜか広告が表示されません。ですのでこの部分は残しておき、CSSなどで非表示にして対応するのが良さそうです。

 

またその他注意点としてはjavascriptファイルの読み込み順があり、cordova.jsを読み込んだ後で、index.jsを読み込むようなるよう記述します。

 

【index.html】※一部抜粋

…
  <script type="text/javascript" src="cordova.js"></script>
  <script type="text/javascript" src="js/index.js"></script>
</body>
…

 

また、バナー表示の場合は画面下部にバナーの高さで40pxほどのスペースがとられるので、デザインやレイアウトなども考慮する必要があります。

 

 

いかがでしょうか、プラグインを利用するので広告を表示させるのにそこまで難しくはないと思います。広告の表示位置などは色々と設定できるみたいなので、アプリに合わせてカスタマイズしてみてはどうでしょうか。

 

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】