(字母排序搜索)类似微信通讯录效果

这篇博客分享了如何创建一个类似微信通讯录的字母排序搜索功能。通过使用拼音库pinyin4j,实现了汉字转拼音并进行排序。文中包含关键代码的类如SideBarView、PingYinUtil和ContactAdapter的介绍,并提供了部分布局文件的细节。最后展示了实现的效果图,并邀请读者提出改进意见。
摘要由CSDN通过智能技术生成

最近刚好有要做一个聊天通讯录,有点类似微信,所以自己也把探索的总结一下,可能还要进一步优化;
不多说,先上效果图看看:
模拟器有点卡
这里先说一些,要使用拼音字母转换,我们引用了第三方拼音库(pinyin4j-2.5.0.jar),下面我也会提供出来,这里面有源代码
(字母排序搜索)类似微信通讯录效果
用到的图片:
头像弹框
还有在drawable目录下的一些样式布局:
在sidebar_background.xml中:

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle" >
    <gradient
        android:angle="90.0"
        android:endColor="#11000000"
        android:startColor="#11000000" />
    <corners
        android:bottomLeftRadius="3dip"
        android:bottomRightRadius="3dip"
        android:topLeftRadius="3dip"
        android:topRightRadius="3dip" />
</shape>

在colleague_list_item_selector.xml中:

<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
    <item android:state_pressed="true" ><color android:color="#d9d9d9" />       
    </item>
    <item android:state_pressed="false"><color android:color="#ffffff" />
    </item>
    <item android:state_selected="false"><color android:color="#ffffff" />
    </item>
    <item ><color android:color="#ffffff"/></item>
</selector>

在layout布局中,一个Activity布局,一个子条目item布局和列表底部显示总共多少人的尾布局;
在activity_main.xml中;

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="#e1e2e6"
    android:orientation="vertical" >
    <FrameLayout
        android:layout_width="fill_parent"
        android:layout_height="fill_parent" >       
            <ListView
                android:id="@+id/colleague_lv_Contact"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:layout_gravity="center"
                android:divider="@null" />
        <TextView
            android:id="@+id/colleague_tv_dialog"
            android:layout_width="80.0dip"
            android:layout_height="80.0dip"
            android:layout_gravity="center"
           android:background="@drawable/colleague_dialog"
            android:gravity="center"
            android:textColor="#ffffffff"
            android:textSize="30.0dip"
            android:visibility="invisible" />
        <com.demo.address.SideBarView
            android:id="@+id/colleague_sideBar"
            android:layout_width="20dp"
            android:layout_height="wrap_content"
            android:layout_gravity="right|center_vertical" />
    </FrameLayout>
</LinearLayout>

在fragment_colleague_item.xml中;

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:gravity="center_vertical"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:background="#ffffff"
        android:orientation="vertical" >
        <TextView
            android:id="@+id/colleague_tv_catalog"
            android:layout_width="fill_parent"
            android:layout_height="22dp"
            android:background="#ecedf1"
            android:gravity="center_vertical"
            android:paddingLeft="5dip"
            
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值