Androidアプリ(.NET MAUI)でGoogle AdMob広告を表示させる

.NET MAUI
この記事は約9分で読めます。
スポンサーリンク

.NET MAUIアプリのプロジェクト(.NET8.0)を作成し、AndroidでAdMob広告が表示できるかを確認した。「Plugin.MauiMTAdmob」を使うことで、AdMob広告を表示させることができた。

スポンサーリンク

Plugin.MauiMTAdmobのインストール

NuGetで「Plugin.MauiMTAdmob」をインストールする。(バージョンは1.0.4を使用)

「user-messaging-platform-2.0.0.aar」に関しては、エラーが発生しなかったため、追加しなかった。

スポンサーリンク

テスト用広告

今回はテスト用のバナー広告を表示させるため、以下のIDを使用する。

テスト用アプリケーションIDca-app-pub-3940256099942544~3347511713
テスト用ユニットID(バナー広告)ca-app-pub-3940256099942544/6300978111

バナー広告以外のユニットIDは、以下のサイトを参照。
https://developers.google.com/admob/android/test-ads?hl=ja#sample_ad_units

スポンサーリンク

バナー広告の表示

バナー広告を表示させるために、以下のコードのハイライト部分を追加する。

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android">
	<application android:allowBackup="true" android:icon="@mipmap/appicon" android:roundIcon="@mipmap/appicon_round" android:supportsRtl="true">
    <meta-data android:name="com.google.android.gms.ads.APPLICATION_ID"
           android:value="ca-app-pub-3940256099942544~3347511713" />
  </application>
	<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
	<uses-permission android:name="android.permission.INTERNET" />
</manifest>
using Android.App;
using Android.Content.PM;
using Android.Gms.Ads;
using Android.OS;

namespace MauiApp1
{
    [Activity(Theme = "@style/Maui.SplashTheme", MainLauncher = true, ConfigurationChanges = ConfigChanges.ScreenSize | ConfigChanges.Orientation | ConfigChanges.UiMode | ConfigChanges.ScreenLayout | ConfigChanges.SmallestScreenSize | ConfigChanges.Density)]
    public class MainActivity : MauiAppCompatActivity
    {
        protected override void OnCreate(Bundle savedInstanceState)
        {
            base.OnCreate(savedInstanceState);
            MobileAds.Initialize(this);
        }
    }
}
using Microsoft.Extensions.Logging;
using Plugin.MauiMTAdmob;

namespace MauiApp1
{
    public static class MauiProgram
    {
        public static MauiApp CreateMauiApp()
        {
            var builder = MauiApp.CreateBuilder();
            builder
                .UseMauiApp<App>()
                .UseMauiMTAdmob()
                .ConfigureFonts(fonts =>
                {
                    fonts.AddFont("OpenSans-Regular.ttf", "OpenSansRegular");
                    fonts.AddFont("OpenSans-Semibold.ttf", "OpenSansSemibold");
                });

#if DEBUG
    		builder.Logging.AddDebug();
#endif

            return builder.Build();
        }
    }
}
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://schemas.microsoft.com/dotnet/2021/maui"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             xmlns:ads="clr-namespace:Plugin.MauiMTAdmob.Controls;assembly=Plugin.MauiMTAdmob"
             x:Class="MauiApp1.MainPage">

    <ScrollView>
        <VerticalStackLayout
            Padding="30,0"
            Spacing="25">
            <Image
                Source="dotnet_bot.png"
                HeightRequest="185"
                Aspect="AspectFit"
                SemanticProperties.Description="dot net bot in a race car number eight" />

            <Label
                Text="Hello, World!"
                Style="{StaticResource Headline}"
                SemanticProperties.HeadingLevel="Level1" />

            <Label
                Text="Welcome to .NET Multi-platform App UI"
                Style="{StaticResource SubHeadline}"
                SemanticProperties.HeadingLevel="Level2"
                SemanticProperties.Description="Welcome to dot net Multi platform App U I" />

            <Button
                x:Name="CounterBtn"
                Text="Click me" 
                SemanticProperties.Hint="Counts the number of times you click"
                Clicked="OnCounterClicked"
                HorizontalOptions="Fill" />

            <ads:MTAdView
                x:Name="myAds"
                AdsId="ca-app-pub-3940256099942544/6300978111"
                AdSize="AnchoredAdaptive"
                IsVisible="true"/>
        </VerticalStackLayout>
    </ScrollView>

</ContentPage>

以下のように、ボタンの下に、テスト用バナー広告が表示されていることを確認できた。

まとめ

  • .NET MAUI(.NET8.0)のAndroidで、AdMob広告の表示を確認できた。
  • iOSの場合は、次の記事を参照。
タイトルとURLをコピーしました