Flutter实战1 --- 写一个天气查询的APP
这些题目是今年群友去腾讯、百度、小米、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。hum: “湿度“+json[‘HeWeather6’][0][‘now’][‘hum’]+”%”,在写UI的工程中,我们可以用到Flutter的hot reload的特性,写布局的时候,按。,在手机上就可以看到写好的UI,但这时候的数据是写死的,下来看如何通过http获取数据。有An
}
4.2 HotReload
在写UI的工程中,我们可以用到Flutter的hot reload的特性,写布局的时候,按ctrl+s或cmd+s就可以在手机上实时看到界面的变化。
这个功能很好用。
4.3添加图片资源
Flutter可以添加不同的资源,例如图片、文本、配置文件、静态数据等。
添加资源时,需要在pubspec.yaml文件中的flutter属性下添加assets,并标明要添加资源的路径,例如,我们要加入指定的图片时,可以这么写:
flutter:
assets:
- assets/my_icon.png
- assets/background.png
如果要添加的资源太多,也可以添加文件夹,例如:
flutter:
assets:
- assets/
在本demo中,要添加一个背景图,我们在工程的根目录下创建images目录,将背景图放在images目录下,然后在pubspec.yaml中添加:
flutter:
The following line ensures that the Material Icons font is
included with your application, so that you can use the icons in
the material Icons class.
uses-material-design: true
assets:
- images/
4.4 写WeatherWidget的UI布局
在Scaffold中添加body的属性,来写UI的布局,如下:
class WeatherState extends State{
@override
Widget build(BuildContext context) {
// TODO: implement build
return Scaffold(
body: new Stack(
fit: StackFit.expand,
children: [
new Image.asset(“images/weather_bg.jpg”,fit: BoxFit.fitHeight,),
new Column(
mainAxisAlignment: MainAxisAlignment.start,
crossAxisAlignment: CrossAxisAlignment.center,
children: [
new Container(
width: double.infinity,
margin: EdgeInsets.only(top: 40.0),
child: new Text(
“广州市”,
textAlign: TextAlign.center,
style: new TextStyle(
color: Colors.white,
fontSize: 30.0,
),
),
),
new Container(
width: double.infinity,
margin: EdgeInsets.only(top: 100.0),
child: new Column(
children: [
new Text(
“20 °”,
style: new TextStyle(
color: Colors.white,
fontSize: 80.0
)),
new Text(
“晴”,
style: new TextStyle(
color: Colors.white,
fontSize: 45.0
)),
new Text(
“湿度 80%”,
style: new TextStyle(
color: Colors.white,
fontSize: 30.0
),
)
],
),
)
],
)
],
),
);
}
}
按ctrl+s,在手机上就可以看到写好的UI,但这时候的数据是写死的,下来看如何通过http获取数据。
5.通过http获取数据
要通过http数据,我们首先要添加http的依赖库,在pubspec.yaml中的dependencies添加如下:
dependencies:
flutter:
sdk: flutter
The following adds the Cupertino Icons font to your application.
Use with the CupertinoIcons class for iOS style icons.
cupertino_icons: ^0.1.2
http: ^0.12.0
然后在当前工程目录下运行以下命令行:
$ flutter packages get
或者在Android Stuido 打开pubspec.yaml 文件,点击上面的packages get
这里操作的意义是,拉取http的库。
5.1 创建WeatherData类
通过 new -> Dart File 在lib目录下创建WeatherData
class WeatherData{
String cond; //天气
String tmp; //温度
String hum; //湿度
WeatherData({this.cond, this.tmp, this.hum});
factory WeatherData.fromJson(Map<String, dynamic> json) {
return WeatherData(
cond: json[‘HeWeather6’][0][‘now’][‘cond_txt’],
tmp: json[‘HeWeather6’][0][‘now’][‘tmp’]+“°”,
hum: “湿度 “+json[‘HeWeather6’][0][‘now’][‘hum’]+”%”,
);
}
factory WeatherData.empty() {
return WeatherData(
cond: “”,
tmp: “”,
hum: “”,
);
}
}
5.2 数据获取
class WeatherState extends State{
WeatherData weather = WeatherData.empty();
WeatherState(){
_getWeather();
}
void _getWeather() async{
WeatherData data = await _fetchWeather();
setState((){
weather = data;
});
}
Future _fetchWeather() async{
final response = await http.get(‘https://free-api.heweather.com/s6/weather/now?location=广州&key=ebb698e9bb6844199e6fd23cbb9a77c5’);
if(response.statusCode == 200){
return WeatherData.fromJson(json.decode(response.body));
}else{
return WeatherData.empty();
}
}
@override
Widget build(BuildContext context) {
…
}
}
5.3 将之前写死的数据换成WeatherData
…
child: new Column(
children: [
new Text(
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。





既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
结尾
- 腾讯T4级别Android架构技术脑图;查漏补缺,体系化深入学习提升

- 一线互联网Android面试题含详解(初级到高级专题)
这些题目是今年群友去腾讯、百度、小米、乐视、美团、58、猎豹、360、新浪、搜狐等一线互联网公司面试被问到的题目。并且大多数都整理了答案,熟悉这些知识点会大大增加通过前两轮技术面试的几率

有Android开发3-5年基础,希望突破瓶颈,成为架构师的小伙伴,可以关注我
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
60、新浪、搜狐等一线互联网公司面试被问到的题目。并且大多数都整理了答案,熟悉这些知识点会大大增加通过前两轮技术面试的几率
[外链图片转存中…(img-d1kAC7RB-1711819280312)]
有Android开发3-5年基础,希望突破瓶颈,成为架构师的小伙伴,可以关注我
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
更多推荐


所有评论(0)