cool_ui 0.1.6 copy "cool_ui: ^0.1.6" to clipboard
cool_ui: ^0.1.6 copied to clipboard

outdated

用flutter实现一些我认为好看的UI控件,目前暂时只有Popover,Weui,不过有什么觉得好看的可以提Issue

cool_ui pub package #

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

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

dependencies:
  cool_ui: "^0.1.6"

控件 #

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('左上角内容'),
                        )
        });

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 | | 按钮点击事件,返回true取消默认反应(不关闭Popover) | | [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,
  Alignment alignment = const Alignment(0.0,-0.2),
  RouteTransitionsBuilder transitionBuilder})
Param Type Default Description
[context] BuildContext 上下文
[message] Widget 提示消息
[alignment] Alignment 默认是居中偏上 Toast的位置
[icon] Widget 图标
[transitionBuilder] RouteTransitionsBuilder 自定义过度动画

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

showWeuiSuccessToast #

仿Weui的SuccessToast效果

Future showWeuiSuccessToast({
  @required BuildContext context,
  @required Widget message=const Text("成功"),
  Alignment alignment = const Alignment(0.0,-0.2),
  RouteTransitionsBuilder transitionBuilder,
  Duration closeDuration = const Duration(seconds: 3)
  })
Param Type Default Description
[context] BuildContext 上下文
[transitionBuilder] RouteTransitionsBuilder 自定义过度动画
[alignment] Alignment 默认是居中偏上 Toast的位置
[message] Widget 成功 提示消息
[closeDuration] Duration 3s 关闭时间

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

showWeuiLoadingToast #

仿Weui的LoadingToast效果

VoidCallback showWeuiToast({
  @required BuildContext context,
  @required Widget message,
  Alignment alignment = const Alignment(0.0,-0.2),
  RouteTransitionsBuilder transitionBuilder
  })
Param Type Default Description
[context] BuildContext 上下文
[message] Widget 提示消息
[alignment] Alignment 默认是居中偏上 Toast的位置
[transitionBuilder] RouteTransitionsBuilder 自定义过度动画

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

24
likes
0
pub points
87%
popularity

Publisher

unverified uploader

用flutter实现一些我认为好看的UI控件,目前暂时只有Popover,Weui,不过有什么觉得好看的可以提Issue

Repository (GitHub)
View/report issues

License

unknown (LICENSE)

Dependencies

flustars, flutter

More

Packages that depend on cool_ui