1 package org.average.whereami;
3 import android.app.Activity;
4 import android.net.wifi.WifiManager;
5 import android.os.Bundle;
6 import android.os.AsyncTask;
7 import android.os.Handler;
8 import android.os.SystemClock;
9 import android.net.ConnectivityManager;
10 import android.net.NetworkInfo;
11 import android.content.BroadcastReceiver;
12 import android.content.Intent;
13 import android.content.IntentFilter;
14 import android.content.Context;
15 import android.content.res.Resources;
16 import android.text.format.Time;
17 import android.util.Log;
18 import android.view.View;
19 import android.view.Menu;
20 import android.view.MenuInflater;
21 import android.view.MenuItem;
22 import android.view.Window;
23 import android.view.WindowManager;
24 import android.widget.TextView;
26 public class WhereAmI extends Activity
28 private WifiManager wifiman;
29 private Integer runningtasks = 0;
31 private class UpdateTarget {
33 private Integer updater; // will be the function/object
34 private BgUpdate task;
36 private class BgUpdate extends AsyncTask<Void, Void, String> {
38 protected String doInBackground(Void... params) {
39 Log.w("WhereAmI", "BgUpdate " + updater + " starting");
40 SystemClock.sleep(5000); // real job do be done here
41 Log.w("WhereAmI", "BgUpdate about to return");
42 return "5 seconds passed in " + updater;
46 protected void onPostExecute(String str) {
47 Log.w("WhereAmI", "BgUpdate callback executing");
50 if (runningtasks <= 0) {
51 boolean wifion = wifiman.setWifiEnabled(false);
52 Log.w("WhereAmI", "disabling wifi result " + wifion);
55 tvs.setText(R.string.lasttry);
56 tvs.append(tm.format(" %d/%m/%Y %H:%M:%S"));
61 protected void onCancelled() {
62 Log.w("WhereAmI", "BgUpdate callback cancelled");
67 public UpdateTarget(TextView tv, Integer updater) {
69 this.updater = updater;
72 public void launch() {
73 tv.setText(R.string.updating);
74 task = new BgUpdate();
78 public void cancel() {
82 private UpdateTarget[] ut;
84 private TextView tvt, tvd, tvs;
85 private Resources res;
86 private String[] month;
87 private String[] wday;
89 private Handler mHandler = new Handler();
91 private Runnable updateClock = new Runnable () {
93 long now = System.currentTimeMillis();
96 tvt.setText(tm.format("%H:%M"));
99 long next = tm.toMillis(false);
100 mHandler.postDelayed(this, next-now+1);
104 private Runnable updateCal = new Runnable () {
106 long now = System.currentTimeMillis();
107 Time tm = new Time();
114 tm.set(now + 86400000);
118 long next = tm.toMillis(false);
119 mHandler.postDelayed(this, next-now+1);
123 private Runnable updateInfo = new Runnable () {
125 Log.w("WhereAmI", "updateInfo starting");
126 IntentFilter intentFilter =
127 new IntentFilter("android.net.conn.CONNECTIVITY_CHANGE");
128 registerReceiver(connChanged,intentFilter);
129 boolean wifion = wifiman.setWifiEnabled(true);
130 Log.w("WhereAmI", "enabling wifi result " + wifion);
131 mHandler.postDelayed(resetInfo, 30000);
132 mHandler.postDelayed(this, 60000);
136 private Runnable resetInfo = new Runnable () {
138 Log.w("WhereAmI", "resetInfo starting");
139 unregisterReceiver(connChanged);
140 if (runningtasks > 0) {
141 for (int i = 0; i < ut.length; i++) {
144 Time tm = new Time();
146 tvs.setText(R.string.failtry);
147 tvs.append(tm.format(" %d/%m/%Y %H:%M:%S"));
149 boolean wifion = wifiman.setWifiEnabled(false);
150 Log.w("WhereAmI", "disabling wifi result " + wifion);
154 private final BroadcastReceiver connChanged = new BroadcastReceiver() {
156 public void onReceive(Context context, Intent intent) {
157 ConnectivityManager cm = (ConnectivityManager)context.
158 getSystemService(Context.CONNECTIVITY_SERVICE);
159 NetworkInfo activeNetwork = cm.getActiveNetworkInfo();
160 boolean isConnected = activeNetwork != null &&
161 activeNetwork.isConnectedOrConnecting();
162 Log.w("WhereAmI", "Connectivity changed to " + isConnected);
164 for (int i = 0; i < ut.length; i++) {
172 /** Called when the activity is first created. */
174 public void onCreate(Bundle savedInstanceState)
176 super.onCreate(savedInstanceState);
177 wifiman = (WifiManager)getSystemService(Context.WIFI_SERVICE);
178 requestWindowFeature(Window.FEATURE_NO_TITLE);
179 getWindow().addFlags(WindowManager.LayoutParams.FLAG_KEEP_SCREEN_ON);
180 //getWindow().addFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN);
181 //getWindow().clearFlags(WindowManager.LayoutParams.
182 // FLAG_FORCE_NOT_FULLSCREEN);
183 setContentView(R.layout.main);
184 res = getResources();
185 month = res.getStringArray(R.array.month);
186 wday = res.getStringArray(R.array.wday);
187 tvt = (TextView)findViewById(R.id.time);
188 tvd = (TextView)findViewById(R.id.date);
189 tvs = (TextView)findViewById(R.id.timestamp);
190 ut = new UpdateTarget[] {
191 new UpdateTarget((TextView)findViewById(R.id.location), 1),
192 new UpdateTarget((TextView)findViewById(R.id.phonecall), 2)
194 Log.w("WhereAmI", "created UI, about to start update task");
195 mHandler.post(updateClock);
196 mHandler.post(updateCal);
197 mHandler.post(updateInfo);
198 Log.w("WhereAmI", "created UI, update task created");
201 /** Called when put to background */
203 public void onPause()
206 Log.w("WhereAmI", "calling finish");
210 /** Called when the activity is destroyed. */
212 public void onDestroy()
215 Log.w("WhereAmI", "going down");
216 mHandler.removeCallbacks(updateClock);
217 mHandler.removeCallbacks(updateCal);
218 mHandler.removeCallbacks(updateInfo);
219 //unregisterReceiver(connChanged);
220 boolean wifion = wifiman.setWifiEnabled(false);
221 Log.w("WhereAmI", "disabling wifi result " + wifion);
224 /** Called when the menu is activated. */
226 public boolean onCreateOptionsMenu(Menu menu) {
227 MenuInflater inflater = getMenuInflater();
228 inflater.inflate(R.menu.main_menu, menu);
232 /** Called when the menu item is selected */
234 public boolean onOptionsItemSelected(MenuItem item) {
235 switch (item.getItemId()) {
240 Log.w("WhereAmI", "settings requested");
243 return super.onOptionsItemSelected(item);