Flutter GoogleMobileAds fluid height

83 views Asked by At

I am looking to implement Google Admanager native and normal banners in my app and cannot figure out a way to get the height to adapt to the different banners, without having to specify it beforehand.

This is my current code:

import 'dart:io';

import 'package:flutter/material.dart';
import 'package:flutter_hooks/flutter_hooks.dart';
import 'package:google_mobile_ads/google_mobile_ads.dart';

class NativeAdBanner extends HookWidget {
  const NativeAdBanner({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    final bannerAd = useState<NativeAd?>(null);
    final bannerAdIsLoaded = useState<bool>(false);

    // load the banner ad
    useEffect(
      () {
        bannerAd.value = NativeAd(
          adUnitId: Platform.isAndroid
              ? 'ca-app-pub-3940256099942544/2247696110'
              : 'ca-app-pub-3940256099942544/2934735716',
          nativeTemplateStyle: NativeTemplateStyle(
            templateType: TemplateType.medium,
          ),
          listener: NativeAdListener(
            onAdLoaded: (Ad ad) {
              print('$BannerAd loaded.');
              bannerAdIsLoaded.value = true;
            },
            onAdFailedToLoad: (Ad ad, LoadAdError error) {
              print('$BannerAd failedToLoad: $error');
              ad.dispose();
            },
            onAdOpened: (Ad ad) => print('$BannerAd onAdOpened.'),
            onAdClosed: (Ad ad) => print('$BannerAd onAdClosed.'),
          ),
          request: const AdRequest(),
        )..load();

        return () => bannerAd.value!.dispose();
      },
      [],
    );

    // if we have an ad to show -> show it
    if (bannerAdIsLoaded.value && bannerAd.value != null) {
      return SizedBox(
        width: double.infinity,
        child: Align(
          alignment: Alignment.center,
          child: ConstrainedBox(
            constraints: const BoxConstraints(
              minWidth: 300,
              minHeight: 350,
              maxHeight: 800,
              maxWidth: 450,
            ),
            child: AdWidget(ad: bannerAd.value!),
          ),
        ),
      );
    }

    return const SizedBox();
  }
}

I really need to be able to pass an adUnitId and the native ad to adapt natively to the height of it.

I have found multiple issues, but no solution yet. For example: https://github.com/googleads/googleads-mobile-flutter/issues/442

Did anyone figure this out?

0

There are 0 answers