Android WiFi-Direct BroadcastReceiver coutume de travail
-
21-12-2019 - |
Question
Je suis en train d'essayer de vous connecter à un réseau wi-fi Direct à l'aide de Nexus 4.
J'ai le code suivant:
public class MainActivity extends ActionBarActivity {
WifiP2pManager mWifiP2pManager;
Channel mChannel;
WiFiDirectBroadcastReceiver mReceiver;
IntentFilter mIntentFilter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mIntentFilter = new IntentFilter();
mIntentFilter.addAction(WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTION);
mIntentFilter.addAction(WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION);
mIntentFilter.addAction(WifiP2pManager.WIFI_P2P_CONNECTION_CHANGED_ACTION);
mIntentFilter.addAction(WifiP2pManager.WIFI_P2P_THIS_DEVICE_CHANGED_ACTION);
mWifiP2pManager = (WifiP2pManager)getSystemService(WIFI_P2P_SERVICE);
mChannel = mWifiP2pManager.initialize(this, getMainLooper(), null);
((ImageButton)findViewById(R.id.imageButton_power)).setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Log.d("p2p", "discoverPeers() called");
mWifiP2pManager.discoverPeers(mChannel, new WifiP2pManager.ActionListener() {
@Override
public void onSuccess() {
Log.d("p2p", "discoverPeers() Success");
}
@Override
public void onFailure(int reason) {
Log.d("p2p", "discoverPeers() Failure: " + reason);
}
});
}
});
}
@Override
protected void onResume() {
super.onResume();
mReceiver = new WiFiDirectBroadcastReceiver(mWifiP2pManager, mChannel, this);
registerReceiver(mReceiver, mIntentFilter);
}
@Override
protected void onPause() {
super.onPause();
unregisterReceiver(mReceiver);
}
}
Et le BroadcastReceiver:
public class WiFiDirectBroadcastReceiver extends BroadcastReceiver {
private WifiP2pManager mManager;
private Channel mChannel;
private MainActivity mActivity;
public WiFiDirectBroadcastReceiver(WifiP2pManager manager, Channel channel, MainActivity activity) {
super();
this.mManager = manager;
this.mChannel = channel;
this.mActivity = activity;
}
@Override
public void onReceive(Context context, Intent intent) {
String action = intent.getAction();
Log.d("p2p", "Action: " + action);
if (WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTION.equals(action)) {
// Check to see if Wi-Fi is enabled and notify appropriate activity
} else if (WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION.equals(action)) {
Log.d("p2p", "Requesting for peers");
if (mManager != null) {
mManager.requestPeers(mChannel, peerListListener);
}
} else if (WifiP2pManager.WIFI_P2P_CONNECTION_CHANGED_ACTION.equals(action)) {
// Respond to new connection or disconnections
} else if (WifiP2pManager.WIFI_P2P_THIS_DEVICE_CHANGED_ACTION.equals(action)) {
// Respond to this device's wifi state changing
}
}
private WifiP2pManager.PeerListListener peerListListener = new WifiP2pManager.PeerListListener() {
@Override
public void onPeersAvailable(WifiP2pDeviceList peers) {
Log.d("p2p", "deviceCount = " + peers.getDeviceList().size());
}
};
}
Quand je clique sur le bouton de la discoverPeers()
renvoie Succès.Cependant, je n'ai jamais obtenir toutes les émissions spécifiées dans le IntentFilter, quand j'ai commencer/reprendre l'activité, je reçois quelques émissions:
02-26 16:19:08.684 7656-7656/com.exemple.app D/p2p﹕ Action:android.net.wifi.le p2p.STATE_CHANGED 02-26 16:19:08.684
7656-7656/com.exemple.app D/p2p﹕ Action:android.net.wifi.le p2p.CONNECTION_STATE_CHANGE 02-26 16:19:08.684
7656-7656/com.exemple.app D/p2p﹕ Action:android.net.wifi.le p2p.THIS_DEVICE_CHANGED
Mais aucun d'entre eux sont le one je me suis inscrit à la IntentFilter et pour une raison que je obtenir ces 3 bien qu'ils ne sont pas ajoutés au filtre.
Edit: Il semble que j'ai confondu avec le nom des cordes et ils sont à la valeur réelle, je reçois certaines des mesures que j'ai ajouté à la IntentFilter.
La solution
Alors vous êtes en train d'obtenir des résultats corrects même s'ils ne sont pas comme vous l'espériez.Lorsque vous p2p changement d'état que vous êtes censé voir "android.net.wifi.le p2p.CONNECTION_STATE_CHANGE" de la valeur.Et en va de même pour les autres filtres.Consulter cette page: http://developer.android.com/reference/android/net/wifi/p2p/WifiP2pManager.html#WIFI_P2P_CONNECTION_CHANGED_ACTION
Autres conseils
vous ne savez pas si vous êtes toujours à la suite de cette cependant, Google a ajouté une note dans la WifiP2p de référence qui jette quelque lumière sur cette question.(Un problème que j'ai eu aussi) Trouvé ici: http://developer.android.com/training/connect-devices-wirelessly/wifi-direct.html
// Code for when the discovery initiation is successful goes here.
// No services have actually been discovered yet, so this method
// can often be left blank. Code for peer discovery goes in the
// onReceive method, detailed below.
À partir de cette remarque, il semble que vous obtiendrez la onSuccess() indique SI le discoverPeers() a été un succès, MAIS vous ne recevrez que le " WIFI_P2P_PEERS_CHANGED_ACTION de diffusion indiquant que la liste des pairs a changé, SI l'on dispose d'un pair à détecter.J'ai testé avec deux téléphones intelligents de l'exécution d'un wifiP2p app.
J'espère que cette aide, si au moins vous pouvez vous trouver la réponse dans les références google.