zoukankan      html  css  js  c++  java
  • Android MVP 构架初试

    目前讨论MVP MVVM 的架构也来越多,这种构架也很适合Android。研究MVP记录如下

    源码地址RxMVP分支Tag02

    原有的MVC构架

    刚开始接触Android的时候会觉得Android的整个代码架构就是一个MVC。

    • M : 业务层和模型层,相当与javabean和我们的业务请求代码
    • V : 视图层,对应Android的layout.xml布局文件
    • C : 控制层,对应于Activity中对于UI 的各种操作

    看起来MVC架构很清晰,但是实际的开发中,请求的业务代码往往被丢到了Activity里面,大家都知道layout.xml的布局文件只能提供默认的UI设置,所以开发中视图层的变化也被丢到了Activity里面,再加上Activity本身承担着控制层的责任。所以Activity达成了MVC集合的成就,最终我们的Activity就变得越来越难看,从几百行变成了几千行。维护的成本也越来越高

    新的MVP架构

    • M : 还是业务层和模型层
    • V : 视图层的责任由Activity来担当
    • P : 新成员Prensenter 用来代理 C(control) 控制层

    MVP与MVC最大的不同,其实是Activity职责的变化,由原来的C (控制层) 变成了 V(视图层),不再管控制层的问题,只管如何去显示。控制层的角色就由我们的新人 Presenter来担当,这种架构就解决了Activity过度耦合控制层和视图层的问题。

    一个简单实践

    声明了一个接口,带有请求数据业务的方法

    RequestBiz

    public interface RequestBiz {
        //请求数据业务
        void requestForData(OnRequestListener listener);
    }
    

    RequestBizIml

    请求的实现类为了模拟网络请求,开启了一个会sleep 10秒的线程,然后装填请求的数据,通过OnRequestListener 接口回调出去,与我们平时开发的方式一致。

    public class RequestBizIml implements RequestBiz {
    
        @Override
        public void requestForData(final OnRequestListener listener) {
    
            new Thread(new Runnable() {
                @Override
                public void run() {
                    try {
                        Thread.sleep(1000*10);
                        ArrayList<String> data = new ArrayList<String>();
                        for(int i = 1 ; i< 10 ; i++){
                            data.add("item"+i);
                        }
                        if(null != listener){
                            listener.onSuccess(data);
                        }
                    }catch(Exception e){
                        e.printStackTrace();
                    }
                }
            }).start();
        }
    }
    

    OnRequestListener

    数据请求的回掉接口,声明了成功和失败的方法 。

    public interface OnRequestListener {
    
        void onSuccess(List<String> data);
        void onFailed();
    }
    

    到此业务层完成,开始MVP的写法.

    由于Activity变成了view层不再去控制界面,但是具体的界面的改变api其实还是由Activity来提供的,所以在写MVP之前需要思考,View层需要哪些方法。

    • 显示loading
    • 隐藏loading
    • listview的初始化
    • 弹出Toast消息

    MvpView

    写MvpView之前接口需要想想界面有哪些交互,根据业务逻辑来确定

    public interface MvpView {
         //显示loading progress
         void showLoading();
         //隐藏loading progress
         void hideLoading();
         //ListView的初始化
         void setListItem(List<String> data);
         //Toast 消息
         void showMessage(String messgae);
    }
    

    接下来开始写presenter层, 同样在写presenter之前想想控制层需要哪些方法

    • 网络请求
    • 点击事件
    public class MvpPresenter {
    
        private MvpView mvpView;
        RequestBiz requestBiz;
        private Handler mHandler;
    
        public MvpPresenter(MvpView mvpView) {
            this.mvpView = mvpView;
            requestBiz = new RequestBizIml();
            mHandler = new Handler(Looper.getMainLooper());
        }
    
        public void onResume(){
            mvpView.showLoading();
            requestBiz.requestForData(new OnRequestListener() {
                @Override
                public void onSuccess(final List<String> data) {
                   //由于请求开启了新线程,所以用handler去更新界面
                    mHandler.post(new Runnable() {
                        @Override
                        public void run() {
                            mvpView.hideLoading();
                            mvpView.setListItem(data);
                        }
                    });
    
                }
    
                @Override
                public void onFailed() {
                    mvpView.showMessage("请求失败");
                }
            });
        }
    
    
        public void onDestroy(){
            mvpView = null;
        }
    
        public void onItemClick(int position){
            mvpView.showMessage("点击了item" + position);
        }
    
    }
    

    Presenter完成,现在就剩下一件事,Activity中使用Presenter

    完整版MVPActivity

    public class MVPActivity extends AppCompatActivity implements MvpView, AdapterView.OnItemClickListener {
        @BindView(R.id.mvp_listview)
        ListView mvpListView;
    
        MvpPresenter mvpPresenter;
        SweetAlertDialog pd;
        Context mContext;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
            mContext= this;
            ButterKnife.bind(this);
            mvpListView.setOnItemClickListener(this);
            mvpPresenter = new MvpPresenter(this);
        }
    
        @Override
        protected void onResume() {
            super.onResume();
            mvpPresenter.onResume();
        }
    
        @Override
        protected void onDestroy() {
            mvpPresenter.onDestroy();
            super.onDestroy();
        }
    
        @Override
        public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
            mvpPresenter.onItemClick(position);
        }
    
        @Override
        public void showLoading() {
            if (pd == null) {
                pd = new SweetAlertDialog(mContext, SweetAlertDialog.PROGRESS_TYPE);
                pd.getProgressHelper().setBarColor(Color.parseColor("#A5DC86"));
                pd.setTitleText("Loading");
                pd.setCancelable(true);
            }
            pd.show();
        }
    
        @Override
        public void hideLoading() {
            pd.hide();
        }
    
        @Override
        public void setListItem(List<String> data) {
            ArrayAdapter adapter = new ArrayAdapter(MVPActivity.this,
                    android.R.layout.simple_list_item_1, data);
            mvpListView.setAdapter(adapter);
        }
    
    
        @Override
        public void showMessage(String message) {
            Toast.makeText(this, message, Toast.LENGTH_SHORT).show();
        }
    }
    

    源码地址:https://github.com/Javen205/RxMVP

    转载: http://blog.csdn.net/dantestones/article/details/50899235

  • 相关阅读:
    如何在iOS中使用Block(转)
    blocks 学习(转)
    关于sqlite3 top的查询
    IOS多线程编程
    iOS平台内存常见问题(转)
    关于C中数组的组织存放
    消息推送机制实现与探讨
    IOS单例模式(Singleton)
    assign copy retain
    关于浮动,怪异模式
  • 原文地址:https://www.cnblogs.com/zyw-205520/p/5813689.html
Copyright © 2011-2022 走看看