星空网 > 软件开发 > 操作系统

列表右侧边栏拼音展示效果

最近忙着做项目,好久之前的技术都没有时间总结,而发现自己的博客好多写的技术都比自己掌握的时候晚了很多。不管怎么样,写技术博客一定是一个想成为优秀程序猿或者已经是优秀程序猿必须做的。好吧,下面进行学习阶段。

记得很久之前就使用过侧边拼音栏了,先看下它的效果,一个列表,列表的右侧有一个拼音列表,当列表发生滑动的时候,拼音列表也随着滑动,而规律就是拼音列表滑动的位置为显示列表的当前位置的文字的首字母决定,当然,直接点击拼音列表的一个位置,显示列表也会直接滑动到对应拼音开头的文字所在位置。

列表右侧边栏拼音展示效果images/loading.gif' data-original="http://images2015.cnblogs.com/blog/493196/201511/493196-20151109235623509-1693012148.gif" width="275" height="392" />

下面看一个使用的示例,这里我们使用本地的

而我的这个注意列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果

  1 <?"1.0" encoding="utf-8"?>  2 <resources>  3   <string-array name="北京市">  4     <item>东城区</item>  5     <item>西城区</item>  6     <item>崇文区</item>  7     <item>宣武区</item>  8     <item>朝阳区</item>  9     <item>丰台区</item> 10     <item>石景山区</item> 11     <item>海淀区</item> 12     <item>门头沟区</item> 13     <item>房山区</item> 14     <item>通州区</item> 15     <item>顺义区</item> 16     <item>昌平区</item> 17     <item>大兴区</item> 18     <item>怀柔区</item> 19     <item>平谷区</item> 20     <item>密云县</item> 21     <item>延庆县</item> 22     <item>北京周边</item> 23   </string-array> 24   <string-array name="上海市"> 25     <item>黄浦区</item> 26     <item>卢湾区</item> 27     <item>徐汇区</item> 28     <item>长宁区</item> 29     <item>静安区</item> 30     <item>普陀区</item> 31     <item>闸北区</item> 32     <item>虹口区</item> 33     <item>杨浦区</item> 34     <item>闵行区</item> 35     <item>宝山区</item> 36     <item>嘉定区</item> 37     <item>浦东区</item> 38     <item>金山区</item> 39     <item>松江区</item> 40     <item>奉贤区</item> 41     <item>崇明区</item> 42     <item>南汇区</item> 43     <item>青浦区</item> 44   </string-array> 45   <string-array name="广州市"> 46     <item>荔湾区</item> 47     <item>越秀区</item> 48     <item>海珠区</item> 49     <item>天河区</item> 50     <item>白云区</item> 51     <item>黄埔区</item> 52     <item>番禺区</item> 53     <item>花都区</item> 54     <item>南沙区</item> 55     <item>萝岗区</item> 56     <item>增城</item> 57   </string-array> 58   <string-array name="天津市"> 59     <item>和平区</item> 60     <item>河东区</item> 61     <item>河西区</item> 62     <item>南开区</item> 63     <item>河北区</item> 64     <item>红桥区</item> 65     <item>滨海新区</item> 66     <item>东丽区</item> 67     <item>西青区</item> 68     <item>津南区</item> 69     <item>北辰区</item> 70     <item>武清区</item> 71     <item>宝坻区</item> 72     <item>宁河县</item> 73     <item>静海县</item> 74     <item>蓟县</item> 75   </string-array> 76   <string-array name="河北省"> 77     <item>石家庄市</item> 78     <item>唐山市</item> 79     <item>秦皇岛市</item> 80     <item>邯郸市</item> 81     <item>邢台市</item> 82     <item>保定市</item> 83     <item>张家口市</item> 84     <item>承德市市</item> 85     <item>沧州市</item> 86     <item>廊坊市</item> 87     <item>衡水市</item> 88   </string-array> 89   <string-array name="山西省"> 90     <item>太原市</item> 91     <item>大同市</item> 92     <item>阳泉市</item> 93     <item>长治市</item> 94     <item>晋城市</item> 95     <item>朔州市</item> 96     <item>晋中市</item> 97     <item>运城市</item> 98     <item>忻州市</item> 99     <item>临汾市</item> 100     <item>吕梁市</item> 101   </string-array> 102   <string-array name="内蒙古自治区"> 103     <item>呼和浩特市</item> 104     <item>包头市</item> 105     <item>乌海市</item> 106     <item>赤峰市</item> 107     <item>通辽市</item> 108     <item>鄂尔多斯市</item> 109     <item>呼伦贝尔市</item> 110     <item>巴彦淖尔市</item> 111     <item>乌兰察布市</item> 112     <item>兴安盟</item> 113     <item>锡林郭勒盟</item> 114     <item>阿拉善盟</item> 115   </string-array> 116   <string-array name="辽宁省"> 117     <item>沈阳市</item> 118     <item>大连市</item> 119     <item>鞍山市</item> 120     <item>抚顺市</item> 121     <item>本溪市</item> 122     <item>丹东市</item> 123     <item>锦州市</item> 124     <item>营口市</item> 125     <item>阜新市</item> 126     <item>辽阳市</item> 127     <item>盘锦市</item> 128     <item>铁岭市</item> 129     <item>朝阳市</item> 130     <item>葫芦岛市</item> 131   </string-array> 132   <string-array name="吉林省"> 133     <item>长春市</item> 134     <item>吉林市</item> 135     <item>四平市</item> 136     <item>辽源市</item> 137     <item>通化市</item> 138     <item>白山市</item> 139     <item>松原市</item> 140     <item>白城市</item> 141     <item>延边朝鲜自治州</item> 142   </string-array> 143   <string-array name="黑龙江省"> 144     <item>哈尔滨市</item> 145     <item>齐齐哈尔市</item> 146     <item>鸡西市</item> 147     <item>鹤岗市</item> 148     <item>双鸭山市</item> 149     <item>大庆市</item> 150     <item>伊春市</item> 151     <item>佳木斯市</item> 152     <item>七台河市</item> 153     <item>牡丹江市</item> 154     <item>黑河市</item> 155     <item>绥化市</item> 156     <item>大兴安岭地区</item> 157   </string-array> 158   <string-array name="江苏省"> 159     <item>南京市</item> 160     <item>无锡市</item> 161     <item>徐州市</item> 162     <item>常州市</item> 163     <item>苏州市</item> 164     <item>南通市</item> 165     <item>连云港市</item> 166     <item>淮安市</item> 167     <item>盐城市</item> 168     <item>扬州市</item> 169     <item>镇江市</item> 170     <item>泰州市</item> 171     <item>宿迁市</item> 172   </string-array> 173   <string-array name="浙江省"> 174     <item>杭州市</item> 175     <item>宁波市</item> 176     <item>温州市</item> 177     <item>嘉兴市</item> 178     <item>湖州市</item> 179     <item>绍兴市</item> 180     <item>金华市</item> 181     <item>衡州市</item> 182     <item>舟山市</item> 183     <item>台州市</item> 184     <item>丽水市</item> 185   </string-array> 186   <string-array name="安徽省"> 187     <item>合肥市</item> 188     <item>芜湖市</item> 189     <item>蚌阜市</item> 190     <item>淮南市</item> 191     <item>马鞍山市</item> 192     <item>淮北市</item> 193     <item>铜陵市</item> 194     <item>安庆市</item> 195     <item>黄山市</item> 196     <item>滁州市</item> 197     <item>阜阳市</item> 198     <item>宿州市</item> 199     <item>六安市</item> 200     <item>毫州市</item> 201     <item>池州市</item> 202     <item>宣城市</item> 203   </string-array> 204   <string-array name="福建省"> 205     <item>福州市</item> 206     <item>厦门市</item> 207     <item>莆田市</item> 208     <item>三明市</item> 209     <item>泉州市</item> 210     <item>漳州市</item> 211     <item>南平市</item> 212     <item>龙岩市</item> 213     <item>宁德市</item> 214   </string-array> 215   <string-array name="江西省"> 216     <item>南昌市</item> 217     <item>景德镇市</item> 218     <item>萍乡市</item> 219     <item>九江市</item> 220     <item>新余市</item> 221     <item>鹰潭市</item> 222     <item>赣州市</item> 223     <item>吉安市</item> 224     <item>宜春市</item> 225     <item>抚州市</item> 226     <item>上饶市</item> 227   </string-array> 228   <string-array name="山东省"> 229     <item>济南市</item> 230     <item>青岛市</item> 231     <item>淄博市</item> 232     <item>枣庄市</item> 233     <item>东营市</item> 234     <item>烟台市</item> 235     <item>潍坊市</item> 236     <item>济宁市</item> 237     <item>泰安市</item> 238     <item>威海市</item> 239     <item>日照市</item> 240     <item>莱芜市</item> 241     <item>临沂市</item> 242     <item>德州市</item> 243     <item>聊城市</item> 244     <item>滨州市</item> 245     <item>菏泽市</item> 246   </string-array> 247   <string-array name="河南省"> 248     <item>郑州市</item> 249     <item>开封市</item> 250     <item>洛阳市</item> 251     <item>平顶山市</item> 252     <item>安阳市</item> 253     <item>鹤壁市</item> 254     <item>新乡市</item> 255     <item>焦作市</item> 256     <item>许昌市</item> 257     <item>漯河市</item> 258     <item>三门峡市</item> 259     <item>南阳市</item> 260     <item>商丘市</item> 261     <item>信阳市</item> 262     <item>周口市</item> 263     <item>驻马店市</item> 264     <item>济源市</item> 265   </string-array> 266   <string-array name="湖北省"> 267     <item>武汉市</item> 268     <item>黄石市</item> 269     <item>十堰市</item> 270     <item>宜昌市</item> 271     <item>襄阳市</item> 272     <item>鄂州市</item> 273     <item>荆门市</item> 274     <item>黄冈市</item> 275     <item>咸宁市</item> 276     <item>随州市</item> 277     <item>恩师土家族苗族自治州</item> 278     <item>仙桃市</item> 279     <item>潜江市</item> 280     <item>天门市</item> 281     <item>神农架林市</item> 282   </string-array> 283   <string-array name="湖南省"> 284     <item>长沙市</item> 285     <item>株洲市</item> 286     <item>湘潭市</item> 287     <item>衡阳市</item> 288     <item>邵阳市</item> 289     <item>岳阳市</item> 290     <item>常德市</item> 291     <item>张家界市</item> 292     <item>益阳市</item> 293     <item>彬州市</item> 294     <item>永州</item> 295     <item>怀化市</item> 296     <item>娄底市</item> 297     <item>湘西土家族自治州</item> 298   </string-array> 299   <string-array name="广东省"> 300     <item>广州市</item> 301     <item>韶关市</item> 302     <item>深圳市</item> 303     <item>珠海市</item> 304     <item>汕头市</item> 305     <item>佛山市</item> 306     <item>江门市</item> 307     <item>茂名市</item> 308     <item>惠州市</item> 309     <item>梅州市</item> 310     <item>汕尾市</item> 311     <item>河源市</item> 312     <item>阳江市</item> 313     <item>清远市</item> 314     <item>东莞市</item> 315     <item>中山市</item> 316     <item>潮州市</item> 317     <item>揭阳市</item> 318     <item>云浮市</item> 319   </string-array> 320   <string-array name="广西壮族自治区"> 321     <item>南宁市</item> 322     <item>柳州市</item> 323     <item>桂林市</item> 324     <item>梧州市</item> 325     <item>北海市</item> 326     <item>防城港市</item> 327     <item>钦州市</item> 328     <item>贵港市</item> 329     <item>玉林市</item> 330     <item>百色市</item> 331     <item>贺州市</item> 332     <item>河池市</item> 333     <item>来宾市</item> 334     <item>崇左市</item> 335   </string-array> 336   <string-array name="海南省"> 337     <item>海口市</item> 338     <item>三亚市</item> 339   </string-array> 340   <string-array name="重庆市"> 341     <item>万州区</item> 342     <item>渝中区</item> 343     <item>大渡口区</item> 344     <item>江北区</item> 345     <item>沙坪坝区</item> 346     <item>九龙坡区</item> 347     <item>南岸区</item> 348     <item>渝北区</item> 349     <item>巴南区</item> 350     <item>长寿区</item> 351     <item>江津区</item> 352     <item>合川区</item> 353     <item>永川区</item> 354     <item>南川区</item> 355     <item>大足区</item> 356   </string-array> 357   <string-array name="四川省"> 358     <item>成都市</item> 359     <item>自贡市</item> 360     <item>攀枝花市</item> 361     <item>泸州市</item> 362     <item>德阳市</item> 363     <item>锦阳市</item> 364     <item>广元市</item> 365     <item>遂宁市</item> 366     <item>内江市</item> 367     <item>乐山市</item> 368     <item>南充市</item> 369     <item>眉山市</item> 370     <item>宜宾市</item> 371     <item>广安市</item> 372     <item>达州市</item> 373     <item>雅安市</item> 374     <item>巴中市</item> 375     <item>资阳市</item> 376   </string-array> 377   <string-array name="贵州省"> 378     <item>贵阳市</item> 379     <item>六盘水市</item> 380     <item>遵义市</item> 381     <item>安抚市</item> 382     <item>铜仁市</item> 383     <item>毕节市</item> 384   </string-array> 385   <string-array name="云南省"> 386     <item>昆明市</item> 387     <item>曲靖市</item> 388     <item>玉溪市</item> 389     <item>保山市</item> 390     <item>昭通市</item> 391     <item>丽江市</item> 392     <item>普洱市</item> 393     <item>临沧市</item> 394   </string-array> 395   <string-array name="西藏自治区"> 396     <item>拉萨市</item> 397   </string-array> 398   <string-array name="陕西省"> 399     <item>西安市</item> 400     <item>铜川市</item> 401     <item>宝鸡市</item> 402     <item>咸阳市</item> 403     <item>渭南市</item> 404     <item>延安市</item> 405     <item>汉中市</item> 406     <item>榆林市</item> 407     <item>安康市</item> 408     <item>商洛市</item> 409   </string-array> 410   <string-array name="甘肃省"> 411     <item>兰州市</item> 412     <item>嘉峪关市</item> 413     <item>金昌市</item> 414     <item>白银市</item> 415     <item>天水市</item> 416     <item>武威市</item> 417     <item>张掖市</item> 418     <item>平凉市</item> 419     <item>酒泉市</item> 420     <item>庆阳市</item> 421     <item>定西市</item> 422     <item>陇南市</item> 423   </string-array> 424   <string-array name="青海省"> 425     <item>西宁市</item> 426   </string-array> 427   <string-array name="宁夏回族自治区"> 428     <item>银川市</item> 429     <item>石嘴山市</item> 430     <item>吴忠市</item> 431     <item>固原市</item> 432     <item>中卫市</item> 433   </string-array> 434   <string-array name="新疆维吾尔族自治区"> 435     <item>乌鲁木齐市</item> 436     <item>克拉玛依市</item> 437   </string-array> 438   <string-array name="台湾省"> 439     <item>台北市</item> 440     <item>高雄市</item> 441     <item>基隆市</item> 442     <item>台中市</item> 443     <item>台南市</item> 444     <item>新竹市</item> 445     <item>嘉义市</item> 446   </string-array> 447   <string-array name="香港"> 448     <item>香港岛</item> 449     <item>九龙</item> 450     <item>新界</item> 451   </string-array> 452   <string-array name="澳门"> 453     <item>澳门半岛</item> 454     <item>澳门离岛</item> 455   </string-array> 456   <string-array name="朝阳区"> 457     <item>国贸</item> 458     <item>CBD</item> 459     <item>大望路</item> 460     <item>四惠</item> 461     <item>双井</item> 462     <item>劲松</item> 463     <item>潘家园</item> 464     <item>广渠门</item> 465     <item>建外大街</item> 466     <item>东大桥</item> 467     <item>工体</item> 468     <item>朝外大街</item> 469     <item>京广桥</item> 470     <item>团结湖</item> 471     <item>朝阳公园</item> 472     <item>呼家楼</item> 473     <item>三里屯</item> 474     <item>麦子店</item> 475     <item>燕莎</item> 476     <item>三元桥</item> 477     <item>国展</item> 478     <item>西坝河</item> 479     <item>柳芳</item> 480     <item>和平街</item> 481     <item>左家庄</item> 482     <item>太阳宫</item> 483     <item>芍药居</item> 484     <item>安贞</item> 485     <item>亚运村</item> 486     <item>安慧桥</item> 487     <item>小关</item> 488     <item>北沙滩</item> 489     <item>奥运村</item> 490     <item>大屯</item> 491     <item>小营</item> 492     <item>望京</item> 493     <item>来广营</item> 494     <item>媒体村</item> 495     <item>花家地</item> 496     <item>北苑</item> 497     <item>大山子</item> 498     <item>酒仙桥</item> 499     <item>甘露园</item> 500     <item>首都机场</item> 501     <item>东坝</item> 502     <item>姚家园</item> 503     <item>水碓子</item> 504     <item>甜水园</item> 505     <item>朝青板块</item> 506     <item>石佛营</item> 507     <item>十里堡</item> 508     <item>红庙</item> 509     <item>百子湾</item> 510     <item>高碑店</item> 511     <item>双桥</item> 512     <item>定福庄</item> 513     <item>常营</item> 514     <item>慈云寺</item> 515     <item>管庄</item> 516     <item>南磨房</item> 517     <item>垡头</item> 518     <item>豆各庄</item> 519     <item>十八里店</item> 520     <item>小红门</item> 521     <item>十里河</item> 522     <item>惠新西街</item> 523     <item>将台路</item> 524     <item>八里庄</item> 525     <item>欢乐谷</item> 526     <item>惠新里</item> 527     <item>朝阳周边</item> 528     <item>健翔桥</item> 529     <item>孙河</item> 530     <item>松榆里</item> 531     <item>华威桥</item> 532   </string-array> 533   <string-array name="海淀区"> 534     <item>中关村</item> 535     <item>北京大学</item> 536     <item>清华大学</item> 537     <item>五道口</item> 538     <item>上地</item> 539     <item>西三旗</item> 540     <item>西二旗</item> 541     <item>清河</item> 542     <item>二里庄</item> 543     <item>学院路</item> 544     <item>知春路</item> 545     <item>牡丹园</item> 546     <item>北航</item> 547     <item>北太平庄</item> 548     <item>蓟门桥</item> 549     <item>双榆树</item> 550     <item>人民大学</item> 551     <item>皂君庙</item> 552     <item>大钟寺</item> 553     <item>魏公村</item> 554     <item>白石桥</item> 555     <item>交通大学</item> 556     <item>紫竹桥</item> 557     <item>花园桥</item> 558     <item>北洼路</item> 559     <item>航天桥</item> 560     <item>甘家口</item> 561     <item>军博</item> 562     <item>公主坟</item> 563     <item>厂洼</item> 564     <item>万寿路</item> 565     <item>五棵松</item> 566     <item>永定路</item> 567     <item>西八里庄</item> 568     <item>定慧寺</item> 569     <item>田村</item> 570     <item>四季青</item> 571     <item>香山</item> 572     <item>世纪城</item> 573     <item>苏州桥</item> 574     <item>苏州街</item> 575     <item>万泉河</item> 576     <item>万柳</item> 577     <item>增光路</item> 578     <item>西苑</item> 579     <item>马连洼</item> 580     <item>西北旺</item> 581     <item>车道沟</item> 582     <item>西山</item> 583     <item>万寿寺</item> 584     <item>明光桥</item> 585     <item>安宁庄</item> 586     <item>海淀周边</item> 587     <item>联想桥</item> 588     <item>金沟河</item> 589     <item>恩济里</item> 590     <item>五路居</item> 591   </string-array> 592   <string-array name="东城区"> 593     <item>东直门</item> 594     <item>东直门外</item> 595     <item>和平里</item> 596     <item>雍和宫</item> 597     <item>安定门</item> 598     <item>交道口</item> 599     <item>东四十条</item> 600     <item>海运仓</item> 601     <item>北新桥</item> 602     <item>朝阳门</item> 603     <item>建国门</item> 604     <item>北京站</item> 605     <item>王府井</item> 606     <item>景山</item> 607     <item>灯市口</item> 608     <item>沙滩</item> 609     <item>东单</item> 610     <item>东四</item> 611     <item>东城周边</item> 612   </string-array> 613   <string-array name="西城区"> 614     <item>西直门</item> 615     <item>车公庄</item> 616     <item>官园</item> 617     <item>百万庄</item> 618     <item>阜成门</item> 619     <item>西四</item> 620     <item>展览路</item> 621     <item>月坛</item> 622     <item>金融街</item> 623     <item>西单</item> 624     <item>德胜门</item> 625     <item>六铺炕</item> 626     <item>积水潭</item> 627     <item>小西天</item> 628     <item>新街口</item> 629     <item>马甸</item> 630     <item>鼓楼</item> 631     <item>地安门</item> 632     <item>复兴门</item> 633     <item>西便门</item> 634     <item>南礼士路</item> 635     <item>什刹海</item> 636     <item>木樨地</item> 637     <item>三里河</item> 638     <item>西城周边</item> 639     <item>真武庙</item> 640   </string-array> 641   <string-array name="崇文区"> 642     <item>崇文门</item> 643     <item>前门</item> 644     <item>新世界</item> 645     <item>广渠门</item> 646     <item>东花市</item> 647     <item>法华寺</item> 648     <item>体育馆路</item> 649     <item>磁器口</item> 650     <item>天坛</item> 651     <item>永定门</item> 652     <item>龙潭湖</item> 653     <item>光明楼</item> 654     <item>崇文周边</item> 655   </string-array> 656   <string-array name="宣武区"> 657     <item>广安门外</item> 658     <item>广安门内</item> 659     <item>天宁寺</item> 660     <item>马连道</item> 661     <item>红莲</item> 662     <item>白纸坊</item> 663     <item>南菜园</item> 664     <item>大观园</item> 665     <item>白广路</item> 666     <item>牛街</item> 667     <item>长椿街</item> 668     <item>宣武门</item> 669     <item>椿树街道</item> 670     <item>菜市口</item> 671     <item>陶然亭</item> 672     <item>珠市口</item> 673     <item>虎坊桥</item> 674     <item>天桥</item> 675     <item>大栅栏</item> 676     <item>和平门</item> 677     <item>宣武周边</item> 678   </string-array> 679   <string-array name="丰台区"> 680     <item>西客站</item> 681     <item>太平桥</item> 682     <item>六里桥</item> 683     <item>丰台路</item> 684     <item>青塔</item> 685     <item>岳各庄</item> 686     <item>卢沟桥</item> 687     <item>长辛店</item> 688     <item>云岗</item> 689     <item>北大地</item> 690     <item>丰台体育馆</item> 691     <item>丽泽桥</item> 692     <item>科技园区</item> 693     <item>世界公园</item> 694     <item>花乡</item> 695     <item>玉泉营</item> 696     <item>菜户营</item> 697     <item>西罗园</item> 698     <item>右安门</item> 699     <item>草桥</item> 700     <item>洋桥</item> 701     <item>木樨园</item> 702     <item>新发地</item> 703     <item>赵公口</item> 704     <item>嘉园</item> 705     <item>刘家窑</item> 706     <item>蒲黄榆</item> 707     <item>左安门</item> 708     <item>方庄</item> 709     <item>东铁匠营</item> 710     <item>丰益桥</item> 711     <item>看丹桥</item> 712     <item>成寿寺</item> 713     <item>宋家庄</item> 714     <item>大红门</item> 715     <item>七里庄</item> 716     <item>马家堡</item> 717     <item>五里店</item> 718     <item>角门</item> 719     <item>南苑</item> 720     <item>东高地</item> 721     <item>和义</item> 722     <item>莲花池</item> 723     <item>丰台周边</item> 724   </string-array> 725   <string-array name="通州区"> 726     <item>北关</item> 727     <item>北关环岛</item> 728     <item>永顺</item> 729     <item>新华大街</item> 730     <item>通州北苑</item> 731     <item>八里桥</item> 732     <item>果园</item> 733     <item>九棵树</item> 734     <item>梨园</item> 735     <item>土桥</item> 736     <item>临河里</item> 737     <item>中仓</item> 738     <item>西门</item> 739     <item>乔庄</item> 740     <item>东关</item> 741     <item>运河大街</item> 742     <item>玉桥</item> 743     <item>张家湾</item> 744     <item>八通轻轨沿线</item> 745     <item>武夷花园</item> 746     <item>潞城</item> 747     <item>马驹桥</item> 748     <item>漷县</item> 749     <item>次渠</item> 750     <item>通州周边</item> 751   </string-array> 752   <string-array name="石景山区"> 753     <item>八宝山</item> 754     <item>玉泉路</item> 755     <item>鲁谷</item> 756     <item>永乐</item> 757     <item>衙门口</item> 758     <item>八角</item> 759     <item>老山</item> 760     <item>杨庄</item> 761     <item>古城</item> 762     <item>苹果园</item> 763     <item>金顶街</item> 764     <item>模式口</item> 765     <item>五里坨</item> 766     <item>西山</item> 767     <item>八大处</item> 768     <item>石景山周边</item> 769     <item>广宁</item> 770   </string-array> 771   <string-array name="房山区"> 772     <item>长阳</item> 773     <item>良乡</item> 774     <item>阎村</item> 775     <item>迎风</item> 776     <item>窦店</item> 777     <item>房山城关</item> 778     <item>琉璃河</item> 779     <item>韩村河</item> 780     <item>燕山</item> 781     <item>周口店</item> 782     <item>房山周边</item> 783   </string-array> 784   <string-array name="昌平区"> 785     <item>天通苑</item> 786     <item>立水桥</item> 787     <item>东小口</item> 788     <item>霍营</item> 789     <item>小汤山</item> 790     <item>北七家</item> 791     <item>回龙观</item> 792     <item>龙泽</item> 793     <item>城北</item> 794     <item>沙河</item> 795     <item>百善</item> 796     <item>阳坊</item> 797     <item>南口</item> 798     <item>城南</item> 799     <item>昌平县城</item> 800     <item>昌平周边</item> 801     <item>南邵镇</item> 802   </string-array> 803   <string-array name="大兴区"> 804     <item>亦庄</item> 805     <item>旧宫</item> 806     <item>郁花园</item> 807     <item>同兴园</item> 808     <item>西红门</item> 809     <item>兴华大街</item> 810     <item>清源</item> 811     <item>兴丰大街</item> 812     <item>海子角</item> 813     <item>黄村</item> 814     <item>兴业大街</item> 815     <item>观音寺</item> 816     <item>滨河</item> 817     <item>林校路</item> 818     <item>新宫</item> 819     <item>庞各庄</item> 820     <item>大兴周边</item> 821   </string-array> 822   <string-array name="顺义区"> 823     <item>胜利</item> 824     <item>石园</item> 825     <item>天竺</item> 826     <item>新国展</item> 827     <item>机场</item> 828     <item>南彩</item> 829     <item>马坡</item> 830     <item>后沙峪</item> 831     <item>李桥</item> 832     <item>光明</item> 833     <item>裕龙</item> 834     <item>建新</item> 835     <item>杨镇</item> 836     <item>顺义城区</item> 837     <item>中央别墅区</item> 838     <item>顺义周边</item> 839   </string-array> 840   <string-array name="密云县"> 841     <item>密云城区</item> 842     <item>不老屯</item> 843     <item>溪翁庄</item> 844     <item>密云周边</item> 845   </string-array> 846   <string-array name="怀柔区"> 847     <item>雁栖</item> 848     <item>桥梓</item> 849     <item>怀柔城区</item> 850     <item>渤海镇</item> 851     <item>庙城</item> 852     <item>怀柔周边</item> 853   </string-array> 854   <string-array name="延庆县"> 855     <item>延庆城区</item> 856     <item>大榆树</item> 857     <item>八达岭</item> 858     <item>延庆周边</item> 859   </string-array> 860   <string-array name="平谷区"> 861     <item>金海湖</item> 862     <item>滨河路</item> 863     <item>平谷城区</item> 864     <item>兴谷</item> 865     <item>渔阳</item> 866     <item>王辛庄</item> 867     <item>平谷周边</item> 868   </string-array> 869   <string-array name="门头沟区"> 870     <item>大峪</item> 871     <item>东辛房</item> 872     <item>龙泉</item> 873     <item>城子街道</item> 874     <item>永定</item> 875     <item>潭柘寺</item> 876     <item>军庄</item> 877     <item>门头沟周边</item> 878   </string-array> 879   <string-array name="北京周边"> 880     <item>香河</item> 881     <item>燕郊</item> 882     <item>三河</item> 883     <item>固安</item> 884   </string-array> 885   <string-array name="天河区"> 886     <item>员村</item> 887     <item>东圃</item> 888     <item>车陂</item> 889     <item>黄村</item> 890     <item>棠下</item> 891     <item>上社</item> 892     <item>华景新城</item> 893     <item>天河公园</item> 894     <item>石牌</item> 895     <item>岗顶</item> 896     <item>龙口西</item> 897     <item>龙口东</item> 898     <item>五山</item> 899     <item>天河北</item> 900     <item>林和</item> 901     <item>体育中心</item> 902     <item>体育西路</item> 903     <item>天河南</item> 904     <item>天河东路</item> 905     <item>黄埔大道西</item> 906     <item>猎德</item> 907     <item>冼村</item> 908     <item>珠江新城</item> 909     <item>广州大道中</item> 910     <item>沙河</item> 911     <item>天平架</item> 912     <item>粤垦</item> 913     <item>沙太南</item> 914     <item>天河客运站</item> 915     <item>元岗</item> 916     <item>长兴</item> 917     <item>长湴</item> 918     <item>植物园</item> 919     <item>龙洞</item> 920     <item>新塘</item> 921     <item>珠吉</item> 922     <item>中山大道</item> 923     <item>前进</item> 924     <item>员村二横路</item> 925     <item>兴华</item> 926     <item>沙东</item> 927     <item>天园</item> 928     <item>登峰</item> 929     <item>凤凰</item> 930   </string-array> 931   <string-array name="海珠区"> 932     <item>赤岗</item> 933     <item>客村</item> 934     <item>广州大道南</item> 935     <item>新港</item> 936     <item>新港西</item> 937     <item>中大</item> 938     <item>下渡路</item> 939     <item>怡乐路</item> 940     <item>琶洲</item> 941     <item>东晓南</item> 942     <item>晓港</item> 943     <item>昌岗</item> 944     <item>江南大道南</item> 945     <item>江南西</item> 946     <item>江南中</item> 947     <item>江南大道中</item> 948     <item>前进路</item> 949     <item>素社</item> 950     <item>滨江东</item> 951     <item>滨江</item> 952     <item>宝岗</item> 953     <item>南华西</item> 954     <item>工业大道北</item> 955     <item>沙园</item> 956     <item>工业大道</item> 957     <item>南石头</item> 958     <item>江燕路</item> 959     <item>海幢</item> 960     <item>工业大道南</item> 961     <item>南洲</item> 962     <item>沥滘</item> 963     <item>官洲</item> 964     <item>华洲</item> 965     <item>工业大道中</item> 966     <item>瑞宝</item> 967     <item>凤阳</item> 968     <item>龙凤</item> 969     <item>江海</item> 970   </string-array> 971   <string-array name="越秀区"> 972     <item>小北</item> 973     <item>环市东</item> 974     <item>建设</item> 975     <item>淘金</item> 976     <item>黄花岗</item> 977     <item>水荫路</item> 978     <item>东风东</item> 979     <item>梅花村</item> 980     <item>杨箕村</item> 981     <item>五羊新城</item> 982     <item>东山口</item> 983     <item>农林下路</item> 984     <item>中山路</item> 985     <item>东川</item> 986     <item>农讲所</item> 987     <item>广卫</item> 988     <item>北京路</item> 989     <item>解放南</item> 990     <item>解放北</item> 991     <item>流花</item> 992     <item>东风路</item> 993     <item>盘福路</item> 994     <item>六榕</item> 995     <item>西门口</item> 996     <item>大新</item> 997     <item>人民</item> 998     <item>嘉禾</item> 999     <item>白云</item>1000     <item>大沙头</item>1001     <item>东湖</item>1002     <item>二沙岛</item>1003     <item>光塔</item>1004     <item>环市中</item>1005     <item>大东</item>1006     <item>华乐</item>1007     <item>诗书</item>1008     <item>洪桥</item>1009   </string-array>1010   <string-array name="白云区">1011     <item>三元里</item>1012     <item>新市</item>1013     <item>黄石</item>1014     <item>机场路</item>1015     <item>同和</item>1016     <item>京溪</item>1017     <item>梅花园</item>1018     <item>广州大道北</item>1019     <item>广园路</item>1020     <item>棠景</item>1021     <item>同德围</item>1022     <item>西槎路</item>1023     <item>罗冲围</item>1024     <item>金沙洲</item>1025     <item>石井</item>1026     <item>景泰</item>1027     <item>白云大道南</item>1028     <item>白云大道北</item>1029     <item>黄边</item>1030     <item>嘉禾望岗</item>1031     <item>桂花岗</item>1032     <item>伍仙桥</item>1033     <item>沙太北</item>1034     <item>龙归</item>1035     <item>人和</item>1036     <item>南湖</item>1037     <item>永平</item>1038     <item>太和</item>1039     <item>广花</item>1040     <item>均禾</item>1041     <item>江高</item>1042     <item>钟落潭</item>1043     <item>竹料</item>1044     <item>良田</item>1045     <item>九佛</item>1046     <item>神山</item>1047     <item>矿泉</item>1048     <item>松洲</item>1049     <item>鹤边</item>1050   </string-array>1051   <string-array name="荔湾区">1052     <item>芳村</item>1053     <item>站前</item>1054     <item>西村</item>1055     <item>环市西</item>1056     <item>南岸路</item>1057     <item>中山八路</item>1058     <item>西关</item>1059     <item>周门</item>1060     <item>荔湾路</item>1061     <item>陈家祠</item>1062     <item>东风西</item>1063     <item>西华路</item>1064     <item>光复北路</item>1065     <item>康王路</item>1066     <item>龙津</item>1067     <item>上下九</item>1068     <item>沙面</item>1069     <item>黄沙</item>1070     <item>花地湾</item>1071     <item>坑口</item>1072     <item>白鹤洞</item>1073     <item>龙溪</item>1074     <item>桥东</item>1075     <item>窖口</item>1076     <item>桥中</item>1077     <item>昌华</item>1078     <item>黄岐</item>1079     <item>华林</item>1080     <item>岭南</item>1081     <item>逢源</item>1082     <item>多宝</item>1083     <item>金花</item>1084     <item>南源</item>1085     <item>彩虹</item>1086     <item>第一津街</item>1087     <item>白鹅潭</item>1088   </string-array>1089   <string-array name="番禺区">1090     <item>市桥</item>1091     <item>祈福</item>1092     <item>钟村</item>1093     <item>大石</item>1094     <item>桥南</item>1095     <item>洛溪</item>1096     <item>南浦</item>1097     <item>华南</item>1098     <item>石碁</item>1099     <item>石楼</item>1100     <item>东涌</item>1101     <item>鱼窝头</item>1102     <item>大岗</item>1103     <item>榄核</item>1104     <item>沙头</item>1105     <item>东环</item>1106     <item>灵山</item>1107     <item>黄阁</item>1108     <item>横沥</item>1109     <item>万顷沙</item>1110     <item>顺德碧桂园</item>1111     <item>亚运城</item>1112     <item>大学城</item>1113   </string-array>1114   <string-array name="黄埔区">1115     <item>黄埔</item>1116     <item>黄埔区府</item>1117     <item>大沙</item>1118     <item>文冲</item>1119     <item>鱼珠</item>1120     <item>南岗</item>1121     <item>红山</item>1122     <item>穗东</item>1123     <item>长洲</item>1124     <item>荔联</item>1125   </string-array>1126   <string-array name="花都区">1127     <item>新华</item>1128     <item>狮岭</item>1129     <item>新区</item>1130     <item>旧区</item>1131     <item>花城路</item>1132     <item>花东</item>1133     <item>雅瑶</item>1134     <item>花山</item>1135     <item>芙蓉</item>1136     <item>炭步</item>1137     <item>赤坭</item>1138     <item>北兴</item>1139     <item>梯面</item>1140     <item>花侨</item>1141   </string-array>1142   <string-array name="萝岗区">1143     <item>开发东区</item>1144     <item>开发西区</item>1145     <item>科学城</item>1146     <item>萝岗镇</item>1147   </string-array>1148   <string-array name="南沙区">1149     <item>龙穴街道</item>1150     <item>南沙街道</item>1151     <item>珠江街道</item>1152     <item>万顷沙镇</item>1153     <item>黄阁镇</item>1154     <item>横沥镇</item>1155     <item>榄核镇</item>1156     <item>大岗镇</item>1157     <item>东涌镇</item>1158   </string-array>1159   <string-array name="增城">1160     <item>荔城</item>1161     <item>荔城</item>1162     <item>新塘</item>1163     <item>广园东</item>1164     <item>永和</item>1165     <item>三江</item>1166     <item>朱村</item>1167     <item>仙村</item>1168     <item>沙庄</item>1169     <item>中新</item>1170     <item>小楼</item>1171     <item>正果</item>1172     <item>镇龙</item>1173     <item>福和</item>1174     <item>派潭</item>1175     <item>新塘</item>1176     <item>广园东</item>1177     <item>永和</item>1178     <item>三江</item>1179     <item>朱村</item>1180     <item>仙村</item>1181     <item>沙庄</item>1182     <item>中新</item>1183     <item>小楼</item>1184     <item>正果</item>1185     <item>镇龙</item>1186     <item>福和</item>1187     <item>派潭</item>1188   </string-array>1189   <string-array name="长宁区">1190     <item>北新泾</item>1191     <item>地铁中山公园</item>1192     <item>古北</item>1193     <item>虹桥路</item>1194     <item>江苏路地铁</item>1195     <item>上海影城</item>1196     <item>天山路</item>1197     <item>西郊公园</item>1198     <item>仙霞</item>1199     <item>新华路</item>1200     <item>镇宁路</item>1201     <item>周家桥</item>1202   </string-array>1203   <string-array name="黄浦区">1204     <item>半淞园路</item>1205     <item>董家渡</item>1206     <item>黄浦周边</item>1207     <item>老西门</item>1208     <item>南京东路</item>1209     <item>南浦大桥</item>1210     <item>南外滩</item>1211     <item>蓬莱公园</item>1212     <item>人民广场</item>1213     <item>外滩/十六铺</item>1214     <item>西藏南路</item>1215     <item>斜桥</item>1216     <item>豫园</item>1217   </string-array>1218   <string-array name="徐汇区">1219     <item>漕宝路地铁口</item>1220     <item>漕河泾</item>1221     <item>长桥</item>1222     <item>枫林路</item>1223     <item>复兴中路</item>1224     <item>衡山路</item>1225     <item>华东理工</item>1226     <item>淮海西路</item>1227     <item>华泾</item>1228     <item>湖南路</item>1229     <item>康建</item>1230     <item>凌云路</item>1231     <item>龙华</item>1232     <item>日晖新村</item>1233     <item>上海交大</item>1234     <item>上海南站</item>1235     <item>上海师大</item>1236     <item>上海图书馆</item>1237     <item>上海植物园</item>1238     <item>田林</item>1239     <item>万体馆</item>1240     <item>襄阳公园</item>1241     <item>斜土路</item>1242     <item>徐汇周边</item>1243     <item>徐家汇</item>1244     <item>肇嘉浜路</item>1245   </string-array>1246   <string-array name="静安区">1247     <item>北京西路</item>1248     <item>曹家渡</item>1249     <item>江宁路</item>1250     <item>静安寺</item>1251     <item>静安周边</item>1252     <item>南京西路</item>1253     <item>上海电视台</item>1254     <item>西康路</item>1255     <item>新闸路</item>1256     <item>玉佛寺</item>1257   </string-array>1258   <string-array name="普陀区">1259     <item>曹杨</item>1260     <item>长风公园</item>1261     <item>长寿路</item>1262     <item>长征</item>1263     <item>甘泉路</item>1264     <item>光新</item>1265     <item>华东师大</item>1266     <item>建德花园</item>1267     <item>金沙江路</item>1268     <item>李子园</item>1269     <item>普陀周边</item>1270     <item>轻纺市场</item>1271     <item>桃浦</item>1272     <item>万里城</item>1273     <item>武宁路</item>1274     <item>宜川路</item>1275     <item>真光</item>1276     <item>真如</item>1277     <item>中远两湾城</item>1278   </string-array>1279   <string-array name="闸北区">1280     <item>宝山路</item>1281     <item>场中路</item>1282     <item>大宁路</item>1283     <item>共和新路</item>1284     <item>和田地区</item>1285     <item>老北站</item>1286     <item>彭浦</item>1287     <item>天目西路</item>1288     <item>汶水路</item>1289     <item>西藏北路</item>1290     <item>新客站</item>1291     <item>延长路</item>1292     <item>闸北公园</item>1293     <item>闸北周边</item>1294     <item>芷江西路</item>1295   </string-array>1296   <string-array name="虹口区">1297     <item>北外滩</item>1298     <item>大柏树</item>1299     <item>海宁路</item>1300     <item>和平公园</item>1301     <item>虹口周边</item>1302     <item>虹口足球场</item>1303     <item>江湾</item>1304     <item>凉城</item>1305     <item>临平路</item>1306     <item>鲁迅公园</item>1307     <item>曲阳路</item>1308     <item>四川北路</item>1309     <item>四平路</item>1310     <item>提篮桥</item>1311     <item>周家嘴路</item>1312   </string-array>1313   <string-array name="杨浦区">1314     <item>鞍山</item>1315     <item>长白新村</item>1316     <item>长阳路</item>1317     <item>东外滩</item>1318     <item>黄兴</item>1319     <item>江浦路</item>1320     <item>控江路</item>1321     <item>平凉路</item>1322     <item>五角场</item>1323     <item>新华医院</item>1324     <item>新江湾城</item>1325     <item>杨浦大桥</item>1326     <item>杨浦公园</item>1327     <item>杨浦周边</item>1328     <item>远光旦</item>1329     <item>中原</item>1330     <item>周家嘴路</item>1331   </string-array>1332   <string-array name="闵行区">1333     <item>北桥区快</item>1334     <item>漕宝路</item>1335     <item>春申</item>1336     <item>东兰新村</item>1337     <item>凤溪</item>1338     <item>古美罗阳</item>1339     <item>航华</item>1340     <item>虹梅路</item>1341     <item>虹桥</item>1342     <item>华漕</item>1343     <item>江川路</item>1344     <item>静安新城</item>1345     <item>金虹桥</item>1346     <item>纪王</item>1347     <item>老闵行</item>1348     <item>龙柏金汇</item>1349     <item>马桥</item>1350     <item>梅陇</item>1351     <item>闵行周边</item>1352     <item>南方商城</item>1353     <item>浦江</item>1354     <item>蔷薇新村</item>1355     <item>七宝</item>1356     <item>七莘路</item>1357     <item>莘庄</item>1358     <item>莘庄工业区</item>1359     <item>吴泾</item>1360     <item>颛桥</item>1361     <item>诸翟</item>1362   </string-array>1363   <string-array name="宝山区">1364     <item>宝山周边</item>1365     <item>大场</item>1366     <item>大华路</item>1367     <item>东城区</item>1368     <item>高境</item>1369     <item>共富新村</item>1370     <item>共康</item>1371     <item>顾村</item>1372     <item>锦秋花园</item>1373     <item>刘行</item>1374     <item>罗店</item>1375     <item>罗泾</item>1376     <item>罗南</item>1377     <item>上海大学</item>1378     <item>水产路</item>1379     <item>泗塘</item>1380     <item>淞宝</item>1381     <item>淞南</item>1382     <item>通河西城</item>1383     <item>通河新村</item>1384     <item>杨行</item>1385     <item>友谊路</item>1386     <item>月浦</item>1387     <item>张庙</item>1388   </string-array>1389   <string-array name="嘉定区">1390     <item>安亭</item>1391     <item>曹王</item>1392     <item>封浜</item>1393     <item>丰庄</item>1394     <item>黄渡</item>1395     <item>华亭</item>1396     <item>嘉定城区</item>1397     <item>嘉定新村</item>1398     <item>嘉定周边</item>1399     <item>江桥新城</item>1400     <item>金鹤新城</item>1401     <item>菊园新区</item>1402     <item>娄塘</item>1403     <item>马陆</item>1404     <item>南翔</item>1405     <item>唐行</item>1406     <item>外冈</item>1407     <item>徐行</item>1408     <item>真新</item>1409     <item>朱桥</item>1410   </string-array>1411   <string-array name="浦东区">1412     <item>八佰伴</item>1413     <item>北蔡</item>1414     <item>碧云</item>1415     <item>曹路</item>1416     <item>昌里</item>1417     <item>川沙</item>1418     <item>东昌站地铁站</item>1419     <item>东方路地铁</item>1420     <item>东明路</item>1421     <item>高桥</item>1422     <item>高行</item>1423     <item>合庆</item>1424     <item>花木</item>1425     <item>金桥</item>1426     <item>金杨新村</item>1427     <item>联洋</item>1428     <item>临港新城</item>1429     <item>六里</item>1430     <item>龙阳路地铁站</item>1431     <item>陆家嘴</item>1432     <item>梅园</item>1433     <item>南码头</item>1434     <item>浦东周边</item>1435     <item>三林</item>1436     <item>上钢新村</item>1437     <item>上南</item>1438     <item>世博滨江</item>1439     <item>世纪公园</item>1440     <item>塘桥</item>1441     <item>唐镇</item>1442     <item>外高桥</item>1443     <item>潍坊新村</item>1444     <item>杨东</item>1445     <item>洋泾</item>1446     <item>御桥</item>1447     <item>张江</item>1448     <item>周家渡</item>1449     <item>竹园商贸区</item>1450   </string-array>1451   <string-array name="金山区">1452     <item>枫泾</item>1453     <item>朱泾</item>1454     <item>亭林</item>1455     <item>漕泾</item>1456     <item>金山新城</item>1457     <item>金山周边</item>1458     <item>金山中部</item>1459   </string-array>1460   <string-array name="松江区">1461     <item>车墩</item>1462     <item>大港</item>1463     <item>洞泾</item>1464     <item>方松</item>1465     <item>九亭</item>1466     <item>练塘</item>1467     <item>泖港</item>1468     <item>茸北</item>1469     <item>莘闵</item>1470     <item>佘山</item>1471     <item>石湖荡</item>1472     <item>泗泾</item>1473     <item>松江大学城</item>1474     <item>松江工业区</item>1475     <item>松江科技园</item>1476     <item>松江老城</item>1477     <item>松江新城</item>1478     <item>松江周边</item>1479     <item>塔汇</item>1480     <item>小昆山</item>1481     <item>新浜</item>1482     <item>新桥</item>1483     <item>叶榭</item>1484     <item>永丰</item>1485     <item>岳阳</item>1486     <item>中山</item>1487   </string-array>1488   <string-array name="青浦区">1489     <item>白鹤</item>1490     <item>华新镇</item>1491     <item>金泽</item>1492     <item>青浦北部</item>1493     <item>青浦工业园区</item>1494     <item>青浦新城</item>1495     <item>青浦周边</item>1496     <item>香花桥</item>1497     <item>夏阳街道</item>1498     <item>徐泾</item>1499     <item>赵屯</item>1500     <item>赵巷</item>1501     <item>重固</item>1502     <item>朱家角</item>1503   </string-array>1504   <string-array name="奉贤区">1505     <item>金汇</item>1506     <item>南桥</item>1507     <item>庄行</item>1508     <item>奉城</item>1509     <item>柘林</item>1510     <item>海湾</item>1511     <item>海湾旅游区</item>1512     <item>奉贤周边</item>1513     <item>西渡</item>1514   </string-array>1515   <string-array name="崇明区">1516     <item>城桥</item>1517     <item>堡镇</item>1518     <item>陈家</item>1519     <item>长兴岛</item>1520     <item>崇明周边</item>1521   </string-array>1522   <string-array name="卢湾区">1523     <item>打浦桥</item>1524     <item>复兴公园</item>1525     <item>淮海公园</item>1526     <item>淮海中路</item>1527     <item>鲁班路</item>1528     <item>瑞金二路</item>1529     <item>世博滨江</item>1530     <item>五里桥</item>1531     <item>新天地</item>1532     <item>中山南一路</item>1533   </string-array>1534   <string-array name="南汇区">1535     <item>南汇周边</item>1536     <item>芦潮港</item>1537     <item>泥城</item>1538     <item>航头</item>1539     <item>新场</item>1540     <item>惠南</item>1541     <item>祝桥</item>1542     <item>周浦</item>1543     <item>康桥</item>1544   </string-array>1545 </resources>

cityarrays.

一、写布局文件:

看上面效果图可以看出,省市名是一种布局,拼音标签是一种布局。那么就需要先写两种布局

1、拼音标签布局

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 <?"1.0" encoding="utf-8"?> 2 <LinearLayout "http://schemas.android.com/apk/res/android" 3   android:orientation="vertical" 4   android:layout_width="match_parent" 5   android:layout_height="match_parent" 6   android:dividerPadding="1dp" 7   android:paddingLeft="10dp" 8   android:paddingBottom="2dp" 9   android:paddingTop="2dp"10   android:background="#F5F5F5"11   >12 13   <TextView14     android:id="@+id/tv_item_city"15     android:layout_width="match_parent"16     android:layout_height="wrap_content"17     android:textColor="#f00"18     android:textSize="18sp"19     android:padding="2dp"20     android:text="label"21     />22 23 </LinearLayout>

item_city_list_label.

2、省市名布局

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 <?"1.0" encoding="utf-8"?> 2 <LinearLayout "http://schemas.android.com/apk/res/android" 3   android:orientation="vertical" 4   android:layout_width="match_parent" 5   android:layout_height="match_parent" 6   android:dividerPadding="1dp" 7   android:paddingLeft="10dp" 8   android:paddingBottom="8dp" 9   android:paddingTop="8dp"10   android:background="#FFFFFF"11   >12 13   <TextView14     android:id="@+id/tv_item_city"15     android:layout_width="match_parent"16     android:layout_height="wrap_content"17     android:textColor="#000000"18     android:padding="2dp"19     android:textSize="18sp"20     android:text="city"21     />22 23 </LinearLayout>

item_city_list_city.

3、主布局文件

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 <RelativeLayout "http://schemas.android.com/apk/res/android" 2         "http://schemas.android.com/tools" 3         android:layout_width="match_parent" 4         android:layout_height="match_parent" 5         tools:context="com.archie.lazyhousewifeiy.cityandauntdetail.CityListActivity"> 6  7  8  9   <RelativeLayout10       android:layout_width="match_parent"11       android:layout_height="match_parent"12       >13 14     <ListView15         android:id="@+id/list_view_cities"16         android:layout_width="match_parent"17         android:layout_height="match_parent"18         />19     <!-- 这里就是我们要使用的自定义拼音列表了,注意SideBar前面是你自己的包名,这里我的包名为:com.xqx.SideBarDemo-->20     <com.xqx.SideBarDemo.SideBar21         android:id="@+id/side_bar"22         android:layout_width="30dp"23         android:layout_height="match_parent"24         android:layout_alignParentRight="true"25         android:paddingTop="10dp"26         android:paddingBottom="10dp"27         />28   </RelativeLayout>29 30   <TextView31       android:id="@+id/tv_text_dialog"32       android:layout_width="wrap_content"33       android:layout_height="wrap_content"34       android:layout_centerInParent="true"35       android:background="#D2D2D2"36       android:visibility="gone"37       android:padding="10dp"38       android:textColor="#2DB7E1"39       android:textSize="30sp"40       android:text="A"41       />42 43 </RelativeLayout>44   

main.

 

二、现在写java代码了

1、首先看我们主要使用的一个自定义View,用来显示拼音列表,大家可以看看源码,将内容显示为自己喜欢的样子

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 package com.xqx.SideBarDemo; 2  3 import android.content.Context; 4 import android.graphics.Canvas; 5 import android.graphics.Color; 6 import android.graphics.Paint; 7 import android.util.AttributeSet; 8 import android.view.MotionEvent; 9 import android.view.View; 10 import android.widget.TextView; 11  12  13 public class SideBar extends View { 14  15   public String[] characters = new String[] { "#", "A", "B", "C", "D", "E", "F", 16       "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", 17       "X", "Y", "Z" }; 18  19   private Paint paint; 20   private int textSize = 20;    //拼音文字大小 21   private int defaultTextColor =  //默认拼音文字的颜色 Color.parseColor("#D2D2D2");  22   private int selectedTextColor = //选中后的拼音文字的颜色 Color.parseColor("#2DB7E1"); 23   private int touchedBgColor =  //触摸时的拼音文字的颜色 Color.parseColor("#F5F5F5"); 24   private TextView text_dialog; 25  26   private OnTouchingLetterChangedListener onTouchingLetterChangedListener; 27  28   private int position = -1; 29  30   public SideBar(Context context) { 31     super(context); 32   } 33  34   public SideBar(Context context, AttributeSet attrs) { 35     super(context, attrs); 36     init(); 37   } 38  39   public SideBar(Context context, AttributeSet attrs, int defStyle) { 40     super(context, attrs, defStyle); 41     init(); 42   } 43    44   public void setTextDialog(TextView textView){ 45     this.text_dialog = textView; 46   }  47  48   private void init() { 49     paint = new Paint(); 50     paint.setAntiAlias(true); 51   } 52  53   @Override 54   protected void onDraw(Canvas canvas) { 55     super.onDraw(canvas); 56  57     int height = getHeight(); 58     int width = getWidth(); 59     int singleHeight = height / characters.length; 60  61     for (int i = 0; i < characters.length; i++) { 62       if (i == position) { 63         paint.setColor(selectedTextColor); 64       } else { 65         paint.setColor(defaultTextColor); 66       } 67       paint.setTextSize(textSize); 68  69       float xPos = width / 2 - paint.measureText(characters[i]) / 2; 70       float yPos = singleHeight * i + singleHeight; 71       canvas.drawText(characters[i], xPos, yPos, paint); 72     } 73   } 74  75   @Override 76   public boolean onTouchEvent(MotionEvent event) { 77     int action = event.getAction(); 78     float y = event.getY(); 79     position = (int) (y / (getHeight() / characters.length)); 80     if (position >= 0 && position <   Constants.CITY_TYPE.length) { 81       onTouchingLetterChangedListener.onTouchingLetterChanged(position); 82       switch (action) { 83         case MotionEvent.ACTION_UP: 84           setBackgroundColor(Color.TRANSPARENT); 85           position = -1; 86           invalidate(); 87           if (text_dialog != null) { 88             text_dialog.setVisibility(View.INVISIBLE); 89           } 90           break; 91         default: 92           setBackgroundColor(touchedBgColor); 93           invalidate(); 94           text_dialog.setText(characters[position]); 95           break; 96       } 97     }else{ 98       setBackgroundColor(Color.TRANSPARENT); 99       if (text_dialog != null) {100         text_dialog.setVisibility(View.INVISIBLE);101       }102 103     }104     return true;105   }106 107   public void setOnTouchingLetterChangedListener(108       OnTouchingLetterChangedListener onTouchingLetterChangedListener) {109     this.onTouchingLetterChangedListener = onTouchingLetterChangedListener;110   }111 112 113   public interface OnTouchingLetterChangedListener {114     public void onTouchingLetterChanged(int position);115   }116 117 }

SideBar.java

2、创建一个city的实体类

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 package com.xqx.SideBarDemo; 2  3  4 public class City { 5   // 标记 拼音,label 6   public static final int CITY_TYPE_LABEL = 0; 7   // 标记 城市名 8   public static final int CITY_TYPE_CITY = 1; 9 10   private String cityName; //城市名11   private String cityType; //城市类型12 13   @Override14   public String toString() {15     return "City{" +16         "cityName='" + cityName + '\'' +17         ", cityType='" + cityType + '\'' +18         '}';19   }20 21   public static int getTypeCount(){22     return 2;23   }24 25   public int getType(){26 27     if(cityType.equals("label")){28       return CITY_TYPE_LABEL;29     }else{30       return CITY_TYPE_CITY;31     }32 33   }34 35   public String getCityName() {36     return cityName;37   }38 39   public void setCityName(String cityName) {40     this.cityName = cityName;41   }42 43   public void setCityType(String cityType) {44     this.cityType = cityType;45   }46 }

City.java

3、解析本地列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果

 1 package com.xqx.SideBarDemo; 2  3  4 import org. 5 import org. 6 import org. 7  8 import java.io.FileNotFoundException; 9 import java.io.IOException; 10 import java.io.InputStream; 11 import java.util.ArrayList; 12 import java.util.List; 13 import java.util.TreeMap; 14  15 import javax. 16 import javax. 17 import javax. 18  19 /** 20  * 解析本地 21 */ 22 public class Parse 23  24   private TreeMap<String, List<String>> cities; 25  26   private List<String> city; 27  28   // 城市列表第一层 29   private List<String> cityList; 30  31   private String tagName; 32  33   // 城市列表第一层城市数量 34   private int cityNum = 1; 35  36   public Parsein) { 37  38     SAXParserFactory factory = SAXParserFactory.newInstance(); 39  40     try { 41  42       SAXParser parser = factory.newSAXParser(); 43  44       parser.parse(in, this); 45  46     } catch (ParserConfigurationException e) { 47       e.printStackTrace(); 48     } catch (SAXException e) { 49       e.printStackTrace(); 50     } catch (FileNotFoundException e) { 51       e.printStackTrace(); 52     } catch (IOException e) { 53       e.printStackTrace(); 54     } 55  56   } 57  58   public TreeMap<String, List<String>> getCities(){ 59  60     return cities; 61  62   } 63  64   public List<String> getCityList(){ 65  66     return cityList; 67  68   } 69  70   @Override 71   public void startDocument() throws SAXException { 72  73     cities = new TreeMap<String, List<String>>(new CityComparator()); 74  75     cityList = new ArrayList<String>(); 76  77   } 78  79   @Override 80   public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException { 81  82     tagName = qName; 83  84     if("string-array".equals(qName)){ 85  86       if (attributes != null){ 87  88         for (int i = 0; i < attributes.getLength(); i++) { 89  90           String attrName = attributes.getQName(i); 91  92           String attrValue = attributes.getValue(i); 93  94           if("name".equals(attrName)){ 95  96             city = new ArrayList<String>(); 97  98             cities.put(attrValue, city); 99 100             if(cityNum <= Constants.CITY_NUMBER) {101 102               cityList.add(attrValue);103 104               cityNum ++;105             }106 107           }108 109         }110 111       }112 113     }114 115   }116 117   @Override118   public void characters(char[] ch, int start, int length) throws SAXException {119 120     String data = new String(ch, start, length);121 122     if("item".equals(tagName)){123 124       city.add(data);125 126     }127 128   }129 130   @Override131   public void endElement(String uri, String localName, String qName) throws SAXException {132 133     tagName = null;134 135   }136 137   @Override138   public void endDocument() throws SAXException {139   }140 141 }

Parse

4、汉字转换为拼音的类

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 package com.xqx.SideBarDemo; 2  3 import net.sourceforge.pinyin4j.PinyinHelper; 4 import net.sourceforge.pinyin4j.format.HanyuPinyinCaseType; 5 import net.sourceforge.pinyin4j.format.HanyuPinyinOutputFormat; 6 import net.sourceforge.pinyin4j.format.HanyuPinyinToneType; 7 import net.sourceforge.pinyin4j.format.HanyuPinyinVCharType; 8 import net.sourceforge.pinyin4j.format.exception.BadHanyuPinyinOutputFormatCombination; 9 10 11 public class HanziToPinYin {12 13   /**14    * 如果字符串string是汉字,则转为拼音并返回15    * @param string16    * @return17   */18   public static char toPinYin(String string){19     HanyuPinyinOutputFormat hanyuPinyin = new HanyuPinyinOutputFormat();20     hanyuPinyin.setCaseType(HanyuPinyinCaseType.UPPERCASE);21     hanyuPinyin.setToneType(HanyuPinyinToneType.WITHOUT_TONE);22     hanyuPinyin.setVCharType(HanyuPinyinVCharType.WITH_U_UNICODE);23     String[] pinyinArray=null;24     char hanzi = string.charAt(0);25     try {26       //是否在汉字范围内27       if(hanzi>=0x4e00 && hanzi<=0x9fa5){28         pinyinArray = PinyinHelper.toHanyuPinyinStringArray(hanzi, hanyuPinyin);29       }30     } catch (BadHanyuPinyinOutputFormatCombination e) {31       e.printStackTrace();32     }33     //将获取到的拼音返回34     return pinyinArray[0].charAt(0);35   }36 37 38 }

HanziToPinYin.java

5、ListView的适配器

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 package com.xqx.SideBarDemo; 2  3 import android.content.Context; 4 import android.view.LayoutInflater; 5 import android.view.View; 6 import android.view.ViewGroup; 7 import android.widget.BaseAdapter; 8 import android.widget.TextView; 9 10 import java.util.List;11 12 public class CityListAdapter extends BaseAdapter {13 14   private List<City> cities;15   private Context context;16   public CityListAdapter(Context context, List<City> cities) {17     this.cities = cities;18     this.context = context;19   }20   @Override21   public int getCount() {22     return cities.size();23   }24   @Override25   public int getViewTypeCount() {26     return City.getTypeCount();27   }28   @Override29   public Object getItem(int position) {30     return cities.get(position);31   }32   @Override33   public long getItemId(int position) {34     return position;35   }36 37   @Override38   public int getItemViewType(int position) {39     return cities.get(position).getType();40   }41 42   //判断是否可以点击,即判断是否是省市名拼音43   @Override44   public boolean isEnabled(int position) {45 46     if (getItemViewType(position) == City.CITY_TYPE_LABEL){47       return false;48     }49     return super.isEnabled(position);50   }51 52   @Override53   public View getView(int position, View convertView, ViewGroup parent) {54 55     // 如果是label 即拼音 就为label布局56     if(getItemViewType(position) == City.CITY_TYPE_LABEL){57       convertView = LayoutInflater.from(context).inflate(R.layout.item_city_list_label, parent, false);58     }else{59       //如果是城市,则为城市名称布局60       convertView = LayoutInflater.from(context).inflate(R.layout.item_city_list_city, parent, false);61     }62     //显示列表项文字63     TextView tv = (TextView) convertView.findViewById(R.id.tv_item_city);64     tv.setText(cities.get(position).getCityName());65     return convertView;66   }67 }

CityListAdapter.java

6、处理重庆问题(重庆会被分析为zhongqin ,注意,自己测试)

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 package com.xqx.SideBarDemo; 2  3 import java.text.CollationKey; 4 import java.text.Collator; 5 import java.text.RuleBasedCollator; 6 import java.util.Comparator; 7 import java.util.Locale; 8  9 10 public class CityComparator implements Comparator<String> {11 12   private RuleBasedCollator collator;13 14   public CityComparator() {15 16     collator = (RuleBasedCollator) Collator.getInstance(Locale.CHINA);17 18   }19 20   @Override21   public int compare(String lhs, String rhs) {22 23     lhs = lhs.replace("重庆", "崇庆");24     rhs = rhs.replace("重庆", "崇庆");25     CollationKey c1 = collator.getCollationKey(lhs);26     CollationKey c2 = collator.getCollationKey(rhs);27 28     return c1.compareTo(c2);29   }30 }

CityComparator.java

7、存放一个常量的类

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 package com.xqx.SideBarDemo; 2  3 public class Constants { 4  5  6   public static final String "cityarrays."; 7  8   // 根据cityarrays. 9   public static final int CITY_NUMBER = 35;10 11 12   public static final String[] CITY_TYPE = new String[] { "#", "A", "B", "C", "D", "E", "F",13       "G", "H", "I", "J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W",14       "X", "Y", "Z" };15 16 }

Constants.

8、主MainActivity

列表右侧边栏拼音展示效果列表右侧边栏拼音展示效果
 1 package com.xqx.SideBarDemo; 2  3 import android.app.Activity; 4 import android.content.Intent; 5 import android.content.res.AssetManager; 6 import android.os.Bundle; 7 import android.view.View; 8 import android.view.Window; 9 import android.widget.AdapterView; 10 import android.widget.ListView; 11 import android.widget.TextView; 12  13 import java.io.IOException; 14 import java.io.InputStream; 15 import java.util.ArrayList; 16 import java.util.Collections; 17 import java.util.List; 18 import java.util.TreeMap; 19  20 public class MainActivity extends Activity implements AdapterView.OnItemClickListener { 21   /** 22    * Called when the activity is first created. 23   */ 24   private TreeMap<String, List<String>> citiesAll; 25   // 存放正规带有标志的城市集合 26   private List<City> cityList; 27   private CityListAdapter adapter; 28   private SideBar sideBar; 29   private TextView dialog_text; 30   private ListView cityListView; 31  32  33   @Override 34   protected void onCreate(Bundle savedInstanceState) { 35     super.onCreate(savedInstanceState); 36     requestWindowFeature(Window.FEATURE_NO_TITLE); 37     setContentView(R.layout.main); 38  39     cityListView = (ListView) findViewById(R.id.list_view_cities); 40  41  42     sideBar = (SideBar) findViewById(R.id.side_bar); 43  44     dialog_text = (TextView) findViewById(R.id.tv_text_dialog); 45  46     cityList = new ArrayList<City>(); 47  48     adapter = new CityListAdapter(this, cityList); 49  50     cityListView.setAdapter(adapter); 51  52     cityListView.setOnItemClickListener(this); 53  54     initData(); 55     initSideBar(); 56   } 57  58   private void initSideBar() { 59  60     sideBar.setTextDialog(dialog_text); 61     // 设置拼音列表的滑动事件, 62     sideBar.setOnTouchingLetterChangedListener(new SideBar.OnTouchingLetterChangedListener() { 63       @Override 64       public void onTouchingLetterChanged(int position) { 65         String city_label = Constants.CITY_TYPE[position]; 66         for (int i = 0; i < cityList.size(); i++) { 67           if (cityList.get(i).getCityName().equals(city_label)) { 68             cityListView.setSelection(i); 69             dialog_text.setVisibility(View.VISIBLE); 70             break; 71           } 72           if(i == cityList.size() -1){ 73             dialog_text.setVisibility(View.INVISIBLE); 74           } 75         } 76       } 77     }); 78  79   } 80  81   private void initData() { 82  83     // 84     AssetManager assets = getResources().getAssets(); 85     try { 86       InputStream open = assets.open(Constants. 87       //SAX解析 88       Parsenew Parse 89       citiesAll = parse 90  91       // 存放第一层城市列表名称 92       List<String> cities = parse 93  94       // 对第一层城市列表排序 95       Collections.sort(cities, new CityComparator()); 96  97       // 添加第一个标签 98       String cityType = HanziToPinYin.toPinYin(cities.get(0)) + ""; 99 100       City city = new City();101 102       city.setCityName(cityType);103 104       city.setCityType("label");105 106       cityList.add(city);107 108       for (int i = 0; i < cities.size(); i++) {109 110         String string = cities.get(i);111 112         String s = null;113         if(string.contains("重庆")){114 115           s = HanziToPinYin.toPinYin("崇庆") + "";116         }else{117 118           s = HanziToPinYin.toPinYin(string) + "";119         }120 121 122         if(s.equals(cityType)){123 124           city = new City();125           city.setCityName(string);126           city.setCityType(cityType);127 128           cityList.add(city);129 130         }else{131 132           // 添加标签133           cityType = s;134           city = new City();135           city.setCityName(cityType);136           city.setCityType("label");137 138           cityList.add(city);139 140           // 添加城市141           city = new City();142           city.setCityName(string);143           city.setCityType(cityType);144 145           cityList.add(city);146 147           adapter.notifyDataSetChanged();148 149         }150       }151     } catch (IOException e) {152       e.printStackTrace();153     }154 155   }156 157   // 省市列表项点击事件158   @Override159   public void onItemClick(AdapterView<?> parent, View view, int position, long id) {160 161   }162 163 }

MainActivity.java

最重要的一点:

pinyin4j-2.5.0.jar 这个jar包 一定要有,放在libs下  ,大家可以百度去下载这个jar包




原标题:列表右侧边栏拼音展示效果

关键词:

*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: admin#shaoqun.com (#换成@)。
相关文章
我的浏览记录
最新相关资讯
海外公司注册 | 跨境电商服务平台 | 深圳旅行社 | 东南亚物流