常用快捷键:
展开/关闭代码块:
command + .
跳转到 下/上 一个光标位置:alt + command + →/←
(右/左箭头)
去除无用的import头文件:ctrl +alt + o
全局搜索:command + shift + f
快速更换/添加/移除widget:鼠标点到要操作的widget上,按下alt + 回车
一键复制:command + d
flutter代码格式化:Mac:command + alt + f
Windows:Ctrl+Alt+L
颜色的各种写法
Color c1 = Color(0xFF3CAAFA);
Color c2 = Color.fromRGBO(60, 170, 250, 0.2);
Color c3 = Color.fromARGB(255, 60, 170, 250);
Color c5 = Colors.blue;
Color c6 = Colors.red[600];
项目不能新建directory的解决办法
解决文件夹中嵌套文件夹呈现 xxx.yyy的格式(按下图取消勾选):
data:image/s3,"s3://crabby-images/0234c/0234cd5ff43211809d7a500d4c39ac354a395f09" alt=""
flutter 控件随着键盘弹出自适应上下移动 防止遮挡
flutter项目拉下来如果有主模块有分模块 需要分别同时点一下这个
data:image/s3,"s3://crabby-images/254c8/254c8f4f6c077c9173b60c3ec22499d13364c3f0" alt=""
flutter中如何导入插件 .jar包(
image.png
例如MVP模板 StlIdePlugin)
data:image/s3,"s3://crabby-images/9c3a9/9c3a9bbe384a82522e5958a1f91bf530b89e7d2f" alt=""
data:image/s3,"s3://crabby-images/8a73a/8a73a2928735139714bc98bc68f5cd9e2f92172c" alt=""
flutter 如何创建使用导入的MVP模板
在Android studio顶部菜单栏上 选中STL 打开编辑栏
data:image/s3,"s3://crabby-images/e41fa/e41fa66ba1c049559ffc4617d09339c813b78560" alt=""
data:image/s3,"s3://crabby-images/c9117/c91179741acc9d573d832f6710272ce714592c9c" alt=""
模板说明
data:image/s3,"s3://crabby-images/a6933/a69339869eed6f6b01b6f008fb1139e6b90b8040" alt=""
flutter如何引入脚本(多语言 辅助R文件)
data:image/s3,"s3://crabby-images/f8424/f84247bcf9c1426f2b5a98989cae0b48525dc4ef" alt=""
data:image/s3,"s3://crabby-images/9f149/9f1491317593b4a1cc5bf3fe5aff27656728f552" alt=""
data:image/s3,"s3://crabby-images/c4fc6/c4fc62d255084418346a18a89f4753582c2b7fa5" alt=""
data:image/s3,"s3://crabby-images/03801/03801f285e4cd97485b3b524f65d9ede4264969b" alt=""
如何跑脚本:
data:image/s3,"s3://crabby-images/ce95d/ce95d081afe778eb428b858ec7131e0c71e8dbfb" alt=""
项目中如何使用:
data:image/s3,"s3://crabby-images/4277d/4277df516730e9c6dc4e1e02d449f562c082b94e" alt=""
附上脚本内容
data:image/s3,"s3://crabby-images/dee93/dee93b06cf02a0a636fc22f58c39d640771ea86c" alt=""
flutter 多语言
easy_localization
APP账号密码登录流程:
data:image/s3,"s3://crabby-images/1cb0f/1cb0fb33022b4d7f4030b9e8da286e909c6b2e30" alt=""
APP自动登录流程
data:image/s3,"s3://crabby-images/c818c/c818ccdf2178f7c12e469383a188efdd23198dd1" alt=""
flutter 自定义底部切圆角弹框
void _clickMoreBtn() {
showModalBottomSheet(
context: context,
backgroundColor: Colors.transparent, // 重点!!!
builder: (BuildContext context) {
return Container(
height: 462.h,
width: double.infinity,
child: Center(child: OtherLoginWaySheet()),
decoration: BoxDecoration(
color: Colors.white,
borderRadius: BorderRadius.only(
topLeft: Radius.circular(50.w),
topRight: Radius.circular(50.w),
),
),
);
},
);
}
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:libcommon/res/colors.dart';
import 'package:flutter_svg/flutter_svg.dart';
import 'package:flutter_screenutil/flutter_screenutil.dart';
import 'package:libcommon/generated/codegen_r_loader.g.dart';
import 'package:stl_easy_localization/stl_easy_localization.dart';
class OtherLoginWaySheet extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Container(
child: Column(children: [
Padding(
padding: EdgeInsets.only(top: 80.w, bottom: 40.h),
child: InkWell(
onTap: () {
print("点击QQ登录");
},
child: Container(
width: 240.w,
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
SizedBox(
width: 56.w,
height: 56.w,
child: SvgPicture.asset(
"assets/svg/fxchat_login_ic_login_qq.svg",
package: 'fxchat_login',
),
),
SizedBox(width: 20.w),
Text(R.fxchat_login_qq_login).tr(),
],
),
),
),
),
Padding(
padding: EdgeInsets.only(top: 30.0.h, bottom: 60.h),
child: InkWell(
onTap: () {
print("点击微博登录");
},
child: Container(
width: 240.w,
child: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [
SizedBox(
width: 56.w,
height: 56.w,
child: SvgPicture.asset(
"assets/svg/fxchat_login_ic_login_weibo.svg",
package: 'fxchat_login',
),
),
SizedBox(width: 20.w),
Text(R.fxchat_login_weibo_login).tr(),
],
),
),
),
),
SizedBox(
width: 654.w,
height: 96.h,
child: FlatButton(
color: ColorsUtil.hexToColor("#eff1f4"),
onPressed: () {
Navigator.of(context).pop();
},
child: Text(
R.fxchat_login_cancel.tr(),
style: TextStyle(
fontSize: 16,
fontWeight: FontWeight.w500,
color: ColorsUtil.hexToColor("#e61e222b")),
),
),
),
]),
);
}
}
使用Android studio 进行版本控制和冲突解决等
data:image/s3,"s3://crabby-images/b9ed6/b9ed6058e8a342ffd8a1817263c8d7b67725b249" alt=""
data:image/s3,"s3://crabby-images/789ed/789ed8ff5862b48cca9a3580add5dfeecf3a6bb3" alt=""
data:image/s3,"s3://crabby-images/86952/86952e73ff6bc78fb4acfe076fbea141042789cb" alt=""
创建按钮装不下字的时候 需要新添加一行
visualDensity: VisualDensity(horizontal: -4, vertical: -4),
Container(
width: 120.w,
height: 56.h,
child: FlatButton(
visualDensity: VisualDensity(horizontal: -4, vertical: -4),
color: Colors.yellow,
disabledColor: Colors.black12,
textColor: Colors.red,
disabledTextColor: Colors.grey,
onPressed: () {},
child: Text(
"同意",
style: TextStyle(fontSize: 14),
),
shape: RoundedRectangleBorder(
borderRadius: BorderRadius.circular(28.h)),
),
)
flutter 退出到指定页面
STLRouter.of().navigator.pushNamedAndRemoveUntil(
RouterFXChatMine.ROUTER_INNER_MINE_PAGE, (route) => route == null);
使用Android studio 进行Git版本控制
用Android studio打开你的本地项目,
data:image/s3,"s3://crabby-images/bd737/bd737352b95912a0aefcce9a717f0b7bdb6218d4" alt=""
data:image/s3,"s3://crabby-images/281aa/281aade64ca4fbd2d11bcc7a0c22be7c922cc23f" alt=""
data:image/s3,"s3://crabby-images/70199/701994ad17560ba4c6f014f0674b1749b14177f4" alt=""
data:image/s3,"s3://crabby-images/a2685/a2685a6ead4e0ddfde73d74b9e6797f0508a0b66" alt=""
data:image/s3,"s3://crabby-images/9e89c/9e89c14f5bee29cc7bfedfb714adf3796c45952c" alt=""
data:image/s3,"s3://crabby-images/f6203/f62035caf48089b5d7bffe87180d8289b7c2e6a7" alt=""
Git版本控制——保存修改到本地
data:image/s3,"s3://crabby-images/11abd/11abd80488fec8a861bf75032ac596a476b46185" alt=""
flutter 清除应用库的缓存
data:image/s3,"s3://crabby-images/7e283/7e283bbf5267b1bd3689f95c15770ec3b885f37f" alt=""
flutter 清除缓存
flutter clean
image.png
汇聊拉完代码需要在终端输入下面命令 batchUpgrade.sh是自己写的
作用是快速 pub upgrade 各个模块
./batchUpgrade.sh
data:image/s3,"s3://crabby-images/c8019/c801985d4ef1bd5d28ee151e97abe37e234b58ab" alt=""
data:image/s3,"s3://crabby-images/04ce1/04ce1618f7d4f98b9b458cbc53beb2fc65b8daec" alt=""
对应的文件内容
data:image/s3,"s3://crabby-images/0d226/0d2260dc3d8320818a714ab3a51c9b69cd0506b8" alt=""
// batchUpgrade.sh
#!/bin/bash
for subDir in `ls`
do
subPath="$(pwd)/$subDir"
if [ -d "$subPath" ]
then
#判断文件夹中是否包含 yaml文件
needUpgrade=false
for subFile in `ls $subPath`
do
if [ "${subFile##*.}"x = "yaml"x ]
then
needUpgrade=true
fi
done
if [ $needUpgrade = true ]
then
cd $subPath
flutter pub upgrade
cd ..
fi
fi
done
#根目录下执行
flutter pub upgrade
网友评论