From 4512e826b56e13e1f2be228db4bc0646a831a074 Mon Sep 17 00:00:00 2001
From: 姚旭斌 <15805828761@163.com>
Date: Mon, 12 Mar 2018 16:48:20 +0800
Subject: [PATCH] no message
---
app/src/main/AndroidManifest.xml | 8 +++++++-
app/src/main/java/com/shunzhi/parent/adapter/SchoolListAdapter.java | 96 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
app/src/main/java/com/shunzhi/parent/bean/SchoolBean.java | 26 ++++++++++++++++++++++++++
app/src/main/java/com/shunzhi/parent/ui/activity/MyChildActivity.java | 4 +++-
app/src/main/java/com/shunzhi/parent/ui/activity/binding/CheckInfoActivity.java | 30 ++++++++++++++++++++++++++++++
app/src/main/java/com/shunzhi/parent/ui/activity/binding/SelectSchoolActivity.java | 196 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
app/src/main/java/com/shunzhi/parent/util/CharacterParser.java | 138 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
app/src/main/java/com/shunzhi/parent/views/SideBar.java | 140 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
app/src/main/res/drawable-xhdpi/progress_bg.png | Bin 0 -> 531 bytes
app/src/main/res/drawable-xhdpi/select_ok.png | Bin 0 -> 1495 bytes
app/src/main/res/drawable/rudiobtn_gray.xml | 6 ++++++
app/src/main/res/drawable/sidebar_background.xml | 10 ++++++++++
app/src/main/res/layout/activity_check_info.xml | 11 +++++++++++
app/src/main/res/layout/activity_select_school.xml | 109 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
app/src/main/res/layout/item_school.xml | 44 ++++++++++++++++++++++++++++++++++++++++++++
15 files changed, 816 insertions(+), 2 deletions(-)
create mode 100644 app/src/main/java/com/shunzhi/parent/adapter/SchoolListAdapter.java
create mode 100644 app/src/main/java/com/shunzhi/parent/bean/SchoolBean.java
create mode 100644 app/src/main/java/com/shunzhi/parent/ui/activity/binding/CheckInfoActivity.java
create mode 100644 app/src/main/java/com/shunzhi/parent/ui/activity/binding/SelectSchoolActivity.java
create mode 100644 app/src/main/java/com/shunzhi/parent/util/CharacterParser.java
create mode 100644 app/src/main/java/com/shunzhi/parent/views/SideBar.java
create mode 100644 app/src/main/res/drawable-xhdpi/progress_bg.png
create mode 100644 app/src/main/res/drawable-xhdpi/select_ok.png
create mode 100644 app/src/main/res/drawable/rudiobtn_gray.xml
create mode 100644 app/src/main/res/drawable/sidebar_background.xml
create mode 100644 app/src/main/res/layout/activity_check_info.xml
create mode 100644 app/src/main/res/layout/activity_select_school.xml
create mode 100644 app/src/main/res/layout/item_school.xml
diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml
index 0e326b8..71368a4 100644
--- a/app/src/main/AndroidManifest.xml
+++ b/app/src/main/AndroidManifest.xml
@@ -53,7 +53,13 @@
-
+
+
diff --git a/app/src/main/java/com/shunzhi/parent/adapter/SchoolListAdapter.java b/app/src/main/java/com/shunzhi/parent/adapter/SchoolListAdapter.java
new file mode 100644
index 0000000..8dfede3
--- /dev/null
+++ b/app/src/main/java/com/shunzhi/parent/adapter/SchoolListAdapter.java
@@ -0,0 +1,96 @@
+package com.shunzhi.parent.adapter;
+
+
+import android.content.Context;
+import android.view.LayoutInflater;
+import android.view.View;
+import android.view.ViewGroup;
+import android.widget.ImageView;
+import android.widget.TextView;
+
+import com.share.mvpsdk.base.adapter.BaseRecyclerViewAdapter;
+import com.share.mvpsdk.base.adapter.BaseRecyclerViewHolder;
+import com.shunzhi.parent.R;
+import com.shunzhi.parent.bean.SchoolBean;
+
+import java.util.List;
+
+/**
+ * Created by Administrator on 2018/3/9 0009.
+ */
+
+public class SchoolListAdapter extends BaseRecyclerViewAdapter {
+
+ Context context;
+ Listlist;
+
+ public SchoolListAdapter(Context context,Listlist) {
+ this.context = context;
+ this.list=list;
+ }
+
+
+ @Override
+ public BaseRecyclerViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
+ View view = LayoutInflater.from(context).inflate(R.layout.item_school, null);
+ return new MyViewHolder(view);
+ }
+
+ private class MyViewHolder extends BaseRecyclerViewHolder {
+ TextView school_name;
+ ImageView select_school;
+ TextView tvLetter;
+
+ public MyViewHolder(View view) {
+ super(view);
+ school_name = view.findViewById(R.id.school_name);
+ select_school = view.findViewById(R.id.select_school);
+ tvLetter = view.findViewById(R.id.uiPPLetter);
+ }
+
+ @Override
+ public void onBindViewHolder(SchoolBean object, int position) {
+ int section = getSectionForPosition(position);
+ //如果当前位置等于该分类首字母的Char的位置 ,则认为是第一次出现,并且不是老师
+ if (position == getPositionForSection(section)) {
+ tvLetter.setVisibility(View.VISIBLE);
+ tvLetter.setText(object.getSortLetters());
+ if (object.getSortLetters().equals("#")) {
+ tvLetter.setVisibility(View.GONE);
+ }
+ } else {
+ tvLetter.setVisibility(View.GONE);
+ }
+
+ school_name.setText(object.getSchoolname());
+
+
+ }
+
+
+
+
+ }
+ public int getPositionForSection(int section) {
+ for (int i = 0; i < getCount(); i++) {
+ String sortStr = list.get(i).getSortLetters();
+ char firstChar = sortStr.toUpperCase().charAt(0);
+ if (firstChar == section) {
+ return i;
+ }
+ }
+
+ return -1;
+ }
+ public int getCount() {
+ return list.size();
+ }
+
+ public int getSectionForPosition(int position) {
+
+ return list.get(position).getSortLetters().charAt(0);
+
+ }
+
+
+}
diff --git a/app/src/main/java/com/shunzhi/parent/bean/SchoolBean.java b/app/src/main/java/com/shunzhi/parent/bean/SchoolBean.java
new file mode 100644
index 0000000..03fbda8
--- /dev/null
+++ b/app/src/main/java/com/shunzhi/parent/bean/SchoolBean.java
@@ -0,0 +1,26 @@
+package com.shunzhi.parent.bean;
+
+/**
+ * Created by Administrator on 2018/3/9 0009.
+ */
+
+public class SchoolBean {
+ String schoolname;
+ String SortLetters;
+
+ public String getSchoolname() {
+ return schoolname;
+ }
+
+ public void setSchoolname(String schoolname) {
+ this.schoolname = schoolname;
+ }
+
+ public String getSortLetters() {
+ return SortLetters;
+ }
+
+ public void setSortLetters(String sortLetters) {
+ SortLetters = sortLetters;
+ }
+}
diff --git a/app/src/main/java/com/shunzhi/parent/ui/activity/MyChildActivity.java b/app/src/main/java/com/shunzhi/parent/ui/activity/MyChildActivity.java
index b2c5a9a..b571a3e 100644
--- a/app/src/main/java/com/shunzhi/parent/ui/activity/MyChildActivity.java
+++ b/app/src/main/java/com/shunzhi/parent/ui/activity/MyChildActivity.java
@@ -1,6 +1,7 @@
package com.shunzhi.parent.ui.activity;
import android.annotation.SuppressLint;
+import android.content.Intent;
import android.graphics.Color;
import android.os.Bundle;
import android.support.annotation.NonNull;
@@ -20,6 +21,7 @@ import com.shunzhi.parent.adapter.ChildAdapter;
import com.shunzhi.parent.bean.ChildBean;
import com.shunzhi.parent.contract.mine.MyChildContract;
import com.shunzhi.parent.presenter.mine.MyChildPresenter;
+import com.shunzhi.parent.ui.activity.binding.SelectSchoolActivity;
import com.yanzhenjie.recyclerview.swipe.SwipeMenu;
import com.yanzhenjie.recyclerview.swipe.SwipeMenuBridge;
import com.yanzhenjie.recyclerview.swipe.SwipeMenuCreator;
@@ -106,7 +108,7 @@ public class MyChildActivity extends BaseMVPCompatActivity list = new ArrayList<>();
+ SchoolListAdapter schoolListAdapter;
+
+ @NonNull
+ @Override
+ public BasePresenter initPresenter() {
+ return null;
+ }
+
+ @Override
+ protected void initView(Bundle savedInstanceState) {
+ sideBar = findViewById(R.id.sidrbar);
+ dialog = findViewById(R.id.dialog);
+ go_next=findViewById(R.id.go_next);
+ go_next.setOnClickListener(this);
+
+
+
+
+ list.add("阿尔卑斯");
+ list.add("阿尔卑斯");
+ list.add("阿尔卑斯");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("阿尔卑斯");
+ list.add("阿尔卑斯");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("阿尔卑斯");
+ list.add("阿尔卑斯");
+ list.add("阿尔卑斯");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("血色城堡");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("贝克街");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ list.add("血色城堡");
+ schoollist = findViewById(R.id.schoollist);
+ schoollist.setLayoutManager(new LinearLayoutManager(this));
+ final ListschoolList=OrderedSortSmodel(list);
+ schoolListAdapter = new SchoolListAdapter(this,schoolList);
+ schoolListAdapter.addAll(schoolList);
+ schoollist.setAdapter(schoolListAdapter);
+ sideBar.setOnTouchingLetterChangedListener(new SideBar.OnTouchingLetterChangedListener() {
+ @Override
+ public void onTouchingLetterChanged(String s) {
+ //该字母首次出现的位置
+ int position = -1;
+ if (schoolListAdapter != null && schoolListAdapter.getCount() > 0) {
+
+ position = schoolListAdapter.getPositionForSection(s.charAt(0));
+ }
+ if (position != -1 && position != 0) {
+ schoollist.smoothScrollToPosition(position);
+ }
+ }
+ });
+
+ }
+
+ @Override
+ protected int getLayoutId() {
+ return R.layout.activity_select_school;
+ }
+
+
+ List OrderedSortSmodel(List list) {
+ List schoolList = new ArrayList<>();
+ CharacterParser characterParser = CharacterParser.getInstance();
+ for (String c : list) {
+ SchoolBean s = new SchoolBean();
+ s.setSchoolname(c);
+
+ //汉字转换成拼音
+ String pinyin = characterParser.getSelling(s.getSchoolname());
+ String sortString = "";
+ try {
+ sortString = pinyin.substring(0, 1).toUpperCase();
+ } catch (Exception err) {
+ continue;
+ }
+ // 正则表达式,判断首字母是否是英文字母
+ if (sortString.matches("[A-Z]") ) {
+ s.setSortLetters(sortString.toUpperCase());
+ } else {
+ s.setSortLetters("#");
+ }
+ schoolList.add(s);
+ }
+
+ return orderByNameIndexAndIndentity(schoolList);
+ }
+
+
+ public static List orderByNameIndexAndIndentity(List sortModels) {
+ Collections.sort(sortModels, new Comparator() {
+ @Override
+ public int compare(SchoolBean o1, SchoolBean o2) {
+ if (o1.getSortLetters().equals("#") && o2.getSortLetters().matches("[A-Z]")) {
+ return -1;
+ } else if (o1.getSortLetters().equals("#") && !o2.getSortLetters().matches("[A-Z]")) {
+
+ return 0;
+ } else if (!o1.getSortLetters().equals("#") && o2.getSortLetters().matches("[A-Z]")) {
+ return o1.getSortLetters().compareTo(o2.getSortLetters());
+ } else if (!o1.getSortLetters().equals("#") && !o2.getSortLetters().matches("[A-Z]")) {
+ return 1;
+ }
+ return o1.getSortLetters().compareTo(o2.getSortLetters());
+ }
+
+ @Override
+ public boolean equals(Object o) {
+ return super.equals(o);
+ }
+ });
+ return sortModels;
+
+ }
+
+ @Override
+ public void onClick(View v) {
+ if(v==go_next){
+ startActivity(new Intent().setClass(SelectSchoolActivity.this,CheckInfoActivity.class));
+
+ }
+
+ }
+}
diff --git a/app/src/main/java/com/shunzhi/parent/util/CharacterParser.java b/app/src/main/java/com/shunzhi/parent/util/CharacterParser.java
new file mode 100644
index 0000000..70a213d
--- /dev/null
+++ b/app/src/main/java/com/shunzhi/parent/util/CharacterParser.java
@@ -0,0 +1,138 @@
+package com.shunzhi.parent.util;
+
+/**
+ * Created by xf on 2015/9/22.
+ */
+/**
+ * Java汉字转换为拼音
+ *
+ */
+public class CharacterParser {
+ private static int[] pyvalue = new int[] {-20319, -20317, -20304, -20295, -20292, -20283, -20265, -20257, -20242, -20230, -20051, -20036, -20032,
+ -20026, -20002, -19990, -19986, -19982, -19976, -19805, -19784, -19775, -19774, -19763, -19756, -19751, -19746, -19741, -19739, -19728,
+ -19725, -19715, -19540, -19531, -19525, -19515, -19500, -19484, -19479, -19467, -19289, -19288, -19281, -19275, -19270, -19263, -19261,
+ -19249, -19243, -19242, -19238, -19235, -19227, -19224, -19218, -19212, -19038, -19023, -19018, -19006, -19003, -18996, -18977, -18961,
+ -18952, -18783, -18774, -18773, -18763, -18756, -18741, -18735, -18731, -18722, -18710, -18697, -18696, -18526, -18518, -18501, -18490,
+ -18478, -18463, -18448, -18447, -18446, -18239, -18237, -18231, -18220, -18211, -18201, -18184, -18183, -18181, -18012, -17997, -17988,
+ -17970, -17964, -17961, -17950, -17947, -17931, -17928, -17922, -17759, -17752, -17733, -17730, -17721, -17703, -17701, -17697, -17692,
+ -17683, -17676, -17496, -17487, -17482, -17468, -17454, -17433, -17427, -17417, -17202, -17185, -16983, -16970, -16942, -16915, -16733,
+ -16708, -16706, -16689, -16664, -16657, -16647, -16474, -16470, -16465, -16459, -16452, -16448, -16433, -16429, -16427, -16423, -16419,
+ -16412, -16407, -16403, -16401, -16393, -16220, -16216, -16212, -16205, -16202, -16187, -16180, -16171, -16169, -16158, -16155, -15959,
+ -15958, -15944, -15933, -15920, -15915, -15903, -15889, -15878, -15707, -15701, -15681, -15667, -15661, -15659, -15652, -15640, -15631,
+ -15625, -15454, -15448, -15436, -15435, -15419, -15416, -15408, -15394, -15385, -15377, -15375, -15369, -15363, -15362, -15183, -15180,
+ -15165, -15158, -15153, -15150, -15149, -15144, -15143, -15141, -15140, -15139, -15128, -15121, -15119, -15117, -15110, -15109, -14941,
+ -14937, -14933, -14930, -14929, -14928, -14926, -14922, -14921, -14914, -14908, -14902, -14894, -14889, -14882, -14873, -14871, -14857,
+ -14678, -14674, -14670, -14668, -14663, -14654, -14645, -14630, -14594, -14429, -14407, -14399, -14384, -14379, -14368, -14355, -14353,
+ -14345, -14170, -14159, -14151, -14149, -14145, -14140, -14137, -14135, -14125, -14123, -14122, -14112, -14109, -14099, -14097, -14094,
+ -14092, -14090, -14087, -14083, -13917, -13914, -13910, -13907, -13906, -13905, -13896, -13894, -13878, -13870, -13859, -13847, -13831,
+ -13658, -13611, -13601, -13406, -13404, -13400, -13398, -13395, -13391, -13387, -13383, -13367, -13359, -13356, -13343, -13340, -13329,
+ -13326, -13318, -13147, -13138, -13120, -13107, -13096, -13095, -13091, -13076, -13068, -13063, -13060, -12888, -12875, -12871, -12860,
+ -12858, -12852, -12849, -12838, -12831, -12829, -12812, -12802, -12607, -12597, -12594, -12585, -12556, -12359, -12346, -12320, -12300,
+ -12120, -12099, -12089, -12074, -12067, -12058, -12039, -11867, -11861, -11847, -11831, -11798, -11781, -11604, -11589, -11536, -11358,
+ -11340, -11339, -11324, -11303, -11097, -11077, -11067, -11055, -11052, -11045, -11041, -11038, -11024, -11020, -11019, -11018, -11014,
+ -10838, -10832, -10815, -10800, -10790, -10780, -10764, -10587, -10544, -10533, -10519, -10331, -10329, -10328, -10322, -10315, -10309,
+ -10307, -10296, -10281, -10274, -10270, -10262, -10260, -10256, -10254};
+ public static String[] pystr = new String[] {"a", "ai", "an", "ang", "ao", "ba", "bai", "ban", "bang", "bao", "bei", "ben", "beng", "bi", "bian",
+ "biao", "bie", "bin", "bing", "bo", "bu", "ca", "cai", "can", "cang", "cao", "ce", "ceng", "cha", "chai", "chan", "chang", "chao", "che",
+ "chen", "cheng", "chi", "chong", "chou", "chu", "chuai", "chuan", "chuang", "chui", "chun", "chuo", "ci", "cong", "cou", "cu", "cuan",
+ "cui", "cun", "cuo", "da", "dai", "dan", "dang", "dao", "de", "deng", "di", "dian", "diao", "die", "ding", "diu", "dong", "dou", "du",
+ "duan", "dui", "dun", "duo", "e", "en", "er", "fa", "fan", "fang", "fei", "fen", "feng", "fo", "fou", "fu", "ga", "gai", "gan", "gang",
+ "gao", "ge", "gei", "gen", "geng", "gong", "gou", "gu", "gua", "guai", "guan", "guang", "gui", "gun", "guo", "ha", "hai", "han", "hang",
+ "hao", "he", "hei", "hen", "heng", "hong", "hou", "hu", "hua", "huai", "huan", "huang", "hui", "hun", "huo", "ji", "jia", "jian",
+ "jiang", "jiao", "jie", "jin", "jing", "jiong", "jiu", "ju", "juan", "jue", "jun", "ka", "kai", "kan", "kang", "kao", "ke", "ken",
+ "keng", "kong", "kou", "ku", "kua", "kuai", "kuan", "kuang", "kui", "kun", "kuo", "la", "lai", "lan", "lang", "lao", "le", "lei", "leng",
+ "li", "lia", "lian", "liang", "liao", "lie", "lin", "ling", "liu", "long", "lou", "lu", "lv", "luan", "lue", "lun", "luo", "ma", "mai",
+ "man", "mang", "mao", "me", "mei", "men", "meng", "mi", "mian", "miao", "mie", "min", "ming", "miu", "mo", "mou", "mu", "na", "nai",
+ "nan", "nang", "nao", "ne", "nei", "nen", "neng", "ni", "nian", "niang", "niao", "nie", "nin", "ning", "niu", "nong", "nu", "nv", "nuan",
+ "nue", "nuo", "o", "ou", "pa", "pai", "pan", "pang", "pao", "pei", "pen", "peng", "pi", "pian", "piao", "pie", "pin", "ping", "po", "pu",
+ "qi", "qia", "qian", "qiang", "qiao", "qie", "qin", "qing", "qiong", "qiu", "qu", "quan", "que", "qun", "ran", "rang", "rao", "re",
+ "ren", "reng", "ri", "rong", "rou", "ru", "ruan", "rui", "run", "ruo", "sa", "sai", "san", "sang", "sao", "se", "sen", "seng", "sha",
+ "shai", "shan", "shang", "shao", "she", "shen", "sheng", "shi", "shou", "shu", "shua", "shuai", "shuan", "shuang", "shui", "shun",
+ "shuo", "si", "song", "sou", "su", "suan", "sui", "sun", "suo", "ta", "tai", "tan", "tang", "tao", "te", "teng", "ti", "tian", "tiao",
+ "tie", "ting", "tong", "tou", "tu", "tuan", "tui", "tun", "tuo", "wa", "wai", "wan", "wang", "wei", "wen", "weng", "wo", "wu", "xi",
+ "xia", "xian", "xiang", "xiao", "xie", "xin", "xing", "xiong", "xiu", "xu", "xuan", "xue", "xun", "ya", "yan", "yang", "yao", "ye", "yi",
+ "yin", "ying", "yo", "yong", "you", "yu", "yuan", "yue", "yun", "za", "zai", "zan", "zang", "zao", "ze", "zei", "zen", "zeng", "zha",
+ "zhai", "zhan", "zhang", "zhao", "zhe", "zhen", "zheng", "zhi", "zhong", "zhou", "zhu", "zhua", "zhuai", "zhuan", "zhuang", "zhui",
+ "zhun", "zhuo", "zi", "zong", "zou", "zu", "zuan", "zui", "zun", "zuo"};
+ private StringBuilder buffer;
+ private String resource;
+
+
+ private static class InstanceHolder{
+ private static final CharacterParser characterParser = new CharacterParser();
+ }
+ public static CharacterParser getInstance() {
+ return InstanceHolder.characterParser;
+ }
+
+ public String getResource() {
+ return resource;
+ }
+
+ public void setResource(String resource) {
+ this.resource = resource;
+ }
+
+ /** * 汉字转成ASCII码 * * @param chs * @return */
+ private int getChsAscii(String chs) {
+ int asc = 0;
+ try {
+ byte[] bytes = chs.getBytes("gb2312");
+ if (bytes == null || bytes.length > 2 || bytes.length <= 0) {
+ throw new RuntimeException("illegal resource string");
+ }
+ if (bytes.length == 1) {
+ asc = bytes[0];
+ }
+ if (bytes.length == 2) {
+ int hightByte = 256 + bytes[0];
+ int lowByte = 256 + bytes[1];
+ asc = (256 * hightByte + lowByte) - 256 * 256;
+ }
+ } catch (Exception e) {
+ System.out.println("ERROR:ChineseSpelling.class-getChsAscii(String chs)" + e);
+ }
+ return asc;
+ }
+
+ /** * 单字解析 * * @param str * @return */
+ public String convert(String str) {
+ String result = null;
+ int ascii = getChsAscii(str);
+ if (ascii > 0 && ascii < 160) {
+ result = String.valueOf((char) ascii);
+ } else {
+ for (int i = (pyvalue.length - 1); i >= 0; i--) {
+ if (pyvalue[i] <= ascii) {
+ result = pystr[i];
+ break;
+ }
+ }
+ }
+ return result;
+ }
+
+ /** * 词组解析 * * @param chs * @return */
+ public String getSelling(String chs) {
+ String key, value;
+ buffer = new StringBuilder();
+ for (int i = 0; i < chs.length(); i++) {
+ key = chs.substring(i, i + 1);
+ if (key.getBytes().length >= 2) {
+ value = (String) convert(key);
+ if (value == null) {
+ value = "unknown";
+ }
+ } else {
+ value = key;
+ }
+ buffer.append(value);
+ }
+ return buffer.toString();
+ }
+
+ public String getSpelling() {
+ return this.getSelling(this.getResource());
+ }
+
+}
diff --git a/app/src/main/java/com/shunzhi/parent/views/SideBar.java b/app/src/main/java/com/shunzhi/parent/views/SideBar.java
new file mode 100644
index 0000000..e7cf568
--- /dev/null
+++ b/app/src/main/java/com/shunzhi/parent/views/SideBar.java
@@ -0,0 +1,140 @@
+package com.shunzhi.parent.views;
+
+import android.content.Context;
+import android.graphics.Canvas;
+import android.graphics.Color;
+import android.graphics.Paint;
+import android.graphics.Typeface;
+import android.graphics.drawable.ColorDrawable;
+import android.util.AttributeSet;
+import android.view.MotionEvent;
+import android.view.View;
+import android.widget.TextView;
+
+import com.shunzhi.parent.R;
+
+
+public class SideBar extends View {
+ // 触摸事件
+ private OnTouchingLetterChangedListener onTouchingLetterChangedListener;
+ // 26个字母
+ public static 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", "#" };
+ private int choose = -1;// 选中
+ private Paint paint = new Paint();
+
+ private TextView mTextDialog;
+
+ public void setTextView(TextView mTextDialog) {
+ this.mTextDialog = mTextDialog;
+ }
+
+
+ public SideBar(Context context, AttributeSet attrs, int defStyle) {
+ super(context, attrs, defStyle);
+ }
+
+ public SideBar(Context context, AttributeSet attrs) {
+ super(context, attrs);
+ }
+
+ public SideBar(Context context) {
+ super(context);
+ }
+
+ /**
+ * 重写这个方法
+ */
+ protected void onDraw(Canvas canvas) {
+ super.onDraw(canvas);
+ // 获取焦点改变背景颜色.
+ int height = getHeight();// 获取对应高度
+ int width = getWidth(); // 获取对应宽度
+ //int singleHeight = height / b.length;// 获取每一个字母的高度
+ int singleHeight = height / b.length;// 获取每一个字母的高度
+
+ for (int i = 0; i < b.length; i++) {
+ if(!b[i].equals("")) {
+ paint.setColor(Color.rgb(33, 65, 98));
+ // paint.setColor(Color.WHITE);
+ paint.setTypeface(Typeface.DEFAULT_BOLD);
+ paint.setAntiAlias(true);
+ //paint.setAlpha(0);//透明
+ paint.setTextSize(26);
+ // 选中的状态
+ if (i == choose) {
+ paint.setColor(Color.parseColor("#3399ff"));
+ paint.setFakeBoldText(true);
+ }
+ // x坐标等于中间-字符串宽度的一半.
+ 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();// 点击y坐标
+ final int oldChoose = choose;
+ final OnTouchingLetterChangedListener listener = onTouchingLetterChangedListener;
+ final int c = (int) (y / getHeight() * b.length);// 点击y坐标所占总高度的比例*b数组的长度就等于点击b中的个数.
+ switch (action) {
+ case MotionEvent.ACTION_UP:
+ gotoStart();
+ break;
+
+ default:
+ setBackgroundResource(R.drawable.sidebar_background);
+ if (oldChoose != c) {
+ if (c >= 0 && c < b.length) {
+ if (listener != null) {
+ listener.onTouchingLetterChanged(b[c]);
+ }
+ if (mTextDialog != null) {
+ mTextDialog.setText(b[c]);
+ mTextDialog.setVisibility(View.VISIBLE);
+ }
+
+ choose = c;
+ invalidate();
+ }
+ }
+
+ break;
+ }
+ return true;
+ }
+
+ /**
+ * 向外公开的方法
+ *
+ * @param onTouchingLetterChangedListener
+ */
+ public void setOnTouchingLetterChangedListener(
+ OnTouchingLetterChangedListener onTouchingLetterChangedListener) {
+ this.onTouchingLetterChangedListener = onTouchingLetterChangedListener;
+ }
+
+ /**
+ * 接口
+ *
+ * @author coder
+ *
+ */
+ public interface OnTouchingLetterChangedListener {
+ public void onTouchingLetterChanged(String s);
+ }
+
+ public void gotoStart(){
+ setBackgroundDrawable(new ColorDrawable(0x77dddddd));
+ choose = -1;
+ invalidate();
+ if (mTextDialog != null) {
+ mTextDialog.setVisibility(View.INVISIBLE);
+ }
+ }
+}
diff --git a/app/src/main/res/drawable-xhdpi/progress_bg.png b/app/src/main/res/drawable-xhdpi/progress_bg.png
new file mode 100644
index 0000000..ae7af60
Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/progress_bg.png differ
diff --git a/app/src/main/res/drawable-xhdpi/select_ok.png b/app/src/main/res/drawable-xhdpi/select_ok.png
new file mode 100644
index 0000000..057433a
Binary files /dev/null and b/app/src/main/res/drawable-xhdpi/select_ok.png differ
diff --git a/app/src/main/res/drawable/rudiobtn_gray.xml b/app/src/main/res/drawable/rudiobtn_gray.xml
new file mode 100644
index 0000000..e567a17
--- /dev/null
+++ b/app/src/main/res/drawable/rudiobtn_gray.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/app/src/main/res/drawable/sidebar_background.xml b/app/src/main/res/drawable/sidebar_background.xml
new file mode 100644
index 0000000..95ec8fc
--- /dev/null
+++ b/app/src/main/res/drawable/sidebar_background.xml
@@ -0,0 +1,10 @@
+
+
+
+
+
+
+
diff --git a/app/src/main/res/layout/activity_check_info.xml b/app/src/main/res/layout/activity_check_info.xml
new file mode 100644
index 0000000..ba4a6d3
--- /dev/null
+++ b/app/src/main/res/layout/activity_check_info.xml
@@ -0,0 +1,11 @@
+
+
+
+
+
+
diff --git a/app/src/main/res/layout/activity_select_school.xml b/app/src/main/res/layout/activity_select_school.xml
new file mode 100644
index 0000000..a0e57b4
--- /dev/null
+++ b/app/src/main/res/layout/activity_select_school.xml
@@ -0,0 +1,109 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/app/src/main/res/layout/item_school.xml b/app/src/main/res/layout/item_school.xml
new file mode 100644
index 0000000..48ff1c4
--- /dev/null
+++ b/app/src/main/res/layout/item_school.xml
@@ -0,0 +1,44 @@
+
+
+
+
+
+
+
+
+
+
+
+
--
libgit2 0.21.0