Я зарегистрировал приемник, который прослушивает сетевые события:
<receiver
android:label="NetworkConnection"
android:name=".ConnectionChangeReceiver" >
<intent-filter >
<action android:name="android.net.conn.CONNECTIVITY_CHANGE" />
</intent-filter>
</receiver>
Приемник также очень прост:
public class ConnectionChangeReceiver extends BroadcastReceiver {
@Override
public void onReceive(Context context, Intent intent) {
ConnectivityManager connectivityManager = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
NetworkInfo activeNetInfo = connectivityManager.getActiveNetworkInfo();
if (activeNetInfo != null) {
Log.v("@@@","Receiver : " + activeNetInfo);
} else {
Log.v("@@@","Receiver : " + "No network");
}
}
}
Проблема в том, что когда Wifi подключен, я получаю 3 одинаковых сообщения подряд, например:
Receiver : NetworkInfo: type: WIFI[], state: CONNECTED/CONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: true
Receiver : NetworkInfo: type: WIFI[], state: CONNECTED/CONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: true
Receiver : NetworkInfo: type: WIFI[], state: CONNECTED/CONNECTED, reason: (unspecified), extra: (none), roaming: false, failover: false, isAvailable: true
Все они "ПОДКЛЮЧЕНЫ/ПОДКЛЮЧЕНЫ" (не должны ли они быть чем-то вроде CONNECTING/OBTAINING_IPADDR и т.д.), поэтому проблема в том, как я могу сказать, когда она действительно подключена? У меня есть некоторые подпрограммы, которые я хочу сделать, когда wifi действительно подключен, и я не хочу, чтобы их вызывали три раза подряд.
PS: 3G отправляет только одно сообщение, поэтому здесь нет проблем.
Обновление:
Похоже на проблему с устройством.
Для теста я взял 2 Desire HD и 4 случайных телефона Android (различные модели Aquos и некоторые китайские вещи без названия). Как на DHD, так и на одном случайном телефоне на wifi connect я получил 3 сообщения, на оставшихся телефонах я получил только одно сообщение. WTF.