前言java
首先我要说明的是:我知道MVP已经成为主流,可是鉴于本人的思惟还没能理解,打算先从标准MVC入手,而后转入MVP模式。过程其实仍是颇有趣的,最重要的事情是理解思想。android
思想web
MVC实际上是【model、view、controller】这三个词的简称,就算是把这几个直接翻译过来也不是很好理解。从view提及,view就是你眼睛看到的,手指摸到的那些东西,由于是一些可视化的东西因此起了这么个名字。model主要是用来进行一些耗时操做的,例如,联网请求都放在这里头是比较好的。controller,是起到链接model和view的功能。你联网获取到了一些数据,而后须要让它显示出来,这个操做须要controller来完成。因此你看他的名字实际上叫作控制器,控制输入【来自于model中的联网数据】控制输出【使数据显示在view上】,因此实际上activity每每扮演的就是controller的职责,可是实际上,因为不少开发者对于架构的体会不明朗,常常把联网操做与UI绘制都写在activity中,这样的话会致使activity的负担太重。为了不这一现象应该对结构进行合理安排。架构
实例【以Retrofit联网为例】ide
先看主页布局svg
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="click here to connect by retrofit"
android:textAllCaps="false" />
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_margin="10dp" />
点击按钮进行联网而且把联网获取到的数据显示在textview中,若是失败则显示联网数据获取失败。
这里主要贴出model与controller包下的代码。
- model-KpiInfoModel.java布局
public interface KpiInfoModel {
void getKpiInfo(Map params, OnKpiInfoListener listener);
}
model-OnKpiInfoListener.java
public interface OnKpiInfoListener {
void onSuccess(ResultBean resultBean);
void onFailed();
}
以上KpiInfoModel 主要是用于提供进行联网动做的入口方法,这里看起来会有一点吃力。一样的,OnKpiInfoListener 提供了联网之后的操做方法。而后咱们须要去实现这两个接口,而且重写里面的方法。this
model-KpiInfoModelImp.java
public class KpiInfoModelImp implements KpiInfoModel {
@Override
public void getKpiInfo(Map params, final OnKpiInfoListener listener) {
Call> call = MainApplication.factory.getKpiInfo(params);
call.enqueue(new Callback>() {
@Override
public void onResponse(Call> call, Response> response) {
if (response.isSuccessful() && response.body() != null) {
listener.onSuccess(response.body());
} else {
onFailure(call, null);
}
}
@Override
public void onFailure(Call> call, Throwable t) {
listener.onFailed();
}
});
}
}
以上就是联网的model,而且以及写好了实现类,用于在controller中使用。spa
controller-MainActivity.java
public class MainActivity extends AppCompatActivity implements OnKpiInfoListener {
private Button btnMain;
private TextView tvMain;
private KpiInfoModelImp kpiInfoModel;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.acticity_home);
initView();
kpiInfoModel = new KpiInfoModelImp();
btnMain.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Map params = new HashMap<>();
params.put("user_id", "198");
kpiInfoModel.getKpiInfo(params, MainActivity.this);
}
});
}
private void initView() {
btnMain = (Button) findViewById(R.id.btnMain);
tvMain = (TextView) findViewById(R.id.tvMain);
}
@Override
public void onSuccess(ResultBean resultBean) {
tvMain.setText(resultBean.getResult_data().toString());
}
@Override
public void onFailed() {
tvMain.setText("数据获取失败");
}
}
经过以上实例代码能够看出,activity只起到了和view互动的做用,只针对view进行操做,而联网部分则所有是在model里,这样对与业务的分离具备好处。但也具备必定的劣势,能够看出model的这块代码较为琐碎,也许是我本人封装的很差。但从把MVC理解透彻对于之后转入MVP应该具备必定的好处。翻译