What I want to achieve: I want to open a pop up explaining my app when it starts.
My approach: As far as I understand it from googling the issue, I should use the showDialog() method. In its most basic form:
showDialog(
context: context,
builder: (context) {
return Text('data');
});
I tried returning actual dialogs (e.g. AlertDialog) but it doesn't change the behavior so I'm just using Text() with a string as a placeholder for now.
The problem:
No matter where I place the showDialog function, it doesn't work as intended (also see scrennshots below):
- Placing it in initState: I get an error message about inherited Widgets being called before the initState is done + an explanation about dependiencies I can barely follow.
- Placing it in the build method: I get an error message that setState() or markNeedsBuild() gets called while the app is already buildung widgets.
- Placing it in DidChangeAppLifeCycleState(): This is actually working and opening the pop when I pause the app and then resume it. It is not opening on app startup though.
- Wrapping it in WidgetsBinding.instance!.addPostFrameCallback(): An idea I picked up here: How to show a popup on app start in Flutter. Doesn't change the outcome of the error messages, neither in initState nor in build.
Any ideas?
Screenshots:
From initState:
From build method:
From DidChangeAppLifecycleState (the "succesful" variant:
Using
WidgetsBinding.instance.addPostFrameCallback
insideinitState
perform its inner task after the 1st frame is complete.Next issue arise for not having material. You can directly return
AlertDialog
onbuilder
or wrap with any material widget likeMaterial
,Scaffold
..If you are running version<3 null safety, use
WidgetsBinding.instance?.addPostFrameCallback