Coder Social home page Coder Social logo

kanybekmomukeyev / flutter_deer Goto Github PK

View Code? Open in Web Editor NEW

This project forked from simplezhli/flutter_deer

0.0 1.0 0.0 23.61 MB

🦌 Flutter 练习项目。包括完整UI设计图,更贴近真实项目的练习。Flutter practice project. Includes a complete UI design and exercises that are closer to real projects.

License: Apache License 2.0

Java 0.92% Ruby 0.44% Objective-C 1.69% Dart 96.95%

flutter_deer's Introduction

Flutter Deer

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

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

本项目设计图见design目录,你可以通过我提供的设计图有目标的去练习。所有的实现仅是个人的学习理解,如果有更好的实现方案欢迎交流。

预览

部分页面效果如下:

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

实现效果包括

  • mvp模式
  • 使用 provider做状态管理
  • 基于dio的网络请求封装(支持泛型,基于FlutterJsonBeanFactory插件实现)
  • 使用Sliver系列组件实现复杂滚动效果
  • 使用高德地图定位选择地址
  • 输入框等部件的处理封装
  • 下拉刷新 + 上拉加载更多
  • 应用检查更新
  • PopupWindow
  • 扫码功能(barcode_scan插件)
  • 简易的过渡动画
  • 侧滑删除
  • 城市选择
  • 类似京东的三级联动
  • 各种自定义Dialog
  • 头部列表吸顶
  • 密码输入键盘
  • 验证码输入框
  • 自定义简易日历
  • 曲线图及饼状图
  • 模块化路由管理
  • 更多的细节优化

具体可以下载体验:

Android版安装包:点击下载

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

项目运行环境

1. Flutter version 1.7.8+hotfix.4
 
2. Dart version 2.4.0

注意事项

  • debug模式下会有部分卡顿现象,属于正常现象。良好的体验需要打release 包。 iOS可以执行命令flutter build ios 以创建release版本。 Android可以执行命令flutter build apk 以创建release版本。

  • FlutterJsonBeanFactory插件使用可以查看这篇文章

  • 本人也尝试过升级过稳定版本1.7.8+hotfix.21.7.8+hotfix.3,但是因为华为小米的个别机型在删除TextField中的文字会导致崩溃(具体点击查看),所以推荐采用1.7.8+hotfix.4

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

使用到的三方库

功能
dio 网络库
provider 状态管理
flutter_2d_amap 高德2D地图
cached_network_image 图片缓存
fluro 路由管理
flutter_oktoast Toast
common_utils Dart 常用工具类库
flutter_slidable 侧滑删除
flustars Flutter 常用工具类库
flutter_swiper Flutter 轮播组件
url_launcher 启动URL的插件
image_picker 图片选择插件
rxdart Dart的响应式扩展
webview_flutter WebView插件
keyboard_actions 处理键盘事件
sticky_headers 列表悬浮头
azlistview 城市选择列表
date_utils 常用的日期工具类
bezier_chart 曲线图表
sprintf 格式化String
barcode_scan 扫码功能

详细内容可以参看pubspec.yaml文件

后续计划:

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

  • 下拉刷新 + 上拉加载更多

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

  • 项目中有使用这一套框架及组件,会同步修复及优化遇到的问题。

已知问题:

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

  • 输入框在不设置obscureText属性的情况下(false),无法弹出密码模式键盘。(暂时使用BlacklistingTextInputFormatter去除可能会输入的中文)

心得及问题记录

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.

flutter_deer's People

Contributors

imgbotapp avatar simplezhli avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.