У меня есть настоящее Android-устройство (Android 4.1.1). Поддерживает такие приложения, как Xender, ShareIt, Zapya и т. Д., Которые используют Wi-Fi Direct для передачи файлов.WiFi прямой возврат P2P_UNSUPPORTED
Но когда я запускаю свое приложение, он говорит P2P_UNSUPPORTED.
Мои манифеста разрешения являются ....
<uses-permission android:name="android.permission.ACCESS_WIFI_STATE"/>
<uses-permission android:name="android.permission.CHANGE_WIFI_STATE"/>
<uses-permission android:name="android.permission.CHANGE_NETWORK_STATE"/>
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
Мой MainActivity.java, как это ..
intentFilter.addAction(WifiManager.WIFI_STATE_CHANGED_ACTION);
intentFilter.addAction(WifiP2pManager.WIFI_P2P_STATE_CHANGED_ACTION);
intentFilter.addAction(WifiP2pManager.WIFI_P2P_PEERS_CHANGED_ACTION);
intentFilter.addAction(WifiP2pManager.WIFI_P2P_CONNECTION_CHANGED_ACTION);
intentFilter.addAction(WifiP2pManager.WIFI_P2P_THIS_DEVICE_CHANGED_ACTION);
Receiver receiver=new Receiver();
registerReceiver(receiver,intentFilter);
WifiP2pManager manager=(WifiP2pManager)getSystemService(WIFI_P2P_SERVICE);
channel=manager.initialize(this, Looper.getMainLooper(),null);
manager.discoverPeers(channel, new WifiP2pManager.ActionListener() {
@Override
public void onSuccess() {
// 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.
}
@Override
public void onFailure(int reasonCode) {
// Code for when the discovery initiation fails goes here.
// Alert the user that something went wrong.
switch (reasonCode){
case WifiP2pManager.BUSY:Log.e("code","BUSY");break;
case WifiP2pManager.ERROR:Log.e("code","ERROR");break;
case WifiP2pManager.P2P_UNSUPPORTED:Log.e("code","P2P_UNSUPPORTED");break;
}
}
});
В журнале ,, я получаю.
code﹕ P2P_UNSUPPORTED
И мой BraodcastReceiver, как это ..
@Override
public void onReceive(Context context, Intent intent) {
//Log.e("intent",intent.getAction());
int state = intent.getIntExtra(WifiP2pManager.EXTRA_WIFI_STATE, -1);
Log.e("raw state", ""+state);
if (state == WifiP2pManager.WIFI_P2P_STATE_ENABLED) {
Log.e("state", "ON");
} else if(state == WifiP2pManager.WIFI_P2P_STATE_DISABLED) {
Log.e("state", "DISABLED "+ state);
}
}
И там я получаю журнал, как ,,
raw state﹕ -1
Примечание: Переменная состояния не равно WifiP2pManage r.WIFI_P2P_STATE_ENABLED ни WifiP2pManager.WIFI_P2P_STATE_DISABLED
Попробуйте запустить демонстрацию Wi-Fi Direct Android и посмотрите, работает ли P2P: https://github.com/android/platform_development/tree/master/samples/WiFiDirectDemo Вот некоторые другие ресурсы Android Wi-Fi Direct: https://groups.google.com/forum/#!topic/wi-fi-direct/uWpuOzHY6y0 – Brendan