Flutter PopupMenuButton 缺少波纹效果
Flutter PopupMenuButton Missing Ripple Effect
上图中的按钮是我试图重现的。点击它时,它应该显示不同温度单位的列表。我从一个凸起的按钮开始,发现只显示一个弹出列表并不容易。所以我将其更改为使用容器。除了缺少点击按钮时的涟漪效应外,它可以正常工作。如果我删除 BoxDecoration 颜色,它确实有效,但我确实希望按钮的颜色为白色。有什么办法可以做到这一点?
Expanded(
flex: 2,
child: PopupMenuButton(
elevation: 3.0,
onSelected: (String value) {
setState(() {
_selection = value;
});
},
child: Container(
height: double.maxFinite,
width: double.maxFinite,
child: Center(
child: Text(
'C\n\nCelsius',
textAlign: TextAlign.center,
),
),
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.circular(10),
border: Border.all(
color: Colors.grey[kButtonBorderShade],
width: 0.5)),
),
itemBuilder: (BuildContext context) =>
<PopupMenuEntry<String>>[
const PopupMenuItem<String>(
value: 'Value1',
child: Text('Choose value 1'),
),
const PopupMenuItem<String>(
value: 'Value2',
child: Text('Choose value 2'),
),
const PopupMenuItem<String>(
value: 'Value3',
child: Text('Choose value 3'),
),
],
),
),
编辑:感谢您在下面的回答。根据给出的建议,我完全按照我想要的方式工作。这是我的最后一个按钮:
Expanded(
flex: 2,
child: ClipRRect(
borderRadius: BorderRadius.all(
Radius.circular(10),
),
child: Material(
color: Colors.white,
child: PopupMenuButton(
onSelected: (String value) {
setState(() {
_selection = value;
});
},
child: Container(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(10),
border: Border.all(
color:
Colors.grey[kButtonBorderShade],
width: 0.5)),
child: Center(
child: Text(
'C\n\nCelsius',
textAlign: TextAlign.center,
),
),
),
itemBuilder: (BuildContext context) =>
<PopupMenuEntry<String>>[
const PopupMenuItem<String>(
value: 'Value1',
child: Text('Choose value 1'),
),
const PopupMenuItem<String>(
value: 'Value2',
child: Text('Choose value 2'),
),
const PopupMenuItem<String>(
value: 'Value3',
child: Text('Choose value 3'),
),
],
),
),
),
),
您可以实现用 Material
包装 PopupMenuButton
并将 color
属性 放在 Material
小部件中而不是 BoxDecoration
,像这样:
Material(
color: Colors.white,
child: PopupMenuButton(...
上图中的按钮是我试图重现的。点击它时,它应该显示不同温度单位的列表。我从一个凸起的按钮开始,发现只显示一个弹出列表并不容易。所以我将其更改为使用容器。除了缺少点击按钮时的涟漪效应外,它可以正常工作。如果我删除 BoxDecoration 颜色,它确实有效,但我确实希望按钮的颜色为白色。有什么办法可以做到这一点?
Expanded(
flex: 2,
child: PopupMenuButton(
elevation: 3.0,
onSelected: (String value) {
setState(() {
_selection = value;
});
},
child: Container(
height: double.maxFinite,
width: double.maxFinite,
child: Center(
child: Text(
'C\n\nCelsius',
textAlign: TextAlign.center,
),
),
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.circular(10),
border: Border.all(
color: Colors.grey[kButtonBorderShade],
width: 0.5)),
),
itemBuilder: (BuildContext context) =>
<PopupMenuEntry<String>>[
const PopupMenuItem<String>(
value: 'Value1',
child: Text('Choose value 1'),
),
const PopupMenuItem<String>(
value: 'Value2',
child: Text('Choose value 2'),
),
const PopupMenuItem<String>(
value: 'Value3',
child: Text('Choose value 3'),
),
],
),
),
编辑:感谢您在下面的回答。根据给出的建议,我完全按照我想要的方式工作。这是我的最后一个按钮:
Expanded(
flex: 2,
child: ClipRRect(
borderRadius: BorderRadius.all(
Radius.circular(10),
),
child: Material(
color: Colors.white,
child: PopupMenuButton(
onSelected: (String value) {
setState(() {
_selection = value;
});
},
child: Container(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(10),
border: Border.all(
color:
Colors.grey[kButtonBorderShade],
width: 0.5)),
child: Center(
child: Text(
'C\n\nCelsius',
textAlign: TextAlign.center,
),
),
),
itemBuilder: (BuildContext context) =>
<PopupMenuEntry<String>>[
const PopupMenuItem<String>(
value: 'Value1',
child: Text('Choose value 1'),
),
const PopupMenuItem<String>(
value: 'Value2',
child: Text('Choose value 2'),
),
const PopupMenuItem<String>(
value: 'Value3',
child: Text('Choose value 3'),
),
],
),
),
),
),
您可以实现用 Material
包装 PopupMenuButton
并将 color
属性 放在 Material
小部件中而不是 BoxDecoration
,像这样:
Material(
color: Colors.white,
child: PopupMenuButton(...