使用CursorAdapter从多个表填充每个ListItem

时间:2013-06-22 07:02:53

标签: android database relational-database android-cursoradapter

我有两个表LectureTimeTableLectureDayTable这些表的结构如下: 分别为_ID | start_time | end_time | location | course_ID_FK_ID | class_Day | classTime_ID_FK | course_ID_FK,我按如下方式创建这些表:

创建LectureTimeTable:

public static final String _ID = "_id";
public static final String COL_CLASS_START_TIME = "startTime";
public static final String COL_CLASS_END_TIME = "endTime";
public static final String COL_CLASS_LOCATION = "loc";
public static final String COL_COURSE_ID_FK = "cls_main_CourseId_fk";

public static final String TABLE_NAME = "lectureTimeTable";

// query for creating the TABLE_CLASS_DAYS_MAIN table.
public static final String TABLE_CREATE = "CREATE TABLE " + TABLE_NAME
        + " (" + _ID + " INTEGER, " + COL_CLASS_START_TIME
        + " TEXT NOT NULL, " + COL_CLASS_END_TIME + " TEXT NOT NULL, "
        + COL_CLASS_LOCATION + " TEXT NOT NULL, " + COL_COURSE_ID_FK
        + " INTEGER, " + "FOREIGN KEY (" + COL_COURSE_ID_FK
        + ") REFERENCES " + Course.TABLE_NAME + " (" + Course._ID + "), "
        + " PRIMARY KEY (" + _ID + ", " + COL_COURSE_ID_FK + "));";

创建LectureDayTable:

public static final String _ID = "_id";
public static final String COL_CLASS_DAY = "classDay";
public static final String COL_CLASS_TIME_ID_FK = "classTime_id_fk";
public static final String COL_COURSE_ID_FK = "course_id_fk";

public static final String TABLE_NAME = "LectureDayTable";

// query for creating the TABLE_CLASS_DAYS_MAIN table.
public static final String TABLE_CREATE = "CREATE TABLE " + TABLE_NAME
        + " (" + _ID + " INTEGER, " + COL_CLASS_DAY + " INTEGER NOT NULL, "
        + COL_CLASS_TIME_ID_FK + " INTEGER, " + COL_COURSE_ID_FK
        + " INTEGER, " + "FOREIGN KEY (" + COL_COURSE_ID_FK + ", "
        + COL_CLASS_TIME_ID_FK + ") REFERENCES "
        + CourseLectureTime.TABLE_NAME + " ("
        + CourseLectureTime.COL_COURSE_ID_FK + ", " + CourseLectureTime._ID
        + "), " + "PRIMARY KEY (" + _ID + ", " + COL_CLASS_TIME_ID_FK
        + ", " + COL_COURSE_ID_FK + "));";

现在我在ListFragment中显示这些信息,我正在显示我设计ListItem的课程的时间表,如图所示  其中我显示Location(in the picture bellow "se")中的start_timeend_timeLectureTimeTable,并且我在days显示所有LectureDayTable(in the following picture "Su" and "Mo") }

Llist Item of the ListFragment

我不知道我的方法是否糟糕,但我通过以下CursorAdapter代码完成了这项工作:

public class ScheduleListAdapter2 extends CursorAdapter {
private TextView classLocationTV;
private TextView classTimeTV;
private TextView sundayTV;
private TextView mondayTV;
private TextView tuesdayTV;
private TextView wednesdayTV;
private TextView thursdayTV;
private TextView fridayTV;
private TextView saturdayTV;
private ContentResolver mContentResolver;

private long timeID = 0;
private long courseId;
private AsyncQueryHandler mAsyncQueryHandler;
private Context context;

public ScheduleListAdapter2(Context context, Cursor c, boolean autoRequery,
        ContentResolver cr, long courseID) {
    super(context, c, autoRequery);
    mContentResolver = cr;
    this.courseId = courseID;
    this.context = context;
    Log.i(MyConstants.LOG_TAG,
            "--------------- ScheduleListAdapter constructor called-------------------");
    // TODO Auto-generated constructor stub
}

@Override
public View newView(Context context, Cursor mCursor, ViewGroup parent) {
    // when the view will be created for first tim*e,
    // we need to tell the adapters, how each item will look
    LayoutInflater inflater = LayoutInflater.from(parent.getContext());
    View retView = inflater.inflate(R.layout.listitem_schedule, parent,
            false);

    Log.i(MyConstants.LOG_TAG,
            "--------------- ScheduleListAdapter newView called-------------------");
    return retView;
}

@Override
public void bindView(View view, Context context, Cursor mCursor) {
    // TODO Auto-generated method stub

    Log.i(MyConstants.LOG_TAG,
            "--------------- ScheduleListAdapter bindView called-------------------");

    classLocationTV = (TextView) view.findViewById(R.id.locationTV);
    classLocationTV.setText(mCursor.getString(mCursor
            .getColumnIndex(CourseLectureTime.COL_CLASS_LOCATION)));

    classTimeTV = (TextView) view.findViewById(R.id.lectureTimeTV);
    classTimeTV.setText(mCursor.getString(mCursor
            .getColumnIndex(CourseLectureTime.COL_CLASS_START_TIME))
            + "-"
            + mCursor.getString(mCursor
                    .getColumnIndex(CourseLectureTime.COL_CLASS_END_TIME)));

    timeID = mCursor.getLong(mCursor.getColumnIndex(CourseLectureTime._ID));
    Log.i(MyConstants.LOG_TAG, "--------------- GOT THE TIME ID: " + timeID);

    sundayTV = (TextView) view.findViewById(R.id.sundayTV);
    mondayTV = (TextView) view.findViewById(R.id.mondayTV);
    tuesdayTV = (TextView) view.findViewById(R.id.tuesdayTV);
    wednesdayTV = (TextView) view.findViewById(R.id.wednesdayTV);
    thursdayTV = (TextView) view.findViewById(R.id.thursdayTV);
    fridayTV = (TextView) view.findViewById(R.id.fridayTV);
    saturdayTV = (TextView) view.findViewById(R.id.saturdayTV);

    mAsyncQueryHandler = new AsyncQueryHandler(mContentResolver) {

        private long mDay;

        @Override
        protected void onQueryComplete(int token, Object cookie,
                Cursor cursor) {
            super.onQueryComplete(token, cookie, cursor);

            Log.i(MyConstants.LOG_TAG,
                    "Returned lecture days: " + cursor.getCount());

            while (cursor.moveToNext()) {
                mDay = cursor.getLong(cursor
                        .getColumnIndex(CourseLectureDay.COL_CLASS_DAY));

                if (mDay == 0) {
                    sundayTV.setTextAppearance(
                            ScheduleListAdapter2.this.context,
                            R.style.enabledDayStyle);
                    sundayTV.setBackgroundResource(R.drawable.enabled_day_background);
                } else if (mDay == 1) {
                    mondayTV.setTextAppearance(
                            ScheduleListAdapter2.this.context,
                            R.style.enabledDayStyle);
                    mondayTV.setBackgroundResource(R.drawable.enabled_day_background);
                } else if (mDay == 2) {
                    tuesdayTV.setTextAppearance(
                            ScheduleListAdapter2.this.context,
                            R.style.enabledDayStyle);
                    tuesdayTV
                            .setBackgroundResource(R.drawable.enabled_day_background);
                } else if (mDay == 3) {
                    wednesdayTV.setTextAppearance(
                            ScheduleListAdapter2.this.context,
                            R.style.enabledDayStyle);
                    wednesdayTV
                            .setBackgroundResource(R.drawable.enabled_day_background);
                } else if (mDay == 4) {
                    thursdayTV.setTextAppearance(
                            ScheduleListAdapter2.this.context,
                            R.style.enabledDayStyle);
                    thursdayTV
                            .setBackgroundResource(R.drawable.enabled_day_background);
                } else if (mDay == 5) {
                    fridayTV.setTextAppearance(
                            ScheduleListAdapter2.this.context,
                            R.style.enabledDayStyle);
                    fridayTV.setBackgroundResource(R.drawable.enabled_day_background);
                } else if (mDay == 6) {
                    saturdayTV.setTextAppearance(
                            ScheduleListAdapter2.this.context,
                            R.style.enabledDayStyle);
                    saturdayTV
                            .setBackgroundResource(R.drawable.enabled_day_background);
                }

            }

        }
    };

    mAsyncQueryHandler
            .startQuery(
                    1,
                    new Object(),
                    CourseLectureDay.CONTENT_URI,
                    new String[] { CourseLectureDay.COL_CLASS_DAY },
                    CourseLectureDay.COL_CLASS_TIME_ID_FK + " = ? AND "
                            + CourseLectureDay.COL_COURSE_ID_FK + " = ? ",
                    new String[] { String.valueOf(timeID),
                            String.valueOf(courseId) }, null);

    }
}

通过提供会议室位置开始时间结束时间一周中的几天来添加时间表即周一,周二等(如果你有更好的想法,请建议我

问题是有时候在ListItem中没有显示正确的天数,或者在FirstList项目中显示最后一个ListItem的天数。我不知道我在这里做错了什么,请建议我更好地实现这个目标:

由于

0 个答案:

没有答案