常用属性设置
android:divider item列表条目之间显示的drawable或color android:dividerHeight 设置item之间线条的宽度 android:scrollbars="none" 设置滚动条, horizontal|vertical|none分别为水平|竖直|不显示滚动条 android:entries 数组资源的引用。比如说在res的资源文件中定义数组,在此处直接引用 android:headerDividersEnabled 当设为false时,ListView将不会在各个header之间绘制divider.默认为true,主要应用在ListView.addHeaderView()上面。 android:FooterDividersEnabled 当设为false时,ListView将不会在各个footer之间绘制divider.默认为true,主要应用在ListView.addFooterView()上面。
最后一条item线条不显示问题
大家在使用ListView的时候,一定会遇到这样一个问题,怎么ListView的最后一个item没有线条啊!如果遇到了那么就是以下这两种情况了:
通过加断点调试发现在listView中,所有的分割线都是通过画一个很窄的矩形来实现的,但是在画分割线前都会都会判断目前的位置A和listView的长度B,如果A=B了,那么就不会画这条分割线了。但是将Listview嵌入到一个View中,一般会设置为高度为wrap_content,这种情况下,最后那条分割线的位置刚好等于listView的高度,所以系统不会画上这条分割线。那要怎么样才会画上呢?很简单,将ListView的高度设置为fill_partent就可以了。 当然以上所说的都是item很少的情况下,如果item很多以至于必须显示滚动条的话,那最后一个item下面是肯定不会有分割线了。
(1)ListView的 layout_height="warp_content" 改成 fill_parent(match_parent)即可显示了
(2)ListView的layout_height是fill_parent,但是数据的长度超出了屏幕长度,这就没办法了。
我从网上看到了这样的解释:
通过加断点调试发现在listView中,所有的分割线都是通过画一个很窄的矩形来实现的,但是在画分割线前都会都会判断目前的位置A和listView的长度B,如果A=B了,那么就不会画这条分割线了。但是将Listview嵌入到一个View中,一般会设置为高度为wrap_content,这种情况下,最后那条分割线的位置刚好等于listView的高度,所以系统不会画上这条分割线。那要怎么样才会画上呢?很简单,将ListView的高度设置为fill_partent就可以了。 当然以上所说的都是item很少的情况下,如果item很多以至于必须显示滚动条的话,那最后一个item下面是肯定不会有分割线了。
ListView局部添加或刷新单个Item
(1)通过 Adapter.notifyDataSetChanged()去重新绘制ListView
public class MainActivity extends Activity {
private ListView listView;
private String[] stringArray = new String[] { "语文", "数学", "英语", "物理", "化学" };
private List<string> list = new ArrayList<string>();
private BaseAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
for (int i = 0; i < stringArray.length; i++) {
list.add(stringArray[i]);
}
listView = (ListView) this.findViewById(R.id.listView);
adapter = new ArrayAdapter<string>(this, R.layout.item, list);
listView.setAdapter(adapter);
listView.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
list.add("xiaotang");
adapter.notifyDataSetChanged();
}
});
}
}
</string></string></string>
通过单击ListView的Item,就会添加一项item.不过需要值得说明这种添加也还是会重新绘制ListView,即重新加载数据。但是它和重新setAdapter()还是有区别的:
ListView.setAdapter()加载完数据会定位到第一项数据,而adapter.notifyDatasetChanged()则还是原来的焦点.
(2)listView获取指定位置View修改
public class MainActivity extends Activity {
private ListView listView;
private String[] stringArray = new String[] { "语文", "数学", "英语", "物理", "化学" };
private List<string> list = new ArrayList<string>();
private BaseAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
for (int i = 0; i < stringArray.length; i++) {
list.add(stringArray[i]);
}
listView = (ListView) this.findViewById(R.id.listView);
adapter = new ArrayAdapter<string>(this, R.layout.item, list);
listView.setAdapter(adapter);
listView.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View view,
int position, long id) {
View v = listView.getChildAt(position
- listView.getFirstVisiblePosition());
if (v instanceof TextView) {
TextView tv = (TextView) v;
tv.setText("xiaotang");
}
}
});
}
</string></string></string>
通过ListView.getChildAt()获取指定位置的View,然后修改其内容,ListView就能被修改了。
ListView整合其他View实现整体滑动:
关键代码如下: private void addHeadView() {
// 获取屏幕宽度,高度
Display display = this.getWindowManager().getDefaultDisplay();
int width = display.getWidth();
int height = display.getHeight();
LinearLayout headView = (LinearLayout) View.inflate(this, R.layout.nav,
null);
AbsListView.LayoutParams lp = new AbsListView.LayoutParams(
new LayoutParams(AbsListView.LayoutParams.MATCH_PARENT,
(int) (height * 0.12)));
headView.setLayoutParams(lp);
listView.addHeaderView(headView);
}
private void initData() {
BaseAdapter adapter = new ArrayAdapter<string>(this, R.layout.item,
stringArray);
listView.setAdapter(adapter);
}
</string>
通过ListView的addHeaderView()将headView添加到了ListView中了。
好了,ListView的基础应用就讲到这儿了。想要了解更多的ListView的应用,敬请关注后面的文章。同时,欢迎大家和我一起学习讨论,一起提高!