모두 안녕하세요 :)안드로이드리스트 뷰 및 텍스트 워처
나는 목표 추가를위한리스트 뷰가 있습니다 (중요하지 않음 : p). listview의 자식에는 사용자가 정보를 입력 할 수있는 textviews 및 edittextbox가 있습니다. 나는리스트 뷰의 자식 중 하나의 텍스트가 변경되었는지를 검사하는 Textwatcher를 가지고 있으므로리스트 뷰와 배열의 배열에 데이터를 쓸 수있다. (액티비티간에 데이터를 전달하기 위해 데이터를 전달할 때도 그렇다. 중대한).
내 문제는 목록에 항목을 추가 할 때 edittext 'discription'에있는 기존의 모든 항목의 텍스트가 새로 추가 된 항목의 텍스트로 변경된다는 것입니다. 예를 들어 listview에 'test'라는 항목이 1 개 있고 '새 테스트입니다'라는 목록에 새 항목을 추가하는 경우 >> 둘 다 'This is a new test'로 변경됩니다. 나는 프로그램을 많이 디버깅하고 결국 (새 항목을 추가 한 후) 프로그램이 's'= '이것은 새로운 테스트'이고 position = '0'인 텍스트 워처를 통해 이동한다는 것을 알아 차렸다. 이것은 아마도 첫 번째 문자의 텍스트가 변경되게합니다. 그러나 이것이 왜 발생하는지 이해하지 못합니다.
누군가 나를 도울 수 있습니까? 이 내 목표 자식 항목이 XML에
class listViewAdapter extends BaseAdapter {
private Context context;
private ArrayList<Goals> list;
public listViewAdapter(final Context context, ArrayList<Goals> list) {
this.context = context;
this.list = list;
}
@Override
public int getCount() {
return list.size();
}
@Override
public Object getItem(int position) {
return list.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
public void synchronise(){
geldclass.setGoals_list(this.list);
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
if (convertView == null) {
final LayoutInflater inflater = (LayoutInflater) context
.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
convertView = inflater.inflate(R.layout.goal_item, parent,
false);
}
Goals goal = (Goals) getItem(position);
final EditText txtdiscription = (EditText) convertView.findViewById(R.id.editDiscription);
txtdiscription.setText(goal.getDiscription());
txtdiscription.addTextChangedListener(new textWatcher(txtdiscription, position));
final EditText txtgoal = (EditText) convertView
.findViewById(R.id.editGoal);
txtgoal.addTextChangedListener(new textWatcher(txtgoal, position));
final EditText txtfrom = (EditText) convertView
.findViewById(R.id.editFrom);
txtfrom.addTextChangedListener(new textWatcher(txtfrom, position));
final EditText txtto = (EditText) convertView
.findViewById(R.id.editto);
txtto.addTextChangedListener(new textWatcher(txtto, position));
final CheckBox check_date = (CheckBox) convertView
.findViewById(R.id.check_enable_date);
check_date
.setOnCheckedChangeListener(new OnCheckedChangeListener() {
@Override
public void onCheckedChanged(CompoundButton buttonView,
boolean isChecked) {
}
});
return convertView;
}
private class textWatcher implements TextWatcher {
private View view;
private int position;
private textWatcher(View view, int position) {
this.view = view;
this.position = position;
}
@Override
public void afterTextChanged(Editable s) {
switch (view.getId()) {
case R.id.editDiscription:
list.get(position).setDiscription(s.toString());
synchronise();
break;
case R.id.editGoal:
list.get(position).setGoalvalue(Integer.parseInt(s.toString()));
synchronise();
break;
}
}
@Override
public void beforeTextChanged(CharSequence s, int start, int count,
int after) {
// TODO Auto-generated method stub
}
@Override
public void onTextChanged(CharSequence s, int start, int before,
int count) {
// TODO Auto-generated method stub
}
}
}
:
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<TableRow
android:id="@+id/tableRow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/textDiscription"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="right"
android:text="@string/name"
android:textSize="15dp"
android:width="80dp" />
<EditText
android:id="@+id/editDiscription"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:inputType="textNoSuggestions"
android:width="120dp" >
</EditText>
</TableRow>
<TableRow
android:id="@+id/tableRow3"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/textGoal"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="right"
android:text="@string/goal"
android:textSize="15dp" />
<EditText
android:id="@+id/editGoal"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:inputType="textNoSuggestions"
android:width="200dp" >
</EditText>
</TableRow>
<TableRow
android:id="@+id/tableRow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<CheckBox
android:id="@+id/check_enable_date"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/from"
android:textSize="15dp" />
<EditText
android:id="@+id/editFrom"
android:enabled="false"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:inputType="date"
android:ems="10" >
</EditText>
</TableRow>
<TableRow
android:id="@+id/tableRow4"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView
android:id="@+id/textfrom"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="right"
android:text="@string/to"
android:textSize="15dp" />
<EditText
android:id="@+id/editto"
android:enabled="false"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:inputType="date"
android:ems="10" >
</EditText>
</TableRow>
</TableLayout>
을 그리고 여기이 항목을 추가 할 경우 ('geldclass'에 관심을 지불하지 않는 것입니다
이
내 목록보기입니다 글로벌 배열 저장된다 .. 그 글로벌 클래스)public void onClick(View v) {
Goals goal = new Goals("this is a new test");
geldclass.addGoals(goal);
goal_adapter = new listViewAdapter(GoalManager.this, geldclass.getGoals_list());
goal_list.setAdapter(goal_adapter);
}
위치를 확인하십시오. var, 제 생각에는 맞지 않습니다. – Timmetje
네, 미안 해요. 'count = 0'에 의해 나는 'position = 0'을 의미했다 .. 디버깅 할 때, 먼저 물마루 위치 = 0 -> 1 -> 2 -> 그리고 0으로 돌아 간다. s '는'이것은 새로운 시험이다 '라고 주장한다. 따라서 새 텍스트는 이전 항목의 설명 텍스트를 덮어 씁니다. –