1、设置项目间分隔线
android:divider=“@android:color/darker_gray”// 图片也可以
android:dividerHeight=“10dp”
android:divider=“@null”// 把分隔线设置为透明
2、隐藏滚动条
android:scrollbars=“none”
3、取消ListView的Item点击效果
当点击ListView中的一项是,系统默认会出现一个点击效果,在Android 5.X上是一个波纹效果,而在Android 5.X之下的版本则是一个改变背景颜色的效果,但可以通过修改listSelector属性来取消点击后的回馈效果
android:liistSelector=”#00000000“
也可以使用Android自带的透明色来实现这一个效果
android:listSelector =“@android:color/transparent”
4、设置ListView需要显示在第几项
listView.setSelection(N)//N就是显示的Item的索引(从0开始)
比如添加数据后希望添加的数据总能显示出来,就可以使用该方法
5、遍历ListView中的所有Item
for(int i=0;i<mListView.getChildCount(); i++) {
View = mListView.getChildAt(i);
}
6、处理空ListView
通过setEmptyView(View view)方法可以给ListView设置一个在空数据下显示的默认提示,比如传进去一个ImageView
7、具有弹性的ListView
listView滚动到顶端(底端)可以下拉(上拉)一段距离然后弹上去(下去)
public class NewListView extends ListView {
public NewListView(Context context) {
super(context);
}
public NewListView(Context context, AttributeSet attrs) {
super(context, attrs);
}
public NewListView(Context context, AttributeSet attrs, int defStyleAttr) {
super(context, attrs, defStyleAttr);
}
@Override
protected boolean overScrollBy(int deltaX, int deltaY, int scrollX, int scrollY, int scrollRangeX, int scrollRangeY, int maxOverScrollX, int maxOverScrollY, boolean isTouchEvent) {
return super.overScrollBy(deltaX, deltaY, scrollX, scrollY, scrollRangeX, scrollRangeY, maxOverScrollX, 100, isTouchEvent);
}
}
maxOverScrollY默认是0,将maxOverScrollY改为可下拉(上拉)的距离即可
8、自动显示、隐藏布局的ListView
package com.example.listview1;
import android.animation.ObjectAnimator;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.util.Log;
import android.view.MotionEvent;
import android.view.View;
import android.view.ViewConfiguration;
import android.widget.AbsListView;
import android.widget.ArrayAdapter;
import android.widget.ListView;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
private Toolbar mToolBar;
private ListView mListView;
private int mTouchSlop;
private float mFirstY;
private float mCurrentY;
private final int DOWN = 0;
private final int UP = 1;
private int mDirection;
private boolean mShow = true;
private ObjectAnimator mAnimator;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
// 用ToolBar取代ActionBar
setSupportActionBar(mToolBar);
// 获取系统ActionBar的高度,也就是ToolBar的高度
int actionBarHeight = mToolBar.getHeight();
// 获取系统认为的最低华滑动距离
mTouchSlop = ViewConfiguration.get(this).getScaledTouchSlop();
View header = new View(this);
header.setLayoutParams(new AbsListView.LayoutParams(AbsListView.LayoutParams.MATCH_PARENT,
actionBarHeight));
mListView.addHeaderView(header);
List<String> list = new ArrayList<>();
for (int i = 0; i < 100; i++) {
list.add("" + i);
}
mListView.setAdapter(new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, list));
// 监听滑动事件
mListView.setOnTouchListener(new View.OnTouchListener() {
@Override
public boolean onTouch(View v, MotionEvent event) {
switch(event.getAction()) {
case MotionEvent.ACTION_DOWN:
Log.i("qqq", "onTouch: down");
mFirstY = event.getY();
break;
case MotionEvent.ACTION_MOVE:
Log.i("qqq", "onTouch: move");
mCurrentY = event.getY();
if(mCurrentY - mFirstY > mTouchSlop) {
mDirection = DOWN;
} else if(mFirstY - mCurrentY > mTouchSlop) {
mDirection = UP;
}
if(mDirection == DOWN) {
if(!mShow) {
toolBarAnim(DOWN);
mShow = !mShow;
}
} else if(mDirection == UP) {
if(mShow) {
toolBarAnim(UP);
mShow = !mShow;
}
}
break;
case MotionEvent.ACTION_UP:
Log.i("qqq", "onTouch: up");
break;
}
// 注意这里是return false;
// 如果返回true,ToolBar的显示隐藏功能还是有的,但是ListView的滑动功能没了
// 原因看博客《Android中View的事件分发机制》
/*
public boolean dispatchTouchEvent(MotionEvent event) {
if (mOnTouchListener != null && (mViewFlags & ENABLED_MASK) == ENABLED &&
mOnTouchListener.onTouch(this, event)) {
return true;
}
return onTouchEvent(event);
}
*/
return false;
}
});
}
private void toolBarAnim(int direction) {
if(mAnimator != null && mAnimator.isRunning()) {
mAnimator.cancel();
}
if(direction == DOWN) {
mAnimator = ObjectAnimator.ofFloat(mToolBar, "translationY", mToolBar.getTranslationY(), 0);
} else if(direction == UP) {
mAnimator = ObjectAnimator.ofFloat(mToolBar, "translationY", mToolBar.getTranslationY(), -mToolBar.getHeight());
}
mAnimator.start();
}
private void initView() {
mToolBar = (Toolbar) findViewById(R.id.id_toolBar);
mListView = (ListView) findViewById(R.id.id_listView);
}
}
上述代码使用了ToolBar,别忘记把Activity的主题声明为NoActionBar
<activity android:name=".MainActivity"
android:theme="@style/Theme.AppCompat.Light.NoActionBar">
以下是布局,注意要使用v7下的toolBar,不然在5.0以下的版本无效
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.listview1.MainActivity">
<ListView
android:id="@+id/id_listView"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:headerDividersEnabled="false"/>
<android.support.v7.widget.Toolbar
android:id="@+id/id_toolBar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="@android:color/holo_blue_light"/>
</RelativeLayout>