808

I'm using flutter screenshot and I expected the screenshot to not have a banner, but it has.

Note that I get a not supported for emulator message for profile and release mode.

0

18 Answers 18

1549
+50

On your MaterialApp set debugShowCheckedModeBanner to false.

MaterialApp(
  debugShowCheckedModeBanner: false,
)

The debug banner will also automatically be removed on the release build.

9
  • 59
    Usage: return new MaterialApp( home: new LoginPage(), debugShowCheckedModeBanner: false, theme: new ThemeData( primarySwatch: Colors.green, )); Commented May 11, 2018 at 13:10
  • 4
    do i need to use debugShowCheckedModeBanner: false on each class means activity ?
    – Ashish
    Commented May 12, 2019 at 4:58
  • 14
    The flutter tool's built-in screenshot command also knows how to automatically remove the "debug" banner while taking a screenshot if that's helpful. Commented Jul 1, 2019 at 15:47
  • 1
    @EricSeidel Not by default it doesn't (Flutter 1.16.4-pre.18 • channel master • github.com/flutter/flutter.git Framework • revision c8efcb632b (6 weeks ago) • 2020-03-27 22:31:01 -0700 Engine • revision 3ee9e3d378) Is there a trick to enable this?
    – Thomas
    Commented May 11, 2020 at 7:40
  • 1
    Is there any way to show it in release build? I am building a release versions but for dev/production environments Commented May 26, 2020 at 12:32
130

Outdated

  • If you are using Android Studio, you can find the option in the Flutter Inspector tab → More Actions.

    Android Studio

  • Or if you're using Dart DevTools, you can find the same button in the top right corner as well.

    Dart DevTools

1
  • 2
    Disappeared on the DevTools View, but I have found it through AndroidStudio
    – stan
    Commented Jan 25, 2021 at 19:39
82

Well, this is the simple answer you want.

MaterialApp(
  debugShowCheckedModeBanner: false
)

CupertinoApp(
  debugShowCheckedModeBanner: false
)

But if you want to go deep with the app (want a release APK file (which doesn't have a debug banner) and if you are using Android Studio then go to RunFlutterRun 'main.dart' in Release mode.

52

If you are using IntelliJ IDEA, there is an option in the Flutter Inspector to disable it.

Run the project:

Open the Flutter inspector

Hide the slow banner

When you are in the Flutter Inspector, click or choose "More Actions."

Picture of the Flutter Inspector

When the menu appears, choose "Hide Debug Mode Banner":

Picture of Hide Debug Mode Banner

1
  • 5
    This menu and related item doesn't exist in idea 2020.3 and flutter 55.0.3
    – AaA
    Commented Apr 13, 2021 at 2:00
45

The debug banner appears only while in development and is automatically removed in the release build.

To hide this there is a need to set debugShowCheckedModeBanner to false

MaterialApp(
  debugShowCheckedModeBanner: false,
)

enter image description here

41

Three ways to remove flutter debug banner:-

1. In the MaterialApp/ScaffoldApp

Snippet

MaterialApp(
  debugShowCheckedModeBanner: false,
)

OR

ScaffoldApp(
             debugShowCheckedModeBanner: false,
        );

2.By making release version of your app

For running release version of your app, use this command

flutter run --release

Or if using real devices rather than emulators or simulators. make a build version of the app.

flutter build apk

3.BY using dart dev tool to remove debug banner

IN vs code type ctr+shift+pin windows and for mac cmd+shift+p and use this command to open dart dev tool

Dart: Open DevTools

enter image description here

32

There is also another way for removing the "debug" banner from the Flutter app. Now after a new release there is no "debugShowCheckedModeBanner: false," code line in the main .dart file. So I think these methods are effective:

  1. If you are using Visual Studio Code, then install `"Dart DevTools" from extensions. After installation, you can easily find the "Dart DevTools" text icon at the bottom of Visual Studio Code. When you click on that text icon, a link will be opened in Google Chrome. From that link page, you can easily remove the banner by just tapping on the banner icon as shown in this screenshot.

NOTE: Dart DevTools is a Dart language debugger extension in Visual Studio Code

  1. If Dart DevTools is already installed in your Visual Studio Code, then you can directly open Google Chrome and open the URL "127.0.0.1: ZZZZZ/?hide=debugger&port=XXXXX"

Note: In this link, replace "XXXXX" by 5 digit port-id (on which your Flutter app is running) which will vary whenever you use the flutter run command and replace "ZZZZZ" by your global (unchangeable) 5 digit debugger-id

Note: These Dart developer tools are only for the Google Chrome browser

0
23

On your MaterialApp set debugShowCheckedModeBanner to false.

 MaterialApp(
    debugShowCheckedModeBanner: false,
  )

The debug banner will also automatically be removed on release build.

If you are using emulator or real device and you want to check it on release mode then =>

   flutter run release --apk 

run this command on terminal Android Studio / Vs Code

23

To remove the Flutter debug banner, there are several possibilities:

  1. The first one is to use the debugShowCheckModeBanner property in your MaterialApp widget.

    Code:

    MaterialApp(
      debugShowCheckedModeBanner: false,
    )
    

    And then do a hot reload.

  2. The second possibility is to hide debug mode banner in Flutter Inspector if you use Android Studio or IntelliJ IDEA.

    Enter image description here

  3. The third possibility is to use Dart DevTools.

1
  • 2
    This menu and related item doesn't exist in idea 2020.3 and flutter 55.0.3
    – AaA
    Commented Apr 13, 2021 at 2:00
18

Use:

MaterialApp(
  debugShowCheckedModeBanner: false,
)

This is the code for removing this banner. The debug banner is due to MaterialApp, e.g., you can see this banner on all that pages that use MaterialApp.

There should be at least one MaterialApp in your app on main root.

18

All other answers are great for Android Studio, but if using Visual Studio Code there is a command you can use to toggle this easily. Open the command palette (Mac: Cmd + Shift + P or Windows: Ctrl + Shift + P). Then type toggle debug-mode banner as shown below:

Enter image description here

10

It's the app.dart class property.

It displays a banner, saying "DEBUG" when running in checked mode. MaterialApp builds one of these by default.

For disabling this banner in debug mode also, you can set a Boolean false.

return MaterialApp(
  theme:....
  debugShowCheckedModeBanner: false,
  home: SplashScreen(),
);

In release mode this has no effect.

10

If you are still in debug mode, you can switch to release mode and the banner will be gone.

release

enter image description here

You can also open the same Run/Debug Configurations window via shortcuts:

ALT+SHIFT+F10, then Press 0 and Press ALT+a.

Now enter --release.

7

If you use Scaffold in Return Section so add on Top MaterialApp and Restart

void main() => runApp(
      const MaterialApp(
                 debugShowCheckedModeBanner: false, 
                 home: Home()),
      );
1
  • This works well
    – Nehal Babu
    Commented Dec 23, 2024 at 7:43
3

This is the simplest way.

For : MaterialApp( debugShowCheckedModeBanner: false )

For : CupertinoApp( debugShowCheckedModeBanner: false )

If you are logically handle another flutter components them you use a bool variable & handle it. For Example bool isDebug === false ;

if(isDebug == true) { debugShowCheckedModeBanner: true }

else { debugShowCheckedModeBanner: false }

Thanks & Enjoy)):

1
  • 1
    Though we thank you for your answer, it would be better if it provided additional value on top of the other answers. In this case, your answer does not provide additional value, since another user already posted that solution. If a previous answer was helpful to you, you should vote it up once you have enough reputation
    – lepsch
    Commented Sep 16, 2022 at 6:26
3

If you are using the Material library

MaterialApp(
  debugShowCheckedModeBanner: false
)

If you are using the GetX library

GetMaterialApp(
  debugShowCheckedModeBanner: false
)

If you are using the Cupertino library

CupertinoApp(
  debugShowCheckedModeBanner: false
)
1
  • This works for me
    – Nehal Babu
    Commented Dec 23, 2024 at 7:42
0

add debugShowCheckedModeBanner: false, into the materialApp Widget.

 MaterialApp(
  debugShowCheckedModeBanner: false
)
1
  • Your answer could be improved with additional supporting information. Please edit to add further details, such as citations or documentation, so that others can confirm that your answer is correct. You can find more information on how to write good answers in the help center.
    – Community Bot
    Commented Dec 18, 2024 at 6:18
0

If you're seeing the debug banner (DEBUG) in your Flutter app and want to remove it, you can do so by setting the debugShowCheckedModeBanner property of the MaterialApp (or CupertinoApp) widget to false.

Example:

MaterialApp(
  debugShowCheckedModeBanner: false, // Hides the debug banner
  home: YourHomePage(),
)

Why is the Debug Banner Appearing in Screenshots?

The debug banner appears because the app is running in debug mode. This banner is Flutter's way of indicating that the app isn't running in production.

If you're taking screenshots and don't want the banner:

  1. Set debugShowCheckedModeBanner to false: This removes the banner while staying in debug mode.
  2. Use Profile or Release Mode (Preferred for production-like screenshots):
  • Profile

    flutter run --profile

  • Release

    flutter run --release

Note: Profile and release modes aren't supported on emulators. You'll need a physical device for these modes.

Additional Tips: If you still need to take screenshots programmatically, you can use a package like flutter_native_screenshot to capture the UI without debug banners.

Let me know if you need more help!

Not the answer you're looking for? Browse other questions tagged or ask your own question.