自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

10分鐘讓你實現(xiàn)在APP中對網(wǎng)絡(luò)狀態(tài)變化進行全局提示

移動開發(fā)
舉一個例子,有的用戶在使用時禁用了 APP 訪問移動網(wǎng)絡(luò),或者有的用戶干脆都沒有打開移動數(shù)據(jù)開關(guān)或者 WIFI 開關(guān)。但是作為開發(fā)人員,我們應(yīng)該避免用戶思考,當用戶使用出現(xiàn)問題時,APP 應(yīng)該能夠引導(dǎo)用戶前往設(shè)置,故有此文。
  • 永遠不要期望用戶按照你預(yù)設(shè)的步驟操作 APP

一個新項目剛剛開始推廣工作,市場人員向我抱怨用戶使用時總會出現(xiàn)各種各樣的問題,大部分問題都是因為用戶操作不當導(dǎo)致的,但是在用戶眼中的結(jié)論就是“你們的 APP 不好用”。

舉一個例子,有的用戶在使用時禁用了 APP 訪問移動網(wǎng)絡(luò),或者有的用戶干脆都沒有打開移動數(shù)據(jù)開關(guān)或者 WIFI 開關(guān)。但是作為開發(fā)人員,我們應(yīng)該避免用戶思考,當用戶使用出現(xiàn)問題時,APP 應(yīng)該能夠引導(dǎo)用戶前往設(shè)置,故有此文。

我們希望當用戶網(wǎng)絡(luò)連接不可用時,及時提醒用戶當前的網(wǎng)絡(luò)狀態(tài)。當連接恢復(fù)時,將提示用的視圖隱藏,并且我們希望這個提示視圖可以工作在所有需要網(wǎng)絡(luò)的頁面中。

思路如下:使用 BaseActivity ,所有頁面繼承該文件,在該文件中實現(xiàn)根據(jù)網(wǎng)絡(luò)狀態(tài)顯示提示、隱藏提示。

好了,廢話少說,show u the code。

1. 實現(xiàn)監(jiān)聽網(wǎng)絡(luò)狀態(tài)變更的廣播接收器

我們使用廣播接收器接收網(wǎng)絡(luò)變化的 Intent,這里直接使用靜態(tài)注冊的方法,因為我們不需要在每個頁面單獨注冊這個 Receiver,那太重量級了。

NetworkConnectChangedReceiver.java

  1. public class NetworkConnectChangedReceiver extends BroadcastReceiver { 
  2.     private static final String TAG = "NetworkConnectChanged"
  3.     @Override 
  4.     public void onReceive(Context context, Intent intent) { 
  5.         //**判斷當前的網(wǎng)絡(luò)連接狀態(tài)是否可用*/ 
  6.         boolean isConnected = NetUtils.isConnected(context); 
  7.         Log.d(TAG, "onReceive: 當前網(wǎng)絡(luò) " + isConnected); 
  8.         EventBus.getDefault().post(new NetworkChangeEvent(isConnected)); 
  9.     } 

事件Event:

  1. public class NetworkChangeEvent { 
  2.     public boolean isConnected; //是否存在網(wǎng)絡(luò) 
  3.  
  4.     public NetworkChangeEvent(boolean isConnected) { 
  5.         this.isConnected = isConnected; 
  6.     } 

判斷網(wǎng)絡(luò)連接是否可用:

  1. /** 
  2.      * 判斷網(wǎng)絡(luò)是否連接 
  3.      * @param context 
  4.      * @return 
  5.      */ 
  6.     public static boolean isConnected(Context context) { 
  7.         ConnectivityManager connectivity = (ConnectivityManager) context 
  8.                 .getSystemService(Context.CONNECTIVITY_SERVICE); 
  9.  
  10.         if (null != connectivity) { 
  11.             NetworkInfo info = connectivity.getActiveNetworkInfo(); 
  12.             if (null != info && info.isConnected()) { 
  13.                 if (info.getState() == NetworkInfo.State.CONNECTED) { 
  14.                     return true
  15.                 } 
  16.             } 
  17.         } 
  18.         return false
  19.     } 

靜態(tài)注冊Receiver:

  1. <receiver android:name=".receiver.NetworkConnectChangedReceiver"
  2.     <intent-filter> 
  3.         <action android:name="android.NET.conn.CONNECTIVITY_CHANGE" /> 
  4.         <action android:name="android.Net.wifi.WIFI_STATE_CHANGED" /> 
  5.         <action android:name="android.net.wifi.STATE_CHANGE" /> 
  6.     </intent-filter> 
  7. </receiver> 

2. 在 BaseActivity中監(jiān)聽事件并處理提示視圖

看到 EventBus 的時候你是不是已經(jīng)知道我的實現(xiàn)方式了(笑 XD),是的就是那個已經(jīng)很久沒人提了的 EventBus。當然還可以使用觀察者模式來實現(xiàn),這樣就不用依賴第三方庫了,但是我們需要的是快速實現(xiàn),且對原有代碼盡可能少的改動,引入觀察者模式顯然不如直接拿 EventBus來的方便。

BaseActivity.java

  1. public class BaseActivity extends Activity { 
  2.  
  3.     protected Context mContext; 
  4.     protected ACache mACache; 
  5.     protected boolean mCheckNetWork = true; //默認檢查網(wǎng)絡(luò)狀態(tài) 
  6.     View mTipView; 
  7.     WindowManager mWindowManager; 
  8.     WindowManager.LayoutParams mLayoutParams; 
  9.  
  10.     @Override 
  11.     protected void onCreate(Bundle savedInstanceState) { 
  12.         super.onCreate(savedInstanceState); 
  13.         mContext = this; 
  14.         this.mACache = ACache.get(mContext); 
  15.         MyApp.addActivity(this); 
  16.         initTipView();//初始化提示View 
  17.         EventBus.getDefault().register(this); 
  18.     } 
  19.  
  20.     @Override 
  21.     protected void onResume() { 
  22.         super.onResume(); 
  23.         MobclickAgent.onResume(this); 
  24.         //在無網(wǎng)絡(luò)情況下打開APP時,系統(tǒng)不會發(fā)送網(wǎng)絡(luò)狀況變更的Intent,需要自己手動檢查 
  25.         hasNetWork(NetUtils.isConnected(mContext)); 
  26.     } 
  27.  
  28.     @Override 
  29.     protected void onPause() { 
  30.         super.onPause(); 
  31.         MobclickAgent.onPause(this); 
  32.     } 
  33.  
  34.     @Override 
  35.     protected void onDestroy() { 
  36.         super.onDestroy(); 
  37.         MyApp.removeActivity(this); 
  38.         EventBus.getDefault().unregister(this); 
  39.     } 
  40.  
  41.     @Override 
  42.     public void finish() { 
  43.         super.finish(); 
  44.         //當提示View被動態(tài)添加后直接關(guān)閉頁面會導(dǎo)致該View內(nèi)存溢出,所以需要在finish時移除 
  45.         if (mTipView != null && mTipView.getParent() != null) { 
  46.             mWindowManager.removeView(mTipView); 
  47.         } 
  48.     } 
  49.  
  50.     @Subscribe(threadMode = ThreadMode.MAIN) 
  51.     public void onNetworkChangeEvent(NetworkChangeEvent event) { 
  52.         hasNetWork(event.isConnected); 
  53.     } 
  54.  
  55.     private void hasNetWork(boolean has) { 
  56.         if (isCheckNetWork()) { 
  57.             if (has) { 
  58.                 if (mTipView != null && mTipView.getParent() != null) { 
  59.                     mWindowManager.removeView(mTipView); 
  60.                 } 
  61.             } else { 
  62.                 if (mTipView.getParent() == null) { 
  63.                     mWindowManager.addView(mTipView, mLayoutParams); 
  64.                 } 
  65.             } 
  66.         } 
  67.     } 
  68.  
  69.     public void setCheckNetWork(boolean checkNetWork) { 
  70.         mCheckNetWork = checkNetWork; 
  71.     } 
  72.  
  73.     public boolean isCheckNetWork() { 
  74.         return mCheckNetWork; 
  75.     } 
  76.  
  77.     private void initTipView() { 
  78.         LayoutInflater inflater = getLayoutInflater(); 
  79.         mTipView = inflater.inflate(R.layout.layout_network_tip, null); //提示View布局 
  80.         mWindowManager = (WindowManager) this.getSystemService(Context.WINDOW_SERVICE); 
  81.         mLayoutParams = new WindowManager.LayoutParams( 
  82.                 ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT, 
  83.                 WindowManager.LayoutParams.TYPE_APPLICATION, 
  84.                 WindowManager.LayoutParams.FLAG_NOT_FOCUSABLE 
  85.                         | WindowManager.LayoutParams.FLAG_NOT_TOUCHABLE, 
  86.                 PixelFormat.TRANSLUCENT); 
  87.         //使用非CENTER時,可以通過設(shè)置XY的值來改變View的位置 
  88.         mLayoutParams.gravity = Gravity.TOP
  89.         mLayoutParams.x = 0; 
  90.         mLayoutParams.y = 0; 
  91.     } 

默認所有繼承 BaseActivity 的頁面當網(wǎng)絡(luò)狀況變化活無網(wǎng)絡(luò)時都會顯示提示,如果某個頁面不需要網(wǎng)絡(luò)狀態(tài)提示,可以在該頁面 onCreate 方法中調(diào)用 setCheckNetWork(false) 即可。

由于我全部頁面都有一個50dp高度的 toolbar,所以我直接在 R.layout.layout_network_tip 文件中設(shè)置了上邊距。你也可以在 BaseActivity 中通過方法來設(shè)置 mLayoutParams.x = 0;mLayoutParams.y = 0; 來使每個頁面動態(tài)設(shè)置提示的位置。

最終效果如下圖:

10分鐘讓你實現(xiàn)在APP中對網(wǎng)絡(luò)狀態(tài)變化進行全局提示

10分鐘讓你實現(xiàn)在APP中對網(wǎng)絡(luò)狀態(tài)變化進行全局提示

ToDo

所有頁面在網(wǎng)絡(luò)鏈接恢復(fù)后應(yīng)該可以自動重新發(fā)起網(wǎng)絡(luò)請求,實現(xiàn)原理其實也很簡單,在BaseActivity中增加一個reConnect()的方法,在網(wǎng)絡(luò)恢復(fù)去除提示View的時候調(diào)用。在各個頁面中重寫該方法即可。

責任編輯:未麗燕 來源: 簡書
相關(guān)推薦

2020-11-06 08:54:43

Vue 3.0函數(shù)代碼

2021-08-02 15:40:20

Java日志工具

2021-04-23 09:50:41

topLinux命令

2021-03-04 09:26:57

微服務(wù)架構(gòu)數(shù)據(jù)

2021-01-07 08:05:20

JenkinsDevOps

2017-11-20 10:25:20

數(shù)據(jù)庫MySQL索引

2017-06-07 18:40:33

PromiseJavascript前端

2009-11-05 10:56:31

WCF通訊

2011-06-10 14:19:49

SEO百度收錄

2023-07-15 18:26:51

LinuxABI

2015-11-12 10:32:40

GitHub控制系統(tǒng)分布式

2021-07-15 06:43:11

Bash調(diào)試腳本

2023-09-07 23:52:50

Flink代碼

2019-07-19 14:06:48

APP代碼打包

2014-11-10 12:29:52

客服網(wǎng)站

2021-02-16 09:17:40

VimLinux編輯器

2024-04-28 12:55:46

redis頻道機制

2021-11-07 23:46:32

MySQLSQL索引

2013-09-13 14:08:01

2019-04-11 13:34:24

點贊
收藏

51CTO技術(shù)棧公眾號