在ListView的右边添加字母列表,点击某个字母时,列表就滚动到预期位置。

<!-- 数字和字母栏在标题栏下边并且停靠在右边 -->
<com.txrj.sms.component.QuickAlphaBar
    android:id="@+id/fast_scroller"
    android:layout_width="22dp"
    android:layout_height="fill_parent"
    android:layout_alignParentRight="true"
    android:layout_below="@+id/title_bar"
    android:layout_gravity="top|right|center"
    android:layout_marginTop="0dip"
    android:background="@null"
    android:scaleType="centerInside"
    android:src="@drawable/dic_background" />

<!-- 当前滚动到哪个字母那里 -->
<TextView
    android:id="@+id/fast_position"
    android:layout_width="70dip"
    android:layout_height="70dip"
    android:layout_centerInParent="true"
    android:layout_gravity="center_horizontal|top"
    android:layout_margin="34dip"
    android:background="@drawable/sort_icon_bg_click"
    android:gravity="center"
    android:padding="2dip"
    android:textColor="#404040"
    android:textSize="48dip"
    android:visibility="invisible" />

/**
* @ClassName QuickAlphaBar
* @description
* @author Txrj
* @date 2013-7-9 上午10:56:16
*/
public class QuickAlphaBar extends ImageButton {
   
    private String[] letters = new String[] { "#", "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 Paint mPaint = new Paint();
    private int select = 0;
    private int singleHeight;
    private ListView mListView;
    private TextView mAlphsTextView;
    private HashMap<String, Integer> alphaIndexer;
    private Handler mHandler = new Handler();

    public QuickAlphaBar(Context context, AttributeSet attrs) {
        super(context, attrs);
    }
   
    /* (non-Javadoc)
     * @see android.view.View#onTouchEvent(android.view.MotionEvent)
     */
    @Override
    public boolean onTouchEvent(MotionEvent event) {
        int lastSelect = select;       
        int index = (int) (event.getY() / singleHeight);
        if (index >= 0 && index < letters.length) {
            String alpha = letters[index];
            if (alphaIndexer.containsKey(alpha)) {
                int position = alphaIndexer.get(alpha);
                if (mListView.getHeaderViewsCount() > 0) {
                    mListView.setSelectionFromTop(position
                            + mListView.getHeaderViewsCount(), 0);
                } else {
                    mListView.setSelectionFromTop(position, 0);
                }
                mAlphsTextView.setText(letters[index]);
            }
        }
        switch(event.getAction()) {
        case MotionEvent.ACTION_DOWN:
            if(lastSelect != index) {
                if(index >= 0 && index < letters.length) {
                    select = index;
                    invalidate();
                }
            }
            mAlphsTextView.setVisibility(VISIBLE);
            break;
        case MotionEvent.ACTION_MOVE:
            if(lastSelect != index) {
                if(index >= 0 && index < letters.length) {
                    select = index;
                    invalidate();
                }
            }
            break;
        case MotionEvent.ACTION_UP:
            select = -1;
            mAlphsTextView.setVisibility(INVISIBLE);
            break;
        }
        return super.onTouchEvent(event);
    }
   
    /* (non-Javadoc)
     * @see android.widget.ImageView#onDraw(android.graphics.Canvas)
     */
    @Override
    protected void onDraw(Canvas canvas) {
        super.onDraw(canvas);
        singleHeight = getHeight() / letters.length;
        for(int i=0;i<letters.length;i++){
            mPaint.setTextSize(20);
            mPaint.setTypeface(Typeface.DEFAULT_BOLD);
            mPaint.setAntiAlias(true);
            mPaint.setColor(Color.GRAY);
            if(i == select) {
                mPaint.setColor(Color.parseColor("#00BFFF"));
                mPaint.setFakeBoldText(true);
            }
            float x = getWidth() / 2 - mPaint.measureText(letters[i]) / 2;
            float y = singleHeight * (i + 1);
            canvas.drawText(letters[i], x, y, mPaint);
            mPaint.reset();
        }
    }
   
    public void setListView(ListView listView) {
        mListView = listView;
    }
   
    public void setAlphaIndexer(HashMap<String, Integer> alphaIndexer) {
        this.alphaIndexer = alphaIndexer;
    }
   
    public void setTextView(TextView textView) {
        this.mAlphsTextView = textView;
    }
}

在ListView的右边添加字母列表的更多相关文章

  1. 获取subgrid中的数据并修改,含添加刷新列表的事件

    var isAddRefresh = false; function setLawsuitQueryResultText() { var queryResultIndex = 7; var gridC ...

  2. 在 Wiki 标记中添加无序列表

    项目:在 Wiki 标记中添加无序列表在编辑一篇维基百科的文章时,你可以创建一个无序列表,即让每个列表项占据一行,并在前面放置一个星号.但是假设你有一个非常大的列表,希望添加前面的星号.你可以在每一行 ...

  3. Python实践练习:在 Wiki 标记中添加无序列表

    题目描述 项目:在 Wiki 标记中添加无序列表 在编辑一篇维基百科的文章时,你可以创建一个无序列表,即让每个列表项占据一行,并在前面放置一个星号.但是假设你有一个非常大的列表,希望添加前面的星号.你 ...

  4. 项目一:第三天 收派标准添加 收派标准分页查询(基于datagrid实现) 收派标准修改快递员添加 快递员列表查询

    1.收派标准添加 n jQuery easyUI window使用 n jQuery easyUI form表单校验 n 收派标准添加页面调整—url params n 服务端实现—三层 2.jQue ...

  5. WPF: 在ListView中添加Checkbox列表

    描述:ListView是WPF中动态绑定工具的数据容器,本文实现了一个在ListView中显示的供用户选择的列表项目,并且控制列表中选择的项目数量,即实现单选. XAML中创建ListView,代码如 ...

  6. 从零开始编写自己的C#框架(22)——添加普通列表页面

    普通列表页面指的是上一章那种有层次感列表以外的正常列表页面,由于上一章已讲解了正常添加页面的相关操作了,所以部分相关的操作本章节就不再罗嗦重复一次了.大家可以试试先用本章内容中的一些简单介绍,自己使用 ...

  7. 关于SimpleAdapter和ListView结合使用,实现列表视图的笔记

    使用ListView需要为其添加适配器: 适配器有两种:1.ArrayAdapter  --用于单独文字显示 2.SimpleAdapter --用于文字和图片显示 这里主要记录SimpleAdapt ...

  8. dedecms讲解-arc.listview.class.php分析,列表页展示

    ./plus/list.php - 动态展示栏目列表页(也可能是频道封面)arc.listview.class.php 是dedecms的列表页的相关处理类__construct()         ...

  9. Add-VMNetworkAdapterAcl(添加访问控制列表)

    Add-VMNetworkAdapterAclCreates an ACL to apply to the traffic through a virtual machine network adap ...

随机推荐

  1. Appium+python自动化5-Appium Inspector

    前言    appium Inspector从入门到放弃!反正你都打开了,那就看下为什么要放弃吧! Appium Inspector是appium自带的一个元素定位工具,上一篇介绍了如何使用uiaut ...

  2. 转 dockerfile 介绍 及 编写

    Docker简介 Docker项目提供了构建在Linux内核功能之上,协同在一起的的高级工具.其目标是帮助开发和运维人员更容易地跨系统跨主机交付应用程序和他们的依赖.Docker通过Docker容器, ...

  3. 使用 Reachability 获取网络状态

    Reachability source https://developer.apple.com/library/ios/samplecode/Reachability/Introduction/Int ...

  4. 多线程demo,订单重复支付

    背景描述,一个商城网站,一个订单支付方案有多个1.金额支付2.积分支付3.工资支付(分期和全额),所以一个订单的方案可能有1:有1.2,或1.2.3 状态,1.订单状态,2,支付状态==>多方案 ...

  5. TFS WorkItem Permission Setting

    TFS非常强大,但是权限设置确实非常的恶心复杂,这貌似是一切NB又傲慢的软件的通病. 那么,在哪里设置 WorkItem 的权限呢? 第一步: 第二步: 第三步,下面你将一目了然. 第四步,Share ...

  6. go语言之进阶篇结构体指针类型匿名字段

    1.结构体指针类型匿名字段 示例: package main import "fmt" type Person struct { name string //名字 sex byte ...

  7. 原生js获取宽高与jquery获取宽高的方法的关系

    说明:1.因为获取高度的情况跟获取宽度的情况一样,所以以下只说获取宽度的情况.  2.以下所说的所有方法与属性所返回的值都是不带单位的.  3.为了方便说明,以下情况采用缩写表示:  obj -> ...

  8. IOS中的手势详解

    1.点击 UITapGestureRecognizer *tap=[[UITapGestureRecognizer alloc] initWithTarget:self action:@selecto ...

  9. scala 学习笔记六 推导

    1.介绍 在Scala中,推导将生成器.过滤器.和定义组合在一起. 2.例子 有一种将result用作val(而不是var)的方式,:“就地”构建result,而不是逐项构建,利用yield关键字,当 ...

  10. BZOJ 3732 Network Link-Cut-Tree (我是认真的!!

    题目大意:给定一个n个点m条边的无向连通图.k次询问两点之间全部路径中最长边的最小值 LCT的裸题! 首先维护一个动态的最小生成树,然后每次增加边时删除两点间路径上权值最大的边.最后询问时直接求x到y ...