Step 1. Add the JitPack repository to your build file
Add it in your root settings.gradle at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url 'https://jitpack.io' }
}
}
Add it in your settings.gradle.kts at the end of repositories:
dependencyResolutionManagement {
repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositories {
mavenCentral()
maven { url = uri("https://jitpack.io") }
}
}
Add to pom.xml
<repositories>
<repository>
<id>jitpack.io</id>
<url>https://jitpack.io</url>
</repository>
</repositories>
Add it in your build.sbt at the end of resolvers:
resolvers += "jitpack" at "https://jitpack.io"
Add it in your project.clj at the end of repositories:
:repositories [["jitpack" "https://jitpack.io"]]
Step 2. Add the dependency
dependencies {
implementation 'com.github.limedroid:xdroidmvp:2.0.1'
}
dependencies {
implementation("com.github.limedroid:xdroidmvp:2.0.1")
}
<dependency>
<groupId>com.github.limedroid</groupId>
<artifactId>xdroidmvp</artifactId>
<version>2.0.1</version>
</dependency>
libraryDependencies += "com.github.limedroid" % "xdroidmvp" % "2.0.1"
:dependencies [[com.github.limedroid/xdroidmvp "2.0.1"]]
#XDroidMvp 轻量级的Android MVP快速开发框架
XDroidMvp是XDroidAndroid快速开发框架的MVP版本,其使用方式类似于XDroid
,大部分源码也来自XDroid
。
XDroidMvp全新文档:https://github.com/limedroid/XDroidMvp/wiki
<p align="center"> <img src="art/XdroidMvp_total.png"/> </p>XDroidMvp
主要会有这些特性:
无需写Contract
! 无需写Present
接口! 无需写View
接口!
新增:
RxJava
& RxAndroid
RxPermission
RxBus
Retrofit
+ rx
Https
android-x
分支保留:
XActivity
、XFragment
、SimpleRecAdapter
、SimpleListAdapter
等基类,可快速进行开发XRecyclerView
,可实现绝大部分需求XStateController
、XRecyclerContentLayout
实现loading、error、empty、content四种状态的自由切换Memory
、Disk
、SharedPreferences
三种方式的缓存,可自由扩展RxBus
,可自由切换到其他事件订阅库Glide
,可自由切换其他图片加载库Log
,支持Json
、Xml
、Throwable
等,蝇量级实现package
、random
、file
...,提供的都是非常常用的方法XCodec
,你想要的加密姿势都有先睹为快
你可以这么使用:
BasePagerFragment
public abstract class BasePagerFragment extends XFragment<PBasePager>{
@Override
public void initData(Bundle savedInstanceState) {
getP().loadData(getType(), 1); //调用P方法
}
public void showData(int page, GankResults model) {
if (page > 1) {
getAdapter().addData(model.getResults());
} else {
getAdapter().setData(model.getResults());
}
contentLayout.getRecyclerView().setPage(page, MAX_PAGE);
if (getAdapter().getItemCount() < 1) {
contentLayout.showEmpty();
return;
}
}
@Override
public PBasePager newP() {
return new PBasePager();
}}
@Override
public int getLayoutId() {
return R.layout.fragment_base_pager;
}
PBasePager
public class PBasePager extends XPresent<BasePagerFragment> {
protected static final int PAGE_SIZE = 10;
public void loadData(String type, final int page) {
Api.getGankService().getGankData(type, PAGE_SIZE, page)
.compose(XApi.<GankResults>getApiTransformer())
.compose(XApi.<GankResults>getScheduler())
.subscribe(new ApiSubcriber<GankResults>() {
@Override
protected void onFail(NetError error) {
getV().showError(error); //调用V方法
}
@Override
public void onNext(GankResults gankResults) {
getV().showData(page, gankResults);
}
});
}
}
使用,仅需四步:
clone 'XDroid'库到本地:
git clone https://github.com/limedroid/XDroidMvp.git
将mvp
作为依赖库,在您的app module 中 添加如下依赖:
compile project(':mvp')
拷贝conf.gradle
到您的项目根目录,并修改项目gradle文件下引入:
apply from: "conf.gradle"
并添加:
allprojects {
repositories {
jcenter()
maven { url "https://jitpack.io" }
}
}
修改XDroidConf
配置类,主要针对log、cache、router、imageloader。若采用默认配置,此步骤可略过.
allprojects {
repositories {
jcenter()
maven { url "https://jitpack.io" }
}
}
dependencies {
implementation 'com.github.limedroid:XDroidMvp:v2.0.1'
}
@BindView
,可以去项目官网查看。Email : droidlover@126.com
XDroid交流群:153569290
XDroid MVC版本:XDroid
若您在使用过程中遇到任何问题,欢迎加入 153569290 群或者是邮件反馈,谢谢您的关注。XDroidMvp会持续维护,如果喜欢,记得star fork。