亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

詳解Android封裝一個全局的BaseActivity

瀏覽:3日期:2022-09-19 16:53:28
1.前言 對于一個Android開發者來說,每一個頁面都繼承一個單獨的系統Activity,有時候會帶來很多不必要的困擾。比如:每一個頁面會有重復的代碼,閱讀起來麻煩;每一次寫新的頁面功能總要打開原來的頁面代碼拷貝一部分過來;有時候代碼調試排查問題也不方便等等。 如果你的項目里面沒有將Activity都繼承自一個自己封裝的BaseActivity、或者針對自己封裝的BaseActivity覺得還不夠完善的,這篇博客可能會對你有幫助!2.特點 封裝:將所有Activity都用到的一部分代碼封裝到一個統一管理的Activity類(后面全部起名叫BaseActivity),然后由這個BaseActivity繼承自Android系統的AppCompatActivity(一般是這個)。 繼承:頁面上用到的Activity都繼承自我們的自己BaseActivity,BaseActivity封裝的方法在Activity內直接調用。 3.代碼及說明 3.1.優缺點 優點:減少了代碼的重復,提高了寫代碼的效率、以及提高了代碼的維護性 缺點:不要任何代碼都放在BaseActivity,那樣可能會導致BaseActivity過于臃腫,不利于代碼的閱讀和維護,甚至出現App奔潰

下面會討論哪些代碼應該放在BaseActivity里面,哪些需要謹慎

3.2.代碼

下面我貼一份我自己封裝的BaseActivity,在代碼中和代碼下面做了解釋:

public abstract class BaseActivity extends AppCompatActivity { public Activity mActivity; private Unbinder mUnbinder; private static float sNoncompatDensity; private static float sNoncompatScaledDensity; private MaterialDialog mDialog; @Override protected void onCreate(@Nullable Bundle savedInstanceState) {super.onCreate(savedInstanceState);onAdjustLayout();setContentView(setContentLayout());//這里的是初始化綁定ButterKnife,在onDestory做了銷毀mUnbinder = ButterKnife.bind(this);this.mActivity = this;//統一將一個activity添加到一個集合里面AppManager.getInstance().addActivity(mActivity);initToolBar();initPresenter();initData(savedInstanceState);Log.e('app', this.getClass().getSimpleName() + '------onCreate'); } @Override protected void onStart() {super.onStart();Log.e('app', this.getClass().getSimpleName() + '------onStart'); } @Override protected void onRestoreInstanceState(Bundle savedInstanceState) {super.onRestoreInstanceState(savedInstanceState);Log.e('app', this.getClass().getSimpleName() + '------onRestoreInstanceState'); } @Override protected void onRestart() {super.onRestart();Log.e('app', this.getClass().getSimpleName() + '------onRestart'); } @Override protected void onResume() {super.onResume();Log.e('app', this.getClass().getSimpleName() + '------onResume'); } @Override protected void onSaveInstanceState(Bundle outState) {super.onSaveInstanceState(outState);Log.e('app', this.getClass().getSimpleName() + '------onSaveInstanceState'); } @Override protected void onPause() {super.onPause();Log.e('app', this.getClass().getSimpleName() + '------onPause'); } @Override protected void onStop() {super.onStop();Log.e('app', this.getClass().getSimpleName() + '------onStop'); } @Override protected void onDestroy() {super.onDestroy();onDestroyActivity();mUnbinder.unbind();Log.e('app', this.getClass().getSimpleName() + '------onDestroy'); } /** * 顯示一個Fragment */ public void showFragment(Fragment fragment) {if (fragment != null && fragment.isHidden()) { FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction(); fragmentTransaction.show(fragment); fragmentTransaction.commit();} } /** * 隱藏一個Fragment */ public void hideFragment(Fragment fragment) {if (fragment != null && !fragment.isHidden()) { FragmentTransaction fragmentTransaction = getSupportFragmentManager().beginTransaction(); fragmentTransaction.hide(fragment); fragmentTransaction.commit();} }//這是一個設置toolbar標題欄的方法,ToolBarOptions類主要是持有一些id public void setToolBar(int toolBarId, ToolBarOptions options) {Toolbar toolbar = findViewById(toolBarId);if (options.titleId != 0) { toolbar.setTitle(options.titleId);} else { toolbar.setTitle('');}if (!TextUtils.isEmpty(options.titleString)) { toolbar.setTitle(options.titleString);}if (options.backgroundColor != 0) { toolbar.setBackgroundResource(options.backgroundColor);}if (options.logoId != 0) { toolbar.setLogo(options.logoId);}setSupportActionBar(toolbar);if (options.isNeedNavigate) { toolbar.setNavigationIcon(options.navigateId); toolbar.setContentInsetStartWithNavigation(0); toolbar.setNavigationOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) { if (!AppUtils.isNotFastClick()) {return; } onNavigateUpClicked();} });} }//子類直接調用展示toast public void showToast(String s) {ToastUtil.showToast(this, s); }//給子類提供一個獲取activity對象的方式 public Activity getActivity() {return this; }//一個彈窗loading庫 github地址: //implementation ’com.afollestad.material-dialogs:core:0.9.6.0’ public void showLoading(String loadDesc) {mDialog = new MaterialDialog.Builder(this).progress(true, -1).content(loadDesc).canceledOnTouchOutside(false).cancelable(false).show(); } public void showLoading(int resId) {mDialog = new MaterialDialog.Builder(this).progress(true, -1).content(getString(resId)).canceledOnTouchOutside(false).cancelable(false).show(); } public void showLoading() {mDialog = new MaterialDialog.Builder(this).progress(true, -1).content('加載中...').canceledOnTouchOutside(false).cancelable(false).show(); } public void hideLoading() {if (mDialog != null) { mDialog.dismiss();} }//這里是退出app相關的邏輯,可以根據自己的退出做具體的處理 public void exitLogin() {SharedPreferenceUtils.getInstance(mActivity).put(Constant.KEY_LOGIN_TOKEN, '');if (mDialog != null) { mDialog.hide(); mDialog = null;}mDialog = new MaterialDialog.Builder(this).canceledOnTouchOutside(false).title('提示').content('賬號已在其他地方登錄,請退出重新登錄!').positiveText('確定').onPositive(new MaterialDialog.SingleButtonCallback() { @Override public void onClick(@NonNull MaterialDialog dialog, @NonNull DialogAction which) {AppManager.getInstance().finishAllActivity();Intent intent = new Intent(mActivity, LoginActivity.class);startActivity(intent);finish(); }}).show(); } private void onNavigateUpClicked() {onBackPressed(); } //開始contentLayout前調整布局(子類若有需要可以單獨復寫) public void onAdjustLayout() { }//下面這5個方法是子類必須實現的,分別是layout布局、toolbar、mvp的persenter初始化、//onCreate內的initData、以及頁面銷毀的onDestroyActivity(可以根據自己的需要添加) public abstract int setContentLayout(); public abstract void initToolBar(); public abstract void initPresenter(); public abstract void initData(Bundle savedInstanceState); public abstract void onDestroyActivity();}3.3.注意點 在BaseActivity的每個生命周期內都有log日志,這里是方便觀察執行到activity的哪個生命周期,logcat也可以簡單封裝一下,統一控制日志是否打印。 BaseActivity并不適合每一個頁面的Activity,比如進入應用的閃屏頁面,就可以考慮不繼承BaseActivity,因為這個頁面通常不需要寫太多代碼。或者還有其他特殊的業務場景下。 需要注意一個Dialog彈窗問題,在BaseActivity里面,每次show一個dialog的時候我都是創建一個新的對象,那么就要注意dialog在未關閉之前不能再去show,否則可能會導致dialog出現異常。但是不要在onDestory方法里面去隱藏dialog彈窗,因為在A頁面進入B頁面的時候,會先執行到B頁面生命周期的onCreate、onStart、onResume三個方法,然后再執行A頁面的onStop可能還有onDestory方法,所以等B頁面加載完成再去銷毀A頁面是錯誤的。 有時候為了方便可能有人會把請求Android中權限檢測的方法放在BaseActivity里面,這樣并不是特別合適,因為所有繼承自BaseActivity的頁面都會去檢測權限,這樣會導致用戶體驗差,所以建議用到權限的地方再去請求,最好自己封裝一個工具類,用起來方便一點。 BaseActivity的封裝并不強求子類必須實現activity生命周期相關的方法,除了幾個抽象方法(我認為子類需要復寫的,可以根據業務自己定),必要的話可以自己復寫。4.總結

不是很復雜,寫的也比較詳細,也基本適用于絕大部分的場景。可能還有其他需要注意的細節回頭想起來再補上。

以上就是詳解Android封裝一個全局的BaseActivity的詳細內容,更多關于Android封裝BaseActivity的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
主站蜘蛛池模板: 宅男午夜剧场 | 国产高清在线精品一区二区 | 国产1024一区二区你懂的 | 免费看叼嘿视频 | 蜜桃视频一区二区三区四区 | 亚洲色图综合 | 久久久久国产亚洲日本 | 欧美洲久久日韩欧美 | 黄免费观看 | 黄色一区二区三区 | 1024国产手机视频基地 | 久久精彩视频 | 免费区欧美一级毛片精品 | 精品国产日韩久久亚洲 | 久亚洲精品不子伦一区 | 青青久久久国产线免观 | 亚洲毛片基地4455ww | 夜色成人网| 日本一区精品 | a级黄色毛片 | 国产精品久久不卡日韩美女 | 日韩免费视频网站 | 香蕉视频视频 | 丁香婷婷激情 | 欧美爱爱小视频 | 国产综合网站 | 午夜羞羞视频在线观看 | www.大香| 国产a久久精品一区二区三区 | 日本道色综合久久影院 | 欧美专区在线 | 久久久久夜 | 国产亚洲片| 一级级黄| 欧美一级视频 | 毛片在线观看地址 | 国产国产精品人在线观看 | 国产网站麻豆精品视频 | 免费观看性欧美特黄 | 无遮挡啪啪成人免费网站 | 中文字幕永久在线视频 |