У меня есть список активности, в каждой строке которого есть поля TextView и EditText. Ранее я использовал simplecursoradapter, но чтобы обойти проблему получения значений из EditText и использования в других действиях. Я не только перерабатываю движущиеся пользовательские входы, но и пытаюсь перейти на другой. Я запустил его, но когда это происходит, он не отображает никаких моих результатов. На данный момент это просто показывает мой нижний колонтитул в нижней части.
// пользовательский адаптер
public class ItemsAdapter extends ArrayAdapter<Model> {
private LayoutInflater mInflater;
private Cursor cursor;
public ItemsAdapter(Context context, int layout, Cursor cursor, String[] from,
int[] to) {
super(context, layout);
this.cursor = cursor;
mInflater = LayoutInflater.from(context);
}
static class ViewHolder {
protected TextView text;
protected EditText edittext;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder;
if (convertView == null) {
convertView = mInflater.inflate(R.layout.edit_row, null);
holder = new ViewHolder();
holder.text = (TextView) convertView.findViewById(R.id.textType);
holder.edittext = (EditText) convertView.findViewById(R.id.editText);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
cursor.moveToPosition(position);
int label_index = cursor.getColumnIndex("userword");
String label = cursor.getString(label_index);
holder.text.setText(label);
return convertView;
}
}
// Мой список активности
public class editview extends ListActivity {
private dbadapter mydbhelper;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
mydbhelper = new dbadapter(this);
mydbhelper.open();
View footer = getLayoutInflater().inflate(R.layout.footer_layout, null);
ListView listView = getListView();
listView.addFooterView(footer);
showResults();
}
private void showResults (){
Cursor cursor = mydbhelper.getUserWord();
startManagingCursor(cursor);
String[] from = new String[] {dbadapter.KEY_USERWORD};
int[] to = new int[] {R.id.textType};
ItemsAdapter adapter = new ItemsAdapter(this, R.layout.edit_row, cursor,
from, to);
adapter.notifyDataSetChanged();
this.setListAdapter(adapter);
}
//footer button
public void onClick(View footer){
final MediaPlayer editClickSound = MediaPlayer.create(this, R.raw.button50);
editClickSound.start();
}
}
// Мой курсор находится в классе dbadapter
// retrieves all the descriptions for the edittext fields
public Cursor getUserWord()
{
return myDataBase.query(USER_WORD_TABLE, new String[] {
KEY_ID,
KEY_CATEGORY,
KEY_SOURCE, KEY_TITLE, KEY_USERWORD, KEY_QUICK
},
KEY_CATEGORY+ "=" + categories.categoryClick + " AND " + KEY_SOURCE+ "="
+source.sourceClick + " AND " + KEY_TITLE+ "=" + title.titleClick,
null, null, null, KEY_ID);
}
Чтобы дать больше информации о том, как это работает. Пользователь пройдёт через серию Listviews, category-> source-> title. Затем приводит их к этому заданию с помощью EditText, где я возьму их входные данные и использую их в следующем задании. Я довольно новичок в пользовательском адаптере курсора, так как я новичок в Android и все еще учусь, поэтому у меня возникают проблемы с пониманием того, что мне не хватает.