From 2d4891c67e0fc52dfdfa9df2574b92dd11fad481 Mon Sep 17 00:00:00 2001 From: xuxiuxi <xuxiuxi@454eff88-639b-444f-9e54-f578c98de674> Date: 星期三, 05 四月 2017 17:08:10 +0800 Subject: [PATCH] --- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/PhoneCallMng.java | 28 ++++++++++++- VisitFace/DemoForBsk/app/src/main/res/layout/fragment_phone_call_left_first_letter_row.xml | 25 ++++++++++++ VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/CharacterParser.java | 4 +- VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/PhoneCallFragment.java | 10 ++++ VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/phonecall/PhoneCallLeftListView.java | 2 5 files changed, 62 insertions(+), 7 deletions(-) diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/PhoneCallFragment.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/PhoneCallFragment.java index ea8a568..7a584c4 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/PhoneCallFragment.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/adapter/PhoneCallFragment.java @@ -31,11 +31,16 @@ @Override public int[] getItemLayouts() { - return new int[]{R.layout.fragment_phone_call_left_row}; + return new int[]{R.layout.fragment_phone_call_left_row, R.layout.fragment_phone_call_left_first_letter_row}; } @Override public void onBindRecycleViewHolder(EasyRecyclerViewHolder viewHolder, int position) { + if (!(getItem(position) instanceof PhoneCallQueryItem)) { + TextView fragment_phone_call_left_row_first_letter_name = viewHolder.findViewById(R.id.fragment_phone_call_left_row_first_letter_name); + fragment_phone_call_left_row_first_letter_name.setText(getItem(position)+"".toUpperCase()); + return; + } TextView fragment_phone_call_left_row_name = viewHolder.findViewById(R.id.fragment_phone_call_left_row_name); TextView fragment_phone_call_left_row_dept = viewHolder.findViewById(R.id.fragment_phone_call_left_interviewee_row_dept); if (isSortByDept) { @@ -62,6 +67,9 @@ @Override public int getRecycleViewItemType(int position) { + if (!(getItem(position) instanceof PhoneCallQueryItem)) { + return 1; + } return 0; } diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/PhoneCallMng.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/PhoneCallMng.java index cc7bf70..dc40388 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/PhoneCallMng.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/service/PhoneCallMng.java @@ -3,6 +3,7 @@ import org.xutils.http.RequestParams; import org.xutils.x; +import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; @@ -14,6 +15,7 @@ import cn.com.basic.face.fragment.PhoneCallFragment; import cn.com.basic.face.util.AppApi; import cn.com.basic.face.service.vo.PhoneCallFragment.PhoneCallQueryItem; +import cn.com.basic.face.util.CharacterParser; public class PhoneCallMng { @@ -29,7 +31,23 @@ public void success() { List<PhoneCallQueryItem> list = getList(PhoneCallQueryItem.class); sort(list, isSortByDept); - PhoneCallFragment.getInstance().get_fragment_phone_call_left_list_view().show(isSortByDept, list); + List allItems = new ArrayList(); + String name = ""; + String prev = ""; + for (int i = 0; i < list.size(); i++) { + PhoneCallQueryItem item = list.get(i); + if (isSortByDept) { + name = CharacterParser.getInstance().getSelling(item.getDeptName()).substring(0, 1); + } else { + name = CharacterParser.getInstance().getSelling(item.getName()).substring(0, 1); + } + if (!name.equals(prev)) { + allItems.add(name); + } + allItems.add(item); + prev = name; + } + PhoneCallFragment.getInstance().get_fragment_phone_call_left_list_view().show(isSortByDept, allItems); } }); } @@ -42,12 +60,16 @@ String dept1Name = t1.getDeptName()==null?"":t1.getDeptName(); String dept2Name = t2.getDeptName()==null?"":t2.getDeptName(); if(!dept1Name.equals(dept2Name)) { - return dept1Name.compareTo(dept2Name); + String dept1Name_a = CharacterParser.getInstance().getSelling(dept1Name).toLowerCase(); + String dept1Name_b = CharacterParser.getInstance().getSelling(dept2Name).toLowerCase(); + return dept1Name_a.compareTo(dept1Name_b); } } String name1 = t1.getName()==null?"":t1.getName(); String name2 = t2.getName()==null?"":t2.getName(); - return name1.compareTo(name2); + String dept1Name_a = CharacterParser.getInstance().getSelling(name1).toLowerCase(); + String dept1Name_b = CharacterParser.getInstance().getSelling(name2).toLowerCase(); + return dept1Name_a.compareTo(dept1Name_b); } }); } diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/CharacterParser.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/CharacterParser.java index 52cddb9..3a0b07e 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/CharacterParser.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/util/CharacterParser.java @@ -69,7 +69,7 @@ } /** * 姹夊瓧杞垚ASCII鐮� * * @param chs * @return */ - private int getChsAscii(String chs) { + public int getChsAscii(String chs) { int asc = 0; try { byte[] bytes = chs.getBytes("gb2312"); @@ -91,7 +91,7 @@ } /** * 鍗曞瓧瑙f瀽 * * @param str * @return */ - public String convert(String str) { + public String convert(String str) { String result = null; int ascii = getChsAscii(str); if (ascii > 0 && ascii < 160) { diff --git a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/phonecall/PhoneCallLeftListView.java b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/phonecall/PhoneCallLeftListView.java index 3acd31b..df3ba80 100644 --- a/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/phonecall/PhoneCallLeftListView.java +++ b/VisitFace/DemoForBsk/app/src/main/java/cn/com/basic/face/widget/phonecall/PhoneCallLeftListView.java @@ -36,7 +36,7 @@ initView(); } - public void show(boolean isSortByDept, List<PhoneCallFragment.PhoneCallQueryItem> list) { + public void show(boolean isSortByDept, List list) { phoneCallLeftAdapter.setList(list); setAdapter(phoneCallLeftAdapter); phoneCallLeftAdapter.setSortByDept(isSortByDept); diff --git a/VisitFace/DemoForBsk/app/src/main/res/layout/fragment_phone_call_left_first_letter_row.xml b/VisitFace/DemoForBsk/app/src/main/res/layout/fragment_phone_call_left_first_letter_row.xml new file mode 100644 index 0000000..fca32e4 --- /dev/null +++ b/VisitFace/DemoForBsk/app/src/main/res/layout/fragment_phone_call_left_first_letter_row.xml @@ -0,0 +1,25 @@ +<?xml version="1.0" encoding="utf-8"?> +<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" + xmlns:fresco="http://schemas.android.com/apk/res-auto" + android:id="@+id/fragment_phone_call_left_interviewee_row_linear_layout" + android:orientation="vertical" + android:layout_width="match_parent" + android:layout_height="match_parent" + android:paddingLeft="20dp" + android:paddingRight="20dp"> + <RelativeLayout + android:id="@+id/fragment_phone_call_left_row_relativeLayout" + android:layout_width="match_parent" + android:layout_height="wrap_content" + android:paddingTop="12dp" + android:paddingBottom="12dp"> + <TextView + android:id="@+id/fragment_phone_call_left_row_first_letter_name" + android:layout_width="wrap_content" + android:layout_height="wrap_content" + android:text="A" + android:layout_centerVertical="true" + android:textSize="@dimen/text_size_big" + android:textColor="@color/colorText_5"/> + </RelativeLayout> +</LinearLayout> \ No newline at end of file -- Gitblit v1.8.0