Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Flutter - DropdownButton overflow

Tags:

flutter

dart

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)

enter image description here 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:

  • Wrapping the drop down in a Row, Column, Padding and ClipRect

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.

like image 835
Dah Avatar asked Oct 31 '17 09:10

Dah


2 Answers

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);                   }), 
like image 121
Raj Yadav Avatar answered Sep 19 '22 03:09

Raj Yadav


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} ')                       ),                     ) 
like image 20
Ganapat Avatar answered Sep 20 '22 03:09

Ganapat