Git Product home page Git Product logo

darren-chenchen / flutter_flowermusic Goto Github PK

View Code? Open in Web Editor NEW
461.0 11.0 119.0 3.49 MB

使用flutter编写的音乐项目,服务器是使用nodejs+mongodb简单搭建的,主要功能包括登录、注册、修改密码、收藏、分享、评论、上传图片、富文本、音频播放、flutter与原生交互、手势、选择图片、上拉加载、下拉刷新等功能。功能较多、但是没有太多的业务逻辑,对于初学者来说很容易看明白。具体的功能和特点请参考demo

License: MIT License

Java 10.24% Ruby 1.17% Swift 8.03% Objective-C 0.01% Dart 80.27% Shell 0.27%

flutter_flowermusic's Introduction

备注:

2019年谷歌推出Provider,代替 Provide 成为官方推荐的状态管理方式,Provide已经不再维护,所有项目已经逐渐替换成了Provider,项目默认分支是provider,可下载该分支查看。

开发环境 flutter v1.12.13+hotfix.5(如有报错可能跟flutter版本相关,可根据个人的flutter版本进行调整)

阅读之前

1、部分截图

()

安卓请扫码下载体验,ios没有证书,无法下载。密码123

项目结构

(logo)

该项目的特点

1、使用mvvm架构编写。 MVVM架构在Flutter中的简单实践

2、Provider和RxDart 的使用

部分封装介绍

1、refresh组件:刷新组件是在pull_to_refresh的基础上进行的再次封装,该库本身是存在一些问题的,所以就自己改了一下使用。希望该库持续更新,还有其他的刷新库,这里就不详细说了。主要是我们在使用时最好能够读懂别人的组件库的代码,这样才能更好的解决问题。也是一种学习方式。pull__to__refresh

2、OpacityTapWidget组件:OpacityTapWidget组件解决了2个问题:

1)点击效果:点击时child有一个透明度的变化

2)点击的热区问题: OpacityTapWidget内部设置padding增加了点击的热区。

new OpacityTapWidget(
    onTap: () {
        Navigator.of(context).pop();
    },
    child: new Icon(Icons.close, color: Colors.white,size: 27,),
)

3、TapWidget组件:和OpacityTapWidget不一样的是TapWidget点击的效果是背景颜色的变化。

部分第三方库的封装与介绍

1.dio 网络请求封装: Dio

  • Dio初始化
dio = new Dio()
      ..options = BaseOptions(
          baseUrl: AppConfig.baseUrl,
          connectTimeout: 30000,
          receiveTimeout: 30000)
      ..interceptors.add(HeaderInterceptor());
      ..interceptors.add(LogInterceptor(responseBody: true, requestBody: true)); 
  • 拦截器
class HeaderInterceptor extends Interceptor {
  @override
  onRequest(RequestOptions options) {
    final token = AppConfig.userTools.getUserToken();
    if (token != null && token.length > 0) {
      options.headers.putIfAbsent('Authorization', () => 'Bearer' + ' ' + token);
    }
//    if (options.uri.path.indexOf('api/user/advice/Imgs') > 0 || options.uri.path.indexOf('api/user/uploadUserHeader') > 0) { // 上传图片
//      options.headers.putIfAbsent('Content-Type', () => 'multipart/form-data');
//      print('上传图片');
//    } else {
//    }
//    options.headers.putIfAbsent('Content-Type', () => 'application/json;charset=UTF-8');

    return super.onRequest(options);
  }
}
  • 属性监听
方式1:
final subjectMore = new BehaviorSubject<bool>.seeded(false);
方式2:
final subjectMore = new BehaviorSubject<bool>();

subjectMore.value = false
_provide.subjectMore.listen((hasMore) {
});

方式1与方式2的不同是,方式1再初始化时就会触发,监听者会在初始化时监听到false参数。

3.flutter_svg 初始化svg格式的图片

new SvgPicture.asset("images/is_single.svg", width: 28, height: 28);

4.shared_preferences 数据存储

由于数据的存储和获取是异步的,但是在项目中使用同步的方法获取用户信息就很是有必要,所以该项目再初始化之前就初始化了shared_preferences,解决了在项目中使用同步的方法获取用户信息这个问题。

void main() async {
  /// 先初始化shared_preferences
  await AppConfig.init();
  runApp(MyApp());
}

最后

1、建议大家把重点放在项目架构的优化上面(mvvm)。

2、该项目只供学习交流使用,严禁用于商业用途.....

有任何问题或者需要服务器端代码可进群:625200323

()

flutter_flowermusic's People

Contributors

darren-chenchen avatar nicew avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

flutter_flowermusic's Issues

provide-provider

我看项目简介里是provide,但是项目里使用的是provider,这个项目状态管理是不是已经全部替换成provider ?

项目跑不起来

错误代码 `* What went wrong:
Execution failed for task ':app:preDebugBuild'.’

Android dependency 'androidx.vectordrawable:vectordrawable' has different version for the compile (1.0.0) and runtime (1.0.1) classpath. You should manually set the same version via DependencyResolution`
AS版本
批注 2019-12-12 000945

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.