BroadcastReceiver не вызывается после возобновления активности - PullRequest
0 голосов
/ 21 октября 2011

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

Я пытаюсь построить модуль Wi-Fi для целей локализации, поэтому я написал BroadcastReceiver для обработки сканирования Wi-Fi и локализации. Приложение работает и выполняет свою работу (довольно простую на данном этапе), с некоторыми проблемами, как при изменении ориентации экрана, так и при нажатии кнопки «Назад» на моем Desire HD, а затем снова при открытии приложения. Но когда я нажимаю клавишу HOME, перехожу на главный экран и затем снова захожу в мое приложение, Broadcast Receiver, похоже, больше не работает, и если я закрываю приложение, я получаю сообщение об ошибке.

Вот код, частично адаптированный с здесь .

public class WiFiDemo extends Activity implements OnClickListener {

private static final String TAG = "WiFiDemo";
WifiManager wifi;
BroadcastReceiver receiver;
WifiManager.WifiLock lock;
boolean wifiPrevState;
boolean scanON = false;
String header;


TextView textStatus;
Button buttonScan;

/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);


    // Setup UI
    textStatus = (TextView) findViewById(R.id.textStatus);
    buttonScan = (Button) findViewById(R.id.buttonScan);
    buttonScan.setOnClickListener(this);

    // Setup WiFi
    if (wifi == null){
        wifi = (WifiManager) getSystemService(Context.WIFI_SERVICE);
    }


    //checking WiFi status, enabling it if needed and locking it.
    wifiPrevState = wifi.isWifiEnabled();
    wifi.setWifiEnabled(true);
    if (lock == null){
        lock = wifi.createWifiLock("lock");
    }

    lock.acquire();

    // Get WiFi status
    WifiInfo info = wifi.getConnectionInfo();
    header="\n\nWiFi Status: \n" + info.toString() + "\n\nAvailable nets:";
    textStatus.append(header);

    // Register Broadcast Receiver
    if (receiver == null)
        receiver = new WiFiScanReceiver(this);

    registerReceiver(receiver, new IntentFilter(
            WifiManager.SCAN_RESULTS_AVAILABLE_ACTION));
    Log.d(TAG, "onCreate()");

}

/*
@Override
protected void onPause(){
    super.onPause();
    wifi.setWifiEnabled(wifiPrevState);
    lock.release();
    unregisterReceiver(receiver);
    Log.d(TAG, "onPause()");
}

@Override
protected void onResume(){
    super.onResume();
    wifi.setWifiEnabled(true);
    lock.acquire();
    registerReceiver(receiver, new IntentFilter(
            WifiManager.SCAN_RESULTS_AVAILABLE_ACTION));
    Log.d(TAG, "onResume()");

}
*/

@Override
public void onStop() {
    super.onStop();
    wifi.setWifiEnabled(wifiPrevState);
    lock.release();
    unregisterReceiver(receiver);

}

public void onClick(View view) {
    Toast.makeText(this, "On Click Clicked. Toast to that!!!",
            Toast.LENGTH_LONG).show();

    if (view.getId() == R.id.buttonScan) {
        Log.d(TAG, "onClick() wifi.startScan()");
        scanON = !scanON;
        wifi.startScan();
    }
}

}

А это BroadcastReceiver

public class WiFiScanReceiver extends BroadcastReceiver {
  private static final String TAG = "WiFiScanReceiver";
  WiFiDemo wifiDemo;
  ScanResult storedBest;

  public WiFiScanReceiver(WiFiDemo wifiDemo) {
    super();
    this.wifiDemo = wifiDemo;
    storedBest = null;
  }

 @Override
 public void onReceive(Context c, Intent intent) {
    List<ScanResult> results = wifiDemo.wifi.getScanResults();
    ScanResult bestSignal = null;
    wifiDemo.textStatus.setText(wifiDemo.header);

    for (ScanResult result : results) {
      if (bestSignal == null
         || WifiManager.compareSignalLevel(bestSignal.level, result.level) < 0)
         bestSignal = result;
      wifiDemo.textStatus.append("\n\n" + result.toString());
    }

      if ( storedBest == null || ((bestSignal.SSID.compareTo(storedBest.SSID)!=0) &&  bestSignal.level>-50)){
         storedBest = bestSignal;
         String locationMessage = String.format("You are near %s's Access Point",
                 bestSignal.SSID);
         Toast.makeText(wifiDemo, locationMessage, Toast.LENGTH_LONG).show();
      }
      String message = String.format("%s networks found. %s is the strongest. Its level is %s",
         results.size(), bestSignal.SSID, bestSignal.level);
      if (wifiDemo.scanON) wifiDemo.wifi.startScan();
      Log.d(TAG, "onReceive() message: " + message);
  }

}

Ответы [ 2 ]

1 голос
/ 21 октября 2011

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

При этом, вероятно, причина в том, что он, вероятно, не работает, в том, что вы отменили регистрацию получателя в onStop и регистрировали только получатель в onCreate. Обычно такие вызовы следует выполнять на тех этапах жизненного цикла, которые совпадают.

  • OnCreate / OnDestroy
  • OnStart / OnStop
  • onResume / OnPause.

Чтобы решить вашу проблему, попробуйте зарегистрировать ваш приемник в onStart вместо onCreate.

0 голосов
/ 21 октября 2011

Ваш метод onResume () закомментирован ...

Вы уверены, что это правильный IntentFilter?

...