'Display notification when app is closed flutter

I Have try to display notification in flutter app 1) When app is open the notification is display but 2) when flutter app is Closed but it is not working or notification is not display I have share my AndroidManifest.xml file please check it and help me , I'am new in flutter

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.tv_dashboard">
<!-- Internet Connection -->
<uses-permission android:name="android.permission.INTERNET" />
<!-- Display Notifications -->
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
<uses-permission android:name="android.permission.VIBRATE" /> 
  <!-- io.flutter.app.FlutterApplication is an android.app.Application that
     calls FlutterMain.startInitialization(this); in its onCreate method.
     In most cases you can leave this as-is, but you if you want to provide
     additional functionality it is fine to subclass or reimplement
     FlutterApplication and put your custom class here. -->
<application
    android:name="io.flutter.app.FlutterApplication"
    android:label="Leads"
    android:usesCleartextTraffic="true"
    android:icon="@mipmap/ic_launcher">
    <activity
        android:name=".MainActivity"
        android:launchMode="singleTop"
        android:theme="@style/LaunchTheme"
        android:configChanges="orientation|keyboardHidden|keyboard|screenSize|smallestScreenSize|locale|layoutDirection|fontScale|screenLayout|density|uiMode"
        android:hardwareAccelerated="true"
        android:windowSoftInputMode="adjustResize"
        android:showWhenLocked="true"
        android:turnScreenOn="true">
        <!-- Specifies an Android theme to apply to this Activity as soon as
             the Android process has started. This theme is visible to the user
             while the Flutter UI initializes. After that, this theme continues
             to determine the Window background behind the Flutter UI. -->
        <meta-data
          android:name="io.flutter.embedding.android.NormalTheme"
          android:resource="@style/NormalTheme"
          />
        <!-- Displays an Android View that continues showing the launch screen
             Drawable until Flutter paints its first frame, then this splash
             screen fades out. A splash screen is useful to avoid any visual
             gap between the end of Android's launch screen and the painting of
             Flutter's first frame. -->
        <meta-data
          android:name="io.flutter.embedding.android.SplashScreenDrawable"
          android:resource="@drawable/launch_background"
          />
        <intent-filter>
            <action android:name="android.intent.action.MAIN"/>
            <category android:name="android.intent.category.LAUNCHER"/>
        </intent-filter>
    </activity>
    <receiver android:name="com.dexterous.flutterlocalnotifications.ScheduledNotificationBootReceiver">
        <intent-filter>
            <action android:name="android.intent.action.BOOT_COMPLETED"/>
            <action android:name="android.intent.action.MY_PACKAGE_REPLACED"/>
        </intent-filter>
    </receiver>
    <receiver android:name="com.dexterous.flutterlocalnotifications.ScheduledNotificationReceiver" />
    <!-- Don't delete the meta-data below.
         This is used by the Flutter tool to generate GeneratedPluginRegistrant.java -->
    <meta-data
        android:name="flutterEmbedding"
        android:value="2" />
</application>


Solution 1:[1]

You can do by using this-

import 'package:flutter/material.dart';
import 'package:flutter_local_notifications/flutter_local_notifications.dart';
import 'package:workmanager/workmanager.dart';

void main() {

// needed if you intend to initialize in the `main` function 
WidgetsFlutterBinding.ensureInitialized();
Workmanager.initialize(

    // The top level function, aka callbackDispatcher 
    callbackDispatcher,

    // If enabled it will post a notification whenever 
    // the task is running. Handy for debugging tasks 
    isInDebugMode: true
 );
 // Periodic task registration 
 Workmanager.registerPeriodicTask(
    "2",

    //This is the value that will be 
    // returned in the callbackDispatcher 
    "simplePeriodicTask",

    // When no frequency is provided 
    // the default 15 minutes is set. 
    // Minimum frequency is 15 min. 
    // Android will automatically change 
    // your frequency to 15 min 
    // if you have configured a lower frequency. 
    frequency: Duration(minutes: 15),
  );
  runApp(MyApp());
  }

   void callbackDispatcher() {
 Workmanager.executeTask((task, inputData) {

    // initialise the plugin of flutterlocalnotifications. 
    FlutterLocalNotificationsPlugin flip = new  
    FlutterLocalNotificationsPlugin();

    // app_icon needs to be a added as a drawable 
    // resource to the Android head project. 
    var android = new AndroidInitializationSettings('@mipmap/ic_launcher');
    var IOS = new IOSInitializationSettings();

    // initialise settings for both Android and iOS device. 
    var settings = new InitializationSettings(android, IOS);
    flip.initialize(settings);
    _showNotificationWithDefaultSound(flip);
    return Future.value(true);
    });
   }

  Future _showNotificationWithDefaultSound(flip) async {

// Show a notification after every 15 minute with the first 
// appearance happening a minute after invoking the method 
var androidPlatformChannelSpecifics = new AndroidNotificationDetails(
        'your channel id',
'your channel name',
'your channel description',
importance: Importance.Max,
priority: Priority.High
);
var iOSPlatformChannelSpecifics = new IOSNotificationDetails();

// initialise channel platform for both Android and iOS device. 
var platformChannelSpecifics = new NotificationDetails(
        androidPlatformChannelSpecifics,
iOSPlatformChannelSpecifics
);
await flip.show(0, 'GeeksforGeeks',
'Your are one step away to connect with GeeksforGeeks',
platformChannelSpecifics, payload: 'Default_Sound'
);
}

class MyApp extends StatelessWidget {
// This widget is the root of your application. 
@override
Widget build(BuildContext context) {
    return MaterialApp(
        title: 'Geeks Demo',
    theme: ThemeData(

    // This is the theme 
    // of your application. 
    primarySwatch: Colors.green,
    ),
    home: HomePage(title: "GeeksforGeeks"),
    );
  }
  }

  class _HomePageState extends State<HomePage> {
@override
Widget build(BuildContext context) {

    // This method is rerun every time setState is called. 
    // The Flutter framework has been optimized 
    // to make rerunning build methods 
    // fast, so that you can just rebuild 
    // anything that needs updating rather 
    // than having to individually change 
    //instances of widgets. 
    return Scaffold(
        appBar: AppBar(

                // Here we take the value from 
                // the MyHomePage object that was created by 
                // the App.build method, and use it 
                // to set our appbar title. 
                title: Text(widget.title),
    ),
    body: new Container(),
    );
  }
  } 

dependencies

    dependencies:
    flutter:
    sdk: flutter
    
    # The following adds the Cupertino Icons font to your application.
    # Use with the CupertinoIcons class for iOS style icons.
    cupertino_icons: ^0.1.2
    # Use with the Workmanger class for background jobs headless execution.
    workmanager: ^0.2.3
    # Use with FlutterLocalNotificationsPlugin class for local push notifications.
    flutter_local_notifications: ^1.4.4+2

And

    <!-- Add below permission inside 'manifest' tag -->
<uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED"/>
<!-- Add below permission inside 'application' tag -->
<receiver android:name="com.dexterous.flutterlocalnotifications.ScheduledNotificationBootReceiver">
<intent-filter>
<action android:name="android.intent.action.BOOT_COMPLETED"/>
<action android:name="android.intent.action.MY_PACKAGE_REPLACED"/>
</intent-filter>
</receiver>
  • and use for more

flutter_local_notifications

thank you

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 Sandeep Pareek