在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. jsp页面传递参数是如何与javabean进行关联的

    总结:1.severlet容器是通过JavaBean中的属性方法名来获取属性名的,然后根据此属性名来从request中取值 2.JavaBean中属性方法的命名,set后的名称要与你从request中 ...

  2. Android只播放gif动画

    使用easygifanimator软件把gif动画打散为图片. 第一步:先上图片素材,以下素材放到res/drawable目录下: 转:http://blog.csdn.net/aminfo/arti ...

  3. SVN使用小结

    SVN是Subversion的简称.是一个开放源码的版本号控制系统.在它的管理下,文件和文件夹能够超越时空的限制,权且当作一种奇妙的"时间机器"吧. 基本功能 版本号控制 作为一个 ...

  4. 混沌数学之Baker模型

    相关DEMO参见:混沌数学之离散点集图形DEMO 相关代码: // http://wenku.baidu.com/view/ac9b57ea172ded630b1cb65b.html class Ba ...

  5. rotate-function

    https://leetcode.com/problems/rotate-function/ public class Solution { public int maxRotateFunction( ...

  6. insert-delete-getrandom-o1

    // 参考了下面一些讨论的解法 // https://discuss.leetcode.com/topic/53235/java-with-hashtable-arraylist/2 class Ra ...

  7. 几个不同版本的framework改进

    一些主要的演变过程及改进,还有很多部分不可能一一列出,下面是从1.1到4.0的一些主要改进: 一..NET Framework 1.1版本 1.ASP.NET移动控件 2.ADO.NET的改动 添加S ...

  8. (转)NGUI制作转圈的技能CD特效

    在技能图标上面放个半透明的精灵,用来做技能冷却的特效,如下图所示,我就用NGUI中的图标来带代替. NGUI制作转圈的技能CD特效 然后修改一下特效的精灵类型,它是在技能图标上面悬浮半透明可旋转的精灵 ...

  9. 装上了Fedora19

    超期服役的Aspire黑机器在一个下午主动退役了,为了填补它留下的空白,趁JD减价入手了一台宏碁(acer) SQX4610 120N,就为了玩Linux. 这机器用光驱启动有些特殊,需要在启动时不断 ...

  10. 更改Apache的首页

    本机Apache的安装过程请见: Apache的首页是由/usr/local/httpd/conf/httpd.conf文件的DocumentRoot决定的. ...## DocumentRoot: ...