内容简介:共有两种实现比较简单的方式第一种比较好理解,将一个控件的透明度设置成0,打到隐藏的目的。第二种办法是使用 SDK 自带的
共有两种实现比较简单的方式
第一种比较好理解,将一个控件的透明度设置成0,打到隐藏的目的。
class _HideAndShowPageState extends State<HideAndShowPage> { bool visible = true; @override Widget build(BuildContext context) { return new Scaffold( appBar: new AppBar( title: new Text('widget显示与隐藏'), centerTitle: true, ), body: new ListView( children: <Widget>[ new Padding( padding: const EdgeInsets.only(left: 10.0, top: 10.0, right: 10.0), child: new RaisedButton( textColor: Colors.black, child: new Text(visible ? '隐藏B 显示A' : '隐藏A 显示B'), onPressed: () { visible = !visible; setState(() {}); }), ), new Padding( padding: const EdgeInsets.only(left: 10.0, top: 10.0, right: 10.0), child: new Stack( children: <Widget>[ new TestAWidget( visible: visible, ), new TestBWidget( visible: !visible, ), ], ), ), ], ), ); } } class TestAWidget extends StatelessWidget { final bool visible; const TestAWidget({Key key, this.visible}) : super(key: key); @override Widget build(BuildContext context) { return AnimatedOpacity( duration: Duration(milliseconds: 300), opacity: visible ? 1.0 : 0.0, child: new Container( color: Colors.blue, height: 100.0, child: new Center( child: new Text('TestAWidget'), ), ), ); } } class TestBWidget extends StatelessWidget { final bool visible; const TestBWidget({Key key, this.visible}) : super(key: key); @override Widget build(BuildContext context) { return AnimatedOpacity( duration: Duration(milliseconds: 300), opacity: visible ? 1.0 : 0.0, child: new Container( color: Colors.green, height: 100.0, child: new Center( child: new Text('TestBWidget'), ), ), ); } }
第二种办法是使用 SDK 自带的 Offstage
控件包裹。
offstage的布局行为完全取决于 offstate 参数,offstage 默认为 true ,不显示;
当 offstage 为 true,child 不会绘制到屏幕上,不会响应点击事件,也不会占用空间; 当 offstage 为 false,child 绘制到屏幕上; 注意,当 offstage 不可见,如果 child 有动画,应该手动停止动画, offstage 不会停止动画;
class TestCWidget extends StatelessWidget { final bool visible; const TestCWidget({Key key, this.visible}) : super(key: key); @override Widget build(BuildContext context) { return new Offstage( offstage: visible, child:new Container( color: Colors.orange, height: 100.0, child: new Center( child: new Text('TestCWidget'), ), ), ); } }
了解更多有深度技术的文章,与移动端、大前端未来方向的认知, 前往订阅 开源实验室小专栏。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- Flutter 设置控件是否可见
- 关于绝对定位和overflow的可见与不可见
- Android可见APP的不可见任务栈(TaskRecord)销毁分析
- 游戏中的 2D 可见性
- 随处可见的公钥证书
- 对象的可见性:volatile 篇
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
设计模式之禅(第2版)
秦小波 / 机械工业出版社 / 2014-2-25 / 89.00元
本书是设计模式领域公认的3本经典著作之一,“极具趣味,容易理解,但讲解又极为严谨和透彻”是本书的写作风格和方法的最大特点。第1版2010年出版,畅销至今,广受好评,是该领域的里程碑著作。深刻解读6大设计原则和28种设计模式的准确定义、应用方法和最佳实践,全方位比较各种同类模式之间的异同,详细讲解将不同的模式组合使用的方法。第2版在第1版的基础上有两方面的改进,一方面结合读者的意见和建议对原有内容中......一起来看看 《设计模式之禅(第2版)》 这本书的介绍吧!