- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一步步实现一个城市选择器
一步步实现一个城市选择器
主要包含以下内容:
1、自动定位所在城市
2、热门城市列表展示
3、所有城市列表的展示
4、输入城市名或者城市拼音搜索对应城市
5、右侧的slidebar城市列表导航栏
请大家先下载Demo然后再一边看demo一边看博客。因为博客里很多代码因为比较简单就不贴了。
首先我们先搭建基本的UI:
分析效果图,我们需要一个顶部title view,一个搜索框,一个定位功能的view,一个展示热门城市的view,一个侧边栏view和一个listview。
顶部title View:
这里有一些需要注意的地方:
我们在新建工程的时候,Android studio会自动生成一个style作为我们的主题:
style name=AppTheme parent=Theme.AppCompat.Light.DarkActionBar
!-- Customize your theme here. --
item name=colorPrimary@color/colorPrimary/item
item name=colorPrimaryDark@color/colorPrimaryDark/item
item name=colorAccent@color/colorAccent/item
/style
android:theme=@style/AppTheme
这个默认的主题是带有actionbar的,如果我们要去掉这个actionbar,首先需要把DarkActionBar改为NoActionBar,因为使用AppCompatActivity的时候,Activity必须使用Theme.AppCompat主题及其子主题,所以我们的自定义的HD_NoActionBar样式必须继承这个主题:
style name=AppTheme parent=Theme.AppCompat.Light.NoActionBar
!-- Customize your theme here. --
item name=colorPrimary@color/colorPrimary/item
item name=colorPrimaryDark@color/colorPrimaryDark/item
item name=colorAccent@color/colorAccent/item
/style
style name=HD_NoActionBar parent=AppTheme
item name=android:windowNoTitletrue/item
item name=android:windowActionBarfalse/item
/style
然后引用这个style:
android:theme=@style/AppTheme.NoActionBar
接下来写我们的头布局 title_view.xml:
LinearLayout xmlns:android=/apk/res/android
xmlns:tools=/tools
android:layout_width=match_parent
android:layout_height=wrap_content
android:orientation=vertical
RelativeLayout
android:layout_width=match_parent
android:layout_height=?attr/actionBarSize
android:background=@color/light_blue
ImageView
android:id=@+id/back
style=@style/Widget.AppCompat.ActionButton
android:layout_width=wrap_content
android:layout_height=match_parent
android:paddingLeft=16dp
android:paddingRight=16dp
android:scaleType=center
android:src=@mipmap/ic_back
tools:ignore=ContentDescription /
TextView
android:layout_width=wrap_content
an
文档评论(0)