An architecture for Android as a replacement of MVC.
Because you want to have more readable, testable code.
Avoid "God Objects", mainly your Activities or Fragments.
Separation of responsibilities by module:
Presenter
: Get a Business Object from the DataProvider and give instructions to the ViewProxyDataProvider
: Communicate with the "outside" to set and get the data, following the instructions of the PresenterViewProxy
: Convert Presenter instructions and set values to Android Views.
Leak safe.
Don't hold a strong reference to the DataProvider
, Presenter
, or ViewProxy
.
The goal is to make this application:
Each public method of the modules are defined into an interface:
public interface FormDef {
interface IPresenter extends Base.IPresenter {
void onClickSaveButton(String value);
}
interface IDataProvider extends Base.IDataProvider {
String getValueSaved();
void saveValue(String value);
}
interface IView extends Base.IView {
void setValueSaved(String text);
}
}
Then you have your:
FormPresenter
that extendsBasePresenter
and implementsFormDef.IPresenter
FormDataProvider
that extendsBaseDataProvider
and implementsFormDef.IDataProvider
FormViewProxy
that extendsBaseViewProxy
and implementsFormDef.IView
The easiest way to use this architecture is to override BaseActivity
, even if it's NOT mandatory.
public class FormActivity extends BaseActivity<FormPresenter, FormViewProxy> {
@Override
public int getContentView() {
return R.layout.activity_form;
}
@Override
public Class<FormPresenter> getPresenterClass() {
return FormPresenter.class; // the class of your presenter to be used within this activity
}
@Override
public FormViewProxy newViewProxy(FormPresenter presenter, Bundle savedInstanceState) {
return new FormViewProxy(this); // the view proxy, with the Activity in param
}
}
Note: it also exists a BaseFragment
to do exactly the same but within a Fragment.
Because BasePresenter
extends ViewModel
(from Android Architecture), it is possible to re-use the same Presenter after a rotation for example.
When you are using BaseActivity
, your presenters will be automatically re-used.
Note: in this case, the DataProvider will also be kept, but you will have to re-create the ViewProxy
.
This library has a dependency on Efficient Adapter to use the same view cache mechanism.
This allows to apply the Presentation pattern to object in an Adapter
as well. Your ViewHolder
should extend PresenterViewHolder
and your Presenter
should extend BaseItemPresenter
.
Nothing special needed.
dependencies {
compile 'com.skocken:presentation:2.4.1'
}
Please fork this repository and contribute back using pull requests.
Any contributions, large or small, major features, bug fixes, unit/integration tests are welcomed and appreciated but will be thoroughly reviewed and discussed.