Приемник результатов сканирования Wifi не работает - PullRequest
6 голосов
/ 13 августа 2011

Я написал простой широковещательный приемник, чтобы показать тост-сообщение, когда сканирование Wi-Fi завершено. Ничего не показывает Вот мой код:

package com.wifi;

import java.util.List;

import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.net.wifi.ScanResult;
import android.net.wifi.WifiManager;
import android.widget.Toast;

public class wifiReceiver extends BroadcastReceiver {
    @Override
    public void onReceive(Context context, Intent intent) {
        Toast.makeText(context,"Scan completed", Toast.LENGTH_LONG).show();

    }

}

Вот файл манифеста:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="com.wifi"
      android:versionCode="1"
      android:versionName="1.0">


    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".wifi" android:label="@string/app_name">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    <receiver android:name=".wifiReceiver">
        <intent-filter>
            <action android:name="android.net.wifi.SCAN_RESULTS"></action>
        </intent-filter>
    </receiver>
    </application>
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
</manifest>

Ответы [ 5 ]

10 голосов
/ 13 августа 2011

ну, это не так просто; -)
пропущено несколько вещей ... вот пример сканирования wifi - здесь находится исходный код http://www.androidsnippets.com/scan-for-wireless-networks

package com.android.wifitester;

import java.util.List;
import android.app.Activity;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.content.IntentFilter;
import android.net.wifi.ScanResult;
import android.net.wifi.WifiManager;
import android.os.Bundle;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.TextView;

public class WifiTester extends Activity {
TextView mainText;
WifiManager mainWifi;
WifiReceiver receiverWifi;
List<ScanResult> wifiList;
StringBuilder sb = new StringBuilder();

public void onCreate(Bundle savedInstanceState) {
   super.onCreate(savedInstanceState);
   setContentView(R.layout.main);
   mainText = (TextView) findViewById(R.id.mainText);
   mainWifi = (WifiManager) getSystemService(Context.WIFI_SERVICE);
   receiverWifi = new WifiReceiver();
   registerReceiver(receiverWifi, new IntentFilter(WifiManager.SCAN_RESULTS_AVAILABLE_ACTION));
   mainWifi.startScan();
   mainText.setText("\\nStarting Scan...\\n");
}

public boolean onCreateOptionsMenu(Menu menu) {
    menu.add(0, 0, 0, "Refresh");
    return super.onCreateOptionsMenu(menu);
}

public boolean onMenuItemSelected(int featureId, MenuItem item) {
    mainWifi.startScan();
    mainText.setText("Starting Scan");
    return super.onMenuItemSelected(featureId, item);
}

protected void onPause() {
    unregisterReceiver(receiverWifi);
    super.onPause();
}

protected void onResume() {
    registerReceiver(receiverWifi, new IntentFilter(WifiManager.SCAN_RESULTS_AVAILABLE_ACTION));
    super.onResume();
}

class WifiReceiver extends BroadcastReceiver {
    public void onReceive(Context c, Intent intent) {
        sb = new StringBuilder();
        wifiList = mainWifi.getScanResults();
        for(int i = 0; i < wifiList.size(); i++){
            sb.append(new Integer(i+1).toString() + ".");
            sb.append((wifiList.get(i)).toString());
            sb.append("\\n");
        }
        mainText.setText(sb);
    }
}
}
4 голосов
/ 15 мая 2016

Я потратил некоторое время на это, и в зависимости от того, какую версию Android вы используете, это может помочь. Для Android M, по-видимому, вам необходимо включить службы определения местоположения, поэтому попробуйте добавить это в свой код, если вы попадаете под эти критерии.

private static final int PERMISSIONS_REQUEST_CODE_ACCESS_COARSE_LOCATION = 1001;

if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.M && checkSelfPermission(Manifest.permission.ACCESS_COARSE_LOCATION) != PackageManager.PERMISSION_GRANTED){
        requestPermissions(new String[]{Manifest.permission.ACCESS_COARSE_LOCATION}, PERMISSIONS_REQUEST_CODE_ACCESS_COARSE_LOCATION); 
}

@Override
public void onRequestPermissionsResult(int requestCode, String[] permissions,
                                       int[] grantResults) {
    if (requestCode == PERMISSIONS_REQUEST_CODE_ACCESS_COARSE_LOCATION
            && grantResults[0] == PackageManager.PERMISSION_GRANTED) {
        // TODO: What you want to do when it works or maybe .PERMISSION_DENIED if it works better
    }
}

Не забудьте добавить в манифест следующее:

<uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />

Надеюсь, это поможет.

1 голос
/ 11 апреля 2012

Я сделал то же самое, что сделали Макс и PVS, но также удалил разрешения на использование и продолжил сканирование.

Удалено из манифеста

Если вы просматриваете документы, если у вас нет разрешений на использование, то ваш получатель не ограничен в отношении того, кому можно отправлять сообщения, но кажется, что если вы используете разрешения, то широковещательная рассылка должна иметь аналогичные разрешения.

Я проверил это с помощью множества действий (ниже) в приемнике и получил их. Но как только я добавляю разрешения на использование любого рода, я не получаю никаких трансляций, странно.

   <receiver android:name=".myReceiver" android:enabled="true">
        <intent-filter android:priority="99999999999">
            <action android:name="android.intent.action.FOUND" />
            <action android:name="android.location.PROVIDERS_CHANGED" />            
            <action android:name="android.hardware.action.NEW_PICTURE" />
            <action android:name="android.hardware.action.NEW_VIDEO" />
            <action android:name="android.net.wifi.STATE_CHANGE" />
            <action android:name="android.net.wifi.NETWORK_IDS_CHANGED" />
            <action android:name="android.net.wifi.SCAN_RESULTS" />
            <action android:name="android.net.wifi.supplicant.CONNECTION_CHANGE" />
            <action android:name="android.net.wifi.supplicant.STATE_CHANGE" />
            <action android:name="android.net.ConnectivityManager.CONNECTIVITY_ACTION" />
            <category android:name="android.intent.category.DEFAULT" />         
        </intent-filter>            
    </receiver>   
0 голосов
/ 08 января 2012

Я начал с ответа Макса выше, и когда это сработало, я приступил к удалению android: enabled = "true", а затем изменил android: name = ". MyReceiver" (не полный путь).Продолжал работать (2.2, API 8)!Под «работой» я подразумеваю, что MyReceiver получал трансляции, когда я включал и выключал WiFi (я не совался в дополнительные функции и т. Д.).У меня также есть разрешения ACCESS_WIFI_STATE и CHANGE_WIFI_STATE.

<receiver android:name=".MyReceiver">
<intent-filter>
<!--  
<action android:name="android.net.wifi.STATE_CHANGED"/>
-->
<action android:name="android.net.wifi.WIFI_STATE_CHANGED"/>
<action android:name="android.net.wifi.SCAN_RESULTS"/>
</intent-filter>
0 голосов
/ 23 октября 2011

Я получил приведенный выше код, работающий со следующим в моем манифесте:

<receiver android:name="com.mumfordmedia.trackify.WifiReceiver" android:enabled="true">
<intent-filter>
    <action android:name="android.net.wifi.SCAN_RESULTS"></action>
</intent-filter>

Обратите внимание на атрибут android: enabled = "true" в элементе получателя и полный путь к классу, который должен быть выполнен при получении сообщения, в отличие от ". classname ".

Всего наилучшего и спасибо за отправную точку, Макс.

...