3

こんにちは、皆さん :)

目標を追加するためのリストビューがあります(重要ではありません:p)。リストビューの子には、ユーザーが情報を入力できるテキストビューと編集テキストボックスがいくつかあります。リストビューの子のいずれかのテキストが変更されたかどうかをチェックするTextwatcherがあるため、リストビューの配列+グローバル配列のクラスにデータを書き込むことができます(アクティブ間でデータを渡すためですが、これも重要ではありません) )。

今私の問題は、アイテムをリストに追加すると、edittext 'discription' 内の以前の既存のすべてのアイテムのテキストが、新しく追加されたアイテムのテキストに変更されることです。たとえば、リストビューに「テスト」という項目が 1 つあり、「これは新しいテストです」という新しい項目をリストに追加すると、両方とも「これは新しいテストです」に変わります。私はプログラムを何度もデバッグし、最後に (新しい項目を追加した後)、プログラムは 's' = 'this is a new test' および position = '0' で textwatcher を通過することに気付きました。これにより、最初のテキストが変更される可能性があります..しかし、なぜこれが起こっているのかわかりません。

誰か助けてくれませんか?

これは私のリストビューです:

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

            }
        }
    }

これはxmlの私の目標の子アイテムです:

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

1 に答える 1