App Open Ads
App open ads appear when users bring your app to the foreground, providing a monetization opportunity during app launches.
Each ad format uses a Zone ID to identify the ad placement. Zone IDs are configured in the Empower dashboard.
Note: All ad status listeners are optional. The SDK handles ad loading and display automatically. Use listeners only if you need to track ad states for analytics, UI updates, or custom logic.
Quick Start
import 'dart:async';import 'dart:io';import 'package:empower_mobile_ads/empower_mobile_ads.dart';final zoneId = Platform.isAndroid ? 'ANDROID_ZONE_ID' : 'IOS_ZONE_ID';// Preload the app open adEmpowerAds.loadAppOpenAd(zoneId);// Show when ad is readyfinal subscription = EmpowerAds.onAppOpenStatusChanged.listen((event) {final status = event['status'];if (status == 'READY') {EmpowerAds.showAppOpen(zoneId);}});
Loading App Open Ads
import 'package:empower_mobile_ads/empower_mobile_ads.dart';// Load with zone IDawait EmpowerAds.loadAppOpenAd('YOUR_ZONE_ID');
The method returns a Future<bool> that resolves to true when the ad starts loading.
Showing App Open Ads
import 'package:empower_mobile_ads/empower_mobile_ads.dart';final shown = await EmpowerAds.showAppOpen('YOUR_ZONE_ID');if (!shown) {print('App Open ad not ready');}
Listening to App Open Status (Optional)
import 'dart:async';import 'package:empower_mobile_ads/empower_mobile_ads.dart';final zoneId = 'YOUR_ZONE_ID';final subscription = EmpowerAds.onAppOpenStatusChanged.listen((event) {final status = event['status'];switch (status) {case 'READY':// Ad is ready to showbreak;case 'FAILED':// Ad failed to loadbreak;case 'SHOWN':// Ad is being displayedbreak;case 'SKIPPED':// User dismissed the adbreak;case 'USED':// Ad was shown and closed — reload for next timeEmpowerAds.loadAppOpenAd(zoneId);break;}});// Clean upsubscription.cancel();
Complete Example
Show the app open ad on cold start only (once per session):
import 'dart:async';import 'dart:io';import 'package:flutter/material.dart';import 'package:empower_mobile_ads/empower_mobile_ads.dart';bool _appOpenShown = false; // Module-level flagclass MyApp extends StatefulWidget {@overrideState<MyApp> createState() => _MyAppState();}class _MyAppState extends State<MyApp> {StreamSubscription? _appOpenSub;final String _zoneId = Platform.isAndroid ? 'ANDROID_ZONE_ID' : 'IOS_ZONE_ID';@overridevoid initState() {super.initState();final appId = Platform.isAndroid? 'your_android_app_identifier': 'your_ios_app_identifier';EmpowerAds.init(EmpowerAdsConfig(appAdIdentifier: appId,));// PreloadEmpowerAds.loadAppOpenAd(_zoneId);// Show once when ready_appOpenSub = EmpowerAds.onAppOpenStatusChanged.listen((event) {final status = event['status'];if (status == 'READY' && !_appOpenShown) {_appOpenShown = true;EmpowerAds.showAppOpen(_zoneId);}});}@overridevoid dispose() {_appOpenSub?.cancel();super.dispose();}@overrideWidget build(BuildContext context) {return MaterialApp(home: HomeScreen(),);}}
Show on Foreground Return
To show the ad when users return to the app, use Flutter's WidgetsBindingObserver:
import 'dart:async';import 'dart:io';import 'package:flutter/material.dart';import 'package:empower_mobile_ads/empower_mobile_ads.dart';class AppOpenHandler extends StatefulWidget {final Widget child;const AppOpenHandler({required this.child});@overrideState<AppOpenHandler> createState() => _AppOpenHandlerState();}class _AppOpenHandlerState extends State<AppOpenHandler> with WidgetsBindingObserver {static const _minBackgroundSeconds = 30;final String _zoneId = Platform.isAndroid ? 'ANDROID_ZONE_ID' : 'IOS_ZONE_ID';StreamSubscription? _statusSub;bool _isAdReady = false;DateTime? _backgroundTime;@overridevoid initState() {super.initState();WidgetsBinding.instance.addObserver(this);// PreloadEmpowerAds.loadAppOpenAd(_zoneId);// Track readiness_statusSub = EmpowerAds.onAppOpenStatusChanged.listen((event) {final status = event['status'];_isAdReady = status == 'READY';if (status == 'USED') {EmpowerAds.loadAppOpenAd(_zoneId); // Reload for next time}});}@overridevoid dispose() {WidgetsBinding.instance.removeObserver(this);_statusSub?.cancel();super.dispose();}@overridevoid didChangeAppLifecycleState(AppLifecycleState state) {if (state == AppLifecycleState.paused) {_backgroundTime = DateTime.now();}if (state == AppLifecycleState.resumed && _backgroundTime != null) {final elapsed = DateTime.now().difference(_backgroundTime!).inSeconds;if (elapsed >= _minBackgroundSeconds && _isAdReady) {EmpowerAds.showAppOpen(_zoneId);}}}@overrideWidget build(BuildContext context) {return widget.child; // Render nothing extra — this is a logic wrapper}}
Usage:
class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(home: AppOpenHandler(child: HomeScreen(),),);}}
Best Practices
- Cold starts — Show on fresh app launches for highest impact
- Don't show on every return — Only show after meaningful background time (30+ seconds)
- Respect user experience — Don't interrupt critical user flows (checkout, onboarding, etc.)
- Always preload — Call
loadAppOpenAdafter showing to prepare for next time - Don't block app launch — Let content load first on cold start
- Once per session — Consider using a module-level flag to limit to one display per cold start
Ad Status Reference
| Status | Description |
|---|---|
INITIALIZING | Ad is loading |
READY | Ad is loaded and ready to display |
FAILED | Ad failed to load |
SHOWN | Ad is being displayed |
SKIPPED | User dismissed the ad |
USED | Ad was shown and closed |