🐛 View debug infos and change settings via a central overlay for your app.
To add a debug overlay to your app, pass DebugOverlay.builder()
to MaterialApp
/CupertinoApp
/WidgetsApp.builder
:
MaterialApp(
builder: DebugOverlay.builder(),
// And other customization...
)
The debug overlay only works in debug mode and is not included in your widget tree in profile or release mode unless you pass
enableOnlyInDebugMode: false
.
There are two ways to open the debug overlay:
- Shake your phone!
(You can disable the shake detection by passing
showOnShake: false
toDebugOverlay.builder
.) - Call
DebugOverlay.show()
.
By default, this overlay includes MediaQueryDebugHelper
, PackageInfoDebugHelper
, and DeviceInfoDebugHelper
.
To add a debug helper, you have to register it by calling either of the following two (which accept any sliver widget):
DebugOverlay.prependHelper(myDebugHelper)
to add it to the front of the listDebugOverlay.appendHelper(myDebugHelper)
to add it to the end of the list
Or, if you want to override all currently registered overlays, set DebugOverlay.helpers.value
to a list of sliver widget.
Displays information obtained from device_info_plus.
Displays information obtained from MediaQuery
.
Displays logs generated by your app. To use it, follow these steps:
-
Store its mutable state, e.g., in a global variable:
final logs = LogCollection( // Default values: maximumSize: 500, onlyStoreLogsInDebugMode: true, );
-
Register the helper and supply its state, e.g., in
main()
:void main() { if (kDebugMode) { DebugOverlay.appendHelper(LogsDebugHelper(logs)); } runApp(MyApp()); }
-
When you generate logs, add them to the collection. Except for
message
, all parameters are optional:logs.add(Log( level: DiagnosticLevel.info, timestamp: DateTime.now(), message: 'My message', error: myException, stackTrace: myStackTrace, ));
The error
field can also hold data for non-error logs.
If it stores JSON data (on an object with a toJson()
method), the data can be inspected using json_view.
This allows you to override the theme mode and locale of your app. To use it, follow these steps:
-
Store its mutable state, e.g., in a global variable:
final mediaOverrideState = ValueNotifier(MediaOverrideState());
-
Register the helper and supply its state, e.g., in
main()
:void main() { if (kDebugMode) { DebugOverlay.prependHelper(MediaOverrideDebugHelper( mediaOverrideState, // To support overriding locales, this value must be set and should // contain the same locales as passed to [MaterialApp.supportedLocales], // [CupertinoApp.supportedLocales] or [WidgetsApp.supportedLocales]. supportedLocales: supportedLocales, )); } runApp(MyApp()); }
-
When building your
MaterialApp
/CupertinoApp
/WidgetsApp
, wrap it in aValueListenableBuilder
that uses the state from step 1:ValueListenableBuilder<MediaOverrideState>( valueListenable: mediaOverrideState, builder: (context, overrideState, child) { return MaterialApp( // You can access overridden values via [overrideState]: themeMode: overrideState.themeMode, locale: overrideState.locale, builder: DebugOverlay.builder(showOnShake: false), supportedLocales: supportedLocales, // And your other customizations... ); }, );
Displays information obtained from package_info_plus.
To implement your own debug helper, you can use the provided DebugHelper
class for the layout.
If your information can be represented with Flutter's DiagnosticsNode
, you can use DiagnosticsBasedDebugHelper
which automatically provides filtering.
This is also used internally by DeviceInfoDebugHelper
, MediaQueryDebugHelper
, and PackageInfoDebugHelper
.