1

Flutterにはfirebase_admobを使用しています。セットアップの指示に従ったところ、広告は Android で正常に機能しています。iOS の唯一の追加手順は、これを に追加することInfo.plistです。

<key>GADApplicationIdentifier</key>
<string>[ADMOB_APP_ID]</string>

iOS ではエラーは発生せず、バナーが空になるだけです。

import 'dart:io';

import 'package:firebase_admob/firebase_admob.dart';
import 'package:my_rents/services/auth.dart';

final String appId = Platform.isAndroid
    ? 'ca-app-pub-code1'
    : 'ca-app-pub-code2';
final String bannerId = Platform.isAndroid
    ? 'ca-app-pub-code3'
    : 'ca-app-pub-code4';
final String interstitialId = Platform.isAndroid
    ? 'ca-app-pub-code5'
    : 'ca-app-pub-code6';

MobileAdTargetingInfo targetingInfo = MobileAdTargetingInfo(
  keywords: <String>['rents', 'state agency', 'investments'],
  childDirected: false,
  testDevices: <String>[], // Android emulators are considered test devices
);

class Ads {
  bool showAds = false;
  static bool disposed;
  bool initialized;
  static BannerAd myBanner;
  static InterstitialAd myInterstitial = InterstitialAd(
    adUnitId: interstitialId,
    targetingInfo: targetingInfo,
  );
  Ads();

  static init() {
    FirebaseAdMob.instance.initialize(appId: appId);
  }

  BannerAd _createBanner() {
    return BannerAd(
      adUnitId: bannerId,
      size: AdSize.smartBanner,
      targetingInfo: targetingInfo,
      listener: (MobileAdEvent event) {
        if (event == MobileAdEvent.loaded) if (disposed)
          myBanner.dispose();
        else
          showBanner();
      },
    );
  }

  loadBanners() {
    disposed = false;
    if (myBanner == null) {
      myBanner = _createBanner();
    }
    myBanner.load();
    myInterstitial..load();
    initialized = true;
  }

  static showBanner() {
    if (myBanner != null) {
      myBanner..show(anchorOffset: 0.0, anchorType: AnchorType.top);
    }
  }

  static void cancelBanner() {
    if (myBanner != null) {
      Future.delayed(const Duration(milliseconds: 500), () {
        disposed = true;
        myBanner?.dispose();
        myBanner = null;
      });
    }
  }

  static showInterstitial() async {
    // TODO: remove this line after showing ads in iOS
    if (Platform.isAndroid) {
      if (authService.accountType.length == 0) {
        myInterstitial
          ..show(
            anchorType: AnchorType.bottom,
            anchorOffset: 0.0,
            horizontalCenterOffset: 0.0,
          );
      }
    }
  }
}

final Ads ads = Ads();

個別の Admob バナーと iOS アプリを Firebase で作成し、GoogleService-info.plist をプロジェクトに含めました。

4

0 に答える 0