--- android/Side9/src/dk/thoerup/side9/Side9WidgetProvider.java 2010/05/03 13:43:53 702 +++ android/Side9/src/dk/thoerup/side9/Side9WidgetProvider.java 2010/05/03 14:54:30 703 @@ -16,95 +16,111 @@ 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 = 6*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 + // 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; }