微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

android – 如何在AppWidgetProvider中调用onUpdate()?

这是我的代码……

String[] show = new String[2];
RemoteViews remoteViews;
public static String ACTION_WIDGET_CONfigURE = "ConfigureWidget";
public static String ACTION_WIDGET_RECEIVER = "ActionReceiverWidget";   

@Override
public void onUpdate( Context context,AppWidgetManager appWidgetManager,int[] appWidgetIds )
{
    show = getString();

    remoteViews = new RemoteViews( context.getPackageName(),R.layout.widget );
    remoteViews.setTextViewText( R.id.widget_title,show[0]);
    remoteViews.setTextViewText( R.id.widget_textview,show[1]);

    Intent configIntent = new Intent(context,SuitAuto.class);
    configIntent.setAction(ACTION_WIDGET_CONfigURE);

    Intent active = new Intent(context,WordWidget.class);
    active.setAction(ACTION_WIDGET_RECEIVER);
    active.putExtra("msg","Message for Button 1");

    PendingIntent actionPendingIntent = PendingIntent.getbroadcast(context,active,0);
    PendingIntent configPendingIntent = PendingIntent.getActivity(context,configIntent,0);

    remoteViews.setonClickPendingIntent(R.id.update,actionPendingIntent);
    remoteViews.setonClickPendingIntent(R.id.Lilo,configPendingIntent);

    appWidgetManager.updateAppWidget(appWidgetIds,remoteViews );
}

private String[] getString() {
    String[] hon = new String[2];
    KamusWidget ad = new KamusWidget(null);
    ad.open();
    hon = ad.getwordday();
    ad.close();
    return hon;
}

@Override
public void onReceive(Context context,Intent intent) {
    // v1.5 fix that doesn't call onDelete Action
    final String action = intent.getAction();
    if (AppWidgetManager.ACTION_APPWIDGET_DELETED.equals(action)) {
        final int appWidgetId = intent.getExtras().getInt(
                AppWidgetManager.EXTRA_APPWIDGET_ID,AppWidgetManager.INVALID_APPWIDGET_ID);

        if (appWidgetId != AppWidgetManager.INVALID_APPWIDGET_ID) {
            this.onDeleted(context,new int[] { appWidgetId });
        }
    } else {
        // check,if our Action was called
        if (intent.getAction().equals(ACTION_WIDGET_RECEIVER)) {
            String msg = "null";
            try {
                msg = intent.getStringExtra("msg");
            } catch (NullPointerException e) {
                Log.e("Error","msg = null");
            }
            Toast.makeText(context,msg,Toast.LENGTH_SHORT).show();


        } else {
            // do nothing
        }

        super.onReceive(context,intent);
    }
}

 }

我只想在单击R.id.update时更新widget_title和widget_textview
它应该运行函数getString来从其他类中获取字符串,以便新的字符串可以传递给textview …

任何的想法?

最佳答案
在onReceive函数的最后,你应该能够创建一个RemoteView并更新小部件:

ComponentName name = new ComponentName(context,WordWidget.class);
int[] ids = appWidgetManager.getAppWidgetIds(name);
if(ids != null && ids.length > 0){
RemoteView remoteViews = new RemoteViews( context.getPackageName(),R.layout.widget );
remoteViews.setTextViewText( R.id.widget_title,context.getString(R.id.new_widget_title));
remoteViews.setTextViewText( R.id.widget_textview,context.getString(R.id.new_widget_text));

Intent configIntent = new Intent(context,SuitAuto.class);
configIntent.setAction(ACTION_WIDGET_CONfigURE);

Intent active = new Intent(context,WordWidget.class);
active.setAction(ACTION_WIDGET_RECEIVER);
active.putExtra("msg","Message for Button 1");

PendingIntent actionPendingIntent = PendingIntent.getbroadcast(context,0);
PendingIntent configPendingIntent = PendingIntent.getActivity(context,0);

remoteViews.setonClickPendingIntent(R.id.update,actionPendingIntent);
remoteViews.setonClickPendingIntent(R.id.Lilo,configPendingIntent);

appWidgetManager.updateAppWidget(ids,remoteViews );
}

我相信您还需要设置Intents:如果不这样做,一旦更新RemoteView,按钮将不再有效.

原文地址:https://www.jb51.cc/android/430437.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐