I am experimenting with Flutter, and currently trying to display an input field and a dropdown in a list view in a dialog box. However, I get the drop-down overflowing the horizontal width of view and causing yellow-gray striped pattern (shown below)
Overflow of DropdownButton widget in ListView
The code is:
class DataInput extends StatefulWidget { @override State createState() => new DataInputState(""); } enum DismissDialogAction { cancel, discard, save, } class DataInputState extends State<DataInput> { final String _data; static const types = const <Map<String, String>>[ const { "id": "103", "desc": "0001 - lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum lorem ipsum" }, const { "id": "804", "desc": "0002 - lorem ipsum lorem ipsum" }, ]; DataInputState(this._data); @override Widget build(BuildContext context) { final ThemeData theme = Theme.of(context); return new Scaffold( appBar: new AppBar( title: const Text("Details"), actions: <Widget>[ new FlatButton( onPressed: () => Navigator.pop(context, DismissDialogAction.save), child: new Row( children: <Widget>[ new Icon(Icons.save, color: Colors.white,), new Text( "Save", style: theme.textTheme.body1.copyWith( color: Colors.white,) ) ], ) ), ], ), body: new ListView( shrinkWrap: true, children: <Widget>[ new Text("Set Label"), new TextField( autocorrect: false, ), new Text("Select Type"), new Container( width: new FractionColumnWidth(0.5).value, child: new DropdownButton( items: types.map((m) => new DropdownMenuItem( key: new Key(m["id"]), child: new Text(m["desc"])) ).toList(growable: false), onChanged: null ), ), ], ), ); } }
Error:
══╡ EXCEPTION CAUGHT BY RENDERING LIBRARY ╞═════════════════════════════════════════════════════════ The following message was thrown during layout: A horizontal RenderFlex overflowed by 433 pixels. The edge of the RenderFlex that is overflowing has been marked in the rendering with a yellow and black striped pattern. This is usually caused by the contents being too big for the RenderFlex. RenderFlex to fit within the available space instead of being sized to their natural size. This is considered an error condition because it indicates that there is content that cannot be seen. If the content is legitimately bigger than the available space, consider clipping it with a RectClip widget before putting it in the flex, or using a scrollable container rather than a Flex, for example using ListView. The specific RenderFlex in question is: RenderFlex#cc264 relayoutBoundary=up12 OVERFLOWING creator: Row ← SizedBox ← DefaultTextStyle ← Stack ← Listener ← _GestureSemantics ← RawGestureDetector ← GestureDetector ← DropdownButton ← ConstrainedBox ← Container ← RepaintBoundary-[<3>] ← ⋯ direction: horizontal mainAxisAlignment: space-between mainAxisSize: min crossAxisAlignment: center textDirection: ltr verticalDirection: down
I have tried the following approaches, and they don't work:
Can someone help me understand this and show how to fix it?
Update Using FittedBox
prevents the overflow, but the text size then shrinks to be un-legible.
The easiest solution is to add the isExpanded
property to true
in DropdownButton
For example:
new DropdownButton( isExpanded: true, //Adding this property, does the magic items: [ new DropdownMenuItem( child: Text("Some large text that needs to be wrapped or ellipsized", overflow: TextOverflow.ellipsis), ), new DropdownMenuItem( child: Text("This is another large text that needs to be wrapped or ellipsized", overflow: TextOverflow.ellipsis), ), new DropdownMenuItem( child: Text("And one more large text that needs to be wrapped or ellipsized", overflow: TextOverflow.ellipsis), ) ], onChanged: (val) { //print(val); }),
I managed to solve the issue by wrapping the child of DropdownMenuItem in a SizedBox and by giving sizedBox a fixed width which will not overflow the UI and still look good.
eg.
new DropdownMenuItem<String>( value: value, child: new SizedBox( width: 200.0, child: new Text('Long text with ${value} ') ), )
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With