最近做盒子项目,需要做一个列表效果,用遥控器上下移动列表时,选中项始终在第三行,且移动时有动画。起初想到使用自定义View来实现,这样确实很方便,但是有一个问题,当我需要更新列表时需要每次重新删除所有的View,再重新创建,而且当列表项很多时,需要创建很多的View,而且动画还需要自己重写。然后就想到是否可以在ListView的基础上实现的这样的效果,因为即使列表项很多时,ListView的创建的View个数也很少,而且它的Adapter刷新机制很方便,而且可以直接使用它的动画。
效果图如下:
1.创建BaseListView,此实际上是一个RelativeLayout,在其中添加一个ListView,封装了很多ListView的方法,但是ListView不对外开放。
(1).固定Item在第三项,使用ListView的smoothScrollBy方法来控制。其中的难点是每次选中项后要计算移动的偏差值。
(2).当移动到列表的最上面或者最下面时,smoothScrollBy方法失效,选中项不会固定在第三项的位置,会直接移到上面去或者下面。解决的方法是在列表上方添加List几个头部和list几个尾部,但是头部和尾部都不能选中。
直接贴出BaseListView的代码:
package com.hm.test.view.base;
import com.hm.test.R;
import android.content.Context;
import android.content.res.Resources;
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.Rect;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.util.Log;
import android.view.KeyEvent;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.AdapterView.OnItemSelectedListener;
import android.widget.HeaderViewListAdapter;
import android.widget.ListAdapter;
import android.widget.ListView;
import android.widget.RelativeLayout;
public class BaseListView extends RelativeLayout {
//选中项和非选中项的高度不一样。
private int mFocusedWidth = 400;
private int mFocusedHeight = 140;
private int mNormalWidth = 400;
private int mNormalHeight = 80;
//固定显示十项
private int mShowItemCount = 10;
//默认选中项始终在第三项
private int mBaseIndex = 2;
//ListView,不对外开放
private ListView mListView;
private Drawable mBaseItemMask;
private Drawable mBaseitemBorder;