摘要:本文用到的组件这是一个简单版仿微信的左滑删除的组件左滑删除组件地址仓库地址问题在上,使用仿微信样式的左滑删除组件时如果这一行的背景色是透明的,就会出现如下问题透明的下可以看到删除和编辑按钮,我们就需要处理一下。
本文用到的组件:
这是一个简单版仿微信的左滑删除的组件:
# 左滑删除组件 left_scroll_actions: any
pub地址:
https://pub.dartlang.org/pack...
仓库地址:
https://github.com/mjl0602/le...
在flutter上,使用仿微信样式的左滑删除组件时,如果这一行的背景色是透明的,就会出现如下问题:
透明的Row下可以看到删除和编辑按钮,我们就需要处理一下。
至于为啥要用透明背景色——因为Scaffold的背景色是渐变的……当时画设计图给自己挖的坑。
组件分装很简单,把滑动进度和透明度挂钩,就可以了:
// 如果Row的背景必须是透明颜色的,就要做处理了: class ExampleRow extends StatefulWidget { final Function onTap; final Function onEdit; final Function onDelete; const ExampleRow({ Key key, this.onTap, this.onDelete, this.onEdit, }) : super(key: key); @override _ExampleRowState createState() => _ExampleRowState(); } class _ExampleRowState extends State效果GIF{ double opa = 0; @override Widget build(BuildContext context) { Widget myDeviceStatus = Icon(Icons.supervised_user_circle); Widget body = Container( padding: EdgeInsets.fromLTRB(12, 0, 0, 0), height: 92, width: double.infinity, child: Row( crossAxisAlignment: CrossAxisAlignment.center, children: [ Expanded( child: Container( height: 66, width: 66, decoration: BoxDecoration( borderRadius: BorderRadius.circular(33), ), child: Placeholder(), ), ), Container( width: 44, height: double.infinity, child: Opacity( opacity: 1 - opa, child: Center( child: myDeviceStatus, ), ), ) ], ), ); List actions = [ Opacity( opacity: opa, child: MaterialButton( child: Container( color: Colors.white.withOpacity(0), alignment: Alignment.center, padding: EdgeInsets.all(20), child: Icon(Icons.delete, color: Colors.red), ), onTap: widget.onDelete, ), ), Opacity( opacity: opa, child: MaterialButton( child: Container( color: Colors.white.withOpacity(0), alignment: Alignment.center, padding: EdgeInsets.all(20), child: Icon(Icons.edit, color: Colors.blue), ), onTap: widget.onDelete, ), ), ]; body = LeftScroll( child: body, buttonWidth: 70, buttons: actions, onTap: widget.onTap, onScroll: (a) { opa = a; setState(() {}); print(a); }, onSlideStarted: () { // opa = 0; setState(() {}); }, onSlideCompleted: () { opa = 1; setState(() {}); }, onSlideCanceled: () { opa = 0; setState(() {}); }, ); return body; } }
还可以,这个思路和UI效果都是可以接受的
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/105984.html
摘要:而在中,我们可以将看做是,但它与并不是完全等价的。中包含有状态和无状态,分别用和表示。在中,由于是不可变的,没有与等价的功能函数。在中,要是先透明需要使用透明的包装一下才能实现。近似于中的,的工作机制和中的一致。文章概述 本人之前主要从事iOS开发工作,刚好Flutter文档中有一篇Flutter for iOS developers的文档,之前两篇文章,我们大致上体验了Flutter,这篇...
阅读 1580·2021-10-14 09:42
阅读 3826·2021-09-07 09:59
阅读 1305·2019-08-30 15:55
阅读 581·2019-08-30 11:17
阅读 3345·2019-08-29 16:06
阅读 511·2019-08-29 14:06
阅读 3133·2019-08-28 18:14
阅读 3655·2019-08-26 13:55