博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Flutter UI基础 - 使用InkWell给任意Widget添加点击事件
阅读量:4049 次
发布时间:2019-05-25

本文共 5698 字,大约阅读时间需要 18 分钟。

在flutter 开发中用InkWell或者GestureDetector将某个组件包起来,可添加点击事件。

GestureDetector 使用点击无水波纹出现,InkWell可以实现水波纹效果。

正常情况下使用 :

InkWell(  //单击事件响应  onTap: () {  },  child: Container(      alignment: Alignment(0, 0),      height: 28,      width: 120,      child: Text("InkWell单击事件"),  ),),

如果在InkWell的上下都出现的颜色的设置,如上中的Container中如果加入了color:Colors.white,或者是Container中的其他widget设置了coloro属性,这时候InkWell的水波纹效果会无效。

1 widget 设置水波纹点击效果 并设置widget背景

在这里插入图片描述

new Center(          child: new Material(            // 设置背景颜色 默认矩形            color: Colors.purple,            child: new InkWell(              //点击事件回调              onTap: () {},              //不要在这里设置背景色,for则会遮挡水波纹效果,如果设置的话尽量设置Material下面的color来实现背景色              child: new Container(                width: 300.0,                height: 50.0,                //设置child 居中                alignment: Alignment(0, 0),                child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),              ),            ),          ),        ),

或者 可以使用 Ink来设置,与Material设置color 的区别是,Ink可设置背景的形状样式。

new Center(          child: new Material(            //INK可以实现装饰容器,实现矩形  设置背景色            child: new Ink(              //设置背景  默认矩形              color: Colors.purple,              child: new InkWell(                //点击事件回调                onTap: () {},                child: new Container(                  width: 300.0,                  height: 50.0,                  //设置child 居中                  alignment: Alignment(0, 0),                  child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),                ),              ),            ),          ),        ),

2 圆角widget 设置水波纹点击效果

在这里插入图片描述

new Center(          child: new Material(            //INK可以实现装饰容器            child: new Ink(              //用ink圆角矩形            // color: Colors.red,              decoration: new BoxDecoration(               //不能同时”使用Ink的变量color属性以及decoration属性,两个只能存在一个                color: Colors.purple,                //设置圆角                borderRadius: new BorderRadius.all(new Radius.circular(25.0)),              ),              child: new InkWell(                //圆角设置,给水波纹也设置同样的圆角                //如果这里不设置就会出现矩形的水波纹效果                borderRadius: new BorderRadius.circular(25.0),                 //设置点击事件回调                onTap: () {                },                child: new Container(                  width: 300.0,                  height: 50.0,                  //设置child 居中                  alignment: Alignment(0, 0),                  child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),                ),              ),            ),          ),        ),

如果 InkWell 与Ink 不同时设置相同的圆角,例如 lnk 设置的圆角为20,而Ink没有设置,就会出现 矩形的水波纹点击效果

在这里插入图片描述

3 圆角widget 设置自定义水波纹颜色点击效果

在这里插入图片描述

InkResponse组件也可实现InkWell组件相同的功能,因为InkWell继承于InkResponse,相比之下,InkResponse可以选择控制水波纹以及高亮底色的形状和剪裁效果。基本使用代码如下:

new Center(          child: new Material(            child: new Ink(              //设置背景              decoration: new BoxDecoration(                color: Colors.purple,                borderRadius: new BorderRadius.all(new Radius.circular(25.0)),              ),              child: new InkResponse(                borderRadius: new BorderRadius.all(new Radius.circular(25.0)),                //点击或者toch控件高亮时显示的控件在控件上层,水波纹下层                //highlightColor: Colors.yellowAccent,                //点击或者toch控件高亮的shape形状                highlightShape: BoxShape.rectangle,                //.InkResponse内部的radius这个需要注意的是,我们需要半径大于控件的宽,如果radius过小,显示的水波纹就是一个很小的圆,                //水波纹的半径                radius: 300.0,                //水波纹的颜色                splashColor: Colors.black,                //true表示要剪裁水波纹响应的界面   false不剪裁  如果控件是圆角不剪裁的话水波纹是矩形                containedInkWell: true,                //点击事件                onTap: () {                  print("click");                },                child: new Container(                  //不能在InkResponse的child容器内部设置装饰器颜色,否则会遮盖住水波纹颜色的,containedInkWell设置为false就能看到是否是遮盖了。                  width: 300.0,                  height: 50.0,                  //设置child 居中                  alignment: Alignment(0, 0),                  child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),                ),              ),            ),          ),        ),

4 圆角widget 设置高亮颜色点击效果

在这里插入图片描述

new Center(          child: new Material(            child: new Ink(              //设置背景              decoration: new BoxDecoration(                color: Colors.purple,                borderRadius: new BorderRadius.all(new Radius.circular(30.0)),              ),              child: new InkResponse(                borderRadius: new BorderRadius.all(new Radius.circular(30.0)),                //点击或者toch控件高亮时显示的控件在控件上层,水波纹下层                highlightColor: Colors.purple[800],                //点击或者toch控件高亮的shape形状                highlightShape: BoxShape.rectangle,                //.InkResponse内部的radius这个需要注意的是,我们需要半径大于控件的宽,如果radius过小,显示的水波纹就是一个很小的圆,                //水波纹的半径                radius: 0.0,                //水波纹的颜色 设置了highlightColor属性后 splashColor将不起效果                splashColor: Colors.red,                //true表示要剪裁水波纹响应的界面   false不剪裁  如果控件是圆角不剪裁的话水波纹是矩形                containedInkWell: true,                onTap: () {                  print(                      'click');                },                child: new Container(                  //不能在InkResponse的child容器内部设置装饰器颜色,否则会遮盖住水波纹颜色的,containedInkWell设置为false就能看到是否是遮盖了。                  width: 300.0,                  height: 50.0,                  //设置child 居中                  alignment: Alignment(0, 0),                  child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),                ),              ),            ),          ),        ),

 

 

转载地址:http://zlnci.baihongyu.com/

你可能感兴趣的文章
测试必会之 Linux 三剑客之 sed
查看>>
Socket请求XML客户端程序
查看>>
Java中数字转大写货币(支持到千亿)
查看>>
Java.nio
查看>>
函数模版类模版和偏特化泛化的总结
查看>>
VMware Workstation Pro虚拟机不可用解决方法
查看>>
最简单的使用redis自带程序实现c程序远程访问redis服务
查看>>
redis学习总结-- 内部数据 字符串 链表 字典 跳跃表
查看>>
iOS 对象序列化与反序列化
查看>>
iOS 序列化与反序列化(runtime) 01
查看>>
iOS AFN 3.0版本前后区别 01
查看>>
iOS ASI和AFN有什么区别
查看>>
iOS QQ侧滑菜单(高仿)
查看>>
iOS 扫一扫功能开发
查看>>
iOS app之间的跳转以及传参数
查看>>
iOS __block和__weak的区别
查看>>
Android(三)数据存储之XML解析技术
查看>>
Spring JTA应用之JOTM配置
查看>>
spring JdbcTemplate 的若干问题
查看>>
Servlet和JSP的线程安全问题
查看>>