我正在尝试为我的应用程序实现一个简单的集合小部件,我正在尝试ListView
在小部件内部显示一个,但ListView
它卡在加载中......并且永远不会完成加载,并且我在数据库中有数据并且列表视图仍在坚持下去。
这是onUpdate
我的 AppWidgetProvider 类中的方法:
@Override
public void onUpdate(Context context, AppWidgetManager appWidgetManager, int[] appWidgetIds) {
int length = appWidgetIds.length;
for (int x = 0; x < length; x++){
RemoteViews remote = new RemoteViews(context.getPackageName(), R.layout.widget_layout);
Intent intent = new Intent(context,RViewsService.class);
intent.putExtra(AppWidgetManager.EXTRA_APPWIDGET_ID, appWidgetIds[x]);
intent.setData(Uri.parse(intent.toUri(Intent.URI_INTENT_SCHEME)));
remote.setRemoteAdapter(R.id.list,intent);
remote.setEmptyView(R.id.list,R.id.empty);
remote.setTextViewText(R.id.title,Utilities.setDayOfWeek());
////////////////////////////////////////////////////////////////////////////////////////////////////////
Intent AddmateriaIntent = new Intent(context,AddMateria.class);
PendingIntent pendingItentForButtonAddMateria = PendingIntent.getActivity(context,0,AddmateriaIntent,0);
remote.setOnClickPendingIntent(R.id.add,pendingItentForButtonAddMateria);
remote.setOnClickPendingIntent(R.id.empty, pendingItentForButtonAddMateria);
appWidgetManager.updateAppWidget(appWidgetIds[x],remote);
}
super.onUpdate(context,appWidgetManager,appWidgetIds);
}
我可以检查并且该方法onUpdate
完成其工作而没有错误。这是 RemoteViewService 和 RemoteViewsFactory,它们也不会在 logCat 上显示错误。
公共类 RViewsService 扩展 RemoteViewsService {
@Override
public RemoteViewsFactory onGetViewFactory(Intent intent) {
return new RViewFactory(getApplicationContext(),intent);
}
class RViewFactory implements RemoteViewsFactory {
private DBAdapter adapter;
private ArrayList<Materia> materias;
private Context context;
public RViewFactory(Context context,Intent intent){
this.context = context;
}
@Override
public void onCreate() {
adapter = new DBAdapter(context).openReadableDatabase();
materias = new ArrayList<Materia>();
Cursor cursor = adapter.query(Utilities.setDayAndTable(), new String[]{DBAdapter.ROW_SUBJECT,DBAdapter.ROW_COLOR_NAME,DBAdapter.ROW_COLOR_HEX}, null, null, null, null, null);
if (cursor != null) {
if (cursor.moveToFirst()) {
while (!cursor.isAfterLast()) {
Materia materia = new Materia();
materia.setSubject(cursor.getString(cursor.getColumnIndex(DBAdapter.ROW_SUBJECT)));
materia.setColor(new ColorObject(cursor.getString(cursor.getColumnIndex(DBAdapter.ROW_COLOR_NAME)),
(cursor.getInt(cursor.getColumnIndex(DBAdapter.ROW_COLOR_HEX)))));
materias.add(materia);
Log.d("log", "Data: " + materia.getSubject());
cursor.moveToNext();
}
}
cursor.close();
}
}
@Override
public void onDataSetChanged() {
}
@Override
public void onDestroy() {
materias = null;
adapter.close();
}
@Override
public int getCount() {
return materias.size();
}
@Override
public RemoteViews getViewAt(int i) {
RemoteViews remote = new RemoteViews(context.getPackageName(),android.R.layout.simple_list_item_1);
remote.setTextViewText(android.R.id.text1,materias.get(i).getSubject());
remote.setTextColor(android.R.id.text1,materias.get(i).getColor().getColor());
return remote;
}
@Override
public RemoteViews getLoadingView() {
return null;
}
@Override
public int getViewTypeCount() {
return 0;
}
@Override
public long getItemId(int i) {
return i;
}
@Override
public boolean hasStableIds() {
return false;
}
}
}
在 LogCat 中,加载 Widget 时我找不到错误或警告,它仅在读取光标时显示(我已经从 LogCat 中删除了文本,因为它与 GC 有关)。
日志猫
05-02 12:54:30.796 21885-21885/schooltimetable.app D/cannon﹕ Data: Math
05-02 12:54:30.806 21885-21885/schooltimetable.app D/cannon﹕ Data: Theory
而且我确信游标会返回数据,因为我已经将它记录在 Logcat 中并且它确实如上所示。
这是声明 AppWidgetProvider 和 RemoteViewService的清单片段:
<receiver android:name="schooltimetable.app.appWidgetProvider" >
<intent-filter>
<action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
</intent-filter>
<meta-data android:name="android.appwidget.provider"
android:resource="@xml/cannon_widget" />
</receiver>
<service android:name=".RViewsService" android:permission="android.permission.BIND_REMOTEVIEWS"/>
我正在Nexus 7 (2012) 上测试我的应用程序:Android 4.4.2
谢谢。