Wciąż nowy dla Androida, a jeszcze bardziej dla niestandardowego adaptera kursora, więc mam problem ze zrozumieniem, jak zapobiec wyświetlaniu widoków z list odtwarzania, aby zapobiec wprowadzaniu jednego tekstu editekstowego do innego podczas przewijania. Widziałem w innym poście mówiącym o zmianie nazwy konwersji, ale jak to zrobić, rysuję puste miejsce. Miałem nadzieję, że ktoś tutaj będzie mógł podać więcej szczegółów lub przykład tego, jak to zrobić w oparciu o kod, który napisałem do tej pory.EditText in ListView bez wprowadzania danych do recyklingu
public class editview extends ListActivity {
private dbadapter mydbhelper;
private PopupWindow pw;
public static int editCount;
public static ListView listView;
/** 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();
}
//Populate view
private void showResults(){
Cursor cursor = mydbhelper.getUserWord();
startManagingCursor(cursor);
String[] from = new String[] {dbadapter.KEY_USERWORD};
int[] to = new int[] {R.id.textType};
ItemAdapter adapter = new ItemAdapter(this, R.layout.edit_row, cursor,
from, to);
adapter.notifyDataSetChanged();
this.setListAdapter(adapter);
editCount = adapter.getCount();
}
//footer button
public void onClick(View footer){
final MediaPlayer editClickSound = MediaPlayer.create(this, R.raw.button50);
editClickSound.start();
startActivity(new Intent("wanted.pro.madlibs.OUTPUT"));
}
//custom cursor adapter
class ItemAdapter extends SimpleCursorAdapter {
private LayoutInflater mInflater;
private Cursor cursor;
public ItemAdapter(Context context, int layout, Cursor cursor, String[] from,
int[] to) {
super(context, layout, cursor, from, to);
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;
}
}
Zmieniono go do
class ItemAdapter extends SimpleCursorAdapter {
private LayoutInflater mInflater;
private Cursor cursor;
Map<Integer, String> inputValues = new HashMap<Integer, String>();
public View getView(final 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);
String oldText = inputValues.get(position);
holder.edittext.setText(oldText == null ? "" : oldText);
holder.edittext.addTextChangedListener(new TextWatcher(){
public void afterTextChanged(Editable editable) {
inputValues.put(position, editable.toString());
}
ale to jest recykling przecież EditText mieć dane. Próbowałem używając hold.edittext.setText (oldText), ale ten sam efekt.
Grałem z aftertextchange, ale okazało się, że nie przechowywał wartości, jak chciałem. IE będzie przechowywać tylko część łańcucha w różnych częściach tablicy. Mógłbym wpisać coś takiego jak pies w ostatni edytor tekstu i kiedy wywoływałbym pozycje w ArrayList editTextList. Wyglądałoby to jak pos1 pos2 do pos3. Nie rozumiem, dlaczego to było tylko chwytanie części ciągu editekstowego. –
maebe
Pozycje wydawały się niewiarygodne, ale może nazwałem je niewłaściwymi. Kiedy używałem adaptera simplycursor, zmieniłem identyfikator edittext za pomocą pętli for i wykorzystywałbym tę pętlę do przechowywania i wywoływania ich przy następnym działaniu. Ale nadal napotykał problemy z recyklingiem. Przez ostatnie dwa tygodnie przyglądałem się problemom izhmaps, ale nie mogę znaleźć żadnych dobrych informacji wyjaśniających, jak z nich korzystać. Tylko fragmenty kodu tu i tam. – maebe
// TextWatcher, zapisuje dane w Array do późniejszego wykorzystania. obserwator klasy implementuje TextWatcher { prywatna pozycja; obserwator publicznych (Int pozycja) { this.position = pozycja; } \t void afterTextChanged (edycji s) { \t \t \t \t \t \t \t \t \t \t \t \t \t \t \t Log.e (String.valueOf (pozycja) „jest Int pozycji”) ; \t Tekst ciągu = s.toString(); \t editview.editTextList.add (położenie, tekst); Czy to, co ja przyszedłem z moim textwatcher – maebe