1

我使用以下代码:

我的主要活动:

public class MainActivity extends Activity {

@Override
protected void onCreate(Bundle savedInstanceState) {
    int idWidget;

    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    if(getIntent().getExtras()!=null){
        idWidget=getIntent().getExtras().getInt("com.example.testwidget.myIntent.IDWidget");

        Toast.makeText(this,"Id widget : "+Integer.toString(idWidget),Toast.LENGTH_LONG).show();
    }
}

@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
}

}

我的小部件提供商:

public class myWidgetProvider extends AppWidgetProvider {

public void onUpdate(Context contexte, AppWidgetManager gestionnaireWidget, int[] appWidgetIds) {
    final int N = appWidgetIds.length;
    int appWidgetId;
    RemoteViews vue;
    Intent intentPostIt;
    PendingIntent pendingIntentPostIt;

    Toast.makeText(contexte,"Starting updating widgets",Toast.LENGTH_SHORT).show();

    for (int i=0; i<N; i++) {
        appWidgetId = appWidgetIds[i];

        Toast.makeText(contexte,"Id widget : "+Integer.toString(appWidgetId),Toast.LENGTH_LONG).show();

        intentPostIt = new Intent(contexte,MainActivity.class);

        Logger.getLogger(MainActivity.class.getName()).log(Level.INFO,"Intent : "+intentPostIt.toString());

        intentPostIt.setAction("com.example.testwidget.myIntent");
        intentPostIt.putExtra("com.example.testwidget.myIntent.IDWidget",appWidgetId);
        pendingIntentPostIt = PendingIntent.getActivity(contexte,0, intentPostIt,0);

        Logger.getLogger(MainActivity.class.getName()).log(Level.INFO,"Intent extra : "+Integer.toString(intentPostIt.getIntExtra("GL.PostIt.IDWidget",-1)));

        vue=new RemoteViews(contexte.getPackageName(),R.layout.widget_description);
        vue.setOnClickPendingIntent(R.id.widget,pendingIntentPostIt);
        gestionnaireWidget.updateAppWidget(appWidgetId,vue);
    }

    Toast.makeText(contexte,"Ending updating widgets",Toast.LENGTH_SHORT).show();
}

}

使用此代码,当在主屏幕上添加第一个小部件时,会Toast通知您 AppWidgetManager 的update功能正在启动。一秒钟Toast为您提供正在处理的小部件的 ID。第三个通知你update函数的结束。

如果您在主屏幕上添加第二个小部件,则会重复相同的序列,但使用另一个 ID 号。

现在,单击第一个小部件:主活动已启动,并且 a为您提供与启动应用程序Toast的绑定的 Id 。Intent关闭应用程序并触摸另一个小部件:该应用程序再次启动并Toast出现另一个。在我看来,它应该给出第二个小部件的 ID。情况并非如此:第一个 Id 再次显示。

为什么我的应用程序在第二个小部件启动时没有检索到正确的 ID 号?我的代码有什么问题吗?它应该如何工作?如果是,我如何区分哪个小部件启动了该应用程序?

4

1 回答 1

0

您需要像这样在 PendingIntent 中使用标志:

    pendingIntentPostIt = PendingIntent.getActivity(contexte,0, intentPostIt,PendingIntent.FLAG_UPDATE_CURRENT);

如果没有该标志,您放置的额外数据将不会更新,因为系统中已经存在相同的 PendingIntent,并且系统只会返回您创建的第一个数据而不更新其数据。

仔细阅读以充分理解为什么会这样:http: //developer.android.com/reference/android/app/PendingIntent.html

从文档:

PendingIntent 本身只是对系统维护的令牌的引用,该令牌描述了用于检索它的原始数据。这意味着,即使它拥有的应用程序的进程被杀死,PendingIntent 本身仍可用于其他已给予它的进程。如果创建应用程序稍后重新检索相同类型的 PendingIntent(相同的操作、相同的 Intent 操作、数据、类别和组件以及相同的标志),它将接收表示相同令牌的 PendingIntent,如果它仍然有效,并且可以因此调用 cancel() 将其删除。由于这种行为,重要的是要知道两个 Intent 何时被认为是相同的,以便检索 PendingIntent。人们犯的一个常见错误是创建多个 PendingIntent 对象,其 Intent 仅在其“额外”方面有所不同 内容,期望每次得到不同的 PendingIntent。这不会发生。Intent 中用于匹配的部分与 Intent.filterEquals 定义的部分相同。如果您使用两个根据 Intent.filterEquals 等效的 Intent 对象,那么您将获得相同的 PendingIntent 对象。

......

于 2013-08-17T19:04:08.233 回答