我想在DropDownButton
的左侧添加图标,但是找不到解决方法。
我想要实现的是这样的:
我尝试了以下代码,但是将图标放置在不需要的位置,并且它还会覆盖箭头图标:
`@override
Widget build(BuildContext context) {
return Scaffold(
body: Container(
margin: EdgeInsets.only(top: 64.0, left: 16.0, right: 16.0),
color: Colors.white,
child: DropdownButton(
icon: Icon(
Icons.person,
color: Colors.redAccent,
size: 20.09,
),
isExpanded: true,
items: _studentList.map((val) {
return DropdownMenuItem(
value: val,
child: Text(val),
);
}).toList(),
value: _currentSelectedItem,
onChanged: (value) {
setState(() {
_currentSelectedItem = value;
});
},
),
),
);
}`
以上代码的输出如下:
我还尝试将Icon()
和DropDownButton()
放在Row()
小部件内,但这不允许DropDownButton()
扩展到全宽。
任何帮助将不胜感激。
谢谢
答案 0 :(得分:1)
如果图标实际上在视觉上应该是DropDown组件的一部分,则可以采用以下路线。它有点 hacky ,缺乏响应能力,但它是进行更多实验的起点。我添加了一个完整的工作示例,因此您可以将其复制粘贴到可运行的主dart文件中。
简而言之,它使用堆栈布局,因此图标仅位于下拉组件上方。然后我填充了文本,以便在左侧留出空间。void main() => runApp(MyApp());
/// This Widget is the main application widget.
class MyApp extends StatelessWidget {
static const String _title = 'Flutter Code Sample';
@override
Widget build(BuildContext context) {
return MaterialApp(
title: _title,
home: Scaffold(
appBar: AppBar(title: const Text(_title)),
body: MyStatefulWidget(),
),
);
}
}
class MyStatefulWidget extends StatefulWidget {
MyStatefulWidget({Key key}) : super(key: key);
@override
_MyStatefulWidgetState createState() => _MyStatefulWidgetState();
}
class _MyStatefulWidgetState extends State<MyStatefulWidget> {
String dropdownValue = 'One';
@override
Widget build(BuildContext context) {
return Scaffold(
body: Center(
child: Stack(
children: <Widget>[
DropdownButton<String>(
value: dropdownValue,
//icon: Icon(Icons.arrow_downward),
iconSize: 24,
elevation: 16,
style: TextStyle(color: Colors.deepPurple),
underline: Container(
height: 2,
color: Colors.deepPurpleAccent,
),
onChanged: (String newValue) {
setState(() {
dropdownValue = newValue;
});
},
items: <String>['One', 'Two', 'Free', 'Four']
.map<DropdownMenuItem<String>>((String value) {
return DropdownMenuItem<String>(
value: value,
child: Padding(
padding: const EdgeInsets.only(left: 30.0),
child: Text("$value"),
),
);
}).toList(),
),
Container(
margin: EdgeInsets.symmetric(vertical: 10),
child: Icon(Icons.arrow_downward)),
],
),
),
);
}
}
答案 1 :(得分:1)
没有用于按所需方式添加图标的特定属性,但是您始终可以在代码中变通并进行一些调整。使用以下代码将Icon()
放置在DropDownButton()
按钮的顶部。
@override
Widget build(BuildContext context) {
return Scaffold(
body: Stack(
children: <Widget>[
Container(
decoration: BoxDecoration(
color: Colors.white,
boxShadow: [
BoxShadow(
color: Colors.grey,
blurRadius: 20.0,
spreadRadius: 0.5,
offset: Offset(1.0, 1.0),
),
],
),
padding: EdgeInsets.only(left: 44.0),
margin: EdgeInsets.only(top: 64.0, left: 16.0, right: 16.0),
child: DropdownButton(
isExpanded: true,
items: your_list.map(
(val) {
return DropdownMenuItem(
value: val,
child: Text(val),
);
},
).toList(),
value: _currentSelectedItem,
onChanged: (value) {
setState(() {
_currentSelectedItem = value;
});
},
),
),
Container(
margin: EdgeInsets.only(top: 80.0, left: 28.0),
child: Icon(
Icons.person,
color: Colors.redAccent,
size: 20.0,
),
),
],
),
);
}
答案 2 :(得分:1)
请记住,一切都是小部件,所以:
iconSize: 0,
hint: Row(
children: [
Container(
child: Text('Freguesias'),
),
Container(
child: Icon(Icons.arrow_drop_down),
),
],
),
答案 3 :(得分:0)
这可能为时已晚。但对即将到来的观众很有帮助。
我们可以使用 DropDownButtonFormField 代替 DropDownButton。其中具有 decoration 属性。有了这个,我们可以利用 prefixIcon 属性将图标添加到 DropDownButton 的左侧:
DropDownButtonFormField(
decoration: InputDecoration(
prefixIcon: Icon(Icons.person, color: Colors.redAccent),
),
...
);
答案 4 :(得分:-1)
我认为您可以尝试以下代码:-
body: Container(
margin: EdgeInsets.only(top: 64.0, left: 16.0, right: 16.0),
color: Colors.white,
child:
child: Row(
children: <Widget>[
Icon(
Icons.person,
color: Colors.redAccent,
size: 20.09,
),
Expanded(
flex:1,
child:DropdownButton(
isExpanded: true,
items: _studentList.map((val) {
return DropdownMenuItem(
value: val,
child: Text(val),
);
}).toList(),
value: _currentSelectedItem,
onChanged: (value) {
setState(() {
_currentSelectedItem = value;
});
},
),
)
]
)
答案 5 :(得分:-2)
这样做的简单方法是将子道具传递给 DropdownMenuItem,然后您可以传递任何小部件,我已经创建了一行并传递了该行中的图标和文本:
items: <String>['George Green School', 'George Blue School', 'George Red School', 'George Yellow School']
.map<DropdownMenuItem<String>>((String value) {
return DropdownMenuItem<String>(
value: value,
child: Row(
children: [
Icon(Icons.dangerous),
Text(value, style: TextStyle(fontSize : 12),),
],
),
);
}).toList(),