flutter 记录

第2节

//安装flutter
git clone https://github.com/flutter/flutter.git
ls ~/.bash_profile
touch ~/.bash_profile
source ~/.bash_profile
vim ~/.bash_profile
/*
//延用系统配置
if [ -f /etc/bash_profile ]; then
./etc/bash_profile
fi
//镜像地址
export PUB_HOSTED_URL=https://pub.flutter-io.cn
export FLUTTER_STORAGE_BASE_URL=https://storage.flutter-io.cn
//路径
export PATH="$PATH:~/Downloads/flutter/bin"
*/
flutter -v

//修改权限
chmod 777
//查看权限
ls -l

。文件是隐藏文件
以前默认bash(。bash_profile),现在zsh(。zshrc)
//切换命令行
//shell
chsh -s
chsh -l

shell
vi 修改文件

iOS有每个环境对应的路径 config里的路径是绝对路径,很多地方要用到所以是绝对路径

echo $PATH

which flutter

flutter doctor

flutter precache

flutter -v

flutter run
flutter run -d 'iPhone X'

flutter create fluter_Demo

跑不起来卡死,清缓存
rm flutter/bin.cache/lockfile

as快捷
common+ {} 光标的上下一个位置
common+。 折叠代码
common+shift+'-' 折叠代码

as编译的时候会自动修改xcconfig配置文件路径

第3节 布局与状态管理

默认写法
class base_widgetTextDemo extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(//
debugShowCheckedModeBanner: false,
home: Scaffold(
appBar: AppBar(
title: Text('title'),
),
body: ContainerDemo(),
),
theme: ThemeData(//主题
primaryColor: Colors.blue,
primarySwatch: Colors.yellow,//统一标题颜色
),
);
}
}

text文字
overflow超出显示

RichText富文本,TextSpan富文本文字

Container 容器
SizedBox(height: 10),//换行占位

alignment -1,-1左上角
横row,纵column,stack中间堆叠

//主轴与交叉轴跟 row和column有关 他两相反
/*

  • 关于主轴:mainAxisAlignment
  • spaceBetween 剩下的空间平均分布到小部件之间 1👌2👌2👌1
  • spaceAround 剩下的空间平均分布到小部件的周围 👌1👌1👌
  • spaceEvenly 剩下的空间和小部件一起平均分布 1👌1👌1👌1
  • */

交叉轴:crossAxisAlignment
/*

  • 交叉轴:crossAxisAlignment;主轴不影响交叉轴布局
  • start上对齐,end下对齐
    *baseline必须要textBaseline
  • // alphabetic 英文字符 //ideographic 中文字符 第一行中文底部对齐
  • */

Expanded 填充式布局,主轴不留间隙的填充, 主轴设置和长度没有意义

Positioned 相对Stack容器最值(左右最宽,上下最长),相对布局,上下左右对齐 = Container

AspectRatio 宽高比例布局 aspectRatio

第4节 项目实战-项目搭建&发现界面

floatingActionButton悬浮按钮
BottomNavigationBar tabar (ixedColor: Colors.green,//选择颜色selectedFontSize: 12.0, selectedFontSize: 12.0,//选择字体大小
ThemeData(highlightColor: Color.fromRGBO(1, 0, 0, 0.0),//透明splashColor: Color.fromRGBO(1, 0, 0, 0.0),//水波纹

替换启动和icon iOS 一样的 安卓 android/app/src/main/res/ 不能用大写字母用下划线,图片拖进去会没了,x是2倍,h1.5,m1 AndroidManifest.xml 修改图片名
安卓被锁住要修改镜像 gradle assembleDebug 报错
启动图片launch_background
<item>
<bitmap
android:gravity="center"
android:src="@mipmap/app_icon" />
</item>
安卓不用加图片后缀名,加了有问题

image图片配置
assets:

  • 文件夹/
    ’文件夹/图片名‘

//以下三个为了安卓
centerTitle: true,//去掉 安卓切换app会有文字
title: Text(
'发现',
),
elevation: 0.0,//去掉 安卓底部边栏

MediaQuery.removePadding(//去掉刘海空隙

margin 外边距,定位子部件,padding 内边距,父部件

二分,或多分布局思维 左右/上下 两块

decoration: BoxDecoration(//装饰器,设置圆角
color: Colors.blue,
borderRadius: BorderRadius.circular(10.0),
image: DecorationImage(
image: AssetImage('images/Hank.png'), fit: BoxFit.cover),//填充
),

width: MediaQuery.of(context).size.width,//获取屏幕宽度

ListView.builder(重用机制

Container(
height: 0.5,
color: WeChatThemeColor,
child: Row(//去掉边
children: <Widget>[
Container(
width: 50,
color: Colors.white,
)
],
),

Container(
color: WeChatThemeColor,包装一下,设一下listview背景色
child: ListView.builder(
controller: _scrollController,
itemCount: _listDatas.length + _headerData.length,
itemBuilder: _itemForRow,
)), //列表
},
), //

//链式编程
_listDatas..addAll(datas)..addAll(datas);

// _listDatas.addAll(datas);
// _listDatas.addAll(datas);

//排序! 首字母排序
_listDatas.sort((Friends a, Friends b) {
  return a.indexLetter.compareTo(b.indexLetter);
});

index思路:第一个必定需要字母头,从第二个开始判断indexLetter跟前一个一样就不显示

iOS打包,app app.framework(flutter代码,字节码,二进制流)/flutter.framework(flutter引擎)

y ~/ itemHeight //取整

_scrollController 添加滚动动画

indexbar控件
1.创建column控件,加scroview让它可以滚动
2.点击拖拽手势(加滚动动画,用控件的坐标算出是第几个)
3.增加控件
4;存储高度,滚动的时候直接取

更新代码库 flutter pub get
flutter packages get => flutter pub get
代码网站 https://pub.dev

import 'package:http/http.dart' as http; //重命名为http

配置允许http

//Map转Json

// final chatJson = json.encode(chat);
// print(chatJson);
//Json转Map
// final newChat = json.decode(chatJson);
// print(newChat is Map);

  • */

const Chat({this.name, this.message, this.imageUrl});//必须创建新对象
factory Chat.fromJson(Map json) {//工厂构造函数:返回任何对象,已有的对象(单例),null,新建的
return Chat(
name: json['name'],
message: json['message'],
imageUrl: json['imageUrl'],
);
}

渲染机制,不在界面上就没有了。可以刻意去保存

flutter闭包,就是一个对象

超时了数据还会来

dart 单线程语音

//耗时操作
//1.后面的操作必须是异步才能用await修饰
//2.当前行数也必须是异步函数 async

getData() async { Future((){//闲时操作).then(value) {}.catchError(errorFunc){}.whenComplete(() { print('完成了!');}); }//先error再then error也会掉then,完成一定会执行

Future有一个执行队列。同级then比Future队列任务级别高

then函数抛异常会直接到下一个catchError函数

//队列
void testFuture() async {
//同级 then比Future队列任务级别高
Future(() {
sleep(Duration(seconds: 2));
return '任务1';
}).then((value) {
print('value结束'); throw Exception('Error'); return 'value任务2';
}).then((value) {
print('value结束'); return 'value任务3';
}).catchError((e)=>print('结束')).then((value) {
print('value 4结束'); throw Exception('Error2'); return 'value任务4';
}).catchError((e)=>print('结束2'));//then函数抛异常会直接到下一个catchError函数
print('任务添加完毕');
}

//微任务scheduleMicrotask高于Future

异步编程 https://www.cnblogs.com/lxlx1798/p/11126564.html

多线程 Isolate

用端口监听,收发消息

异步操作返回都是futuer

compute 多线程,Isolate的封装

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,133评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,682评论 3 390
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,784评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,508评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,603评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,607评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,604评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,359评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,805评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,121评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,280评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,959评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,588评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,206评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,193评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,144评论 2 352

推荐阅读更多精彩内容