Android RecyclerView 打造带悬浮效果的联系人

项目要求,联系人页面,怎样才能好看一点呢? 又不要用ListView,又要带悬浮的标。来吧,说一下联系人的点

首先有个SideBarView 就是侧边字母栏,这个东西呢 关于自定义view ,我Android RecyclerView 打造带悬浮效果的联系人了两个SideBarView Android RecyclerView 打造带悬浮效果的联系人

两种不同风格的SideBarView Tisp;

先贴代码吧


第一种

public class SildeBar extends View {

    public static final String TAG = "SlideBar";
    // 触摸事件
    private OnTouchingLetterChangedListener onTouchingLetterChangedListener;
    // 26个字母
    public static String[] b = { "A", "B", "C", "D", "E", "F", "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q",
            "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "#" };
    private int choose = -1;// 选中
    private Paint paint = new Paint();

    private TextView mTextDialog;
    private float singleHeight;

    public static int dialogColor[] = { R.drawable.dialog_color_blue, R.drawable.dialog_color_green,
            R.drawable.dialog_color_orange, R.drawable.dialog_color_purple, R.drawable.dialog_color_red };;

    public void setTextView(TextView mTextDialog) {
        this.mTextDialog = mTextDialog;
    }

    public SildeBar(Context context, AttributeSet attrs, int defStyle) {
        super(context, attrs, defStyle);
    }

    public SildeBar(Context context, AttributeSet attrs) {
        super(context, attrs);
    }

    public SildeBar(Context context) {
        super(context);
    }

    /**
     * 重写这个方法
     */
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        // 获取焦点改变背景颜色.
        int height = getHeight();// 获取对应高度
        int width = getWidth(); // 获取对应宽度

        // 获取每一个字母的高度
        singleHeight = (height * 1f) / b.length;
        singleHeight = (height * 1f - singleHeight/2) / b.length;
        for (int i = 0; i < b.length; i++) {
           // paint.setColor(Color.rgb(23, 122, 216));

            paint.setColor(Color.GRAY);
            paint.setTypeface(Typeface.DEFAULT_BOLD);
            paint.setAntiAlias(true);
            paint.setTextSize(35);
            // 选中的状态
            if (i == choose) {
                paint.setColor(Color.parseColor("#c60000"));
                paint.setFakeBoldText(true);
            }
            // x坐标等于中间-字符串宽度的一半.
            float xPos = width / 2 - paint.measureText(b[i]) / 2;
            float yPos = singleHeight * i + singleHeight;
            canvas.drawText(b[i], xPos, yPos, paint);
            paint.reset();// 重置画笔
        }

    }

    @RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)
    @Override
    public boolean dispatchTouchEvent(MotionEvent event) {
        final int action = event.getAction();
        final float y = event.getY();// 点击y坐标
        final int oldChoose = choose;
        final OnTouchingLetterChangedListener listener = onTouchingLetterChangedListener;
        final int c = (int) (y / getHeight() * b.length);// 点击y坐标所占总高度的比例*b数组的长度就等于点击b中的个数.

        switch (action) {
            case MotionEvent.ACTION_UP:
                setBackgroundDrawable(new ColorDrawable(0x00808080));
                choose = -1;//
                invalidate();
                if (mTextDialog != null) {
                    mTextDialog.setVisibility(View.INVISIBLE);
                }
                break;
            // 除开松开事件的任何触摸事件
            default:
                setBackgroundResource(R.drawable.bg_slide_bar);

                if (oldChoose != c) {
                    if (c >= 0 && c < b.length) {
                        if (listener != null) {
                            listener.onTouchingLetterChanged(b[c]);
                        }
                        if (mTextDialog != null) {
                            mTextDialog.setText(b[c]);
                            mTextDialog.setVisibility(View.VISIBLE);


                            // 动态改变文字dialog的位置
//                            int right = mTextDialog.getLeft();
//                            mTextDialog.setX(right / 2 * 3);
//                            if(c>24){
//                                mTextDialog.setY(singleHeight * 24);
//                            }else{
//                                mTextDialog.setY(singleHeight * c);
//                            }
                            mTextDialog.setBackground(getContext().getResources().getDrawable(dialogColor[c / 6]));
                        }

                        choose = c;
                        invalidate();
                    }
                }

                break;
        }
        return true;
    }

    /**
     * 向外公开的方法
     *
     * @param onTouchingLetterChangedListener
     */
    public void setOnTouchingLetterChangedListener(OnTouchingLetterChangedListener onTouchingLetterChangedListener) {
        this.onTouchingLetterChangedListener = onTouchingLetterChangedListener;
    }

    /**
     * 接口
     *
     * @author coder
     *
     */
    public interface OnTouchingLetterChangedListener {
        public void onTouchingLetterChanged(String s);
    }

}
这里面放置了几张图。

第二种 就是开源项目

 QuickSideBarView 这个 去百度搜一下  挺好用的

public  abstract  class RcvAdapter<VH extends RecyclerView.ViewHolder> extends  RecyclerView.Adapter<VH>{

    private ArrayList<ContactListInfo> item = new ArrayList<ContactListInfo>();

    public RcvAdapter(){
        setHasStableIds(true);
    }

    public void add(ContactListInfo object){
        item.add(object);
        notifyDataSetChanged();
    }
//添加 索引 列表
    public void add(int index ,ContactListInfo object){
        item.add(index,object);
    }
//添加成哥列表的数据进去
    public void addAll(Collection<? extends ContactListInfo> collection){
        if(collection!=null){
            item.addAll(collection);
            notifyDataSetChanged();
        }
    }
    public void addAll(ContactListInfo... items){
        addAll(Arrays.asList(items));
    }

    public void clear() {
        item.clear();
        notifyDataSetChanged();
    }
    public void remove(String object) {
        item.remove(object);
        notifyDataSetChanged();
    }
    public ContactListInfo getItem(int position){
        return item.get(position);
    }

    @Override
    public long getItemId(int position) {
        return  getItem(position).hashCode();
    }

    @Override
    public int getItemCount() {
        return item.size();
    }

    public abstract long getHeaderId(int position);

    public abstract RecyclerView.ViewHolder onCreateHeaderViewHolder(ViewGroup parent);

    public abstract void onBindHeaderViewHolder(RecyclerView.ViewHolder holder, int position);


}
他的adapter 写成了一个 抽象类,方便我们继承