当前位置: 首页 > 编程笔记 >

Android开发之自定义view实现通讯录列表A~Z字母提示效果【附demo源码下载】

高宏峻
2023-03-14
本文向大家介绍Android开发之自定义view实现通讯录列表A~Z字母提示效果【附demo源码下载】,包括了Android开发之自定义view实现通讯录列表A~Z字母提示效果【附demo源码下载】的使用技巧和注意事项,需要的朋友参考一下

本文实例讲述了Android开发之自定义view实现通讯录列表A~Z字母提示效果。分享给大家供大家参考,具体如下:

开发工具:eclipse

运行环境:htc G9 android2.3.3

话不多说,先看效果图

其实左右边的A~Z是一个自定义的View,它直接覆盖在ListView上。

MyLetterListView:

public class MyLetterListView extends View {
  OnTouchingLetterChangedListener onTouchingLetterChangedListener;
  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"};
  int choose = -1;
  Paint paint = new Paint();
  boolean showBkg = false;
  public MyLetterListView(Context context, AttributeSet attrs, int defStyle) {
    super(context, attrs, defStyle);
  }
  public MyLetterListView(Context context, AttributeSet attrs) {
    super(context, attrs);
  }
  public MyLetterListView(Context context) {
    super(context);
  }
  @Override
  protected void onDraw(Canvas canvas) {
    super.onDraw(canvas);
    if(showBkg){
      canvas.drawColor(Color.parseColor("#40000000"));
    }
    int height = getHeight();
    int width = getWidth();
    int singleHeight = height / b.length;
    for(int i=0;i<b.length;i++){
      paint.setColor(Color.WHITE);
      paint.setTypeface(Typeface.DEFAULT_BOLD);
      paint.setAntiAlias(true);
      if(i == choose){
        paint.setColor(Color.parseColor("#3399ff"));
        paint.setFakeBoldText(true);
      }
      float xPos = width/2 - paint.measureText(b[i])/2;
      float yPos = singleHeight * i + singleHeight;
      canvas.drawText(b[i], xPos, yPos, paint);
      paint.reset();
    }
  }
  @Override
  public boolean dispatchTouchEvent(MotionEvent event) {
    final int action = event.getAction();
    final float y = event.getY();
    final int oldChoose = choose;
    final OnTouchingLetterChangedListener listener = onTouchingLetterChangedListener;
    final int c = (int) (y/getHeight()*b.length);
    switch (action) {
      case MotionEvent.ACTION_DOWN:
        showBkg = true;
        if(oldChoose != c && listener != null){
          if(c > 0 && c< b.length){
            listener.onTouchingLetterChanged(b[c]);
            choose = c;
            invalidate();
          }
        }
        break;
      case MotionEvent.ACTION_MOVE:
        if(oldChoose != c && listener != null){
          if(c > 0 && c< b.length){
            listener.onTouchingLetterChanged(b[c]);
            choose = c;
            invalidate();
          }
        }
        break;
      case MotionEvent.ACTION_UP:
        showBkg = false;
        choose = -1;
        invalidate();
        break;
    }
    return true;
  }
  @Override
  public boolean onTouchEvent(MotionEvent event) {
    return super.onTouchEvent(event);
  }
  public void setOnTouchingLetterChangedListener(
      OnTouchingLetterChangedListener onTouchingLetterChangedListener) {
    this.onTouchingLetterChangedListener = onTouchingLetterChangedListener;
  }
  public interface OnTouchingLetterChangedListener{
    public void onTouchingLetterChanged(String s);
  }
}

然后我在Activity中OnTouchingLetterChangedListener中监听手指触摸到了哪个字母,然后让列表跳转到对应的位置,

弹出首字母提示框:

private class LetterListViewListener implements OnTouchingLetterChangedListener{
    @Override
    public void onTouchingLetterChanged(final String s) {
      if(alphaIndexer.get(s) != null) {
        int position = alphaIndexer.get(s);
        personList.setSelection(position);
        overlay.setText(sections[position]);
        overlay.setVisibility(View.VISIBLE);
        handler.removeCallbacks(overlayThread);
        //延迟一点五秒后执行,让overlay为不可见
        handler.postDelayed(overlayThread, 1500);
      }
    }
}

延迟一秒让弹出的首字母提示框变为不可见,也就是那个首字母提示框只会显示一秒钟的时间:

//设置overlay不可见
private class OverlayThread implements Runnable {
    @Override
    public void run() {
      overlay.setVisibility(View.GONE);
    }
}

还有关于解析汉子的首字母拼音的问题,我这里是查的系统数据库,里面正好有sort_key这一列,比如名字是张三,那么他对应的sort_key就是:ZHANG张SAN三,这样一来就容易多了:

//获得汉语拼音首字母
private String getAlpha(String str) {
    if (str == null) {
      return "#";
    }
    if (str.trim().length() == 0) {
      return "#";
    }
    char c = str.trim().substring(0, 1).charAt(0);
    // 正则表达式,判断首字母是否是英文字母
    Pattern pattern = Pattern.compile("^[A-Za-z]+{1}quot;);
    if (pattern.matcher(c + "").matches()) {
      return (c + "").toUpperCase();
    } else {
      return "#";
    }
}

如果你的数据不是从联系人表中查的,那可以使用第三方jar包,就是pinyin4j-2.5.0。

activity代码和布局文件比较长,我就不在这里贴了。

附:demo源码点击此处本站下载

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android开发入门与进阶教程》、《Android布局layout技巧总结》、《Android视图View技巧总结》、《Android编程之activity操作技巧总结》、《Android操作json格式数据技巧总结》、《Android资源操作技巧汇总》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

 类似资料:
  • 本文向大家介绍Android自定义View实现通讯录字母索引(仿微信通讯录),包括了Android自定义View实现通讯录字母索引(仿微信通讯录)的使用技巧和注意事项,需要的朋友参考一下 一、效果:我们看到很多软件的通讯录在右侧都有一个字母索引功能,像微信,小米通讯录,QQ,还有美团选择地区等等。这里我截了一张美团选择城市的图片来看看; 我们今天就来实现图片中右侧模块的索引功能,包括触摸显示以选中

  • 本文向大家介绍jQuery打字效果实现方法(附demo源码下载),包括了jQuery打字效果实现方法(附demo源码下载)的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery打字效果实现方法。分享给大家供大家参考,具体如下: 运行效果截图如下: 点击此处查看在线演示效果。 1.前台页面代码: 2.jticker_split.js脚本代码: 完整实例代码点击此处本站下载。 希望本文所

  • 本文向大家介绍Android 自定义view实现TopBar效果,包括了Android 自定义view实现TopBar效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android自定义view实现TopBar的具体代码,供大家参考,具体内容如下 布局文件 自定义属性attrs.xml文件 自定义View的Class类 Main方法的代码调用自定义的类和点击事件 效果图: 以上就

  • 本文向大家介绍Android编程实现简易弹幕效果示例【附demo源码下载】,包括了Android编程实现简易弹幕效果示例【附demo源码下载】的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Android编程实现简易弹幕效果。分享给大家供大家参考,具体如下: 首先上效果图,类似于360检测到骚扰电话页面: 布局很简单,上面是一个RelativeLayout,下面一个Button. 功能:

  • 本文向大家介绍jQuery实现的表头固定效果实例【附完整demo源码下载】,包括了jQuery实现的表头固定效果实例【附完整demo源码下载】的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了jQuery实现的表头固定效果。分享给大家供大家参考,具体如下: 运行效果截图如下: 具体实现步骤如下: 一、新建一js文件jQuery_FixedTableHead.js 内容如下: 二、Html实例

  • 本文向大家介绍Android自定义view实现进度条指示效果,包括了Android自定义view实现进度条指示效果的使用技巧和注意事项,需要的朋友参考一下 先看看效果图: 首先是布局文件 添加style-ProgressStyle 添加drawable-my_progress activity里的使用和安卓默认的一样 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。