我的Flutter应用中有一个CupertinoAlertDialog和AlertDialog。每次弹出对话框时,其背后的所有内容都会变暗。我想删除背景。我该怎么办?
CupertinoDialogAction(
child: Text('Delete',
style: TextStyle(color: Colors.red),
),
onPressed: () async {
await CommentActivity.delete(postData[index]['id'])
.then((response) {
if (response) {
setState(() {
postData.removeAt(index);
createPageActivity();
renderPageActivity();
});
Navigator.of(context).pop();
}
});
}
)
],
)
答案 0 :(得分:2)
在showDialog方法中具有barrierColor属性的简单解决方案,我将白色设置为不透明度值为零,并且栅栏阴影消失了
AlertDialog alert = AlertDialog(
backgroundColor: Colors.transparent,
elevation: 0,
content: new Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Loader(),
],
),
);
showDialog(
barrierColor: Colors.white.withOpacity(0),
barrierDismissible: false,
context: context,
builder: (BuildContext context) {
return WillPopScope(
onWillPop: (){},
child: alert);
},
);
答案 1 :(得分:1)
部分解决问题的替代方法是使用几乎透明的颜色作为屏障:
showDialog<void>(
barrierColor: Color(0x01000000),
)
答案 2 :(得分:0)
我认为您正在谈论对话框背景中的黑色推子... 是Material / cupertino实现的一部分,在Material中具有固定值Colors.black54。
您将必须复制showDialog()
代码,并对其进行修改。
演示:
// common Dialog widget shown in both implementation.
Widget buildDialog(BuildContext context) {
return CupertinoDialogAction(
child: Text(
'Delete',
style: TextStyle(color: Colors.red),
),
onPressed: () async {
Navigator.of(context).pop();
},
);
}
void openDialog(BuildContext context) {
// open custom dialog.
openCustomDialog(context);
// open default dialog.
// openFlutterDialog(context);
}
// regular Fluter showDialog()
void openFlutterDialog(BuildContext context) {
showDialog(
context: context,
builder: (ctx) {
return buildDialog(ctx);
},
);
}
void openCustomDialog(BuildContext context) {
showCustomDialog(
context: context,
builder: (ctx) {
return buildDialog(ctx);
},
);
}
// custom implementation of showDialog()...
Future<T> showCustomDialog<T>({
@required BuildContext context,
bool barrierDismissible = true,
WidgetBuilder builder,
}) {
assert(debugCheckHasMaterialLocalizations(context));
final ThemeData theme = Theme.of(context, shadowThemeOnly: true);
return showGeneralDialog(
context: context,
pageBuilder: (BuildContext buildContext, Animation<double> animation,
Animation<double> secondaryAnimation) {
final Widget pageChild = Builder(builder: builder);
return SafeArea(
child: Builder(builder: (BuildContext context) {
return theme != null
? Theme(data: theme, child: pageChild)
: pageChild;
}),
);
},
barrierDismissible: barrierDismissible,
barrierLabel: MaterialLocalizations.of(context).modalBarrierDismissLabel,
// KEY PART TO MODIFY, Flutter doesn't allow a transparent Color,
// values under opacity .01 are considered transparent and will throw an error.
// But this value is transparent enough.
barrierColor: Colors.black.withOpacity(0.01),
// you can modify the default FadeTransition duration here.
transitionDuration: const Duration(milliseconds: 2000),
);
}
这是您要找的吗?
答案 3 :(得分:0)
只需使用de navigator启动对话框,而不使用showDialog()并使用PageRouteBuilder
holder.spinnerCart.setOnItemSelectedListener(new AdapterView.OnItemSelectedListener() {
int count=0;
@Override
public void onItemSelected(AdapterView<?> adapterView, View view, int i, long l) {
if(count >= 1) {
}count++;
}
@Override
public void onNothingSelected(AdapterView<?> adapterView) {
}
});