登录

去注册

登录

注册

去登录

注册

解锁回答区域

  • 扫码关注公众号
  • 发送“我爱安卓

若你登陆,将永久解锁;
若未登录,仅本机解锁。

解锁回答区域

Flutter 实战项目

simplezhli   2019-07-01 20:12   收藏

Flutter Deer

本项目为Flutter的学习练习项目(现阶段主要为UI练习)。

通过设置、修改、组合自带部件以及自定义来实现具体的设计效果,满足日常开发的需求。

本项目设计图见design目录,你可以通过我提供的设计图有目标的去练习。有更好的实现方案欢迎交流。

预览

部分页面效果如下:

实现效果包括

  • 基于dio + rxdart的网络请求封装(支持泛型,自动解析,基于FlutterJsonBeanFactory插件实现)
  • 输入框等部件的处理封装
  • 自定义列表滑动效果
  • PopupWindow
  • 简易的过渡动画
  • 侧滑删除
  • 城市选择
  • 类似京东的三级联动
  • 各种自定义Dialog
  • 头部列表吸顶
  • 密码输入键盘
  • 验证码输入框
  • 自定义简易日历
  • 曲线图及饼状图
  • 模块化路由管理
  • 更多的细节优化

具体可以下载体验:

Android版安装包:点击下载

iOS需要自行下载代码运行。(效果是一致的)

注意

1. `debug`模式下会有部分卡顿现象,属于正常现象。良好的体验需要打`release` 包。
    iOS可以执行命令`flutter build ios` 以创建`release`版本。
    Android可以执行命令`flutter build apk` 以创建`release`版本。
    
2. FlutterJsonBeanFactory插件使用可以查看[这篇文章](https://www.jianshu.com/p/e909f3f936d6)

3. 因为页面有点多,不清楚业务流程可能会导致部分页面无法找到。具体可以参看设计图,或者页面上都随便点点。。。

觉得还可以的话,来个Star、Fork支持一波!有问题欢迎提Issue。

项目环境

1. Flutter version 1.5.4-hotfix.2

2. Dart version 2.3.0 (build 2.3.0-dev.0.5 a1668566e5)

使用到的三方库

功能
dio网络库
cached_network_image图片缓存
fluro路由管理
flutter_oktoastToast
common_utilsDart 常用工具类库
flutter_slidable侧滑删除
flustarsFlutter 常用工具类库
flukitFlutter UI组件库
url_launcher启动URL的插件
image_picker图片选择插件
rxdartDart的响应式扩展
webview_flutterWebView插件
keyboard_actions处理键盘事件
sticky_headers列表悬浮头
azlistview城市选择列表
date_utils常用的日期工具类
bezier_chart曲线图表
sprintf格式化String

具体可以参看pubspec.yaml文件

后续计划:

  • [ ] 添加地图功能,具体实现插件见 flutter_2d_amap

  • [ ] 引入状态管理,预计使用 provider

  • [ ] 下拉刷新 + 上拉加载

TODO

已知问题:

1. ListView在没有设置分割线的情况下,个别Item之间存在大约1像素的间隔。(像素对齐问题)

2. 输入框在不设置`obscureText`属性的情况下(false),无法弹出密码模式键盘。

心得

Thanks For

License

Copyright 2019 simplezhli

Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at

   http://www.apache.org/licenses/LICENSE-2.0

Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.

项目地址:https://github.com/simplezhli/flutter_deer