使用RadioGroup实现底部导航栏效果,不需要java代码。
1、首先创建五个Drawable
其中四个是图片的切换,代码如下:
`<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:state_checked="true" android:drawable="@drawable/nav_cur_icon01"></item>
<item android:state_checked="false" android:drawable="@drawable/nav_icon01"></item>
</selector>`
一个为文字颜色的切换,代码如下:
`<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_checked="false" android:color="#000000"></item>
<item android:state_checked="true" android:color="#2DA77E"></item>
</selector>`
2、在XML文件中写底部导航栏代码
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context=".MainActivity" >
<TextView
android:layout_width="wrap_content"
android:layout_height="0dp"
android:layout_weight="1"
android:text="@string/hello_world" />
<RadioGroup
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal" >
<RadioButton
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/main_bottom_one"
android:gravity="center_horizontal"
android:text="新闻"
android:textColor="@drawable/text_color" />
<RadioButton
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/main_bottom_two"
android:gravity="center_horizontal"
android:text="娱乐"
android:textColor="@drawable/text_color" />
<RadioButton
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/main_bottom_three"
android:gravity="center_horizontal"
android:text="军事"
android:textColor="@drawable/text_color" />
<RadioButton
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:button="@null"
android:drawableTop="@drawable/main_bottom_four"
android:gravity="center_horizontal"
android:text="科技"
android:textColor="@drawable/text_color" />
</RadioGroup>
</LinearLayout>
3、运行,搞定,就是这么简单