我有一个listview
中ListFragment
它会从一个适配器填充,我想强调在列表中点击(或选择)项目,以及以此为基础进行选择的一些动作。 我能够处理该事件,但我如何设置所选项目从列表中选择颜色。
Answer 1:
如果您使用的是ListFragment
,那么你可能不是指定ListView
在XML这意味着你需要设置listSelector
代码。 要小心,不要将其设置在活动的生命周期虽然作为你会结束得太早IllegalStateException
。
level_list_selector.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_selected="false" android:state_pressed="false" android:drawable="@drawable/level_gradient_bg" />
<item android:state_pressed="true" android:drawable="@drawable/level_gradient_bg_hover" />
<item android:state_selected="true" android:state_pressed="false" android:drawable="@drawable/level_gradient_bg_hover" />
</selector>
分段:
public class LevelFragment extends ListFragment {
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
//Create view
...
}
@Override
public void onActivityCreated(Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
getListView().setSelector(R.drawable.level_list_selector);
}
}
注:如果您使用的电池行自定义布局,你需要太设置的列表选择。
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:background="@drawable/level_list_selector"
android:padding="5dip" >
...
</RelativeLayout>
Answer 2:
只需创建你需要的状态选择文件。 这会为您提供解决方案。 例如 -
selector.xml
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- Selected -->
<item
android:state_focused="true"
android:state_pressed="false"
android:drawable="@drawable/bg_list_item_highlighted" /> <!-- @drawable/tab_focus -->
<!-- Pressed -->
<item
android:state_pressed="true"
android:drawable="@drawable/bg_list_item_pressed" /> <!-- @drawable/tab_press -->
</selector>
在你ListView
设置这个选择为listselector。 当然,
<ListView
android:id="@+id/listView1"
android:width="wrap_content"
android:height="wrap_content"
android:listSelector="@drawable/selector" />
看看这些例子 -
ListSelector适用于整个列表
ListView的与选择
Listview_and_list_selector
Answer 3:
为此,你必须做出绘制的列表项的背景。 和“选择”任何从lisView项目之后,将绘制为透明或#000.so时,项目将选择女仆会显示选择。
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://meta.android.com/apk/res/android">
<item android:drawable="@color/transparent" />
<item android:state_pressed="false" android:drawable="@color/BackgroundColor" />
</selector>
Answer 4:
如果你想在你ListFragment标准的ListView行为,您可以设置列表项的行布局采用Android:ATTR / activatedBackgroundIndicator作为背景。 像这样:
ListItem.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="?android:attr/activatedBackgroundIndicator" <!--This is the important bit-->
android:orientation="horizontal">
<ImageView
android:id="@+id/icon"
android:layout_width="wrap_content"
android:layout_height="?android:attr/listPreferredItemHeight" />
<TextView
android:text=""
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:minHeight="?android:attr/listPreferredItemHeight" />
</LinearLayout>
ListFragment.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent">
<ListView xmlns:tools="http://schemas.android.com/tools"
android:id="@id/android:list"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="1"
android:divider="@drawable/divider"
android:dividerHeight="0.5dp" />
<TextView
android:id="@id/android:empty"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:textAppearance="?android:attr/textAppearanceLarge"
android:text="No data" />
</LinearLayout>
在您的ListFragment片段代码,使用自定义布局(这是单声道的代码,但不要绝望):
public override View OnCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
base.OnCreateView(inflater, container, savedInstanceState);
View view = inflater.Inflate(Resource.Layout.ListFragment, container, false);
//... do stuff
}
在您要创建适配器代码中的一些地方,使用列表项的布局。 在这种情况下一个SimpleAdapter将数据映射到一个图标和文本视图。 在ListItem.xml的backgound(机器人:ATTR / activatedBackgroundIndicator)让表现为你在一个正常的列表中看到的项目:
var list = new List<IDictionary<string, object>>(listOfStuff.Count);
foreach (AMap map in listOfStuff) {
var dictionary = new JavaDictionary<string, object> {
{"text", map.Text}, {"icon", Resource.Drawable.SomeIcon}
};
list.Add(dictionary);
}
SimpleAdapter _adapter = new SimpleAdapter(Activity, list,
Resource.Layout.ListItem,
new string[] { "text", "icon" },
new int[] { Resource.Id.text,
Resource.Id.icon });
Answer 5:
在获取视图的方法适配器类()u能做到这一点的..
@Override
public View getView(int position, View convertView, ViewGroup parent) {
View view = super.getView(position, convertView, parent);
view.setTag(position);
if(ur condition){
view.setBackgroundColor(Color.TRANSPARENT);
}else {
view.setBackgroundColor(Color.GREEN);
}
return view;
}