目次
概要
このブログポストではgoogle_mobile_ads
パッケージを使ってAdmobの広告を表示する方法について説明します。
このブログポストではAdmobのバナー広告を表示する方法について説明する予定です。ソースコードは下記のリンクで確認できます。
Admobの設定
FlutterプロジェクトでAdmobを使うためには、Admobのサービスを使う必要があります。
グーグルアドモブの会員登録
グーグルアドモブ(Google Admob)のサイトに移動して会員登録をします。一般的な会員登録やログインの手続きなので説明は省略します。
- グーグルアドモブ(Google Admob)のサイト: https://www.google.com/admob/
Admobの生成
グーグルアドモブ(Google Admob)の使い方についてみてみましょう。グーグルアドモブ(Google Admob)を使うために、グーグルアドモブ(Google Admob)のサイトに会員登録をしてログインをすると下記のような画面が確認できます。
下にあるGET STARTED
ボタンを押してグーグルアドモブ(Google Admob)を使い始めます。
既にアプリがマーケットに登録されたかを選べます。私たちはまだアプリを登録してない状態なのでNO
を選択します。
グーグルアドモブ(Google Admob)を使うためアプリの名前を作成して使うプラットフォームを選択します。私たちはまず、iOS
を選択して進めます。
グーグルアドモブ(Google Admob)の登録を完了しました。親切に下に次にやることについて説明が書いております。
- FlutterにAdmobを設定するため必要な
App ID
をコピーします。 - 広告タイプ(ad unit)をグーグルアドモブ(Google Admob)で設定します。
- アプリをアプリストアに登録したらグーグルアドモブ(Google Admob)に連結する必要があります。
下にあるNEXT: CREATE AD UNIT
を押して広告のタイプを設定する画面に移動します。
私たちは一旦バナー広告を使う予定です。Banner
の下にあるSELECT
ボタンを選択します。
当該バナーの名前を設定します。グーグルアドモブ(Google Admob)のサービスで当該バナーを簡単に探すための名前なので、自分がわかりやすい名前で設定します。入力を完了したらCREATE AD UNIT
ボタンを押して設定を完了します。
グーグルアドモブ(Google Admob)のバナーの設定を完了しました。次に出るApp IDとバナーのAd Unit IDをコピーしておきます。
アンドロイドも上と同じ方法でバナー広告を生成してApp IDとAd Unit IDを生成します。
プロジェクト生成
そしたらgoogle_mobile_ads
パッケージを使ってAdmobの広告を表示するため、Flutterプロジェクトを新しく作ってみましょう。次のコマンドを実行してFlutterプロジェクトを生成します。
flutter create admob_example
cd admob_example
google_mobile_adsパッケージインストール
FlutterプロジェクトでAdmob広告を表示するためgoogle_mobile_ads
のパッケージをインストールする必要があります。次のコマンドを実行してgoogle_mobile_ads
をインストールします。
flutter pub add google_mobile_ads
App ID設定
次はgoogle_mobile_ads
を使ってAdmobの広告を表示するため、iOS/AndroidにApp ID
を設定する必要があります。
AndroidでApp IDの設定
アンドロイドでAdmobのApp ID
を設定するため、android/app/src/main/AndroidManifest.xml
ファイルを開いて下記のように修正します。
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.admob_example">
<application
...>
<meta-data
android:name="com.google.android.gms.ads.APPLICATION_ID"
android:value="[YOUR ANDROID APP ID]"/>
...
</application>
</manifest>
iOSでApp IDの設定
iOSでAdmobのApp ID
を設定するため、ios/Runner/Info.plist
ファイルを開いて下記のように修正します。
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
...
<key>GADApplicationIdentifier</key>
<string>[YOUR iOS APP ID]</string>
<key>LSRequiresIPhoneOS</key>
<true/>
<key>SKAdNetworkItems</key>
<array>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>cstr6suwn9.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>4fzdc2evr5.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>2fnua5tdw4.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>ydx93a7ass.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>5a6flpkh64.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>p78axxw29g.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>v72qych5uu.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>c6k4g5qg8m.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>s39g8k73mm.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>3qy4746246.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>3sh42y64q3.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>f38h382jlk.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>hs6bdukanm.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>prcb7njmu6.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>v4nxqhlyqp.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>wzmmz9fp6w.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>yclnxrl5pm.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>t38b2kh725.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>7ug5zh24hu.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>9rd848q2bz.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>n6fk4nfna4.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>kbd757ywx3.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>9t245vhmpl.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>4468km3ulz.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>2u9pt9hc89.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>8s468mfl3y.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>av6w8kgt66.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>klf5c3l5u5.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>ppxm28t8ap.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>424m5254lk.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>uw77j35x4d.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>578prtvx9j.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>4dzt52r2t5.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>e5fvkxwrpn.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>8c4e2ghe7u.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>zq492l623r.skadnetwork</string>
</dict>
<dict>
<key>SKAdNetworkIdentifier</key>
<string>3qcr597p9d.skadnetwork</string>
</dict>
</array>
</dict>
</plist>
google_mobile_adsの使い方
次はgoogle_mobile_ads
を使ってAdmobの広告を表示するため、main.dart
ファイルを開いて下記のように修正します。
import 'package:flutter/material.dart';
import 'package:flutter/foundation.dart';
import 'package:google_mobile_ads/google_mobile_ads.dart';
const Map<String, String> UNIT_ID = kReleaseMode
? {
'ios': '[YOUR iOS AD UNIT ID]',
'android': '[YOUR ANDROID AD UNIT ID]',
}
: {
'ios': 'ca-app-pub-3940256099942544/2934735716',
'android': 'ca-app-pub-3940256099942544/6300978111',
};
Future<void> main() async {
WidgetsFlutterBinding.ensureInitialized();
MobileAds.instance.initialize();
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
debugShowCheckedModeBanner: false,
home: Home(),
);
}
}
class Home extends StatelessWidget {
@override
Widget build(BuildContext context) {
TargetPlatform os = Theme.of(context).platform;
BannerAd banner = BannerAd(
listener: BannerAdListener(
onAdFailedToLoad: (Ad ad, LoadAdError error) {},
onAdLoaded: (_) {},
),
size: AdSize.banner,
adUnitId: UNIT_ID[os == TargetPlatform.iOS ? 'ios' : 'android']!,
request: AdRequest(),
)..load();
return Scaffold(
appBar: AppBar(
title: Text('Admob'),
),
body: Center(
child: Container(
height: 50,
child: AdWidget(
ad: banner,
),
),
),
);
}
}
ソースコードを一つづつ詳しくみてみましょう。
import 'package:flutter/foundation.dart';
Admobの広告は開発環境の場合、自分のAD UNIT ID
を使うとダメです。自分の開発環境で自分のAD UNIT ID
を使う場合、実際の広告トラピックではなく不正トラピックになるので、いっぱい使うと広告掲載をブロックされる可能性があります。したがって、今回の例ではkReleaseMode
を使って現在実行してる環境がdebug
かrelease
かを区別する予定です。kReleaseMode
を使うためにはfoundation.dart
を使う必要があります。
import 'package:google_mobile_ads/google_mobile_ads.dart';
google_mobile_ads
を使うため、追加します。
const Map<String, String> UNIT_ID = kReleaseMode
? {
'ios': '[YOUR iOS AD UNIT ID]',
'android': '[YOUR ANDROID AD UNIT ID]',
}
: {
'ios': 'ca-app-pub-3940256099942544/2934735716',
'android': 'ca-app-pub-3940256099942544/6300978111',
};
kReleaseMode
を使って現在の環境がrelease
の場合、私たちが作ったAD UNIT ID
を使えるように設定しました。そうでない場合は、Admobが提供するテスト用のAD UNIT ID
を使えるようにしました。
Future<void> main() async {
WidgetsFlutterBinding.ensureInitialized();
MobileAds.instance.initialize();
runApp(MyApp());
}
google_mobile_ads
を使ってAdmobの広告を表示するためMobileAds
を初期化する必要があります。WidgetsFlutterBinding.ensureInitialized();
を使ってFlutterが初期化されたかを確認した後、MobileAds.instance.initialize();
をコールしてMobileAds
を初期化します。
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Flutter Demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
debugShowCheckedModeBanner: false,
home: Home(),
);
}
}
class Home extends StatelessWidget {
}
簡単なサンプルコードを作成するためStateless
ウィジェットを生成しました。
次は実際バナー広告を表示するソースコードを詳しくみてみましょう。
@override
Widget build(BuildContext context) {
TargetPlatform os = Theme.of(context).platform;
BannerAd banner = BannerAd(
listener: BannerAdListener(
onAdFailedToLoad: (Ad ad, LoadAdError error) {},
onAdLoaded: (_) {},
),
size: AdSize.banner,
adUnitId: UNIT_ID[os == TargetPlatform.iOS ? 'ios' : 'android']!,
request: AdRequest(),
)..load();
return Scaffold(
appBar: AppBar(
title: Text('Admob'),
),
body: Center(
child: Container(
height: 50,
child: AdWidget(
ad: banner,
),
),
),
);
}
各プラットフォームよりAD UNIT ID
が違うので、現在のFlutterが実行されてるプラットフォームを識別する必要があります。このためTargetPlatform
を使います。
TargetPlatform os = Theme.of(context).platform;
そしてgoogle_mobile_ads
で提供されてるBannerAd
クラスを使ってバナー広告を生成しましたし、Cascade operatorを使って生成と同時にload()
関数を実行して広告を取ってきました。
BannerAd banner = BannerAd(
listener: BannerAdListener(
onAdFailedToLoad: (Ad ad, LoadAdError error) {},
onAdLoaded: (_) {},
),
size: AdSize.banner,
adUnitId: UNIT_ID[os == TargetPlatform.iOS ? 'ios' : 'android']!,
request: AdRequest(),
)..load();
この時、AdListener
を使って広告に関するイベントにコールバック関数を登録することができまし、AdRequest
の色んなパラメータを使ってもっと効率的な広告を表示することができます。
このように生成した広告をAdWidget
を使って画面に表示します。
AdWidget(
ad: banner,
)
現在の例題は簡単に広告を表示する方法をStateless
ウィジェットを使ってみてみました。もし、Stateful
ウィジェットを使ったら、次のようにウィジェットが消える時、広告も削除しなきゃならないです。
@override
void dispose() {
super.dispose();
_banner.dispose();
}
イシュー
google_mobile_ads
で広告を表示する時経験したイシューを共有します。
await MobileAds.instance.initialize()
私はgoogle_mobile_ads
のバージョンを0.13.4
で設定して使っています。このバージョンより上のバージョンを使う場合、アンドロイドの一部端末でawait MobileAds.instance.initialize()
部分が終わらなくなって、アプリが強制終了される問題が発生しています。
したがって、私はまだ0.13.4
でバージョンを固定して使っています。
dependencies:
...
google_mobile_ads: 0.13.4
Ad failed to load : 3
開発中のアプリをエミューレーターでtest unit id
を使ってバーナー広告を表示すると、Ad failed to load : 3
のエラーメッセージが出って、広告が表示されない問題があります。
私はこの問題を解決するため、開発中のアプリでもtest unit id
ではなく実際のunit id
を使っています。実際のunit id
を使ってもTest mode
と一緒に問題なく広告が表示されることを確認しました。
Test mode
が表示されてるので、不正広告トラピックではないと思ってるので、問題ないと判断して開発する時も実際のunit id
を使っています。
もし、実際のunit id
を使っても同じエラーメッセージが発生すると、そのアプリを実際のデバイスに上げて、実際トラピックを発生してみます。Ad failed to load : 3
メッセージはエラーではなく広告が準備できてたいことを意味します。したがって、設定は問題ないことです。しかし、色んな理由で画面に表示する広告がまだ準備できてないことを意味します。実際のトラピックも広告を準備することに影響があるので、実際デバイスでアプリを動作して実際トラピックを発生してみてください。
完了
これでgoogle_mobile_ads
パッケージを使ってAdmobの広告を表示する方法についてみてみました。今から皆さんも、皆さんのアプリへ広告を追加して履歴をだしてみてください!
私のブログが役に立ちましたか?下にコメントを残してください。それは私にとって大きな大きな力になります!
アプリ広報
Deku
が開発したアプリを使ってみてください。Deku
が開発したアプリはFlutterで開発されています。興味がある方はアプリをダウンロードしてアプリを使ってくれると本当に助かります。