有没有使用expandablelistadapter处理sql查询结果的好例子?
这些文档给出了3个使用expandablelistadapter的例子,但是它们都没有处理sqlite
谢谢
凯文
发布于 2011-03-31 23:16:39
这就是你要的。"QuestionCategory“是我用于组数据的简单类。"SimpleQuestion“用于项目数据。适配器接收上下文、我的DB适配器和具有组类别的就绪ArrayList。适配器初始化它的项ArrayList (然后,在getChild()中,如果需要-当groupPosition改变时,刷新它)。无论如何,它适合我的需求,但任何人都可以根据自己的需求对其进行修改。好好享受吧。
private class QuestionCategory{
public int id;
public String name;
QuestionCategory(int pId, String pName){
this.id = pId;
this.name = pName;
}
}
private class SimpleQuestion extends QuestionCategory{
public int categoryId;
SimpleQuestion(int pCatId, int pId, String pName){
super(pId, pName);
categoryId = pCatId;
}
}
private class QuestionListAdapter extends BaseExpandableListAdapter {
private Context mContext;
private DBAdapter mDB;
private ArrayList<QuestionCategory> mCategoriesArrayList;
private ArrayList<SimpleQuestion> mItemsArrayList;
public QuestionListAdapter(Context pContext, DBAdapter pDb, ArrayList<QuestionCategory> pCategoriesArrayList) {
mContext = pContext;
mDB = pDb;
mCategoriesArrayList = pCategoriesArrayList;
mItemsArrayList = new ArrayList<SimpleQuestion>();
}
@Override
public int getGroupCount() {
return mCategoriesArrayList.size();
}
@Override
public int getChildrenCount(int groupPosition) {
int count = 0;
if(mItemsArrayList.isEmpty() || ((SimpleQuestion)mItemsArrayList.get(0)).categoryId != getGroupId(groupPosition)){
Cursor itemsCursor = mDB.getQuestionsCursor((int)getGroupId(groupPosition));
count = itemsCursor.getCount();
itemsCursor.close();
}
else
count = mItemsArrayList.size();
return count;
}
@Override
public Object getGroup(int groupPosition) {
return mCategoriesArrayList.get(groupPosition);
}
@Override
public long getGroupId(int groupPosition) {
return ((QuestionCategory)getGroup(groupPosition)).id;
}
@Override
public Object getChild(int groupPosition, int childPosition) {
int categoryId = (int)getGroupId(groupPosition);
//Check if we are not in our current group now, or the current cached items are wrong - MUST BE RECACHED
if(mItemsArrayList.isEmpty() || ((SimpleQuestion)mItemsArrayList.get(0)).categoryId != categoryId){
Cursor itemsCursor = mDB.getQuestionsCursor((int)getGroupId(groupPosition));
itemsCursor.requery();
mItemsArrayList.clear();
if (itemsCursor.moveToFirst())
do {
int id = itemsCursor.getInt(itemsCursor.getColumnIndex(DBAdapter.COL_ID));
String name = itemsCursor.getString(itemsCursor.getColumnIndex(DBAdapter.COL_TEXT));
SimpleQuestion newItem = new SimpleQuestion(categoryId, id, name);
mItemsArrayList.add(newItem);
} while (itemsCursor.moveToNext());
itemsCursor.close();
}
return mItemsArrayList.get(childPosition);
}
@Override
public long getChildId(int groupPosition, int childPosition) {
return ((SimpleQuestion)(getChild(groupPosition, childPosition))).id;
}
@Override
public boolean hasStableIds() {
return true;
}
@Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
LinearLayout view;
final QuestionCategory group = (QuestionCategory)getGroup(groupPosition);
String name = group.name;
if (convertView == null) {
view = new LinearLayout(mContext);
String inflater = Context.LAYOUT_INFLATER_SERVICE;
LayoutInflater vi = (LayoutInflater) mContext.getSystemService(inflater);
vi.inflate(R.layout.question_list_item, view, true);
} else {
view = (LinearLayout) convertView;
}
TextView textTV = (TextView) view.findViewById(R.id.questionListItemTVText);
textTV.setText(name);
return view;
}
@Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView, ViewGroup parent) {
LinearLayout view;
final SimpleQuestion item = (SimpleQuestion)getChild(groupPosition, childPosition);
String name = item.name;
if (convertView == null) {
view = new LinearLayout(mContext);
String inflater = Context.LAYOUT_INFLATER_SERVICE;
LayoutInflater vi = (LayoutInflater) mContext.getSystemService(inflater);
vi.inflate(R.layout.question_list_item, view, true);
} else {
view = (LinearLayout) convertView;
}
TextView textTV = (TextView) view.findViewById(R.id.questionListItemTVText);
textTV.setText(name);
return view;
}
@Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
return true;
}
}https://stackoverflow.com/questions/3627987
复制相似问题