Flutter中有多如牛毛的
控件
,控件有多如牛毛的屬性
,屬性又有多如牛毛的枚舉或靜態常量
是否是想一想都頭皮發麻,TM這麼多我怎麼玩。在思考如何玩轉屬性,而後便有此文。數組
本文你能夠學到:bash
[1].自定義無狀態組件的流程
[2].回調方法的使用
[3].如何批量生成你想要的組件
[4].清晰認識:TextDecoration、BoxFit、BlendMode、Alignment
複製代碼
var decorations = [TextDecoration.none,TextDecoration.lineThrough,
TextDecoration.overline,TextDecoration.underline];
var show = MultiShower(
decorations, (type) => Text("張風捷特烈",
style: TextStyle(
fontSize: 20, //字號
decoration: type),
));
複製代碼
可指定容器的寬高和顏色微信
var fitModes = [BoxFit.none,BoxFit.contain,BoxFit.cover,
BoxFit.fill,BoxFit.fitHeight,BoxFit.fitWidth,BoxFit.scaleDown];
var show = MultiShower(
fitModes,
(type) => Image(
image: AssetImage("images/wy_300x200.jpg"),
fit: type,
),
width: 150,//容器寬
color: Colors.red,//容器顏色
);
複製代碼
這若是一個一個測試出來,還不累死人less
//疊合模式數組
var colorBlendModes = [
BlendMode.clear,BlendMode.src,BlendMode.dst,
BlendMode.srcOver,BlendMode.dstOver,BlendMode.srcIn,
BlendMode.dstIn,BlendMode.srcOut,BlendMode.dstOut,
BlendMode.srcATop,BlendMode.dstATop,BlendMode.xor,
BlendMode.plus, BlendMode.modulate,BlendMode.screen,
BlendMode.overlay,BlendMode.darken,BlendMode.lighten,
BlendMode.colorDodge,BlendMode.colorBurn,BlendMode.hardLight,
BlendMode.softLight,BlendMode.difference,BlendMode.exclusion,
BlendMode.multiply,BlendMode.hue,BlendMode.saturation,
BlendMode.color, BlendMode.luminosity,
];
var show = MultiShower(
colorBlendModes,
(mode) => Image(
image: AssetImage("images/icon_head.png"),
color: Colors.blue,
colorBlendMode: mode,
),
width: 60,
height: 60,
);
複製代碼
能夠自定義下發的文字ide
var alignments = [
Alignment.center, Alignment.centerLeft, Alignment.centerRight,
Alignment.topCenter, Alignment.topLeft, Alignment.topRight,
Alignment.bottomCenter, Alignment.bottomLeft, Alignment.bottomRight,
Alignment(0, 0), Alignment(0.5, 0.5)
];
var alignmentInfos = [//下面的文字
"center", "centerLeft", "centerRight",
"topCenter", "topLeft", "topRight", "bottomCenter", "bottomLeft", "bottomRight",
"Alignment(0,0)", "Alignment(0.5,0.5)"
];
var show = MultiShower(
alignments,
(mode) => Align(
alignment: mode,
child: Container(
width: 40,
height: 40,
color: Colors.red,
),
),
infos: alignmentInfos,
width: 100,
);
複製代碼
看起來好像很厲害的感受,如何實現的呢?post
繼承StatelessWidget須要實現build抽象方法,返回Widget對象測試
import 'package:flutter/material.dart';
class MultiShower extends StatelessWidget {
MultiShower();
@override
Widget build(BuildContext context) {
return null;
}
}
複製代碼
import 'package:flutter/material.dart';
class MultiShower extends StatelessWidget {
MultiShower(
this.list,
this.call, {
this.width = 110,
this.height = 110 * 0.618,
this.infos,
this.color = Colors.cyanAccent,
});
final List list;
final List<String> infos;
final Function call;
final double width;
final double height;
final Color color;
@override
Widget build(BuildContext context) {
return null;
}
}
複製代碼
核心就是
在遍歷列表時回調出來列表元素
,以供使用。ui
@override
Widget build(BuildContext context) {
var li = <Widget>[];
for (var i = 0; i < list.length; i++) {
var child = Container(
margin: EdgeInsets.all(7),
color: color,
width: width,
height: height,
child: call(list[i]));
li.add(Column(
children: <Widget>[
child,
Text(infos != null ? infos[i] : list[i].toString().split(".")[1])
],
));
}
return Wrap(
children: li,
);
}
複製代碼
好了,這樣就OK了,是否是沒有想象中的那麼難,最後貼個完整的this
import 'package:flutter/material.dart';
class MultiShower extends StatelessWidget {
MultiShower(
this.list,
this.call, {
this.width = 110,
this.height = 110 * 0.618,
this.infos,
this.color = Colors.cyanAccent,
});
final List list;
final List<String> infos;
final Function call;
final double width;
final double height;
final Color color;
@override
Widget build(BuildContext context) {
var li = <Widget>[];
for (var i = 0; i < list.length; i++) {
var child = Container(
margin: EdgeInsets.all(7),
color: color,
width: width,
height: height,
child: call(list[i]));
li.add(Column(
children: <Widget>[
child,
Text(infos != null ? infos[i] : list[i].toString().split(".")[1])
],
));
}
return Wrap(
children: li,
);
}
}
複製代碼
本文到此接近尾聲了,另外本人有一個Flutter微信交流羣,歡迎小夥伴加入,共同探討Flutter的問題。
本人微信號:zdl1994328
,期待與你的交流與切磋。若是想快速嚐鮮Flutter,《Flutter七日》會是你的必備佳品。spa