preface
In daily development, there are many common parts in every Activity or Fragment, such as Toast, ButterKnike, startActivity, init(), etc. You can encapsulate a BaseActivity based on the Activity, extracting ButterKnike and injecting objects, such as presenter objects. Component can also be extracted into a parent class (including the generic getApplication).
The purpose of doing this is a encapsulation, convenient subclass use, do not need to write in each Activity, Fragment always write the same code, repeat the work out of the parent class, you can inherit the parent class.
The following describes how to encapsulate activities, fragments, and Presenter in a project.
Acitvity packaging and use
BaseActivity
Inherit AppCompatActivity, override the onCreate() method, and set the layout file, but this layout should be provided by subclasses (each Activity has a different layout), so the code defines an abstract method setLayout() for subclasses to implement. Provide your own layout.
Anything else provided by a subclass can define an abstract method in the parent class and let the subclass implement it. Of course, the encapsulated Activity must be declared as abstract.
You can also provide some common methods: startActivity()
In addition, you can extract common things into the parent onCreate() method, such as the ButterKnife control binding and Component injection.
public abstract class BaseActivity<T extends BasePresenter> extends AppCompatActivity { private Unbinder mUnbinder; // Unbind butterknife private AppApplication mApplication; @inject T mPresenter; // Pull out Presenter, generic representation, @Override protected void onCreate(@nullable Bundle savedInstanceState) {// Some render of the font icon LayoutInflaterCompat.setFactory(getLayoutInflater(), new IconicsLayoutInflater(getDelegate())); super.onCreate(savedInstanceState); setContentView(setLayout()); mUnbinder = ButterKnife.bind(this); this.mApplication = (AppApplication) getApplication(); / / the commonly used directly in the parent class to get good things, a subclass directly enjoy setupAcitivtyComponent (mApplication. GetAppComponent ()); init(); } @override protected void onDestroy() {super.ondestroy (); if(mUnbinder ! =Unbinder.EMPTY){ mUnbinder.unbind(); } } // protected void startActivity(Class c){ // // this.startActivity(new Intent(this,c)); //} // // provides many public methods, so that each Activity does not need to write the required method // subclasses implement this method, set their own cloth public abstract int setLayout(); public abstract void setupAcitivtyComponent(AppComponent appComponent); Public void init(); public void init(); }Copy the code
MainActivity
The Activity wrapper is introduced above, and the BaseActivity wrapper is inherited below to realize several abstract methods of the abstract class.
public class MainActivity extends BaseActivity { @BindView(R.id.navigation_view) NavigationView mNavigationView; @BindView(R.id.drawer_layout) DrawerLayout mDrawerLayout; @BindView(R.id.tool_bar) Toolbar mToolBar; @BindView(R.id.tab_layout) TabLayout mTabLayout; @BindView(R.id.view_pager) ViewPager mViewPager; private View headerView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); } @override public int setLayout() {return r.layout.activity_main; } // appComponent passed from the parent class, @override public void setupAcitivtyComponent(AppComponent AppComponent) {} @override public void init() { initDrawerLayout(); initTablayout(); }..}Copy the code
Fragment encapsulation and use
Fragment encapsulation is basically the same as Activity encapsulation. Based on the above encapsulation, you can quickly encapsulate the BaseActvity.
BaseFragment
Inherit Fragment and override onCreateView() method.
Public abstract class BaseFragment<T extends BasePresenter> extends Fragment {private Unbinder mUnbinder; private AppApplication mApplication; private View mRootView; @Inject T mPresenter ; // As with BaseActivity, Nullable @Override public View onCreateView(LayoutInflater inflater, @nullable ViewGroup container, @Nullable Bundle savedInstanceState) { mRootView = inflater.inflate(setLayout(), container, false); // Like BaseActivity, Layout () is implemented by subclasses and provides the layout. mUnbinder= ButterKnife.bind(this, mRootView); // Return mRootView; } @Override public void onActivityCreated(@Nullable Bundle savedInstanceState) { super.onActivityCreated(savedInstanceState); this.mApplication = (AppApplication) getActivity().getApplication(); / / like BaseActivity setupAcitivtyComponent (mApplication getAppComponent ()); init(); } @Override public void onDestroy() { super.onDestroy(); if(mUnbinder ! = Unbinder.EMPTY){ mUnbinder.unbind(); } } public abstract int setLayout(); Public abstract void setupAcitivtyComponent(AppComponent AppComponent); public abstract void init(); }Copy the code
Encapsulation is basically the same as BaseActivity encapsulation.
RecommendFragment
Inherit the BaseFragment encapsulated above and implement a few abstract methods.
// BaseFragment specifies the type of Presenter: RecommendPresenter public class RecommendFragment extends BaseFragment<RecommendPresenter> implements RecommendContract.View { @BindView(R.id.recycle_view) RecyclerView mRecyclerView; private RecomendAppAdatper mAdatper; @Inject ProgressDialog mProgressDialog; @Override public int setLayout() { return R.layout.fragment_recomend; } @override public void setupAcitivtyComponent(AppComponent) AppComponent) {// The appComponent argument is passed from the parent class, Call this method is the parent class DaggerRecommendComponent. Builder () appComponent (appComponent). RemmendModule (new RemmendModule(this)).build().inject(this); } @Override public void init() { mPresenter.requestDatas(); //mPresenter comes from the parent class}..}Copy the code
The encapsulation of activities and fragments is so simple, but the specific encapsulation method must be based on their own business needs or personal preferences. Now, the encapsulation of Presenter.
The encapsulation and use of Presenter
Presenters often use two things: Model and View define generics, and subclasses that extend BasePresenter specify the type of the generic.
BasePresenter
public class BasePresenter<M,V extends BaseView> { protected M mModel; protected V mView; Public BasePresenter(M M, v v){this.mmodel = M; this.mView = v; }}Copy the code
In a subclass, call the parent class’s constructor through its own constructor, so that the subclass can easily use model and view objects
RecommendPresenter
BasePresenter already extracts model and View so that subclasses don’t always have to go to new to get objects, but just pass them through the constructor.
Public class RecommendPresenter extends BasePresenter < RecommendModel RecommendContract. View > {/ / where the need to rely on to use this annotation: System-system-System-System-System-System-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system-system.html RecommendContract.View view) { super(model, view); Public void requestDatas() {mview.showlodading ();} public void requestDatas() {mview.showlodading (); mModel.getApps(new Callback<PageBean<AppInfo>>() { @Override public void onResponse(Call<PageBean<AppInfo>> call, Response<PageBean<AppInfo>> response) { if(response ! =null){ mView.showResult(response.body().getDatas()); } else{ mView.showNodata(); } mView.dimissLoading(); } @Override public void onFailure(Call<PageBean<AppInfo>> call, Throwable t) { mView.dimissLoading(); mView.showError(t.getMessage()); }}); }}Copy the code
conclusion
The above packages for activities, fragments, and Presenter are relatively simple and do not have many functions. Here, they only serve as a primer. More perfect packages need to be modified according to their own business needs.
This article is serialized by wu Weilong, the author of Vegetable bird nest
CAI Bird nest is a professional program ape online learning platform, to provide the most systematic Android project actual combat courses
For reprint, please contact caibird’s Nest public number (CNIAO5), and indicate the source.
Dish bird’s nest
http://www.cniao5.com/forum/thread/811b02a2437e11e7932a00163e0230fa
Focus on the public account to receive “140 sets of excellent open source project source code”