X-Git-Url: http://www.average.org/gitweb/?p=WhereAmI.git;a=blobdiff_plain;f=src%2Forg%2Faverage%2Fwhereami%2FWhereAmI.java;h=f3de41799e734b28e410bb6fa99bf8f39b91cd8b;hp=e9c3c0349518c736b390abcf542cced79027b6f3;hb=69b322114a2b66c1c3751d7414f2be525d301f65;hpb=1f9175b218f70556730b7f27c87296647b2ec219 diff --git a/src/org/average/whereami/WhereAmI.java b/src/org/average/whereami/WhereAmI.java index e9c3c03..f3de417 100644 --- a/src/org/average/whereami/WhereAmI.java +++ b/src/org/average/whereami/WhereAmI.java @@ -16,6 +16,9 @@ import android.content.res.Resources; import android.text.format.Time; import android.util.Log; import android.view.View; +import android.view.Menu; +import android.view.MenuInflater; +import android.view.MenuItem; import android.view.Window; import android.view.WindowManager; import android.widget.TextView; @@ -53,6 +56,12 @@ public class WhereAmI extends Activity tvs.append(tm.format(" %d/%m/%Y %H:%M:%S")); } } + + @Override + protected void onCancelled() { + Log.w("WhereAmI", "BgUpdate callback cancelled"); + runningtasks--; + } } public UpdateTarget(TextView tv, Integer updater) { @@ -117,6 +126,7 @@ public class WhereAmI extends Activity IntentFilter intentFilter = new IntentFilter("android.net.conn.CONNECTIVITY_CHANGE"); registerReceiver(connChanged,intentFilter); + connChangedRegistered = true; boolean wifion = wifiman.setWifiEnabled(true); Log.w("WhereAmI", "enabling wifi result " + wifion); mHandler.postDelayed(resetInfo, 30000); @@ -127,7 +137,10 @@ public class WhereAmI extends Activity private Runnable resetInfo = new Runnable () { public void run() { Log.w("WhereAmI", "resetInfo starting"); - unregisterReceiver(connChanged); + if (connChangedRegistered) { + unregisterReceiver(connChanged); + connChangedRegistered = false; + } if (runningtasks > 0) { for (int i = 0; i < ut.length; i++) { ut[i].cancel(); @@ -142,6 +155,7 @@ public class WhereAmI extends Activity } }; + private boolean connChangedRegistered = false; private final BroadcastReceiver connChanged = new BroadcastReceiver() { @Override public void onReceive(Context context, Intent intent) { @@ -194,8 +208,7 @@ public class WhereAmI extends Activity public void onPause() { super.onPause(); - Log.w("WhereAmI", "calling finish"); - finish(); + Log.w("WhereAmI", "going background"); } /** Called when the activity is destroyed. */ @@ -207,8 +220,34 @@ public class WhereAmI extends Activity mHandler.removeCallbacks(updateClock); mHandler.removeCallbacks(updateCal); mHandler.removeCallbacks(updateInfo); - //unregisterReceiver(connChanged); + if (connChangedRegistered) { + unregisterReceiver(connChanged); + connChangedRegistered = false; + } boolean wifion = wifiman.setWifiEnabled(false); Log.w("WhereAmI", "disabling wifi result " + wifion); } + + /** Called when the menu is activated. */ + @Override + public boolean onCreateOptionsMenu(Menu menu) { + MenuInflater inflater = getMenuInflater(); + inflater.inflate(R.menu.main_menu, menu); + return true; + } + + /** Called when the menu item is selected */ + @Override + public boolean onOptionsItemSelected(MenuItem item) { + switch (item.getItemId()) { + case R.id.quit: + finish(); + return true; + case R.id.settings: + Log.w("WhereAmI", "settings requested"); + return true; + default: + return super.onOptionsItemSelected(item); + } + } }