如何解决是否可以在不将其包裹在容器中的情况下为 Scaffold 背景赋予渐变颜色?
我们可以在不将其包裹在容器中的情况下为 Scaffold 提供渐变背景吗?
Widget build(BuildContext context) {
return Scaffold(
//-----------------------------------
//main background
backgroundColor: Colors.blue[400],body: PageView.builder(
controller: pageController,onPageChanged: (val) {
setState(() {
currentIndex = val;
});
解决方法
不,Scaffold 的背景属性只接受一个 Color
。如果要显示颜色渐变,我认为根据定义应该将其视为 Scaffold 的 body
的一部分。 ;-)
但这真的很容易做到,例如使用 this tutorial。
,我们可以创建一个自定义的 Scaffold
类来完成它:
class CustomScaffold extends StatelessWidget {
CustomScaffold(this.body,this.gradient); // and maybe other Scaffold properties
final Widget body;
final LineGradient gradient;
@override
Widget build(BuildContext context) {
return Scaffold(
body: Container(child: this.body,decoration: BoxDecoration(gradient: this.gradient)),);
}
}
并像这样使用它:
Widget build(BuildContext context) {
LinearGradient _gradient = LinearGradient(colors: [gradientStart,gradientEnd],begin: const FractionalOffset(0.5,0.0),end: const FractionalOffset(0.0,0.5),stops: [0.0,1.0],tileMode: TileMode.clamp
);
return CustomScaffold(
gradient: _gradient,body: PageView.builder(
controller: pageController,onPageChanged: (val) {
setState(() {
currentIndex = val;
});
},),);
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。