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.

Était-ce utile?

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.

Licencié sous: CC-BY-SA avec attribution
Non affilié à StackOverflow
scroll top