Android アプリでより高いネットワーク接続のアップタイムを実現したいと考えています。ユーザーが WiFi カバレッジの端にいる場合、電話は接続を失います。私のアプリはこれを正しく検出します。
ユーザーが再びカバレッジに入ると、ネットワークへの接続が再確立されるまでに長い時間 (数分) かかることがあります。Android WiFi マネージャーでは、「接続済み」に切り替わる前に、「切断済み」(「オフ」ではなく) の状態が長時間続くことがあります。ネットワークは標準の WPA2 ネットワークです。
私はこのようなことを試みました。外部クラスは、接続が失われるたびに ConnectionExecuter を実行します。
private void saveConnectionInfo() {
connectionInfo = wiFiManager.getConnectionInfo();
}
private class ConnectExecuter extends AsyncTask<Void, Void, Void> {
@Override
protected Void doInBackground(Void... params) {
//Do not return before WiFi is enabled and connected
while(!wiFiManager.isWifiEnabled() || !connected()) {
try {
logger.debug(TAG, "Enable");
//Checks is WiFi is disabled, and turns it on in that case.
WiFiEnablementManager.assureWiFiEnabled(wiFiManager);
Thread.sleep(2500);
//if WiFi is not connected then connect to the previous network
logger.debug(TAG, wiFiManager.getConnectionInfo().toString());
if(!connected()) {
logger.debug(TAG, "Reconnecting to network id: " + connectionInfo);
wiFiManager.enableNetwork(connectionInfo.getNetworkId(), true);
wiFiManager.reconnect();
}
Thread.sleep(3000);
} catch (InterruptedException e) {
logger.error(TAG, e);
}
}
return null;
}
private boolean connected() {
if (wiFiManager.getConnectionInfo() != null && connectionInfo != null) {
return wiFiManager.getConnectionInfo().getNetworkId() == connectionInfo.getNetworkId();
}
return false;
}
}
public class WiFiEnablementManager {
public static final ILogger logger = new Logger(WiFiEnablementManager.class.getSimpleName());
public static void assureWiFiEnabled(WifiManager wifiManager) {
if(!wifiManager.isWifiEnabled()){
logger.info("WiFi status disabled: Enabling...");
wifiManager.setWifiEnabled(true);
}
}
}
Android 2.2 では役立つようですが、4.0 では機能しません。また、スリープ ステートメント (2500 ミリ秒と 3000 ミリ秒) は、実際には正当化されない可能性があります。任意の入力を歓迎します。