/[projects]/android/Side9/src/dk/thoerup/side9/Side9WidgetProvider.java
ViewVC logotype

Diff of /android/Side9/src/dk/thoerup/side9/Side9WidgetProvider.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 634 by torben, Wed Mar 24 07:27:34 2010 UTC revision 704 by torben, Mon May 3 21:15:52 2010 UTC
# Line 3  package dk.thoerup.side9; Line 3  package dk.thoerup.side9;
3  import java.net.URL;  import java.net.URL;
4  import java.net.URLConnection;  import java.net.URLConnection;
5    
6    import android.app.PendingIntent;
7  import android.appwidget.AppWidgetManager;  import android.appwidget.AppWidgetManager;
8  import android.appwidget.AppWidgetProvider;  import android.appwidget.AppWidgetProvider;
 import android.appwidget.AppWidgetProviderInfo;  
9  import android.content.Context;  import android.content.Context;
10    import android.content.Intent;
11  import android.graphics.Bitmap;  import android.graphics.Bitmap;
12  import android.graphics.BitmapFactory;  import android.graphics.BitmapFactory;
13    import android.net.ConnectivityManager;
14    import android.net.Uri;
15  import android.util.Log;  import android.util.Log;
16  import android.widget.RemoteViews;  import android.widget.RemoteViews;
17    
18  public class Side9WidgetProvider extends AppWidgetProvider  {  public class Side9WidgetProvider extends AppWidgetProvider  {
19            
20          private Side9Data usedData;  
21                            //The data needs to be static, since BroadcastReceivers (which WidgetProviders extends) are only valid during onReceive()
22            private static Side9Data usedData;
23            private static Bitmap usedBitmap;
24            private static long timestamp;
25    
26            final static long UDPATESPAN = 4*60*60*1000;
27    
28    
29            static  {
30                    timestamp = 0L;
31            }
32    
33            public Side9WidgetProvider() {
34                    Log.i("Side9Pigen", "WidgetProvider constructor called");
35            }
36    
37            private void setImage(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds, Bitmap image) {
38                    // Perform this loop procedure for each App Widget that belongs to this provider
39                    final int N = appWidgetIds.length;
40                    for (int i=0; i<N; i++) {
41                            int appWidgetId = appWidgetIds[i];
42    
43                            RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.side9widget);
44    
45                            if (image != null) {
46                                    views.setImageViewBitmap(R.id.side9picture, image);
47                            } else {
48                                    views.setImageViewResource(R.id.side9picture, R.drawable.side9logo);
49                            }
50                            //views.setTextViewText(R.id.caption, newData.caption);
51    
52    
53                            // Launch a browser when user clicks on the image
54                            Intent viewIntent = new Intent(Intent.ACTION_VIEW, Uri.parse("http://ekstrabladet.dk/side9/"));
55                            viewIntent.setFlags(Intent.FLAG_ACTIVITY_NEW_TASK);
56                            PendingIntent pending = PendingIntent.getActivity(context, 0, viewIntent, Intent.FLAG_ACTIVITY_NEW_TASK);                          
57                            views.setOnClickPendingIntent(R.id.side9picture, pending);                          
58    
59                            // Tell the AppWidgetManager to perform an update on the current App Widget
60                            appWidgetManager.updateAppWidget(appWidgetId, views);
61    
62                            Log.i("Side9Pigen", "done " + appWidgetId);
63                    }      
64            }
65    
66          @Override          @Override
67          public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {          public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
68                  super.onUpdate(context, appWidgetManager, appWidgetIds);                  super.onUpdate(context, appWidgetManager, appWidgetIds);
69                    
70                  final int N = appWidgetIds.length; //                  Log.i("Side9Pigen", "onUpdate:");
71                    
72                  Log.e("onUpdate", "onUpdate:" + N);                  if (usedBitmap == null) { //load default view
73                                            usedBitmap = BitmapFactory.decodeResource(context.getResources(), R.drawable.side9logo);
74                                    }
75          try {  
76                  Side9Data data = Side9Xml.loadXml();  
77                    
78                  if (! data.equals(usedData)) {                  ConnectivityManager connMgr = (ConnectivityManager) context.getSystemService(Context.CONNECTIVITY_SERVICE);
79                          usedData = data; // save the new data                  if (connMgr.getBackgroundDataSetting() == false)
80                                                                    {
81                          URL imgUrl = new URL( data.url );                                        Log.i("Side9Pigen", "background data disabled");
82                                                    return;
83                          URLConnection conn = imgUrl.openConnection();                  }
84                          Bitmap image = BitmapFactory.decodeStream( conn.getInputStream() );  
85                                            if (System.currentTimeMillis() > (timestamp+UDPATESPAN) ) {
86                                            Log.i("Side9Pigen", "time elapsed, force XML reload");
87                          // Perform this loop procedure for each App Widget that belongs to this provider                          usedData = null;
88                          for (int i=0; i<N; i++) {                  }
89                              int appWidgetId = appWidgetIds[i];  
90                                                                        try {
91                              RemoteViews views = new RemoteViews(context.getPackageName(), R.layout.side9widget);                          Side9Data newData = Side9Xml.loadXml();
92                                
93                                                        if (! newData.equals(usedData)) {
94                              views.setImageViewBitmap(R.id.side9picture, image);  
95                                
96                                                                Log.i("Side9Pigen", "(Re)loading image:" + newData.url);
97                              // Tell the AppWidgetManager to perform an update on the current App Widget  
98                              appWidgetManager.updateAppWidget(appWidgetId, views);                                  URL imgUrl = new URL( newData.url );            
99                          }        
100                  } //END if (data.equals)                                  URLConnection conn = imgUrl.openConnection();
101                                                    conn.setConnectTimeout(2500);
102          } catch (Exception e) {                                  Bitmap image = BitmapFactory.decodeStream( conn.getInputStream() );
103                  Log.e("UPDATE", "UPDATE", e);  
104          }                                  usedData = newData; // if we made it to here without exceptions, save the new data
105                                    usedBitmap = image;
106                                    timestamp = System.currentTimeMillis();
107    
108                            } // endif
109    
110                    } catch (Exception e) {
111                            Log.e("Side9Pigen", "update failed", e);
112                    }
113    
114                    setImage(context,appWidgetManager,appWidgetIds, usedBitmap);
115                    Log.i("Side9Pigen", "update completed");
116            }
117    
118    
119            //Called when the last widget is removed/disabled
120            @Override
121            public void onDisabled(Context context) {
122                    super.onDisabled(context);
123    
124                    usedData = null; //free memory
125                    usedBitmap = null;
126          }          }
127    
128  }  }

Legend:
Removed from v.634  
changed lines
  Added in v.704

  ViewVC Help
Powered by ViewVC 1.1.20