Flutter豆瓣客户端,诚心开源

2023-12-18 14:58

本文主要是介绍Flutter豆瓣客户端,诚心开源,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

视频Demo

全项目首页概览

Mar-10-2019 14-12-55.gif

Mar-10-2019 14-13-11.gif

Mar-10-2019 14-17-38.gif

Mar-10-2019 14-17-48.gif

Mar-10-2019 14-18-03.gif

Mar-10-2019 14-18-12.gif

Mar-10-2019 14-18-23.gif

Mar-10-2019 14-30-58.gif

Mar-10-2019 14-31-13.gif

Mar-10-2019 14-32-29.gif

Mar-10-2019 14-32-41.gif

Mar-10-2019 14-33-02.gif

前言

终于,终于写完了。这个项目是我从年前开始写的,然后今年过年没有回家,除了大年三十没有提交代码,有空余时间就一直在写,过完年大年初一就开始写了~~。功夫不负有心人,终于,现在来看是一个成熟度较为满意的作品,才敢拿出来跟大家一起分享。

缘起

忘记关注哪个公众号了,真正接触flutter是18年,算起来是比较晚的了。不过勤能补拙,现在也来的及,只要想学就不晚。如果学习一个知识点,就写个demo就以为掌握了,大错特错。我们更多的是从实际出发利用知识点,完成实际任务。将众多Widget灵活使用,不断的碰壁,解决bug,最终就能够真正的理解这个Widget以及相关知识点。所以,我没有写个demo就完事了。我直接拿一个APP,盘它就好了。

首先说一下,为啥仿豆瓣。因为,总体来看(个人感触,勿喷),豆瓣APP中的UI涉及到的动画、排版,交互等等都是十分优秀的,最重要的是涉及到各种各样的UI,对于学习flutter是一个很好的平台。(还有一点:豆瓣有一些公开的api,这个最重要)其实对于一个Widget的功能点,我们都可以娓娓道来,但是将众多Widget糅合到一起还是有一定的挑战的。挑战意味着机会,意味着能力。

项目能学到什么

定了一个小目标:看到的UI,100%还原。我就以这个为基本线,最终达到了差不多90%的还原吧。

  • 仿了豆瓣APP的90%的页面,UI的样式、页面搭配等等,争取到了90%还原。

  • 整个项目涉及到Flutter 90%的基础Widget,以及各种情景的搭配组合。

某些flutter没有的Widget,这就需要我自己去找了,但是网上没有合适的轮子。我就直接改源码了。例如:

  • 魔改源码实现首页头部特效

     

    header.gif

网上没有类似的,不过flutter原生有类似的。所以就翻源码改。最终实现了一样的效果。这番改动,使得我对flutterAppBar以及flutter的动画有了更深的认识。

  • 打造100%抽屉

drawer.gif

flutter中是没有类似的Widget。所以,我只能自己干。为了实现100%还原这个页面,耗费了我好几个晚上的时间,最终成功了。经过这个洗礼,加深了我对Animation,ScrollNotificationListener,GestureRecognizer等的理解。

  • 影视详情动态背景色

在豆瓣APP中,最吸引我之一的就是豆瓣APP的影视详情的背景色是动态的。每个背景色均是不同的。当然,我这里也实现了。

dymiccolor.gif

详情的颜色根据海报的主题变动

关于这些,我就是举个简单的例子。有些东西,要强迫自己一下。或许收获到更多惊喜。这两个比较难的组件,我在源码中关于思路以及方法都有注释,大家可以去看下。

目的

我写这个项目的初衷,就是跟大家分享知识的。所以,今天我会将GitHub上的项目设置为公开。是时候展示真正的技术了哈~
这个项目中,90%的flutter基础Widget都有使用到,各种百搭情景都有涉及。基本上每个文件都有相关注释。部分方法也有想对应的注释。毕竟是为了分享么。目前的最新分支是master-new,大家可以pull下来后直接在master-new上编译。

开源

最重要的是,大家可以提交代码~~,目前新建了一个dev-open分支。由于本豆芽APP还没完全写完,想锻炼自己的可以向这个分支提交代码。

大家可以向这个分支根据豆瓣UI做设计稿,提交代码

  • 这个分支供广大Flutter开发者来学习Flutter
  • 此分支囊括了Flutter 90%的组件的基本与组合使用,是初学者真正实践的不错选择
  • 在此豆芽APP的首页实现与影片详情的UI特效,基于魔改Flutter源码。有兴趣可以看看
  • 大家想实战自己的Flutter能力,可以将某瓣APP作为设计稿,完成需求,并提交
  • 每位开发者提交的代码,我都会在文档中进行备注

未来版本计划(欢迎Flutter爱好者前来认领)

欢迎Flutter爱好者共同完成

涉及到UI,可参考豆瓣。

萌新TASK

  • 完成任意一个未实现的按钮
  • 完成任意一个未实现的页面
  • 优化原有Widget
  • 爱好者想实现但是未能实现的需求
  • More ...

进阶TASK

  • 优化代码
  • 适当缓存数据
  • 解决卡顿(可参考:https://flutter-io.cn/docs/testing/ui-prformance)
  • 优化路由(可参考咸鱼方案:https://www.yuque.com/xytech/flutter/vf1dpf)

老手TASK

  • 接入rxdart
  • 使用Fish Redux 重构

时至今日,看到一个完整的Flutter项目在自己手中一点点打造出来,满满的成就感。当然,更多的是要分享与大家。来,大家一起学习Flutter,共同进步,提升自己的能力。谢谢大家~

豆芽apk体验下载(10MB)

扫一扫下载豆芽apk体验

源码地址

各位大佬,给个start白~ https://github.com/kaina404/FlutterDouBan

博客地址

Flutter Container
Flutter SafeArea
Flutter Row Column MainAxisAlignment Expanded
Flutter Image全解析
Flutter 常用按钮总结
Flutter ListView豆瓣电影排行榜
Flutter Card
Flutter Navigator&Router(导航与路由)
OverscrollNotification不起效果引起的Flutter感悟分享
Flutter 上拉抽屉实现
Flutter 豆瓣客户端,诚心开源
Flutter 更改状态栏颜色

 

 



作者:徐爱卿
链接:https://www.jianshu.com/p/eee1a97090c0
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。

这篇关于Flutter豆瓣客户端,诚心开源的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/508809

相关文章

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

金融业开源技术 术语

金融业开源技术  术语 1  范围 本文件界定了金融业开源技术的常用术语。 本文件适用于金融业中涉及开源技术的相关标准及规范性文件制定和信息沟通等活动。

安全管理体系化的智慧油站开源了。

AI视频监控平台简介 AI视频监控平台是一款功能强大且简单易用的实时算法视频监控系统。它的愿景是最底层打通各大芯片厂商相互间的壁垒,省去繁琐重复的适配流程,实现芯片、算法、应用的全流程组合,从而大大减少企业级应用约95%的开发成本。用户只需在界面上进行简单的操作,就可以实现全视频的接入及布控。摄像头管理模块用于多种终端设备、智能设备的接入及管理。平台支持包括摄像头等终端感知设备接入,为整个平台提

K8S(Kubernetes)开源的容器编排平台安装步骤详解

K8S(Kubernetes)是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。以下是K8S容器编排平台的安装步骤、使用方式及特点的概述: 安装步骤: 安装Docker:K8S需要基于Docker来运行容器化应用程序。首先要在所有节点上安装Docker引擎。 安装Kubernetes Master:在集群中选择一台主机作为Master节点,安装K8S的控制平面组件,如AP

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

MiniGPT-3D, 首个高效的3D点云大语言模型,仅需一张RTX3090显卡,训练一天时间,已开源

项目主页:https://tangyuan96.github.io/minigpt_3d_project_page/ 代码:https://github.com/TangYuan96/MiniGPT-3D 论文:https://arxiv.org/pdf/2405.01413 MiniGPT-3D在多个任务上取得了SoTA,被ACM MM2024接收,只拥有47.8M的可训练参数,在一张RTX

HomeBank:开源免费的个人财务管理软件

在个人财务管理领域,找到一个既免费又开源的解决方案并非易事。HomeBank 正是这样一个项目,它不仅提供了强大的功能,还拥有一个活跃的社区,不断推动其发展和完善。 开源免费:HomeBank 是一个完全开源的项目,用户可以自由地使用、修改和分发。用户友好的界面:提供直观的图形用户界面,使得非技术用户也能轻松上手。数据导入支持:支持从 Quicken、Microsoft Money

开源分布式数据库中间件

转自:https://www.csdn.net/article/2015-07-16/2825228 MyCat:开源分布式数据库中间件 为什么需要MyCat? 虽然云计算时代,传统数据库存在着先天性的弊端,但是NoSQL数据库又无法将其替代。如果传统数据易于扩展,可切分,就可以避免单机(单库)的性能缺陷。 MyCat的目标就是:低成本地将现有的单机数据库和应用平滑迁移到“云”端

Java Websocket实例【服务端与客户端实现全双工通讯】

Java Websocket实例【服务端与客户端实现全双工通讯】 现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发 出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏 览器需要不断的向服务器发出请求,然而HTTP

Python:豆瓣电影商业数据分析-爬取全数据【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】

**爬取豆瓣电影信息,分析近年电影行业的发展情况** 本文是完整的数据分析展现,代码有完整版,包含豆瓣电影爬取的具体方式【附带爬虫豆瓣,数据处理过程,数据分析,可视化,以及完整PPT报告】   最近MBA在学习《商业数据分析》,大实训作业给了数据要进行数据分析,所以先拿豆瓣电影练练手,网络上爬取豆瓣电影TOP250较多,但对于豆瓣电影全数据的爬取教程很少,所以我自己做一版。 目