0

カスタム アダプターでListFragmentを使用しています。

私のアダプターには矢印の付いたatextviewと hideがあります。imageviewユーザーがアイテムを選択すると、矢印が表示され、背景色が変わります。ただし、ユーザーがリストをスクロールすると、すべての変更がデフォルトに戻ります。

変更を修正するにはどうすればよいですか?

編集:

私のアダプタクラス..

public class PropriedadeAdapter extends BaseAdapter {
private Context context;
private List<Propriedades> prop;

public PropriedadeAdapter(Context context, List<Propriedades> prop) {
    this.context = context;
    this.prop = prop;
}

public int getCount() {
    return prop.size();
}

public Object getItem(int position) {
    return prop.get(position);
}

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

public View getView(int position, View convertView, ViewGroup parent) {
    // Recupera o produto da posição atual
    Propriedades p = prop.get(position);

    // Layout XML
    int arquivoLayout = R.layout.lista_prop;
    LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    View v = inflater.inflate(arquivoLayout, null);

    // Atualiza o valor do Text para o nome do produto
    TextView textNome = (TextView) v.findViewById(R.id.nome);
    textNome.setText(p.getNome());

    return v;
}
}

私のフラグメントクラス..

public class frag_lista extends ListFragment{

ImageView ultimoItem = null;

@Override
public void onActivityCreated(Bundle savedInstanceState) {
    super.onActivityCreated(savedInstanceState);
     ArrayList<Propriedades> props = new ArrayList<Propriedades>();
    for(int i = 0; i <50; i++)
    {
        Propriedades prop = new Propriedades();
        prop.setNome("FRUTA "+i);
        props.add(prop);
    }
    setListAdapter(new PropriedadeAdapter(this.getActivity(),props));
}


@Override
public void onListItemClick(ListView l, View v, int position, long id) {
    ImageView seta = (ImageView)v.findViewById(R.id.imgSeta);
    seta.setVisibility(0);
    LinearLayout linha = (LinearLayout)v.findViewById(R.id.linha);
    linha.setBackgroundColor(Color.GRAY);
    if(ultimoItem != null)
    {
        ultimoItem.setVisibility(4);
    }
    ultimoItem = seta;
}   

}

onListItemClick メソッドの変更を永続化するにはどうすればよいですか????

4

2 に答える 2

0

あなたのコメントによると、アダプターを正しく使用していないと思います。

Adapterは、ListView によって自動的に呼び出されるメソッドを提供します。

選択したインデックスをメモリに保持し、 getView (...)メソッドが呼び出されるたびにビューの状態を復元する必要があります (position 引数から判断)。

ListView と Adapter に関するチュートリアルを探します。

編集:

コードをテストしていないことに注意してください。ただし、次のようなものになる可能性があります。

// TeddyBearFr: Class name typically starts with a capital letter! Frag_lista, not frag_lista
public class frag_lista extends ListFragment{

    ImageView ultimoItem = null;

    @Override
    public void onActivityCreated(Bundle savedInstanceState) {
        super.onActivityCreated(savedInstanceState);
         ArrayList<Propriedades> props = new ArrayList<Propriedades>();
        for(int i = 0; i <50; i++)
        {
            Propriedades prop = new Propriedades();
            prop.setNome("FRUTA "+i);
            props.add(prop);
        }
        setListAdapter(new PropriedadeAdapter(this.getActivity(),props));
    }


    @Override
    public void onListItemClick(ListView l, View v, int position, long id) {

        // TeddyBearFr: notify the adapter
        ( (PropriedadeAdapter) this.getListAdapter() ).onListItemClick(position);

        // TeddyBearFr: your last item must be managed in the getView(...) method of the Adapter
        //if(ultimoItem != null)
        //{
        //  ultimoItem.setVisibility(4);    // TeddyBearFr: don't use integer like this, use Android constants! View.INVISIBLE
        //}
        //ultimoItem = seta;
    }   

}


public class PropriedadeAdapter extends BaseAdapter {
    private final static String TAG = "PropriedadeAdapter";
    private Context context;
    private List<Propriedades> prop;
    private Set<Integer> mSelectedItemsPosition;

    public PropriedadeAdapter(Context context, List<Propriedades> prop) {
        this.context = context;
        this.prop = prop;
        // TeddyBearFr: set to store selected indexes
        this.mSelectedItemsPosition = new HashSet<Integer>();
    }

    public int getCount() {
        return prop.size();
    }

    public Object getItem(int position) {
        return prop.get(position);
    }

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

    public View getView(int position, View convertView, ViewGroup parent) {
        Log.d(TAG, "getView(position=" + position + ", convertView=" + convertView + ", parent=" + parent + ")" );

        // Recupera o produto da posição atual
        Propriedades p = prop.get(position);

        // TeddyBearFr: use existing view if exist ; otherwise create a new one
        View v;
        if( convertView == null ){
            // Layout XML
            int arquivoLayout = R.layout.lista_prop;
            LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
            v = inflater.inflate(arquivoLayout, null);
        }
        else{
            v = convertView;
        }

        // Atualiza o valor do Text para o nome do produto
        TextView textNome = (TextView) v.findViewById(R.id.nome);
        textNome.setText(p.getNome());

        // TeddyBearFr: update view according its selection state
        ImageView seta = (ImageView)v.findViewById(R.id.imgSeta);
        boolean isViewSelected = this.mSelectedItemsPosition.contains(position);
        int visibility = ( isViewSelected ? VIEW.VISIBLE : VIEW.GONE );
        seta.setVisibility(visibility);

        LinearLayout linha = (LinearLayout)v.findViewById(R.id.linha);
        linha.setBackgroundColor( isViewSelected ? Color.GRAY : Color.RED );

        if( position == getCount()-1 ){
            // perform special processes on the last item of the list if needed
        }

        return v;
    }

    // TeddyBearFr: callback when click
    public void onListItemClick(int position){
        Log.d(TAG, "onListItemClick(position=" + position + ")");

        // update selected index data
        // Note that I haven't tested if it works. Because native integer "position" will be wrapped in Integer object, there's a chance that the Set compares the references on objects instead of their value
        if( this.mSelectedItemsPosition.contains(position) ){
            this.mSelectedItemsPosition.remove(position);
        }
        else{
            this.mSelectedItemsPosition.add(position);
        }

        // ask the list to be refreshed -> you'll see that getView() will be called only for each displayed view
        this.notifyDataSetChanged();
    }

}
于 2012-02-24T17:38:48.660 に答える