iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android仿微信联系人字母排序效果
  • 186
分享到

Android仿微信联系人字母排序效果

联系字母排序Android 2022-06-06 05:06:11 186人浏览 薄情痞子
摘要

本文实例为大家分享了Android联系人字母排序的具体代码,供大家参考,具体内容如下 实现思路:首先说下布局,整个是一个相对布局,最下面是一个listview,listvie

本文实例为大家分享了Android联系人字母排序的具体代码,供大家参考,具体内容如下

实现思路:首先说下布局,整个是一个相对布局,最下面是一个listview,listview上面是一个自定义的view(右边显示字母),最上面是一个textview(屏幕中间的方块)。

首先说一下右边自定义view,字母是画到view上面的,首先计算一下view的高度,然后除以存放字母数组的长的,得到每个字符的高度;每个字母的宽度都是一样的,所以这里直接设置30sp;

listview显示的是108个梁山好汉的名字;

项目里面使用了一个pinyin4j.jar把每个名字转换为拼音,然后使用charAt(0)获得拼音的第一个字母;

listview的每个item是一个线性布局包裹的两个textview,上面的tv显示的是拼音的第一个字母,下面的tv显示的就是名字;在adapter判断当前条目和上一个条目的拼音首字母是否相同,如果相同隐藏当前item上面的tv;

然后在自定义view设置一个自定义监听;当点击自定义view的时候根据高度判断当前点击的是那个字母,然后根据字母设置listview要跳转的位置;

首先看下布局:


<RelativeLayout xmlns:android="Http://schemas.android.com/apk/res/android" 
  xmlns:tools="http://schemas.android.com/tools" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" > 
  <ListView 
    android:id="@+id/listview" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:cacheColorHint="@android:color/transparent" > 
  </ListView> 
  <com.wxcontacts.www.view.QuickIndexBar 
    android:id="@+id/quickindexbar" 
    android:layout_width="30dp" 
    android:layout_height="match_parent" 
    android:layout_alignParentRight="true" 
     /> 
  <!-- 默认隐藏,当点击自定义view的时候显示 --> 
  <TextView  
    android:visibility="Gone" 
    android:id="@+id/tv_hint" 
    android:gravity="center" 
    android:layout_centerInParent="true" 
    android:layout_width="60dp" 
    android:layout_height="60dp" 
    android:background="@drawable/bg_text" 
    android:text="A" 
    android:textSize="24sp"/> 
</RelativeLayout> 

先不着急看MainActivity代码首先看下自定义view的代码:


//自定义view 
public class QuickIndexBar extends View{ 
  //画笔 
  private Paint paint; 
  String[] lettres={"↑","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","↓"}; 
  //自定义view的宽高 
  private int viewHight; 
  private int viewWidth; 
  //每个文本的高度;(文本高度等于view高度除以文本个数) 
  private int cellHeight; 
  //文本的高度 
  private float textHeight; 
  private int currentIndex=-1; 
  public OnLetterChangeListen onLetterChangeListen; 
  public OnLetterChangeListen getOnLetterChangeListen(){ 
    return onLetterChangeListen; 
  } 
  public void setOnLetterChangeListener(OnLetterChangeListen onLetterChangeListen){ 
    this.onLetterChangeListen=onLetterChangeListen; 
  } 
  //自定义一个字母改变的监听 
  public interface OnLetterChangeListen{ 
    void onLetterChange(String letter); 
    void onResert(); 
  } 
  public QuickIndexBar(Context context) { 
    this(context,null); 
  } 
  public QuickIndexBar(Context context, AttributeSet attrs) { 
    this(context, attrs,0); 
  } 
  public QuickIndexBar(Context context, AttributeSet attrs, int defStyle) { 
    super(context, attrs, defStyle); 
    paint=new Paint(); 
    //设置字体颜色;默认为黑色;我们这里使用黑色 
    //paint.setColor(Color.WHITE); 
    //设置字体大小 
    paint.setTextSize(20); 
    //抗锯齿 
    paint.setAntiAlias(true); 
    //获取字体宽高,因为每个字体宽度不一样,所以获得宽度必须放在循环中做 
    //首先获取字体的属性 
    FontMetrics fontMetrics = paint.getFontMetrics(); 
    //下边界 - 上边界 
    textHeight = (float) Math.ceil(fontMetrics.descent-fontMetrics.ascent); 
  } 
  @Override 
  protected void onDraw(canvas canvas) { 
    super.onDraw(canvas); 
    //获取文本的宽高 
//   getTextWH(); 
    //每个文本的高度; 
    cellHeight=viewHight/lettres.length; 
    //通过循环把字母画出来 
    for(int x=0;x<lettres.length;x++){ 
      String text=lettres[x]; 
      //paint给我们提供了一个测量字体宽度的方法 
      float textWidth = paint.measureText(text); 
      if(currentIndex==x){ 
        //当点击某个字母的时候变色 
        paint.setColor(Color.GRAY); 
      }else{ 
        paint.setColor(Color.BLACK); 
      } 
       
      canvas.drawText(text,viewWidth/2-textWidth/2,cellHeight/2+textHeight/2+cellHeight*x,paint); 
    } 
  } 
  //测量view的宽高 
  @Override 
  protected void onSizeChanged(int w, int h, int oldw, int oldh) { 
    super.onSizeChanged(w, h, oldw, oldh); 
    viewHight =getMeasuredHeight(); 
    viewWidth =getMeasuredWidth(); 
  } 
  @Override 
  public boolean onTouchEvent(MotionEvent event) { 
    switch (event.getAction()) { 
    case MotionEvent.ACTION_DOWN: 
      //计算当前点击的字母,宽度不用考虑,因为宽度都是一样的,计算高度即可,根据你点击或者移动的高度计算你当前所点击的是哪个字母 
      float downY=event.getY(); 
      currentIndex = (int)downY/cellHeight; 
      if(currentIndex<0 || currentIndex>lettres.length-1){ 
      }else{ 
        if(onLetterChangeListen!=null){ 
          onLetterChangeListen.onLetterChange(lettres[currentIndex]); 
        } 
      } 
      //重新绘制;相当于重新调用onDraw()方法 
      invalidate(); 
      break; 
    case MotionEvent.ACTION_MOVE: 
      float moveY=event.getY(); 
      currentIndex = (int)moveY/cellHeight; 
      if(currentIndex<0 || currentIndex>lettres.length-1){ 
      }else{ 
        if(onLetterChangeListen!=null){ 
          onLetterChangeListen.onLetterChange(lettres[currentIndex]); 
        } 
      } 
      //重新绘制 
      invalidate(); 
      break; 
    case MotionEvent.ACTION_UP: 
      currentIndex=-1; 
      if(onLetterChangeListen!=null){ 
        onLetterChangeListen.onResert(); 
      } 
      break; 
    default: 
      break; 
    } 
    return true; 
  } 
} 

下面我为大家准备了一张计算字母xy坐标的图片:


最后是MainActivity的代码:


public class MainActivity extends Activity { 
  private com.wxcontacts.www.view.QuickIndexBar quickIndexBar; 
  private ListView mListView; 
  //当点击自定义view的时候屏幕中间显示一个方块,显示当前点击的字母,默认是隐藏的,当点击的时候才显示 
  private TextView tvHint; 
  private List<HaoHan> hhList=new ArrayList<HaoHan>(); 
  Context context; 
  @Override 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    requestWindowFeature(Window.FEATURE_NO_TITLE); 
    setContentView(R.layout.activity_main); 
    tvHint=(TextView) findViewById(R.id.tv_hint); 
    context=this; 
    //listview 和 自定义view 
    mListView=(ListView) findViewById(R.id.listview); 
    quickIndexBar=(QuickIndexBar) findViewById(R.id.quickindexbar); 
    initHHListData(); 
    mListView.setAdapter(new MainListViewAdapter(context,hhList)); 
    //给自定义view设置自定义监听,当点击到某个字母的时候弹出吐司显示这个字母; 
    //当点击字母的时候遍历集合,找到首字母为点击字母的HaoHan的下标,让listview跳转到响应位置 
    quickIndexBar.setOnLetterChangeListener(new QuickIndexBar.OnLetterChangeListen() { 
      @Override 
      public void onLetterChange(String letter) { 
        quickIndexBar.setBackgroundResource(R.drawable.bg_text); 
        tvHint.setVisibility(View.VISIBLE); 
        tvHint.setText(letter); 
        for(int x=0;x<hhList.size();x++){ 
          if((hhList.get(x).pinyin.charAt(0)+"").equals(letter)){ 
            mListView.setSelection(x); 
            //找到第一个字母相同的直接结束,不再向下找; 
            break; 
          } 
        } 
      } 
      @Override 
      //当手指弹起的时候此方法执行 
      public void onResert() { 
        tvHint.setVisibility(View.GONE); 
        quickIndexBar.setBackgroundResource(Color.TRANSPARENT); 
      } 
    }); 
  } 
  //初始化集合数据 
  private void initHHListData() { 
    HaoHan hh; 
    for(int x=0;x<Cheeses.NAMES.length;x++){ 
      hh=new HaoHan(Cheeses.NAMES[x]); 
      hhList.add(hh); 
    } 
    //给集合排序 
    Collections.sort(hhList); 
  } 
} 

源码下载:http://xiazai.jb51.net/201611/yuanma/AndroidWXcontact(jb51.net).rar

您可能感兴趣的文章:Android仿微信联系人按字母排序Android实现ListView的A-Z字母排序和过滤搜索功能 实现汉字转成拼音Android编程实现对文件夹里文件排序的方法Android基于名称、修改时间、大小实现文件夹排序Android 实现文件夹排序功能的实例代码Android实现列表数据按名称排序、中英文混合排序


--结束END--

本文标题: Android仿微信联系人字母排序效果

本文链接: https://www.lsjlt.com/news/23066.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android仿微信联系人列表字母侧滑控件
    仿微信联系人列表字母侧滑控件, 侧滑控件参考了以下博客:Android实现ListView的A-Z字母排序和过滤搜索功能首先分析一下字母侧滑控件应该如何实现,根据侧滑控件的高度和字母的数量来平均计算每个字母应该占据的高度。在View的onD...
    99+
    2023-05-31
    android 侧滑控件
  • android仿微信联系人索引列表功能
    前言  因为自己在做的一个小软件里面需要用到从A-Z排序的ListView,所以自然而然的想到了微信的联系人,我想要的就是那样的效果。本来没打算自己去写,想要第三方写好的东西,搜了几个之后发现有的太复杂了,有的简单是...
    99+
    2023-05-30
  • Android仿微信底部菜单栏效果
    前言在市面上,大多数的APP都需要通过底部菜单栏来将程序的功能进行分类整理,通常都是分为3-5个大模块,从而正确有效地引导用户去使用我们的APP。实现底部菜单栏的方法也有很多种。1.仿微信底部菜单栏(ViewPager+ImagerView...
    99+
    2023-05-30
    android 菜单
  • Android仿微信输入框效果的实现代码
    仿微信输入框效果图:输入框:<EditText android:layout_width="match_parent" android:layout_height="wrap_content" android:layout...
    99+
    2023-05-31
    android 输入框
  • Android仿微信雷达扫描效果的实现方法
    本文主要给大家介绍的是关于Android实现微信雷达扫描效果的相关内容,分享出来供大家参考学习,下面来看看详细的介绍:废话不多说 先上图(用AS录制的 转换工具不是很好 所以看得效果不是很好)效果图示例代码Activity 代码public...
    99+
    2023-05-31
    android 雷达扫描
  • Android仿微信通话背景的高斯模糊效果
    先看下效果图: 仔细观察上图,我们可以发现,背景图以用户头像为模板,对其进行了高斯模糊,并把它作为整个页面的背景色。 关于Android如何快速实现高斯模糊(毛玻璃效果),网上一堆...
    99+
    2024-04-02
  • Android实现手机联系人分栏效果
    本文实例为大家分享了Android实现手机联系人分栏效果的具体代码,供大家参考,具体内容如下 小编在项目时期遇见了制作手机联系人分栏效果,查询了很多资料,现在总结如下: 添加的代码并...
    99+
    2024-04-02
  • 微信小程序实现竖排slider效果
    本文实例为大家分享了微信小程序实现竖排slider效果的具体代码,供大家参考,具体内容如下 js: Component({   properties: {     blockColo...
    99+
    2024-04-02
  • Android实现仿微软系统加载动画效果
    目录效果图:实现步骤:具体代码实现:1、创建Circle对象2、自定义MinSoftLoadingView实现代码3、布局文件中使用效果图: 实现步骤: 初始化五个圆球分...
    99+
    2024-04-02
  • 如何在Android利用View模仿一个微信的LetterView效果
    如何在Android利用View模仿一个微信的LetterView效果?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。具体代码如下所示: public class LetterV...
    99+
    2023-05-31
    android view letterview
  • Android实现简单底部导航栏 Android仿微信滑动切换效果
    Android仿微信滑动切换最终实现效果:大体思路: 主要使用两个自定义View配合实现; 底部图标加文字为一个自定义view,底部导航栏为一个载体,根据需要来添加底部图标;2. 底部导航栏的设置方法类似于TabLayout的关联,View...
    99+
    2023-05-30
    android 导航栏
  • Android怎么实现手机联系人分栏效果
    今天小编给大家分享一下Android怎么实现手机联系人分栏效果的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。效果图:adap...
    99+
    2023-06-29
  • 微信小程序怎么实现竖排slider效果
    这篇文章主要介绍了微信小程序怎么实现竖排slider效果的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇微信小程序怎么实现竖排slider效果文章都会有所收获,下面我们一起来看看吧。js:Component({&...
    99+
    2023-07-02
  • 微信小程序仿APP section header悬停效果怎么实现
    本篇内容介绍了“微信小程序仿APP section header悬停效果怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!首先写一个非常...
    99+
    2023-06-26
  • 微信小程序scroll-view实现左右联动效果
    微信小程序利用scroll-view实现左右联动,供大家参考,具体内容如下 点击左边的按钮时,右边可以跳动到指定的位置 首先要注意使用scroll-view竖屏滚动,需要给...
    99+
    2024-04-02
  • 微信小程序实现菜单左右联动效果
    本文实例为大家分享了微信小程序实现菜单左右联动效果的具体代码,供大家参考,具体内容如下 原理 首先是获取数据,并且获取数据的长度(需要根据长度来计算元素的高度),通过遍历数据的内容通...
    99+
    2024-04-02
  • 微信小程序实现商品数据联动效果
    微信小程序实现商品数据联动 直接复制代码更改可以看出效果,然后根据自己想要进行调整 注: 以下商品图片用于测试,如有侵权请通知,会删除相关图片。 js部分: // pages/de...
    99+
    2022-11-13
    小程序商品数据联动 小程序联动
  • 微信小程序如何实现仿电影网站页面效果
    这篇文章主要介绍了微信小程序如何实现仿电影网站页面效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。微信小程序仿猫眼实现效果图:movie....
    99+
    2024-04-02
  • 实现微信小程序中的文字打字机效果
    实现微信小程序中的文字打字机效果微信小程序作为一种新兴的应用开发方式,已经在各行业得到了广泛的应用。在小程序中,文字是最为基本的展示形式之一,有时为了增加趣味性和吸引用户注意力,我们可以采用文字打字机效果来呈现文本内容。本文将介绍如何在微信...
    99+
    2023-11-21
    微信小程序 实现 文字打字机
  • 微信小程序实现多行文字滚动效果
    本文实例为大家分享了微信小程序实现多行文字滚动的具体代码,供大家参考,具体内容如下 wxml <view class="full" style="height:100%;o...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作