Shown below is a simplified version of my class. I am having trouble in the onReceive method which isn't updating the widget TextView. It shows the correct information in the logcat which is outputted on the line before the setTextViewText. I'm not sure whats wrong and have been pulling my hair out (and I'm already balding).
public class SnowWidget extends AppWidgetProvider {
public static List<Article> mymtns = new ArrayList<Article>();
public static RemoteViews remoteViews;
public static ComponentName thisWidget;
public static String amount = "";
public static String mtn_name = "";
public static String desc = "";
public static String condition = "";
public static String[] type;
public static int index = 0;
@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager,
int[] appWidgetIds)
{
remoteViews = new RemoteViews(context.getPackageName(), R.layout.main);
thisWidget = new ComponentName(context, SnowWidget.class);
// This one works fine
remoteViews.setTextViewText(R.id.snowwidget, mtn_name+ "
"+ amount+""
"+ condition);
/* Make the buttons work */
Intent next = new Intent(context, SnowWidget.class);
next.setAction(ACTION_WIDGET_RECEIVER);
PendingIntent nextPendingIntent = PendingIntent.getBroadcast(context, 0, next, 0);
remoteViews.setOnClickPendingIntent(R.id.nextMtn, nextPendingIntent);
/* END - Make the buttons work */
appWidgetManager.updateAppWidget(thisWidget, remoteViews);
}
@Override
public void onReceive(Context context, Intent intent) {
// check, if our Action was called
if (intent.getAction().equals(ACTION_WIDGET_RECEIVER)) {
if(mymtns.size() > 0)
{
// This show up correctly in logcat
Log.d("onReceive", "New Info => "+ mtn_name+ "
"+ amount+""
"+ condition);
// This never updates my widget
remoteViews.setTextViewText(R.id.snowwidget, mtn_name+ "
"+ amount+""
"+ condition);
}
}
super.onReceive(context, intent);
}
}
See Question&Answers more detail:
os 与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…