Skip to content

hlder/FinalMvp

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

37 Commits
 
 
 
 

Repository files navigation

使用各种架构的目的无非是让代码变的简洁,易读。并且在多人开发中可以展现出无限的魅力。不同的层可以让不同的人开发,互相独立并互相影响!
框架就是将原本需要一大堆代码的统一起来,来简化代码的编辑。

mvp

Model-View-Presenter的简写,mvp就是一种设计模式,不懂的自己百度一下。

Finalmvp

我们在Android开发中用的最多的无非就是多线程,为了避免手机卡顿,我们在做耗时操作时必须在子线程中执行,而执行完成后又需要在主线程中去做UI操作。 这样就会需要写很多的代码,并且还要考虑子线程主线程的关系,逻辑复杂了之后就容易产生一些意想不到的bug让我们头疼。
这里需要感谢rxjava,让多线程变得不用我们管,哈哈!没错,finalmvp使用了rxjava进行多线程处理,并将rxjava和mvp完美结合。 我们写代码的时候无需关心rxjava,只需要根据 规则编辑代码,便可以编辑出简洁易读并且性能优异的优秀代码,哈哈- -
那就让我们来看看这个神秘的finalmvp吧!

上代码

这里做一个查询天气的demo
在使用前需要rxJava依赖

    implementation 'io.reactivex.rxjava2:rxjava:2.2.2'
    implementation 'io.reactivex.rxjava2:rxandroid:2.1.0'

1.MainView

public interface MainView {
    /**
     * 显示天气的文字
     */
    void showWeatherText(String text);

}

2.MainActivity需要实现MainView接口,并且需要在class上加上@View注解以表示是View层

@View
public class MainActivity extends AppCompatActivity implements MainView{
    @Autowired
    MainPresenter mainPresenter;
    
    private TextView textView;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        textView=findViewById(R.id.textView);
        Finalmvp.init(this);//初始化finalmvp,框架自动扫描注解
    }
    @Override
    public void showWeatherText(String text) {
        textView.setText(text);
    }
}

3.Presenter

public interface MainPresenter {
    void loadWeather();
}

4.MainPresenterImpl实现Presenter,并且需要在class上方加上注解@Presenter,以表示是Presenter层

@Presenter
public class MainPresenterImpl implements MainPresenter{
    @Autowired
    MainView mainView;

    @Autowired
    MainModel mainModel;

    @Override
    public void loadWeather() {
        /**
         * 此处做数据处理,处理完后,在主动让view去修改UI
         */
        Weather weather=mainModel.loadWeatherFromUrl();//获取天气预报信息
        String reslut="";
        if(weather!=null){
            reslut="城市:"+weather.getCity()+"  最低温度:"+weather.getTemp1()+"   最高温度:"+weather.getTemp2()+"    天气情况:"+weather.getWeather();
        }
        mainView.showWeatherText(reslut);
    }
}

5.MainModel直接新建一个model类加上@Model注解

@Model
public class MainModel {
    /**
     * 从服务器获取天气数据,对数据进行基本处理,转成需要的格式(如json,bean,string等)
     * 不需要多线程,直接同步执行就行了
     */
    public Weather loadWeatherFromUrl(){
        String jsonStr=doHttp("http://www.weather.com.cn/data/cityinfo/101010100.html");
        JSONObject jo=JSON.parseObject(jsonStr);
        JSONObject weatherinfo=jo.getJSONObject("weatherinfo");
        Weather weather=weatherinfo.toJavaObject(Weather.class);
        return weather;
    }
    /**
     * 执行http请求
     * 这里只是为演示使用,建议自己使用okhttp等框架
     * 需要同步执行,不需要使用框架内的异步操作
     */
    public static String doHttp(String urlStr) {
        try {
            URL u = new URL(urlStr);
            InputStream in = u.openStream();
            ByteArrayOutputStream out = new ByteArrayOutputStream();
            try {
                byte buf[] = new byte[1024];
                int read;
                while ((read = in.read(buf)) > 0) {
                    out.write(buf, 0, read);
                }
            } finally {
                if (in != null) {
                    in.close();
                }
            }
            byte b[] = out.toByteArray();
            String result=new String(b, "utf-8");
            return result;
        }catch (Exception e){
            e.printStackTrace();
        }
        return "aaaaa";
    }
}

提醒

代码看到这里有人就有疑问了,为什么请求http没有在子线程中执行,哈哈!告诉你们在Presenter运行的时候就已经在子线程了。

完结

到这里就完成了,这样就层次很清晰了。并且不需要操作任何多线程的代码,但实际在Presenter的时候就已经在子线程执行了!

使用方法:

1.Add it in your root build.gradle at the end of repositories:

allprojects {
	repositories {
		...
		maven { url 'https://jitpack.io' }
	}
}

2.Add the dependency

dependencies {
        implementation 'com.github.yuanfen7650:Finalmvp:1.9.5'
}