flutter InkWell实现水波纹点击效果

 更新时间:2020年08月26日 11:30:22   作者:早起的年轻人  
这篇文章主要为大家详细介绍了flutter InkWell实现水波纹点击效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

在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 设置自定义水波纹颜色点击效果

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),),
  ),
  ),
  ),
  ),
 ),

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android 超简易Zxing框架 生成二维码+扫码功能

    Android 超简易Zxing框架 生成二维码+扫码功能

    这篇文章主要介绍了Android 超简易Zxing框架 生成二维码+扫码功能,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • Android带气泡的第三方Tab选项卡

    Android带气泡的第三方Tab选项卡

    这篇文章主要介绍了Android带气泡的第三方Tab选项卡的实例代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-02-02
  • Android继承ViewGroup实现Scroll滑动效果的方法示例

    Android继承ViewGroup实现Scroll滑动效果的方法示例

    这篇文章主要介绍了Android继承ViewGroup实现Scroll滑动效果的方法,结合实例形式分析了Android滑动效果的原理及扩展ViewGroup实现滑动功能的相关操作技巧,需要的朋友可以参考下
    2017-08-08
  • 利用Kotlin实现破解Android版的微信小游戏--跳一跳

    利用Kotlin实现破解Android版的微信小游戏--跳一跳

    这篇文章主要给大家介绍了关于利用Kotlin实现破解Android版微信小游戏--跳一跳的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-12-12
  • Android 详解ThreadLocal及InheritableThreadLocal

    Android 详解ThreadLocal及InheritableThreadLocal

    这篇文章主要介绍了Android 详解ThreadLocal及InheritableThreadLocal的相关资料,需要的朋友可以参考下
    2017-01-01
  • Android开发入门环境快速搭建实战教程

    Android开发入门环境快速搭建实战教程

    最近想重新学习下Android,学习之前开发环境的搭建是个首先要解决的问题,所以下面这篇文章主要给大家介绍了Android开发环境搭建的相关资料,文中将实现的步骤一步步介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧。
    2017-11-11
  • Android 使用 RxJava2 实现倒计时功能的示例代码

    Android 使用 RxJava2 实现倒计时功能的示例代码

    本篇文章主要介绍了Android 使用 RxJava2 实现倒计时功能的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-03-03
  • Android  Wifi的forget()操作实例详解

    Android Wifi的forget()操作实例详解

    这篇文章主要介绍了Android Wifi的forget()操作实例详解的相关资料,需要的朋友可以参考下
    2017-02-02
  • Android编程开发之性能优化技巧总结

    Android编程开发之性能优化技巧总结

    这篇文章主要介绍了Android编程开发之性能优化技巧,较为详细的总结了Android编程中关于性能优化的常用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • Android中Splash应用启动白屏问题的解决方法

    Android中Splash应用启动白屏问题的解决方法

    这篇文章主要为大家详细介绍了Android中Splash应用启动白屏问题的两种解决方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02

最新评论