child: Text(“Hello Flutter!”)
);

这就是一个Widget,Container是Widget的一个子类,当然它里面有各种各样的子类供你使用。

Dart

Dart语言可以说对于移动端开发来说,都比较陌生,因为纯原生开发到现在,我只听说过可以用C#开发iOS,可能我知道的太少了,不过Dart的学习还是比较简单的,安卓开发人员用过Java,iOS开发人员用过Swift,所以再去看Dart都会有似曾相识的感觉。来看个例子:

void main() {
List list = [‘1’, ‘2’, ‘3’, ‘4’, “5”, “6”];
final str = list.join(" ").toString();
print(str);
print(list.skip(1).toList());
print(list.getRange(3, list.length).toList());
}
1 2 3 4 5 6
[2, 3, 4, 5, 6]
[4, 5, 6]

其实和Java和Swift的区别不大,一天差不多就可以入门。

怎么开发一个App

相信很多人已经接触了Flutter官方的教程,可是跟着写了一遍之后,还是一头雾水,不知道到底应该怎么写一个完整的App。下面看一个用Flutter模仿的有妖气漫画的实例:

屏幕快照

这个页面的整个布局都是Widget,在iOS里布局的话,这个必须是一个TableView或者CollectionView,在安卓里应该是ListView,在Flutter里这个Widget也是一个ListView,比较简单。

屏幕快照

这个是在一个ListView里套用了Column,就是垂直排列的意思,在iOS里其实可以用tableView解决,这整个页面可以用使用不同的Cell解决。

项目目录结构

结构

具体只有今日,发现这两个模块的实现,其他的还在学习研究中。

三方库

https://pub.dartlan

《Android学习笔记总结+最新移动架构视频+大厂安卓面试真题+项目实战源码讲义》

【docs.qq.com/doc/DSkNLaERkbnFoS0ZF】 完整内容开源分享

g.org 类似cocoapods.org. 第三方库里的图片加载有个(cached_network_image)还是比较好的,可以缓存,每次显示的时候有个Ease动画。具体可以在项目里运行查看。

网络获取:

/// 获取今日 模块的数据
static Future requestToday() async {
final response = await http.get(todayURL);
final map = jsonDecode(response.body);
final code = map[“code”];
final _data = map[“data”];
final stateCode = _data[“stateCode”];
final message = _data[“message”];
final result = TodayResult(
code: code,
stateCode: stateCode,
message: message,
dayDataList: List()
);
final _returnData = _data[“returnData”];
final _dayDataList = _returnData[“dayDataList”];
if (_dayDataList.length == 0) {
return result;
}
for (int i = 0; i < _dayDataList.length; i++) {
final _dayItemDataList = _dayDataList[i][“dayItemDataList”];
final publish = TodayPublishDate.fromJSON(_dayDataList[i]);
result.dayDataList.add(publish);
for (int j = 0; j < _dayItemDataList.length; j++) {
final _dayItemData = _dayItemDataList[j];
if (j != _dayItemDataList.length-1) {
final dayItemData = DayItemData.fromJSON(_dayItemData);
result.dayDataList.add(dayItemData);
} else {
final dayItemData2 = DayItemData2.fromJSON(_dayItemData);
result.dayDataList.add(dayItemData2);
}
}
}
return result;

Banner滚动:

class BannerWidget extends StatefulWidget {
final List images;
BannerWidget(this.images, {Key key}): super(key: key);
_BannerWidgetState createState() => _BannerWidgetState();
}

class _BannerWidgetState extends State {
final pageController = PageController(initialPage: 0);
Timer timer;

void resetTimer() {
clearTimer();
timer = Timer.periodic(Duration(seconds: 3), (timer) {
if (pageController.positions.isNotEmpty) {
var i = pageController.page.toInt() + 1;
pageController.animateToPage(
i,
duration: Duration(milliseconds: 100),
curve: Curves.linear
);
if (i == widget.images.length-1) {
pageController.jumpToPage(0);
i = 0;
}
}
});
}

void clearTimer() {
if (timer != null) {
timer.cancel();
timer = null;
}
}

@override
void initState() {
// TODO: implement initState
super.initState();
resetTimer();
}

@override
Widget build(BuildContext context){
if (widget.images.length == 0) {
return null;
}
return SizedBox(
height: 231.0,
width: MediaQuery.of(context).size.width,
child: PageView.builder(
controller: pageController,
physics: PageScrollPhysics(parent: ClampingScrollPhysics()),
itemCount: widget.images.length,
itemBuilder: (context, index){
final url = widget.images[index];
return Image(
image: CachedNetworkImageProvider(url),
fit: BoxFit.cover,
);
images.length,
itemBuilder: (context, index){
final url = widget.images[index];
return Image(
image: CachedNetworkImageProvider(url),
fit: BoxFit.cover,
);

Flutter实践之高仿有妖气漫画,2021大厂Android开发面试总结+解答相关推荐

  1. Flutter实践之高仿有妖气漫画,从消息中间件看分布式系统的多种套路

    这就是一个Widget,Container是Widget的一个子类,当然它里面有各种各样的子类供你使用. Dart Dart语言可以说对于移动端开发来说,都比较陌生,因为纯原生开发到现在,我只听说过可 ...

  2. Flutter实践之高仿有妖气漫画,移动客户端开发工程师专业

    Flutter是一个跨平台的框架,在iOS和Android端甚至以后的PC端都可以统一一套代码来实现.Flutter的性能高效,Dart语言的简易性和高效性,也使Flutter采用了Dart来开发跨平 ...

  3. 一款高仿腾讯漫画的漫画阅读类 APP

    早上好,骚年,我是小菜,我的公众号「菜鸟翻身」会推荐 GitHub 上有用的项目,一分钟 get 一个优秀的开源项目,挖掘开源的价值. 我的引语 项目中成长是最快的,实践是王道,项目中成长是最快的,多 ...

  4. iOS仿写有妖气漫画、视频捕获框架、启动页广告页demo、多种动画效果等源码

    iOS精选源码 以tableview的section为整体添加阴影效果/ta'b'le'vi'e'w顶部悬浮-. 一个可以轻松应用自定义过滤器的视频捕获框架. 基于UITableView的组件,旨在显 ...

  5. iOS仿写有妖气漫画、视频捕获框架、启动页广告页demo、多种动画效果等源码...

    iOS精选源码 以tableview的section为整体添加阴影效果/ta'b'le'vi'e'w顶部悬浮.... 一个可以轻松应用自定义过滤器的视频捕获框架. 基于UITableView的组件,旨 ...

  6. Flutter 10天高仿大厂App及小技巧积累总结

    之前,也写过几篇关于 Flutter 的博文,最近,又花了一些时间学习研究 Flutter,完成了高仿大厂 App 项目 (项目使用的接口都是来自线上真实App抓包而来,可以做到和线上项目相同的效果) ...

  7. android仿微信图片上传进度,Android开发之模仿微信打开网页的进度条效果(高仿)...

    一,为什么说是真正的高仿? 阐述这个问题前,先说下之前网上的,各位可以复制这段字,去百度一下  "仿微信打开网页的进度条效果",你会看到有很多类似的文章,不过他们有个共同点,就是实 ...

  8. 推荐 4 个基于 Flutter 的重磅高仿开源项目

    大家新年好呀,我是你们的 猫哥,那个不喜欢吃鱼.又不喜欢喵 的超级猫又回来啦 ~ 相信大家过年都过得开心吧 过得开心,那么就开始学习了哈 ~ 这里为你整理了 4 个 Flutter 优质的开源项目,希 ...

  9. 【Flutter应用】Flutter精仿抖音开源(1),android开发基础知识

    fijkplayer: ^0.8.3 基础的透明动画点击效果 tapped: any map安全取值 safemap: any 主要文件: ./lib ├── main.dart ├── mock │ ...

最新文章

  1. php引用php,PHP7引入的??和?:的区别讲解
  2. keras 的 example 文件 lstm_text_generation.py 解析
  3. testNG安装一直失败解决方法
  4. ios模拟器快捷键操作
  5. tensorflow入门教程和底层机制简单解说——本质就是图计算,自动寻找依赖,想想spark机制就明白了...
  6. [CNT]关于自己的一个小小的slab内存分配器
  7. c#oracle数据库操作类,Oracle数据库操作类(c#)
  8. 高并发编程-Daemon Thread的创建以及使用场景分析
  9. 面试官:ConcurrentHashMap为什么放弃了分段锁?
  10. 7 个顶级的 HTML5 Canvas 动画赏析
  11. Jupyter修改默认文件保存路径
  12. Mathematica .nb程序运行不下去的原因
  13. 除去WebView默认存在的一定像素的边距问题
  14. web电商、商城pc端、商城、购物车、订单、线上支付、web商城、pc商城、登录注册、人工客服、收货地址、现金券、优惠券、礼品卡、团购订单、评价晒单、消息通知、电子产品商城、手机商城、电脑商城
  15. Struts2(补充)
  16. 热血动漫番太好看了!用Python爬取了1T的动漫,内存都爆了
  17. 《嵌入式Linux软硬件开发详解——基于S5PV210处理器》——1.2 S5PV210处理器
  18. 手机腾讯网mt框架简介
  19. 微信消息推送渠道建设
  20. 无线投影仪服务器设置方法,无线投影仪怎么连接,看过教程,原来操作这么简单!...

热门文章

  1. android图形动画
  2. Python字符串相关方法
  3. js使用rgb和argb
  4. python五角星教程_绘制五角星_清华尹成python入门教程_少儿编程视频-51CTO学院
  5. java日期与时间戳相互转换大全
  6. 关于程序员日常接单之淘宝运营
  7. java谐音,那位有If I were a boy 谐音啊?!
  8. java判断经纬度是否在扇形内_地图学复习 (题) (带答案)
  9. matlab 画 带虚部,MATLAB1:求实部、虚部、模和幅角的运算
  10. 【经典算法题-10】背包问题(Knapsack Problem)