package dk.thoerup.side9; import java.net.URL; import java.net.URLConnection; import android.app.PendingIntent; import android.appwidget.AppWidgetManager; import android.appwidget.AppWidgetProvider; import android.content.Context; import android.content.Intent; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.net.ConnectivityManager; import android.net.Uri; import android.util.Log; import android.widget.RemoteViews; public class Side9WidgetProvider extends AppWidgetProvider { //The data needs to be static, since BroadcastReceivers (which WidgetProviders extends) are only valid during onReceive() private static Side9Data usedData; private static Bitmap usedBitmap; private static long timestamp; final static long UDPATESPAN = 3*60*60*1000; static { timestamp = 0L; } public Side9WidgetProvider() { Log.i("Side9Pigen", "WidgetProvider constructor called"); } private void setImage(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds, Bitmap image) { // Perform this loop procedure for each App Widget that belongs to this provider final int N = appWidgetIds.length; for (int i=0; i (timestamp+UDPATESPAN) ) { Log.i("Side9Pigen", "time elapsed, force XML reload"); usedData = null; } try { Side9Data newData = Side9Xml.loadXml(); if (! newData.equals(usedData)) { Log.i("Side9Pigen", "(Re)loading image:" + newData.url); URL imgUrl = new URL( newData.url ); URLConnection conn = imgUrl.openConnection(); conn.setConnectTimeout(2500); Bitmap image = BitmapFactory.decodeStream( conn.getInputStream() ); usedData = newData; // if we made it to here without exceptions, save the new data usedBitmap = image; timestamp = System.currentTimeMillis(); } // endif } catch (Exception e) { Log.e("Side9Pigen", "update failed", e); } setImage(context,appWidgetManager,appWidgetIds, usedBitmap); Log.i("Side9Pigen", "update completed"); } //Called when the last widget is removed/disabled @Override public void onDisabled(Context context) { super.onDisabled(context); usedData = null; //free memory usedBitmap = null; } }