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

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

    正常情况下使用 :

    1. InkWell(
    2. //单击事件响应
    3. onTap: () {
    4. },
    5. child: Container(
    6. alignment: Alignment(0, 0),
    7. height: 28,
    8. width: 120,
    9. child: Text("InkWell单击事件"),
    10. ),
    11. ),

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

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

    InkWell实现水波纹点击效果 - 图1

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

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

    1. new Center(
    2. child: new Material(
    3. //INK可以实现装饰容器,实现矩形 设置背景色
    4. child: new Ink(
    5. //设置背景 默认矩形
    6. color: Colors.purple,
    7. child: new InkWell(
    8. //点击事件回调
    9. onTap: () {},
    10. child: new Container(
    11. width: 300.0,
    12. height: 50.0,
    13. //设置child 居中
    14. alignment: Alignment(0, 0),
    15. child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),
    16. ),
    17. ),
    18. ),
    19. ),
    20. ),

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

    InkWell实现水波纹点击效果 - 图2

    1. new Center(
    2. child: new Material(
    3. //INK可以实现装饰容器
    4. child: new Ink(
    5. //用ink圆角矩形
    6. // color: Colors.red,
    7. decoration: new BoxDecoration(
    8. //不能同时”使用Ink的变量color属性以及decoration属性,两个只能存在一个
    9. color: Colors.purple,
    10. //设置圆角
    11. borderRadius: new BorderRadius.all(new Radius.circular(25.0)),
    12. ),
    13. child: new InkWell(
    14. //圆角设置,给水波纹也设置同样的圆角
    15. //如果这里不设置就会出现矩形的水波纹效果
    16. borderRadius: new BorderRadius.circular(25.0),
    17. //设置点击事件回调
    18. onTap: () {
    19. },
    20. child: new Container(
    21. width: 300.0,
    22. height: 50.0,
    23. //设置child 居中
    24. alignment: Alignment(0, 0),
    25. child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),
    26. ),
    27. ),
    28. ),
    29. ),
    30. ),

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

    InkWell实现水波纹点击效果 - 图3

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

    InkWell实现水波纹点击效果 - 图4

    1. new Center(
    2. child: new Material(
    3. child: new Ink(
    4. //设置背景
    5. decoration: new BoxDecoration(
    6. color: Colors.purple,
    7. borderRadius: new BorderRadius.all(new Radius.circular(25.0)),
    8. ),
    9. child: new InkResponse(
    10. borderRadius: new BorderRadius.all(new Radius.circular(25.0)),
    11. //点击或者toch控件高亮时显示的控件在控件上层,水波纹下层
    12. //highlightColor: Colors.yellowAccent,
    13. //点击或者toch控件高亮的shape形状
    14. highlightShape: BoxShape.rectangle,
    15. //.InkResponse内部的radius这个需要注意的是,我们需要半径大于控件的宽,如果radius过小,显示的水波纹就是一个很小的圆,
    16. //水波纹的半径
    17. radius: 300.0,
    18. //水波纹的颜色
    19. splashColor: Colors.black,
    20. //true表示要剪裁水波纹响应的界面 false不剪裁 如果控件是圆角不剪裁的话水波纹是矩形
    21. containedInkWell: true,
    22. //点击事件
    23. onTap: () {
    24. print("click");
    25. },
    26. child: new Container(
    27. //不能在InkResponse的child容器内部设置装饰器颜色,否则会遮盖住水波纹颜色的,containedInkWell设置为false就能看到是否是遮盖了。
    28. width: 300.0,
    29. height: 50.0,
    30. //设置child 居中
    31. alignment: Alignment(0, 0),
    32. child: Text("登录",style: TextStyle(color: Colors.white,fontSize: 16.0),),
    33. ),
    34. ),
    35. ),
    36. ),
    37. ),

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

    InkWell实现水波纹点击效果 - 图5

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