Switch-开关组件

Switch

Switch为material风格的开关组件,基本用法如下:

var _switchValue = false;
_buildSwitch(){
  return Switch(
    value: _switchValue,
    onChanged: (value){
      setState(() {
        _switchValue = value;
      });
    },
  );
}

效果如下:

image

设置激活状态下thumb及track颜色,用法如下:

Switch(
      activeColor: Colors.red,
      activeTrackColor: Colors.blue,
      ...
    )

效果如下:

image

注意红色区域为thumb,蓝色区域为track。

thumb区域也可以设置图片,用法如下:

Switch(
  activeThumbImage: AssetImage('images/bird.png',),
  ...
)

效果如下:

image

有激活状态样式的设置,也有未激活样式的设置,用法如下:

Switch(
  inactiveThumbColor: Colors.black54,
  inactiveThumbImage: AssetImage('images/bird.png',),
  inactiveTrackColor: Colors.blue,
  ...
)

#SwitchListTile

SwitchListTile是Switch和ListTile组合控件,基本用法如下:

var _switchValue = false;
_buildSwitch(){
  return SwitchListTile(
    title:Text('是否允许4G下载'),
    value: _switchValue,
    onChanged: (value){
      setState(() {
        _switchValue = value;
      });
    },
  );
}

效果如下:

image

所有的属性都是Switch和ListTile属性的组合,可到具体控件查看其属性。

#CupertinoSwitch

CupertinoSwitch是ios风格控件,用法和Switch一样,用法如下:

var _switchValue = false;
_buildSwitch(){
  return CupertinoSwitch(
    value: _switchValue,
    onChanged: (value){
      setState(() {
        _switchValue = value;
      });
    },
  );
}

效果如下:

image

代码:



import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';

/**
 * Switch 开关组件
 */
class SwitchDemo extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return SwitchDemoState();
  }

}


class SwitchDemoState extends State<SwitchDemo> {

  // true 表示关  false 表示开
  var _switchValue = true;

  @override
  Widget build(BuildContext context) {
    return Center(
      child: Column(
        children: [
          Switch(
            value: _switchValue, 
            activeColor: Colors.red, // 激活状态下的颜色
            activeTrackColor: Colors.blue, // 激活状态下的颜色
            onChanged: (value) {
              setState(() {
                _switchValue = value;
              });
            }
          ),
          SwitchListTile(
            title: Text("是否打开"),
            value: _switchValue,
            onChanged: (value) {
              setState(() {
                _switchValue = value;
              });
            },
          ),
          CupertinoSwitch(
            value: _switchValue, 
            onChanged: (value) {
              setState(() {
                _switchValue = value;
              });
            }
          )
        ],
      ),
    );
  }

}
截屏2021-01-10 下午1.25.41.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容