flutter备忘录
2019-07-29 本文已影响0人
不要和哥闹
flutter 安装
1、设置环境变量
sudo vi ~/.bash_profile
export PUB_HOSTED_URL=https://pub.flutter-io.cn
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
:wq
2、下载flutter 放到 ~/flutter
3、在~/.bash_profile设置环境变量
export PATH=~/flutter/bin:$PATH
4、运行 source $HOME/.bash_profile 刷新当前终端窗口。
source $HOME/.bash_profile
5、验证“flutter/bin”是否已在PATH中:
echo $PATH
6、检查安装依赖
flutter doctor
flutter 添加json解析
在pubspec.yaml中添加
dependencies:
json_annotation: ^2.4.0
dev_dependencies:
json_serializable: ^3.1.0
build_runner: ^1.6.4
运行
flutter packages pub run build_runner build
vscode 中添加调试控制台和终端清除快捷键
按住Ctrl+Shift+P组合按钮打开设置窗口,输入>open keyboard Shortcuts File,在里面输入
{
"key": "ctrl+k",
"command": "workbench.action.terminal.clear",
"when": "terminalFocus"
},
{
"key": "ctrl+i",
"command": "workbench.debug.panel.action.clearReplAction",
"when": "inDebugRepl"
}
flutter json 在线转换
https://javiercbk.github.io/json_to_dart/
https://caijinglong.github.io/json2dart/index.html
flutter Widget保活
Flutter提供了混入类AutomaticKeepAliveClientMixin,重载wantKeepAlive即可
flutter 字符串转颜色
Color(int.parse('0xffffffff'))
边框圆角
PhysicalModel(
color: Colors.transparent,
borderRadius: BorderRadius.circular(6),
clipBehavior: Clip.antiAlias,
child: null,
);
设置状态栏颜色
AnnotatedRegion(
value: navAlpha > 0.5 ? SystemUiOverlayStyle.dark : SystemUiOverlayStyle.light,
child:Container()),
)
显示隐藏控件Offstage
/**
* 控制child是否显示
*
当offstage为true,控件隐藏; 当offstage为false,显示;
当Offstage不可见的时候,如果child有动画等,需要手动停掉,Offstage并不会停掉动画等操作。
const Offstage({ Key key, this.offstage = true, Widget child })
*/
设置underline焦点和非焦点情况下颜色
Theme(
data: Theme.of(context).copyWith(
primaryColor: Color(0xff0C8EE9),//有焦点情况下颜色
hintColor: Color(0xffE1E1E1),//没有焦点情况下下划线颜色
inputDecorationTheme: InputDecorationTheme(
hintStyle: TextStyle(color: Color(0xffC5C5C5), fontSize: 18),
),
),
child: Form(
autovalidate: true,
child: Column(
children: <Widget>[
TextField(
controller: _unameController,
focusNode: node1,
textInputAction: TextInputAction.done,
decoration: InputDecoration(hintText: '请输入工号',
),
style: TextStyle(
color: Color(0xff4A4A4A),
fontSize: 18,
fontFamily: 'PingFangSC-Medium',
),
),
TextFormField(
controller: _passwordController,
focusNode: node2,
textInputAction: TextInputAction.done,
decoration: InputDecoration(hintText: '请输入密码'),
style: TextStyle(
color: Color(0xff4A4A4A),
fontSize: 18,
fontFamily: 'PingFangSC-Medium',
),
),
],
),
),
);
设置listview背景
//方法1
class MainWidget extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
theme: ThemeData(
scaffoldBackgroundColor: Colors.red,
),
home: WelcomeRoute(),
);
}
}
//方法2
new Container(
color: const Color(0xFF00FF00),
child: ListView ...
多个动画串联在一起使用Interval
///
/// Definition of the _controller with a whole duration of 10 seconds
///
AnimationController _controller = new AnimationController(
duration: const Duration(seconds: 10),
vsync: this
);
///
/// First animation that moves the ball from the left to the center
///
Animation<Offset> moveLeftToCenter = new Tween(
begin: new Offset(0.0, screenHeight /2),
end: new Offset(screenWidth /2, screenHeight /2)
).animate(
new CurvedAnimation(
parent: _controller,
curve: new Interval(
0.0,
0.20,
curve: Curves.linear,
),
),
);
///
/// Second animation that moves the ball from the center to the top
///
Animation<Offset> moveCenterToTop = new Tween(
begin: new Offset(screenWidth /2, screenHeight /2),
end: new Offset(screenWidth /2, 0.0)
).animate(
new CurvedAnimation(
parent: _controller,
curve: new Interval(
0.20,
0.50,
curve: Curves.linear,
),
),
);
///
/// Third animation that will be used to change the opacity of the ball to make it disappear
///
Animation<double> disappear = new Tween(begin: 1.0, end: 0.0)
.animate(
new CurvedAnimation(
parent: _controller,
curve: new Interval(
0.50,
1.0,
curve: Curves.linear,
),
),
);
本地加载json文件
DefaultAssetBundle.of(context)
.loadString("resource/my_date.json")
.then((loadString) {
List data = jsonDecode(loadString);
setState(() {
models = List.from(data);
});
}).catchError((e){
print(e);
});
final和const
如果您从未打算更改一个变量,那么使用 final 或 const,不是var,也不是一个类型。 一个 final 变量只能被设置一次,两者区别在于:const 变量是一个编译时常量,final变量在第一次使用时被初始化。被final或者const修饰的变量,变量类型可以省略,如:
//可以省略String这个类型声明
final str = "hi world";
//final String str = "hi world";
const str1 = "hi world";
//const String str1 = "hi world";
flutter添加整个文件夹下图片
文件夹下必须有一倍图片否则无法加载
asset在pubspec文件对齐方式
image.png
图片圆角
剪裁Widget 作用
ClipOval 子组件为正方形时剪裁为内贴圆形,为矩形时,剪裁为内贴椭圆
ClipRRect 将子组件剪裁为圆角矩形
ClipRect 剪裁子组件到实际占用的矩形大小(溢出部分剪裁)
ClipOval(child: avatar), //剪裁为圆形
ClipRRect( //剪裁为圆角矩形
borderRadius: BorderRadius.circular(5.0),
child: avatar,
),
flutter icons 名称
flutter教程博客
Flutter中文网
Flutter for React Native 开发者
Flutter实战
Fluttet教程
外国某大神写的博客
How to handle screen transitions in Flutter