目前讨论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 data = new ArrayList();                    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 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 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 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 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

更多相关文章

  1. android连续点击出现多个Activity界面
  2. Android我还可以相信你多少系列文章二之音视频播放
  3. Android我还可以相信你多少系列文章二之音视频播放
  4. Android:从零开始打造自己的深度链接库(四):DeepLinkSo实战
  5. Android简单语音控制应用的实现
  6. 浅谈Android中MVC、MVP、MVVM模式(二)
  7. Android命令行下运行JAVA程序之StatusBar控制
  8. 我的Android重构之旅:框架篇
  9. 浅谈Android中MVC、MVP、MVVM模式(二)

随机推荐

  1. android自带图片资源图标一览,android.R.d
  2. Android 使用View的旋转实现漂亮的动画效
  3. android studio 简单二维码扫描实现
  4. Android之解析Android Map地图返回的Json
  5. 基于 Android(安卓)NDK 的学习之旅-----
  6. Android架构分析之硬件抽象层(HAL)
  7. Activity has leaked window that was or
  8. Android P系统输出图像镜像翻转实现
  9. 使用logcat命令
  10. ImageView设置图片大小