摘要:控件練習(xí)地址一。單選框中的單選框,和一樣本身沒(méi)有狀態(tài),必須父親有狀態(tài)才能改變值屬性此的值當(dāng)選擇此的時(shí)候的回調(diào)。
flutter控件練習(xí)demo地址:github
一。Radio (單選框)1.1 屬性flutter 中的單選框 , 和 Checkbox 一樣 本身沒(méi)有狀態(tài),必須父親有狀態(tài) 才能改變值
value: 此 Radio 的 value 值
onChanged: 當(dāng)選擇此 radio 的時(shí)候 的回調(diào)。 參數(shù)就是 此 value 的值
groupValue: 如果 Radio 的 value 和 groupValue 一樣 就 是此 Radio 選中 其他 設(shè)置為 不選中
activeColor: 選中的顏色
二、RadioListTile(dan) 2.1 屬性value: 此 Radio 的 value 值
onChanged: 當(dāng)選擇此 radio 的時(shí)候 的回調(diào)。 參數(shù)就是 此 value 的值
groupValue: 如果 Radio 的 value 和 groupValue 一樣 就 是此 Radio 選中 其他 設(shè)置為 不選中
activeColor: 選中的顏色
title: 標(biāo)題, 具有代表性的就是 Text
subtitle: 副標(biāo)題(在 title 下面), 具有代表性的就是 Text
isThreeLine = false:// 是否是三行文本
true : 副標(biāo)題 不能為 null
false:如果沒(méi)有副標(biāo)題 ,就只有一行, 如果有副標(biāo)題 ,就只有兩行
dense: 是否密集垂直
secondary: 左邊的一個(gè)控件
selected = false: text 和 icon 的 color 是否 是 activeColor 的顏色
controlAffinity = ListTileControlAffinity.platform:
ListTileControlAffinity.platform 根據(jù)不同的平臺(tái),來(lái)顯示 對(duì)話(huà)框 的位置
ListTileControlAffinity.trailing:勾選在右,title 在中,secondary 在左
ListTileControlAffinity.leading :勾選在左,title 在中,secondary 在右
1.2 demo圖片 1.3 代碼注意點(diǎn) RadioListTile 的父控件 不能選擇Row (暫時(shí)不知道為什么),demo中選的是 Column
import "package:flutter/material.dart";
class RadioDemo extends StatelessWidget {
@override
Widget build(BuildContext context) {
// TODO: implement build
return Scaffold(
appBar: AppBar(
title: Text("Radio 和 Radio RadioListTile "),
centerTitle: true,
),
body: RadioStateDemo(),
);
}
}
class RadioStateDemo extends StatefulWidget {
@override
State createState() {
// TODO: implement createState
return RadioSDemo();
}
}
class RadioSDemo extends State {
String groupValue;
String valueLiu;
String valueZhang;
String valueGuo;
String valueLi;
@override
void initState() {
super.initState();
groupValue = "劉德華";
valueLiu = "劉德華";
valueZhang = "張學(xué)友";
valueGuo = "郭富城";
valueLi = "黎明";
}
@override
Widget build(BuildContext context) {
// TODO: implement build
return Column(
crossAxisAlignment: CrossAxisAlignment.center,
children: [
SizedBox(
height: 20,
),
Text(
"一:Radio",
style: TextStyle(fontWeight: FontWeight.bold, fontSize: 20),
),
Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
Radio(
// 此 Radio 的 value 值
value: valueLiu,
// 當(dāng)選擇此 radio 的時(shí)候 的回調(diào)。 參數(shù)就是 此 value 的值
onChanged: (value) {
setState(() {
groupValue = value;
});
},
// 如果 Radio 的 value 和 groupValue 一樣 就 是此 Radio 選中 其他 設(shè)置為 不選中
groupValue: groupValue,
// 選中的顏色
activeColor: Colors.red,
// 響應(yīng)手勢(shì)的大小 , 默認(rèn)是 48 * 48
// MaterialTapTargetSize.shrinkWrap 水波紋 在中間
// MaterialTapTargetSize.padded 水波紋 靠左上
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
),
Radio(
value: valueZhang,
onChanged: (value) {
setState(() {
groupValue = value;
});
},
groupValue: groupValue,
activeColor: Colors.red,
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
),
Radio(
value: valueGuo,
onChanged: (value) {
setState(() {
groupValue = value;
});
},
groupValue: groupValue,
activeColor: Colors.red,
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
),
Radio(
value: valueLi,
onChanged: (value) {
setState(() {
groupValue = value;
});
},
groupValue: groupValue,
activeColor: Colors.red,
materialTapTargetSize: MaterialTapTargetSize.shrinkWrap,
),
],
),
SizedBox(
height: 40,
),
Text(
"二:RadioListTile",
style: TextStyle(fontWeight: FontWeight.bold, fontSize: 20),
),
// 不知道 為什么 Row 父布局 不行(暫時(shí)不知道why)
Column(
// mainAxisAlignment: MainAxisAlignment.center,
children: [
RadioListTile(
title: Text(valueLiu),
// 必須要的屬性
value: valueLiu,
//是否選中發(fā)生變化時(shí)的回調(diào), 回調(diào)的 bool 值 就是是否選中 , true 是 選中
groupValue: groupValue,
onChanged: _changed,
// 選中時(shí) 填充的顏色
activeColor: Colors.red,
// 標(biāo)題, 具有代表性的就是 Text ,
// selected 如果是 true :
// 如果 不設(shè)置 text 的 color 的話(huà), text的顏色 跟隨 activeColor
// 副標(biāo)題(在 title 下面), 具有代表性的就是 Text , 如果 不設(shè)置 text 的 color 的話(huà), text的顏色 跟隨 activeColor
subtitle: Text("副標(biāo)題"),
// 是否是三行文本
// 如果是 true : 副標(biāo)題 不能為 null
// 如果是 false:
// 如果沒(méi)有副標(biāo)題 ,就只有一行, 如果有副標(biāo)題 ,就只有兩行
isThreeLine: false,
// 是否密集垂直
dense: false,
// 左邊的一個(gè)控件
// secondary: Text("secondary"),
// text 和 icon 的 color 是否 是 activeColor 的顏色
selected: true,
controlAffinity: ListTileControlAffinity.leading,
),
RadioListTile(
title: Text(valueZhang),
value: valueZhang,
groupValue: groupValue,
onChanged: _changed),
RadioListTile(
title: Text(valueGuo),
value: valueGuo,
groupValue: groupValue,
onChanged: _changed),
RadioListTile(
title: Text(valueLi),
value: valueLi,
groupValue: groupValue,
onChanged: _changed),
],
)
],
);
}
void _changed(value) {
groupValue = value;
setState(() {});
}
}
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/7352.html
摘要:是啥是谷歌推出的一套視覺(jué)設(shè)計(jì)語(yǔ)言。比如有的可以換皮膚,而每一套皮膚就是一種設(shè)計(jì)語(yǔ)言,有古典風(fēng)呀炫酷風(fēng)呀極簡(jiǎn)風(fēng)呀神馬的,而就是谷歌風(fēng),有興趣的同學(xué)可以學(xué)習(xí)了解一下官方原版和中文翻譯版,這是每一個(gè)產(chǎn)品經(jīng)理的必修教材。 flutter環(huán)境和運(yùn)行環(huán)境搭建好之后,可以開(kāi)始擼碼了,然而當(dāng)你打開(kāi)VScode,在打開(kāi)項(xiàng)目文件夾后,擺在你面前的是main.dart被打開(kāi)的樣子,里面七七八八的已經(jīng)寫(xiě)好了一...
摘要:布局控件不會(huì)直接呈現(xiàn)內(nèi)容,可看作承載可視控件的容器。布局控件也是可以模擬顯示的,通常用于調(diào)試布局樣式時(shí)用到的網(wǎng)格線(xiàn)標(biāo)尺動(dòng)畫(huà)幀等。但是當(dāng)頁(yè)面內(nèi)容需要超出屏幕尺寸時(shí),就用和代替。 不知不覺(jué)已經(jīng)到了第7篇,然而很多萌新玩家可能還是不知道如何堆砌控件,像用CSS一樣搭出漂亮的APP界面,我也一樣,紅紅火火恍恍惚惚,直到今天含淚讀完Flutter布局基礎(chǔ),仿佛打開(kāi)了一個(gè)全新的世界。 基本概念 在...
摘要:前言最近比較熱門(mén),但是成體系的文章并不多,前期避免不了踩坑我這篇文章主要介紹如何使用實(shí)現(xiàn)一個(gè)比較復(fù)雜的手勢(shì)交互,順便分享一下我在使用過(guò)程中遇到的一些小坑,減少大家入坑作者鏈接先睹為快本項(xiàng)目支持運(yùn)行,效果如下對(duì)了,順便分享一下生成的小竅門(mén),建 前言 Flutter最近比較熱門(mén),但是Flutter成體系的文章并不多,前期避免不了踩坑;我這篇文章主要介紹如何使用Flutter實(shí)現(xiàn)一個(gè)比較復(fù)雜...
摘要:前言最近比較熱門(mén),但是成體系的文章并不多,前期避免不了踩坑我這篇文章主要介紹如何使用實(shí)現(xiàn)一個(gè)比較復(fù)雜的手勢(shì)交互,順便分享一下我在使用過(guò)程中遇到的一些小坑,減少大家入坑作者鏈接先睹為快本項(xiàng)目支持運(yùn)行,效果如下對(duì)了,順便分享一下生成的小竅門(mén),建 前言 Flutter最近比較熱門(mén),但是Flutter成體系的文章并不多,前期避免不了踩坑;我這篇文章主要介紹如何使用Flutter實(shí)現(xiàn)一個(gè)比較復(fù)雜...
摘要:當(dāng)發(fā)送按鈕觸發(fā)事件后調(diào)用函數(shù),在中執(zhí)行了方法,此時(shí)根據(jù)中的變量變更重新渲染對(duì)象,然后大家就可以看到消息記錄框中底部新增了一行消息。 熟悉了flutter的各種控件和相互嵌套的代碼結(jié)構(gòu)后,可以再加深一點(diǎn)難度:加入動(dòng)畫(huà)特效。 雖然flutter的內(nèi)置Metarial控件已經(jīng)封裝好了符合其設(shè)計(jì)語(yǔ)言的動(dòng)畫(huà)特效,使開(kāi)發(fā)者節(jié)約了不少視覺(jué)處理上的精力,比如點(diǎn)擊或長(zhǎng)按listTile控件時(shí)自帶水波紋動(dòng)...
閱讀 1830·2021-09-27 14:02
閱讀 3684·2021-09-27 13:36
閱讀 1102·2019-08-30 12:46
閱讀 1903·2019-08-30 10:51
閱讀 3655·2019-08-29 17:02
閱讀 1029·2019-08-29 16:38
閱讀 1902·2019-08-29 16:37
閱讀 3159·2019-08-26 10:32