flutter笔记(六)-----按钮 各种Button

flutter笔记汇总

flutter提供了以下几种按钮
RaisedButton 、OutlineButton 、FlatButton 、IconButton 、FloatingActionButton 、MaterialButton
其中IconButtonflutter笔记(五)-----图标Icon里已经说过了,这里就不重复了。
接下来挨个看一下。

1、MaterialButton

悬浮按钮自带灰色背景和灰色阴影,按下时阴影变大。
首先还是看一下constructor

const MaterialButton({
  Key key,
  @required VoidCallback onPressed,              //点击按钮的回调函数
  ValueChanged<bool> onHighlightChanged,         //高亮变化的回调
  ButtonTextTheme textTheme,                     //按钮的字体主题
  Color textColor,                               //字体颜色
  Color disabledTextColor,                      //禁用时的字体颜色
  Color color,                                  //按钮背景色
  Color disabledColor,                          //禁用时的背景色
  Color focusColor,                              //联动节点获得焦点时的颜色
  Color hoverColor,                              //鼠标悬停时的颜色
  Color highlightColor,                          //按下背景颜色(长按,不是点击)
  Color splashColor,                            //水波纹颜色
  Brightness colorBrightness,                   //按钮亮度
  double elevation,                              //阴影尺寸
  double focusElevation,                        //联动节点获得焦点时的阴影尺寸
  double hoverElevation,                        //鼠标悬停时阴影尺寸
  double highlightElevation,                    //长按阴影尺寸
  double disabledElevation,                    //禁用时的阴影尺寸
  EdgeInsetsGeometry padding,                  //内边距
  ShapeBorder shape,                            //按钮的形状
  Clip clipBehavior: Clip.none,                //裁剪
  FocusNode focusNode,                         //联动节点
  MaterialTapTargetSize materialTapTargetSize,  //有效的点击区域大小
  Duration animationDuration,                  //动画时间  
  double minWidth,                              //最小宽
  double hight,                                //高度
  Widget child                                  //子节点
})

下面看demo

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      home: Scaffold(
        body: new Container(
          alignment: Alignment.center,
          child: new MaterialButton(
            child: new Text('Button'),
            textTheme: ButtonTextTheme.primary,
            textColor: Colors.red,
            highlightColor: Colors.yellow,
            color: Colors.green,
            splashColor: Colors.purple,
            elevation: 10.0,
            highlightElevation: 20.0,
            padding: EdgeInsets.all(20.0),
            onHighlightChanged: (data) {
              print(data);
            },
            onPressed: () {
              print(1);
            },
          )
        )
      )
    );
  }
}

一个花里胡哨的按钮,下面挨个属性看一下,看效果的话不要像上边一样同时写太多,建议每次只写一个。

onPressed

这个没啥说的,按钮的回调,手指抬起时触发,点击或者长按都会触发。
********特别提醒,值为null的时候,按钮为禁用状态。

onHighlightChanged

onPressed不同,这个按下按钮和松开按钮都会触发,有一个参数,按下为true,松开为false。

textTheme

有三个值
normal:没看出来有啥效果。
primary:没看出来有啥效果+1。
accent:字体变成了主题同一颜色。

textColor

字体颜色,如果Textstyle设置了color,则显示为Text设置的值。

color

背景色

focusColor& focusElevation& focusNode

还没试,看文档的意思是需要一个联动元素,比如输入框,获得焦点的时候按钮改变状态。

disabledTextColor& disabledTextColor& disabledElevation

禁用时按钮的状态,不挨个说了,和非禁用状态写法一样。
按钮是否禁用,没有单独的属性,看onPressed,如果为null,或者不写onPressed则为禁用。

hoverColor

推测是桌面端和web端用的,移动端不知道怎么触发hover。

highlightColor

按钮按下的背景色,不是点击是长按。

splashColor

水波纹的颜色,这个是点击

colorBrightness

亮度
有两个值
Brightness.light:默认的状态,文字黑色,splashColor&highlightColor都是灰色。
Brightness.dark:文字白色,splashColor&highlightColor变亮了???
你没看错,是不是写反了,这是个bug?
这不是个bug,这里的colorBrightness是整个主题的亮度,当app主题亮度为Brightness.light的时候,在这里也设成light,按钮会变暗;相反如果主题亮度为Brightness.dark,这里也设成dark,按钮会变亮。
这是个坑。。。从字面意思来看,谁能看出来这是主题亮度。

elevation& highlightElevation

double类型,阴影和按下按钮状态下的阴影尺寸。

padding

这个之前介绍过,就不重复了。

shape

基于ShapeBorder的类有四个,下面看一下这四个类。

//圆形
const CircleBorder({
  BorderSide side: BorderSide.none
})
//斜角(了解过机械的话可以理解成倒角)
const BeveledRectangleBorder({
  BorderSide side: BorderSide.none,
  BorderRadiusGeometry borderRadius: BorderRadius.zero
})
//圆角
const RoundedRectangleBorder({
  BorderSide side: BorderSide.none,
  BorderRadiusGeometry borderRadius: BorderRadius.zero
})
//也是圆角,但是和RoundedRectangleBorder不同,有最大值,超过最大值以最大值显示。
const ContinuousRectangleBorder({
  BorderSide side: BorderSide.none,
  BorderRadiusGeometry borderRadius: BorderRadius.zero
})

可以看见,除了CircleBorder其他三个都是一样的,为啥这个特殊,少了个属性?
因为CircleBorder是设置按钮为圆形,borderRadius是圆角,根本不需要。。。
下面看一下怎么用:
borderRadius之前的笔记介绍过flutter笔记(三)-----容器组件Container,这里就不重复了,看一下demo。

new RaisedButton(
  child: new Text('button'),
  color: Colors.grey[200],
  shape: ContinuousRectangleBorder(
    borderRadius: BorderRadius.circular(10.0),
   ),
   onPressed: () {
     print(1);
  },
)

这样就给按钮加了圆角。
下面看一下BorderSide

const BorderSide({
  Color color: const Color(0xFF000000),
  double width: 1.0,
  BorderStyle style: BorderStyle.solid
})

这个就比较简单了,之前的也都介绍过这几个属性。

clipBehavior

裁剪,有四个值antiAlias、antiAliasWithSaveLayer 、hardEdge、none,都是对边缘的处理,看文档说antiAlias处理速度要比antiAliasWithSaveLayer快,但是要比hardEdge慢,还没整明白怎么用,以后补充。

materialTapTargetSize

padded:有效点击区域最小为48px * 48px
shrinkWrap:可点击组件的大小。

animationDuration

设置shapeelevation的动画时间,看一下怎么用。

new MaterialButton(
  child: new Text('button'),
  color: Colors.grey[200],
  animationDuration: new Duration(seconds: 10),
  highlightElevation: 200.0,
  textTheme: ButtonTextTheme.accent,
  onPressed: () {
    print(1);
  },
)

这里为了效果明显值写的都比较大,按住按钮不要松手可以看到阴影逐渐变大。
Duration不只可以写secondsdays、hours、minutes、seconds、milliseconds、microseconds都可以。
想不出来在什么情况下一个动画会以天为时间单位。。。

minWidth&height

最小宽度和高度。

child

子节点。

2、OutlineButton

默认有一个边框,不带阴影且背景透明。按下后,边框颜色会变亮、同时出现背景和阴影(较弱)。
看一下constructor

const OutlineButton({
  Key key,
  @required VoidCallback onPressed,
  ButtonTextTheme textTheme,
  Color textColor,     
  Color disabledTextColor,    
  Color color,  
  Color focusColor,  
  Color hoverColor,   
  Color highlightColor,
  Color splashColor,  
  double highlightElevation, 
  BorderSide borderSide,
  Color disabledBorderColor,
  Color highlightedBorderColor,
  EdgeInsetsGeometry padding, 
  ShapeBorder shape, 
  Clip clipBehavior,
  FocusNode focusNode, 
  Widget child 
})

RaisedButton相同的就不说了,这里说一下RaisedButton没有的。
啥是RaisedButton没有的,自己写一下就知道了,多了个边框。。。

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      home: Scaffold(
        body: new Container(
          alignment: Alignment.center,
          child: new OutlineButton(
            child: new Text('Button'),
            borderSide: BorderSide(color: Colors.red, width: 4.0, style: BorderStyle.solid),
//            disabledBorderColor: Colors.blue,
            onPressed: () {
              print(1);
            }
          )
        )
      )
    );
  }
}

disabledBorderColor

禁用时边框颜色,默认为灰色。

borderSide

边框样式,colorwidth没啥说的,一个颜色一个宽度,style要说一下,这个只有solidnone,也就是说只有实线边框和没有边框。

另外这个按钮和MaterialButton相比少了几个属性,对比看吧这里就不列出来了。

3、RaisedButton

MaterialButton默认样式不同,默认带有阴影和灰色背景。按下后,阴影会变大没有heightminWidth

4、FlatButton

扁平按钮,默认背景透明并不带阴影。按下后,会有背景色。
MaterialButton相比少了以下属性:elevation、focusElevation 、hoverElevation 、highlightElevation 、disabledElevation 、animationDuration 、minWidth 、height

5、FloatingActionButton

页面的悬浮按钮。
看一下constructor

const FloatingActionButton({
  Key key,
  Widget child,
  String tooltip,
  Color foregroundColor,          //前景色,不会覆盖文字,加了之后改变了文字的颜色
  Color backgroundColor,        //背景色
  Color focusColor,
  Color hoverColor,
  Object heroTag: const _DefaultHeroTag(),      //动画效果
  double elevation,
  double focusElevation, 
  double hoverElevation, 
  double highlightElevation,  
  double disabledElevation,   
  @required VoidCallback onPressed,
  bool mini: false,                    //为true时按钮尺寸会变小
  ShapeBorder shape,
  Clip clipBehavior: Clip.none,
  FocusNode focusNode, 
  MaterialTapTargetSize materialTapTargetSize,
  bool isExtended: false              //是否扩展
})

什么前景色背景色就不说了,说一下没见过的。

heroTag

设置为null,则不启用过渡动画,如果悬浮按钮在两个页面内的位置不同,页面切换时动作生硬。不设置的话为默认值,平滑过渡。

mini

true时为按钮会缩小,但是要注意的是,这个缩小只是尺寸缩小,不是整体缩放,内容大小还是需要手动设置。

isExtended

是否扩展,默认为false。
不知道怎么用,但是发现个特性。

FloatingActionButton写在Container里,同时Container不写alignment,并且Container设有widthheight
false:按钮会尽量放大到宽高为width&height之中小的那个尺寸,并保持圆形。
true:按钮宽高会变成Container的宽高,不会保持圆形,但是有圆角。
为啥要说写在Container里,因为这货就不是用在Container里的。。。
怎么用往下看

import 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return new MaterialApp(
      home: Scaffold(
        floatingActionButton: FloatingActionButton(
          onPressed: () {
             print(1);
          },
          child: Icon(Icons.add)
        ),
      )
    );
  }
}

这才是常规用法,默认悬浮在右下角,不影响布局。
你说不想放右下角?可以,放哪都行,但是我不打算在这写,因为这个位置不是在按钮这设置的。

如有错误欢迎指出,很多不足欢迎补充。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,458评论 4 363
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,454评论 1 294
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,171评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,062评论 0 207
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,440评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,661评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,906评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,609评论 0 200
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,379评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,600评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,085评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,409评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,072评论 3 237
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,088评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,860评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,704评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,608评论 2 270