Пользовательский адаптер с editText и флажок и TextView

Я застрял в адаптере для просмотра списка: у меня есть textView(имя), флажок, editText(количество имени) в адаптере. Редактировать текст по умолчанию будет отключено, но когда я поставлю галочку, только я смогу ввести количество. в getView я должен был закодировать эту вещь. и в OnItemClick списка просмотра мне нужно сохранить объект Model и сохранить в базе данных.

package com.example.lokesh.agrigate.adapters;

import android.content.Context;
import android.text.Editable;
import android.text.TextWatcher;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.EditText;
import android.widget.Spinner;
import android.widget.TextView;

import com.example.lokesh.agrigate.R;
import com.example.lokesh.agrigate.models.Crop;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * Created by Amit on 2015-10-10.
 */
public class CropListViewAdapter extends BaseAdapter {
    Context mContext;
    List<Integer> positions;
    List<Crop> mCrops;
    public CropListViewAdapter(Context mContext, List<Crop> mCrops) {
        this.mContext = mContext;
        this.mCrops = mCrops;
        mSelectedList=new HashMap<>();
        positions=new ArrayList<>();
    }

    Map<Crop,Integer> mSelectedList=null;



    public void addCrop(List<Crop> crops){
        this.mCrops=crops;
    }

    @Override
    public int getCount() {
        return mCrops.size();
    }

    @Override
    public Crop getItem(int position) {
        return mCrops.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {
        Crop crop=getItem(position);
        Holder mHolder=null;
        if(convertView==null){
            LayoutInflater inflater=(LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            convertView=  inflater.inflate(R.layout.crop_list_item,null);
            mHolder=new Holder();
            convertView.setTag(mHolder);

            mHolder.mName=(TextView)convertView.findViewById(R.id.crpname);
            mHolder.mHelpText=(TextView)convertView.findViewById(R.id.quantityHelpText);
            mHolder.mCheckox=(CheckBox)convertView.findViewById(R.id.checkCrop);
            mHolder.mQuantityEditText=(EditText)convertView.findViewById(R.id.quantity);

            mHolder.mQuantityEditText.addTextChangedListener(new TextWatcher() {
                @Override
                public void beforeTextChanged(CharSequence s, int start, int count, int after) {

                }

                @Override
                public void onTextChanged(CharSequence s, int start, int before, int count) {

                }

                @Override
                public void afterTextChanged(Editable s) {

                }
            });

            mHolder.mCheckox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    int getPosition = (int) buttonView.getTag();
                    if (isChecked) {


                    } else {

                    }
                    buttonView.setChecked(isChecked);
                }
            });


        }else{
            mHolder=(Holder)convertView.getTag();
        }

        mHolder.mCheckox.setTag(position);
        mHolder.mName.setText(crop.toString());

        return convertView;
    }

    public void setData(List<Crop> crops) {
        this.mCrops=crops;
    }


    class Holder{
        TextView mName;
        TextView mHelpText;
        CheckBox mCheckox;
        EditText mQuantityEditText;


    }
}

Активность OnItemClick:

Map<Crop,Integer> data=new HashMap<>();
AdapterView.OnItemClickListener onCropItemClickListener=new AdapterView.OnItemClickListener() {
    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
        CheckBox checkBox=(CheckBox)view.findViewById(R.id.checkCrop);
        Crop crop=(Crop)parent.getItemAtPosition(position);
        if(checkBox.isChecked()){

            EditText ed=(EditText)view.findViewById(R.id.quantity);
            if(!TextUtils.isEmpty(ed.getText().toString()))
              data.put(crop,Integer.parseInt(ed.getText().toString()));
        }else{
           data.remove(crop);
        }
    }
};

Пожалуйста, помогите мне исправить адаптер и OnItemClick:

2 ответа

Включите редактирование текста в блоке setOnCheckedChangeListener.

        mHolder.mCheckox.setOnCheckedChangeListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
        if (((CheckBox) v).isChecked()){
              mHolder.mQuantityEditText(true)
                } else {
                   mHolder.mQuantityEditText(false)
                }
                buttonView.setChecked(isChecked);//not sure why you doing this, required if you just want to enable/disable edit text
            }
        });

Пройдя много поисков на разных сайтах, поняв проблему и исправив код, я создал новую модель и использовал ее вместо обрезки, чтобы проверить мой код:

    mCropList=mDbAdapter.getAllCrops();
    mEmployees=mDbAdapter.getAllEmployee();
    mTransactionModels=new ArrayList<>();
    for(Crop crop: mCropList){
        TransactionModel transactionModel=new TransactionModel();
        transactionModel.setIsSelected(false);  // this is to keep track of checkbox selection
        transactionModel.setQuantity(0);  // get EditText value of quantity .
        transactionModel.setDate(date);
        transactionModel.setName(crop.getName());
        transactionModel.setId(crop.getId());
        mTransactionModels.add(transactionModel);
    }



mCropListViewAdapter=new CropListViewAdapter(mContext,transactionModels);
            mCropListView.setAdapter(mCropListViewAdapter);   // Setting adapter

Ниже приведен код модифицированного адаптера:

пакет com.example.lokesh.agrigate.adapters;

import android.content.Context;
import android.text.Editable;
import android.text.TextUtils;
import android.text.TextWatcher;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.Button;
import android.widget.CheckBox;
import android.widget.CompoundButton;
import android.widget.EditText;
import android.widget.Spinner;
import android.widget.TextView;
import android.widget.Toast;

import com.example.lokesh.agrigate.R;
import com.example.lokesh.agrigate.models.Crop;
import com.example.lokesh.agrigate.models.TransactionModel;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * Created by Amit on 2015-10-10.
 */
public class CropListViewAdapter extends BaseAdapter {
    Context mContext;
    List<Integer> positions;
    List<TransactionModel> mTransactionModels;
    public CropListViewAdapter(Context mContext, List<TransactionModel> mTransactionModels) {
        this.mContext = mContext;
        this.mTransactionModels = mTransactionModels;
        mSelectedList=new HashMap<>();
        positions=new ArrayList<>();
    }

    Map<Crop,Integer> mSelectedList=null;



    public void addCrop(List<TransactionModel> mTransactionModels){
        this.mTransactionModels=mTransactionModels;
    }

    @Override
    public int getCount() {
        return mTransactionModels.size();
    }

    @Override
    public TransactionModel getItem(int position) {
        return mTransactionModels.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {
       final TransactionModel transactionModel =getItem(position);
        Holder mHolder=null;
        if(convertView==null){
            LayoutInflater inflater=(LayoutInflater)mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            convertView=  inflater.inflate(R.layout.crop_list_item,null);
            mHolder=new Holder();
            convertView.setTag(mHolder);

            mHolder.mName=(TextView)convertView.findViewById(R.id.crpname);
            mHolder.mHelpText=(TextView)convertView.findViewById(R.id.quantityHelpText);
            mHolder.mCheckox=(CheckBox)convertView.findViewById(R.id.checkCrop);
            mHolder.mQuantityEditText=(EditText)convertView.findViewById(R.id.quantity);
            mHolder.watcher=new MutableWatcher();
            mHolder.mQuantityEditText.addTextChangedListener(mHolder.watcher);


            mHolder.mCheckox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    int getPosition = (int) buttonView.getTag();
                    if (isChecked) {


                        mTransactionModels.get(getPosition).setIsSelected(buttonView.isChecked());
                    } else {
                        mTransactionModels.get(getPosition).setIsSelected(buttonView.isChecked());
                    }


                }
            });


        }else{
            mHolder=(Holder)convertView.getTag();
        }
        mHolder.mQuantityEditText.setTag(position);


        mHolder.mCheckox.setTag(position);
        mHolder.mName.setText(transactionModel.getName().toString());
        mHolder.watcher.setActive(false);
        mHolder.mQuantityEditText.setText(mTransactionModels.get(position).getQuantity()+"");
        mHolder.watcher.setPosition(position);
        mHolder.watcher.setActive(true);
        mHolder.mCheckox.setChecked(mTransactionModels.get(position).isSelected());

        return convertView;
    }

    public void setData(List<TransactionModel> mTransactionModels) {
        this.mTransactionModels=mTransactionModels;
    }

    public List<TransactionModel> getmTransactionModels(){
        return mTransactionModels;
    }


    class Holder{
        TextView mName;
        TextView mHelpText;
        CheckBox mCheckox;
        EditText mQuantityEditText;
        MutableWatcher watcher;


    }

    class MutableWatcher implements TextWatcher {

        private int mPosition;
        private boolean mActive;

        void setPosition(int position) {
            mPosition = position;
        }

        void setActive(boolean active) {
            mActive = active;
        }

        @Override
        public void beforeTextChanged(CharSequence s, int start, int count, int after) { }

        @Override
        public void onTextChanged(CharSequence s, int start, int before, int count) { }

        @Override
        public void afterTextChanged(Editable s) {
            if (mActive) {
                if(s.length()>0) {
                    mTransactionModels.get(mPosition).setQuantity(Integer.parseInt(s.toString()));
                }else {

                    Toast.makeText(mContext, "Not a valid Number", Toast.LENGTH_SHORT).show();
                }
            }
        }
    }
}

Теперь вместо того, чтобы блокировать Edittext для непроверенных элементов, я изменил свою проверку как:

for(TransactionModel model: models ){
                if(model.isSelected()){
                    if(model.getQuantity()<=0){
                        Toast.makeText(mContext,"Please enter a valid quantity",Toast.LENGTH_SHORT).show();
                        return;
                    }else{
                        model.setEmployee(mCurrentEmployee);

                        mValidModels.add(model);
                    }

                }else{
                    count++;
                }
            }
Другие вопросы по тегам