Android MVP设计架构:Model层数据传递到View层

model.request(s, new Callback<Integer, Object>() {

@Override

public Object call(Integer i) {

updateProgress(i);

return null;

}

});

}

@Override

public void progress(int i) {

}

private void updateProgress(int i) {

view.progress(i);

if (i > 0 && i < 100) {

view.status(“下载中…”);

}

if (i == 100) {

view.status(“下载完成”);

}

}

}

测试:

package zhangphil.demo;

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import android.view.View;

import android.widget.Button;

import android.widget.TextView;

public class MainActivity extends AppCompatActivity implements LoadView {

private TextView progress,status;

private Button button;

private Presenter presenter;

private AppCompatActivity activity;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

activity = this;

setContentView(R.layout.activity_main);

progress = findViewById(R.id.progress);

button = findViewById(R.id.button);

status=findViewById(R.id.status);

presenter = new LoadPresenter(this);

button.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

presenter.action(“https://zhangphil.blog.csdn.net/”);

}

});

}

@Override

public void status(final String s) {

activity.runOnUiThread(new Runnable() {

@Override

public void run() {

status.setText(s);

}

});

}

@Override

public void progress(final Integer i) {

activity.runOnUiThread(new Runnable() {

@Override

public void run() {

progress.setText(i + " %");

}

});

}

}

另外一种方案,不使用Callback回调,直接在Model层调用Presenter层预设的更新函数,在此函数里面进一步触发View的更新,如:

package zhangphil.demo;

public interface Model<T, R> {

R request(T t);

}

package zhangphil.demo;

public interface View {

void progress(T t);

}

package zhangphil.demo;

public interface Presenter {

void action(T t);

void progress(int i);

}

框架模型实现:

package zhangphil.demo;

import android.os.SystemClock;

import java.util.concurrent.CompletableFuture;

public class LoadModel implements Model<String, Object> {

private Presenter presenter;

public LoadModel(Presenter presenter) {

this.presenter = presenter;

}

/**

  • 模拟下载。

  • @param s

  • @return

*/

@Override

public Object request(String s) {

CompletableFuture.runAsync(new Runnable() {

@Override

public void run() {

for (int i = 0; i <= 100; i++) {

SystemClock.sleep(100);

presenter.progress(i);

}

}

});

return null;

}

}

package zhangphil.demo;

public interface LoadView extends View {

void status(T t);

}

package zhangphil.demo;

public class LoadPresenter implements Presenter {

private LoadView view;

private Model model;

public LoadPresenter(LoadView view) {

this.view = view;

model = new LoadModel(this);

}

@Override

public void action(String s) {

model.request(s);

}

@Override

public void progress(int i) {

updateProgress(i);

}

private void updateProgress(int i) {

view.progress(i);

if (i > 0 && i < 100) {

view.status(“下载中…”);

}

if (i == 100) {

view.status(“下载完成”);

}

}

}

测试:

package zhangphil.demo;

import android.support.v7.app.AppCompatActivity;

import android.os.Bundle;

import android.view.View;

import android.widget.Button;

import android.widget.TextView;

public class MainActivity extends AppCompatActivity implements LoadView {

private TextView progress, status;

private Button button;

private Presenter presenter;

private AppCompatActivity activity;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

activity = this;

setContentView(R.layout.activity_main);

progress = findViewById(R.id.progress);

button = findViewById(R.id.button);

status = findViewById(R.id.status);

presenter = new LoadPresenter(this);

button.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

presenter.action(“https://zhangphil.blog.csdn.net/”);

}

});

}

@Override

public void status(final String s) {

activity.runOnUiThread(new Runnable() {

@Override

public void run() {

status.setText(s);

}

});

}

写在最后

由于本文罗列的知识点是根据我自身总结出来的,并且由于本人水平有限,无法全部提及,欢迎大神们能补充~

将来我会对上面的知识点一个一个深入学习,也希望有童鞋跟我一起学习,一起进阶。

提升架构认知不是一蹴而就的,它离不开刻意学习和思考。

**这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家,**梳理了多年的架构经验,筹备近1个月最新录制的,相信这份视频能给你带来不一样的启发、收获。

最近还在整理并复习一些Android基础知识点,有问题希望大家够指出,谢谢。

希望读到这的您能转发分享和关注一下我,以后还会更新技术干货,谢谢您的支持!

转发+点赞+关注,第一时间获取最新知识点

Android架构师之路很漫长,一起共勉吧!

{

@Override

public void run() {

status.setText(s);

}

});

}

写在最后

由于本文罗列的知识点是根据我自身总结出来的,并且由于本人水平有限,无法全部提及,欢迎大神们能补充~

将来我会对上面的知识点一个一个深入学习,也希望有童鞋跟我一起学习,一起进阶。

提升架构认知不是一蹴而就的,它离不开刻意学习和思考。

**这里,笔者分享一份从架构哲学的层面来剖析的视频及资料分享给大家,**梳理了多年的架构经验,筹备近1个月最新录制的,相信这份视频能给你带来不一样的启发、收获。

[外链图片转存中…(img-NJqOLjs1-1718809640307)]

[外链图片转存中…(img-8kbnDunc-1718809640307)]

最近还在整理并复习一些Android基础知识点,有问题希望大家够指出,谢谢。

希望读到这的您能转发分享和关注一下我,以后还会更新技术干货,谢谢您的支持!

转发+点赞+关注,第一时间获取最新知识点

Android架构师之路很漫长,一起共勉吧!

  • 22
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值