Skip to content

Latest commit

 

History

History
176 lines (148 loc) · 5.67 KB

README.md

File metadata and controls

176 lines (148 loc) · 5.67 KB

cool_ui pub package

用flutter实现一些我认为好看的UI控件
希望大家提一些觉得不错的控件,我自己一个人想有时候想到的比较有限

Usage Add this to your package's pubspec.yaml file:

dependencies:
  cool_ui: "^0.1.5"

控件

CupertinoPopoverButton

仿iOS的UIPopover效果的

用于弹窗的按钮

CupertinoPopoverButton({
    this.child,
    this.popoverBuild,
    this.popoverColor=Colors.white,
    @required this.popoverWidth,
    @required this.popoverHeight,
    BoxConstraints popoverConstraints,
    this.onTap,
    this.transitionDuration=const Duration(milliseconds: 200),
    this.radius=8.0});
Param Type Default Description
child Widget 按钮的内容
popoverBuild WidgetBuilder 生成弹出框的内容
[popoverWidth] double 弹出框的宽度
[popoverHeight] double 弹出框的高度
[popoverConstraints] BoxConstraints maxHeight:123.0 maxWidth:150.0 弹出框的最大最小高宽
[onTap] BoolCallback 按钮点击事件,返回true取消默认反应(不打开Popover)
[popoverColor] Color 白色 弹出框的背景颜色
[transitionDuration] Duration 0.2s 过度动画时间
[radius] double 8.0 弹出框的圆角弧度

Example

CupertinoPopoverButton(
        child: Container(
          margin: EdgeInsets.all(20.0),
          width: 80.0,
          height: 40.0,
          decoration: BoxDecoration(
              color: Colors.white,
              borderRadius: BorderRadius.all(Radius.circular(5.0)),
              boxShadow: [BoxShadow(color: Colors.black12,blurRadius: 5.0)]
          ),
          child: Center(child:Text('左上角')),
        ),
        popoverBuild:(BuildContext context){
              return  Container(
                          width: 100.0,
                          height: 100.0,
                          child: Text('左上角内容'),
                        )
        });

Image text

CupertinoPopoverMenuList

Popover弹出的菜单样式列表,一般与CupertinoPopoverMenuItem一起用,会给两个Item加间隔线

CupertinoPopoverMenuList({this.children})
Param Type Description
children List 子元素,一般是CupertinoPopoverMenuItem

CupertinoPopoverMenuItem

单个菜单项

const CupertinoPopoverMenuItem({
    this.leading,
    this.child,
    this.onTap,
    this.isTapClosePopover=true
  });
Param Type Description
[leading] Widget 菜单左边,一般放图标
[child] Widget 菜单内容
[onTap] BoolCallback
[isTapClosePopover] bool 是否点击关闭

案例核心代码

    CupertinoPopoverMenuList(
                    children: <Widget>[
                      CupertinoPopoverMenuItem(leading: Icon(Icons.add),child: Text("新增"),),
                      CupertinoPopoverMenuItem(leading: Icon(Icons.edit),child: Text("修改"),),
                      CupertinoPopoverMenuItem(leading: Icon(Icons.delete),child: Text("删除"),)
                    ],
                  )

showWeuiToast

仿Weui的Toast效果

VoidCallback showWeuiToast({
  @required BuildContext context,
  @required Widget message,
  @required Widget icon,
  RouteTransitionsBuilder transitionBuilder})
Param Type Description
[context] BuildContext 上下文
[message] Widget 提示消息
[icon] Widget 图标
[transitionBuilder] RouteTransitionsBuilder 自定义过度动画

返回参数:VoidCallback,用于关闭Toast

Image text

showWeuiSuccessToast

仿Weui的SuccessToast效果

Future showWeuiSuccessToast({
  @required BuildContext context,
  @required Widget message=const Text("成功"),
  RouteTransitionsBuilder transitionBuilder,
  Duration closeDuration = const Duration(seconds: 3)
  })
Param Type Default Description
[context] BuildContext 上下文
[transitionBuilder] RouteTransitionsBuilder 自定义过度动画
[message] Widget 成功 提示消息
[closeDuration] Duration 3s 关闭时间

返回参数:Future dart 异步操作,代表Toast已关闭

showWeuiLoadingToast

仿Weui的LoadingToast效果

VoidCallback showWeuiToast({
  @required BuildContext context,
  @required Widget message,
  RouteTransitionsBuilder transitionBuilder
  })
Param Type Description
[context] BuildContext 上下文
[message] Widget 提示消息
[transitionBuilder] RouteTransitionsBuilder 自定义过度动画

返回参数:VoidCallback,用于关闭Toast