我目前正在尝试在Android中实现一个ListView,其中包含带有图标和描述文本的行。当用户按下一行时,背景颜色应该改变,图标应该被替换,如下图所示。
使用选择器更改背景没问题。但我只是想不出一个简单的方法来改变图标。我尝试的是添加两个相互重叠的图标:
<RelativeLayout
android:layout_width="50dp"
android:layout_height="50dp"
android:padding="10dp" >
<ImageView
android:id="@+id/general_list_item_icon"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:scaleType="centerInside" />
<ImageView
android:id="@+id/general_list_item_icon_active"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:visibility="gone" />
</RelativeLayout>
然后我在每个ImageView中放置一个drawable,并希望在用户按下该行时切换可见性。是否有可能使用类似于背景的选择器来执行此操作?
另外:由于ListView是动态填充的,因此使用带有静态可绘制引用的选择器不起作用。
答案 0 :(得分:9)
您可以使用setChoiceMode
listView.setChoiceMode(ListView.CHOICE_MODE_SINGLE);
在调用set adapter之前调用此方法。并覆盖适配器的getview
方法。
示例代码。
public View getView(int position, View convertView,
ViewGroup parent) {
if(convertView!=null){
ImageView img = (ImageView)convertView.findViewById(R.id.imageView1);
if(mylist.isItemChecked(position)){
convertView.setBackgroundColor(Color.WHITE);// here you can set any color.
img.setImageResource(R.drawable.img1);//img1 is stored in your rawable folder.
}else{
convertView.setBackgroundColor(0);
img.setImageResource(R.drawable.img2);
}
}
return super.getView(position, convertView, parent);
}
我希望这能为您提供所需的解决方案。祝一切顺利。谢谢。
答案 1 :(得分:1)
这是我的解决方案,对我有用:
public void setNavDrawerItemNormal()
{
for (int i=0; i< mDrawerList.getChildCount(); i++)
{
View v = mDrawerList.getChildAt(i);
ImageView icon = ((ImageView) v.findViewById(R.id.icon));
icon.setImageResource(navMenuIcons.getResourceId(0, -1));
}
}
private class SlideMenuClickListener implements
ListView.OnItemClickListener {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
long id) {
//adapter.notifyDataSetChanged();
setNavDrawerItemNormal();
if(view!=null) {
ImageView img = (ImageView) view.findViewById(R.id.icon);
img.setImageResource(R.drawable.abs__ic_go);//img1 is stored in your rawable folder.
}
// display view for selected nav drawer item
displayView(position);
}
}