2012-07-18 1 views
3

모두 안녕하세요 :)안드로이드리스트 뷰 및 텍스트 워처

나는 목표 추가를위한리스트 뷰가 있습니다 (중요하지 않음 : 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); 
      } 
+0

위치를 확인하십시오. var, 제 생각에는 맞지 않습니다. – Timmetje

+0

네, 미안 해요. 'count = 0'에 의해 나는 'position = 0'을 의미했다 .. 디버깅 할 때, 먼저 물마루 위치 = 0 -> 1 -> 2 -> 그리고 0으로 돌아 간다. s '는'이것은 새로운 시험이다 '라고 주장한다. 따라서 새 텍스트는 이전 항목의 설명 텍스트를 덮어 씁니다. –

답변

2
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); 
      } 

setNotifyDatasetChanges()가 목록에 새로운 변화 데이터로 목록보기를 새로 고치려면 어댑터

public void onClick(View v) { 
       Goals goal = new Goals("this is a new test"); 
       geldclass.addGoals(goal); 
       goal_adapter.setNotifyDatasetChanges(); 
      } 

호출로 변경해야합니다, 나는 geldclass.getGoals_list() 당신이 를 초기화 동일한 목록이 있으리라 믿고있어 어댑터 전에.

+1

사실 이것은 제가 Listview에서 겪었던 문제 중 하나였습니다. 마지막 해결책은 뷰에 위치에 태그를 추가하고 텍스트 워처에서 해당 위치를 반환하는 것입니다. 리스너를 초기화 할 때 위치를 전달하는 대신. Android에서보기를 다시 사용하고 잘못된 위치를 전달합니다. –