Flutter入门进阶之旅(八)Button Widget

引言

上一篇博文中咱们学习了GestureDetector,了解到借助GestureDetector能够赋予某些自己不具有点击回调的widget点击回调能力,完成跟用户的一些简单手势交互并做出相应的逻辑处理,咱们还提到了有些widget像RaisedButton和FloatingActionButton控件自己就有onPressed回调,当用户点击控件时触发回调。本篇博客中咱们就把上篇博客中说起到的各类Button归类统一说明一下。java

Button集合效果图 app

在这里插入图片描述

上述RaisedButton、FlatButton、OutlineButton、MaterialButton、还有RawMaterialButton、FloationgActionButton,我分三类给你们讲解,OutlineButton做为一类,RaisedButton、FlatButton、MaterialButton、RawMaterialButton不管是从构造方法仍是使用上都很类似,这几个button分为一类,另外FloatingActionButton做为一类。less

1.OutlineButton:

OutlineButton默认带有一个边框,咱们能够经过属性指定正常状态,跟用户点击状态下的边框颜色。 ide

在这里插入图片描述

咱们来看下OutlineButton的构造方法,而且对它的相应属性作下使用说明。学习

const OutlineButton({ Key key, @required VoidCallback onPressed, ButtonTextTheme textTheme, //按钮上字体主题 Color textColor, //字体颜色 Color disabledTextColor, //按钮禁用时候文字的颜色 Color color, //按钮背景颜色 Color highlightColor,//点击或者toch控件高亮的时候显示在控件上面,水波纹下面的颜色 Color splashColor, //水波纹的颜色 double highlightElevation,//高亮时候的阴影 this.borderSide,//按钮边框 this.disabledBorderColor, //按钮禁用时边框的颜色 this.highlightedBorderColor,//高亮时边框的颜色 EdgeInsetsGeometry padding,//边距 ShapeBorder shape, //设置shape Clip clipBehavior = Clip.none, Widget child, }) 复制代码

上述OutlineButton效果图上两个button的具体代码:测试

未指定任何样式:字体

new OutlineButton(onPressed: () {}, child: new Text("OutlineButton")),
复制代码

效果图ui

在这里插入图片描述

设置边框样式this

new OutlineButton(
           textColor: Colors.blue,
           highlightedBorderColor: Colors.deepOrange,
           shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(20.0)),
           borderSide: new BorderSide(color: Colors.blueAccent),
           onPressed: () {},
           child: new Text("OutlineButton")
         ),
复制代码

效果图 spa

在这里插入图片描述

2.FloatingActionButton

FloatingActionButton作过原生安卓开发的读者应该很熟悉这个名字,在Flutter中不光引用了原生安卓的叫法,使用方法也大同小异。 构造方法

const FloatingActionButton({ Key key, this.child, this.tooltip, this.foregroundColor, this.backgroundColor, this.heroTag = const _DefaultHeroTag(), this.elevation = 6.0,
    this.highlightElevation = 12.0,
    @required this.onPressed,
    this.mini = false,
    this.shape = const CircleBorder(), this.clipBehavior = Clip.none,
    this.materialTapTargetSize,
    this.isExtended = false,
  })
复制代码

因为使用方法跟原生安卓中相似,我就不展开详细讲解了,稍后我会把篇首效果图上的全部代码贴上,你们可参考里面对floatingactionbutton的用法。

3.RaisedButton、FlatButton、OutlineButton、MaterialButton

这几类button十分相似,因此我把他们归为一类作讲解,可是也会有细微的差异,像FlatButton不支持设置手指点击抬起后的颜色,其余常规用法几乎一致,关于具体的细微差异,读者可自行对比构造方法,自行测试,我拿RaisedButton把代码,贴上代码,为你们演示下这几类Button的经常使用属性配置说明。

new RaisedButton(
            color: Colors.blueAccent,
            //按钮的背景颜色
            padding: EdgeInsets.all(15.0),
            //按钮距离里面内容的内边距
            textColor: Colors.white,
            //文字的颜色
            textTheme: ButtonTextTheme.normal,
            //按钮的主题
            onHighlightChanged: (bool b) {
              //水波纹高亮变化回调
            },
            disabledTextColor: Colors.black54,
            //按钮禁用时候文字的颜色
            disabledColor: Colors.black54,
            //按钮被禁用的时候显示的颜色
            highlightColor: Colors.green,
            //点击或者toch控件高亮的时候显示在控件上面,水波纹下面的颜色
            splashColor: Colors.amberAccent,
            //水波纹的颜色
            colorBrightness: Brightness.light,
            //按钮主题高亮
            elevation: 10.0,
            //按钮下面的阴影
            highlightElevation: 10.0,
            //高亮时候的阴影
            disabledElevation: 10.0,
            //按下的时候的阴影
            shape: new RoundedRectangleBorder(
                borderRadius: BorderRadius.circular(20.0)),
            //设置形状
            onPressed: () {},
            child: new Text("RaisedButton"),
          ),
复制代码

上述讲解中读者若是有不明白的地方能够参考文章开篇中贴出的各类button的效果图源码作参考,或者留言给我一块探讨,文章开篇中贴出的各类button的效果图源码以下。

import 'package:flutter/material.dart';


void main() {
  runApp(new MaterialApp(home: new ButtonPage()));
}
class ButtonPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return new Scaffold(
      appBar: new AppBar(
        title: new Text("Button Widget"),
      ),
      floatingActionButton: new FloatingActionButton(
          onPressed: () {}, child: new Icon(Icons.adb), tooltip: "点击"),
      body: new ListView(
        children: <Widget>[
          new Text("简单样式",
              textAlign: TextAlign.center,
              style: new TextStyle(color: Colors.brown, fontSize: 20.0)),
          new RaisedButton(onPressed: () {}, child: new Text("RaisedButton")),
          new FlatButton(onPressed: () {}, child: new Text("FlatButton")),
          new MaterialButton(
              onPressed: () {}, child: new Text("MaterialButton")),
          new RawMaterialButton(
              onPressed: () {}, child: new Text("RawMaterialButton")),
          new OutlineButton(onPressed: () {}, child: new Text("OutlineButton")),
          new SizedBox(height: 20),
          new Text("升级样式",
              textAlign: TextAlign.center,
              style: new TextStyle(color: Colors.brown, fontSize: 20.0)),
          new RaisedButton(
            color: Colors.blueAccent,
            //按钮的背景颜色
            padding: EdgeInsets.all(15.0),
            //按钮距离里面内容的内边距
            textColor: Colors.white,
            //文字的颜色
            textTheme: ButtonTextTheme.normal,
            //按钮的主题
            onHighlightChanged: (bool b) {
              //水波纹高亮变化回调
            },
            disabledTextColor: Colors.black54,
            //按钮禁用时候文字的颜色
            disabledColor: Colors.black54,
            //按钮被禁用的时候显示的颜色
            highlightColor: Colors.green,
            //点击或者toch控件高亮的时候显示在控件上面,水波纹下面的颜色
            splashColor: Colors.amberAccent,
            //水波纹的颜色
            colorBrightness: Brightness.light,
            //按钮主题高亮
            elevation: 10.0,
            //按钮下面的阴影
            highlightElevation: 10.0,
            //高亮时候的阴影
            disabledElevation: 10.0,
            //按下的时候的阴影
            shape: new RoundedRectangleBorder(
                borderRadius: BorderRadius.circular(20.0)),
            //设置形状
            onPressed: () {},
            child: new Text("RaisedButton"),
          ),
          new FlatButton(
              color: Colors.lightGreen,
              textColor: Colors.red,
              onPressed: () {}, child: new Text("FlatButton")),
          new OutlineButton(
              textColor: Colors.blue,
              highlightedBorderColor: Colors.deepOrange,
              shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(20.0)),
              borderSide: new BorderSide(color: Colors.blueAccent),
              onPressed: () {},
              child: new Text("OutlineButton")
          ),
          MaterialButton(
              color: Colors.yellow,
              textColor: Colors.red,
              onPressed: () {},
              child: new Text("MaterialButton")
          ),
          RawMaterialButton(
              fillColor: Colors.deepOrange,
              onPressed: () {},
              child: new Text("RawMaterialButton",style: new TextStyle(color: Colors.white),)
          )
        ],
      ),
    );
  }
}
复制代码
相关文章
相关标签/搜索