แบนเนอร์

โฆษณาแบนเนอร์จะใช้ตำแหน่งภายในเลย์เอาต์ของแอป โดยจะอยู่ด้านบนหรือด้านล่างของแอปก็ได้ หน้าจออุปกรณ์ โฆษณาเหล่านี้จะยังคงแสดงบนหน้าจอในระหว่างที่ผู้ใช้โต้ตอบกับแอป และสามารถรีเฟรชโดยอัตโนมัติหลังจากเวลาผ่านไประยะหนึ่ง

คู่มือนี้แสดงวิธีผสานรวมโฆษณาแบนเนอร์จาก AdMob ลงใน แอป Flutter นอกจากข้อมูลโค้ดและวิธีการแล้ว ยังมี เกี่ยวกับการปรับขนาดแบนเนอร์อย่างเหมาะสม

ทดสอบด้วยโฆษณาทดสอบเสมอ

เมื่อสร้างและทดสอบแอป โปรดใช้โฆษณาทดสอบแทน โฆษณาที่ใช้งานจริง การไม่ดำเนินการดังกล่าวอาจส่งผลให้บัญชีของคุณถูกระงับ

วิธีที่ง่ายที่สุดในการโหลดโฆษณาทดสอบคือการใช้รหัสหน่วยโฆษณาทดสอบโดยเฉพาะของเรา แบนเนอร์:

Android

ca-app-pub-3940256099942544/6300978111

iOS

ca-app-pub-3940256099942544/2934735716

ระบบจะกำหนดค่าให้หน่วยโฆษณาทดสอบแสดงโฆษณาทดสอบสำหรับทุกคำขอ และ คุณสามารถใช้เครื่องมือดังกล่าวในแอปของคุณเองขณะเขียนโค้ด ทดสอบ และแก้ไขข้อบกพร่อง เพียงตรวจสอบให้แน่ใจว่าได้แทนที่รหัสเหล่านั้นด้วยรหัสหน่วยโฆษณาของคุณเอง ก่อนที่จะเผยแพร่ แอป

โหลดโฆษณา

ตัวอย่างต่อไปนี้เป็นการสร้างอินสแตนซ์โฆษณาแบนเนอร์

class BannerExampleState extends State<BannerExample> {
  BannerAd? _bannerAd;
  bool _isLoaded = false;

  // TODO: replace this test ad unit with your own ad unit.
  final adUnitId = Platform.isAndroid
    ? 'ca-app-pub-3940256099942544/6300978111'
    : 'ca-app-pub-3940256099942544/2934735716';

  /// Loads a banner ad.
  void loadAd() {
    _bannerAd = BannerAd(
      adUnitId: adUnitId,
      request: const AdRequest(),
      size: AdSize.banner,
      listener: BannerAdListener(
        // Called when an ad is successfully received.
        onAdLoaded: (ad) {
          debugPrint('$ad loaded.');
          setState(() {
            _isLoaded = true;
          });
        },
        // Called when an ad request failed.
        onAdFailedToLoad: (ad, err) {
          debugPrint('BannerAd failed to load: $error');
          // Dispose the ad here to free resources.
          ad.dispose();
        },
      ),
    )..load();
  }
}

ตารางด้านล่างแสดงรายการขนาดแบนเนอร์มาตรฐาน

ขนาดเป็นหน่วย dp (กว้างxสูง) คำอธิบาย ขนาดคงที่ของ AdSize
320x50 แบนเนอร์มาตรฐาน banner
320x100 แบนเนอร์ขนาดใหญ่ largeBanner
320x250 สี่เหลี่ยมผืนผ้ากลาง mediumRectangle
468x60 แบนเนอร์ขนาดเต็ม fullBanner
728x90 ลีดเดอร์บอร์ด leaderboard
ความกว้างที่ระบุ x ความสูงแบบปรับอัตโนมัติ แบนเนอร์แบบปรับขนาดได้ ไม่มี

หากต้องการกำหนดขนาดแบนเนอร์ที่กำหนดเอง ให้ตั้งค่า AdSize ที่ต้องการ ดังนี้

final AdSize adSize = AdSize(300, 50);

เมื่อใช้ BannerAdListener คุณจะสามารถฟังเหตุการณ์ในวงจรได้ เช่น เหมือนกับตอนที่โฆษณาโหลด ตัวอย่างนี้จะใช้แต่ละวิธีและบันทึกข้อความ ลงในคอนโซล

class BannerExampleState extends State<BannerExample> {
  BannerAd? _bannerAd;
  bool _isLoaded = false;

  // TODO: replace this test ad unit with your own ad unit.
  final adUnitId = Platform.isAndroid
    ? 'ca-app-pub-3940256099942544/6300978111'
    : 'ca-app-pub-3940256099942544/2934735716';


  /// Loads a banner ad.
  void loadAd() {
    _bannerAd = BannerAd(
      adUnitId: adUnitId,
      request: const AdRequest(),
      size: AdSize.banner,
      listener: BannerAdListener(
        // Called when an ad is successfully received.
        onAdLoaded: (ad) {
          debugPrint('$ad loaded.');
          setState(() {
            _isLoaded = true;
          });
        },
        // Called when an ad request failed.
        onAdFailedToLoad: (ad, err) {
          debugPrint('BannerAd failed to load: $error');
          // Dispose the ad here to free resources.
          ad.dispose();
        },
        // Called when an ad opens an overlay that covers the screen.
        onAdOpened: (Ad ad) {},
        // Called when an ad removes an overlay that covers the screen.
        onAdClosed: (Ad ad) {},
        // Called when an impression occurs on the ad.
        onAdImpression: (Ad ad) {},
      ),
    )..load();
  }
}

แสดงโฆษณาแบนเนอร์

หากต้องการแสดง BannerAd เป็นวิดเจ็ต คุณต้องสร้างอินสแตนซ์ AdWidget ด้วยโฆษณาที่รองรับหลังจากเรียก load() คุณจะสร้างวิดเจ็ตก่อนเวลา กำลังโทรหา load() แต่ต้องเรียกใช้ load() ก่อนที่จะเพิ่มลงในวิดเจ็ต ต้นไม้

AdWidget รับค่ามาจากคลาส Widget ของ Flutter และสามารถใช้งานได้เหมือนกับประเภทอื่นๆ วิดเจ็ต สำหรับ iOS ให้ตรวจสอบว่าได้วางวิดเจ็ตไว้ในวิดเจ็ตโดยระบุ ความกว้างและความสูง มิฉะนั้น โฆษณาของคุณอาจไม่แสดง BannerAd สามารถวางไว้ในคอนเทนเนอร์ที่มีขนาดตรงกับโฆษณา

...
if (_bannerAd != null) {
  Align(
    alignment: Alignment.bottomCenter,
    child: SafeArea(
      child: SizedBox(
        width: _bannerAd!.size.width.toDouble(),
        height: _bannerAd!.size.height.toDouble(),
        child: AdWidget(ad: _bannerAd!),
      ),
    ),
  )
}
...

ต้องทิ้งโฆษณาเมื่อไม่จำเป็นต้องใช้การเข้าถึงแล้ว แนวทางปฏิบัติแนะนำ สำหรับเวลาที่จะโทรหา dispose() คือหลังจากนำ AdWidget ออกจาก แผนผังวิดเจ็ตหรือใน BannerAdListener.onAdFailedToLoad() Callback

เท่านี้ก็เรียบร้อย ตอนนี้แอปของคุณพร้อมแสดงโฆษณาแบนเนอร์แล้ว

การจำกัดการเลื่อนใน Android 9 และเก่ากว่า

เราทราบว่าอุปกรณ์รุ่นเก่าหรือต่ำกว่าบางรุ่นที่ใช้ Android 9 หรือ ก่อนหน้านี้ อาจมีประสิทธิภาพไม่ดีพอ เมื่อแสดงโฆษณาแบนเนอร์แบบอินไลน์ในมุมมองที่เลื่อนได้ เราขอแนะนำเฉพาะ ใช้แบนเนอร์ประเภทนี้ใน Android 10 ขึ้นไป แบนเนอร์ตำแหน่งคงที่ เช่น แบนเนอร์ที่ยึดไว้ จะไม่ได้รับผลกระทบและสามารถใช้งานได้อย่างมีประสิทธิภาพสูงสุดใน Android API ทุกระดับ

ตัวอย่างที่สมบูรณ์ใน GitHub

แบนเนอร์