5

select/unselectlistiviewの画像に問題が発生しています。私の場合、

ByDefault->image color(Yellow)
First click->image color(Orange)
Second click->image color(Yellow)

ユーザーが途中でクリックすると完璧ですが、ユーザーが最初に最初の画像をクリックし、2回目に2番目の画像をクリックすると、両方の画像の色がオレンジ色になります(これは問題です)。

私の場合、一度に1つの画像の色だけがオレンジ色(選択されていることを意味します)です。

4

1 に答える 1

1
  1. HoneyComb以上のみをサポートしている場合は、簡単です。StateListDrawableを作成し、リストビューアイテムの背景に設定します。

セレクター.xml

<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_activated="true" android:drawable="@drawable/item_focus" />
    <item android:drawable="@android:color/transparent" />
</selector>

リストビューアイテムのレイアウト

<ImageView
    android:id="@+id/image"
    android:layout_width="100dp"
    android:layout_height="100dp"
    android:padding="5dp" />

最後に、リストビューの選択モードをに設定しますSINGLE

list.setChoiceMode(ListView.CHOICE_MODE_SINGLE);

2. HoneyComb以前をサポートすることに成功した場合は、チェック可能な独自のレイアウト実装を作成する必要があります。これは、チェック状態を使用してワークアウトするために行います。LinearLayoutの例を見てみましょう(他の人にも同じことができます)。

 package com.example.listviewactivestate;

 import android.content.Context;
 import android.util.AttributeSet;
 import android.view.View;
 import android.widget.Checkable;
 import android.widget.LinearLayout;

 public class CustomLinearLayout extends LinearLayout implements Checkable {


private static final int[] CHECKED_STATE_SET = { android.R.attr.state_checked };

private boolean checked = false;

public CustomLinearLayout (Context context, AttributeSet attrs) {
    super(context, attrs);
}

public CustomLinearLayout (Context context) {
    super(context);
}

@Override
public boolean isChecked() {
    return checked;
}

@Override
public void setChecked(boolean checked) {
    this.checked = checked;

    refreshDrawableState();

    // Propagate to childs
    final int count = getChildCount();
    for (int i = 0; i < count; i++) {
        final View child = getChildAt(i);
        if (child instanceof Checkable) {
            ((Checkable) child).setChecked(checked);
        }
    }
}

@Override
protected int[] onCreateDrawableState(int extraSpace) {
    final int[] drawableState = super.onCreateDrawableState(extraSpace + 1);
    if (isChecked()) {
        mergeDrawableStates(drawableState, CHECKED_STATE_SET);
    }
    return drawableState;
}

@Override
public void toggle() {
    this.checked = !this.checked;
}
 }

このカスタムビューをxmlで使用します

 <?xml version="1.0" encoding="utf-8"?>
 <com.example.listviewactivestate.CustomLinearLayout 

 xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="@drawable/selector"
>

<ImageView
    android:id="@+id/image"
    android:layout_width="100dp"
    android:layout_height="100dp"
    android:padding="5dp" />

</com.example.listviewactivestate.CustomLinearLayout >

state_activatedに変更state_checked

<selector xmlns:android="http://schemas.android.com/apk/res/android">
   <item android:state_checked="true" android:drawable="@drawable/item_focus" />
   <item android:drawable="@android:color/transparent" />
</selector>

また、リストビュー選択モードをに設定しSINGLEます。動作しない場合は、次onItemClickEventのように追加してください

list.setOnItemClickListener(new OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
                // TODO Auto-generated method stub
                list.setItemChecked(position, true);//make sure click item is set to checked.

            }
        });
于 2012-12-18T14:57:49.480 に答える