FragmentTabHost介紹
FragmentTabHost代表整個(gè)底部導(dǎo)航欄慎颗,它包含的每一個(gè)Item,稱之為TabSpec言询,點(diǎn)擊可以切換到相應(yīng)的Fragment分頁(yè)俯萎。TabSpec里面需要有指示器Indicator,用來設(shè)置樣式运杭。
相較于RadioButton(RadioGroup)+ Fragment的實(shí)現(xiàn)方式夫啊,F(xiàn)ragmentTabHost實(shí)現(xiàn)簡(jiǎn)單,對(duì)資源的控制相對(duì)較好辆憔。
FragmentTabHost基本用法
1.FragmentTabHost XML布局
注意
1. 使用 v4 的FragmentTabHost
2. FragmentTabHost需要使用Android自帶的id
@android:id/tabhost
3. FragmentTabHost中的FrameLayout也需要使用自帶id
@android:id/tabcontent
因?yàn)閷?shí)現(xiàn)的是底部菜單涮母,底部的FrameLayout設(shè)置為0dp
真正展示內(nèi)容的是上方的FrameLayout
<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=".ui.activity.MainActivity">
<FrameLayout
android:id="@+id/fra_content"
android:layout_width="match_parent"
android:layout_height="0dp"
android:layout_weight="1" />
<android.support.v4.app.FragmentTabHost
android:id="@android:id/tabhost"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="#E8E8E8">
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="0dp"
android:layout_height="0dp" />
</android.support.v4.app.FragmentTabHost>
</LinearLayout>
2.drawable設(shè)置
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:drawable="@mipmap/red_img" android:state_selected="true" />
<item android:drawable="@mipmap/base_img" />
</selector>
文本選擇設(shè)置
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:color="@color/colorAccent" android:state_selected="true" />
<item android:color="#000" />
</selector>
設(shè)置Tab Host每個(gè)Item的樣式
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:orientation="vertical">
<ImageView
android:id="@+id/tab_img"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/red_press" />
<TextView
android:id="@+id/tab_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="123"
android:textColor="@color/text_press" />
</LinearLayout>
2.代碼實(shí)現(xiàn)
步驟
1. 為TabHost設(shè)置初始化
mFraTabHost.setup(mContext, getSupportFragmentManager(), R.id.fra_content);
2. 生成每個(gè)Item
TabHost.TabSpec mTabSpec = mFraTabHost.newTabSpec("Tag" + i);
3. 為每個(gè)Item指定樣式
mTabSpec.setIndicator(View view);
4. 將每個(gè)Item添加到TabHost,同時(shí)也添加Fragment
mFraTabHost.addTab(mTabSpec, fraClass[i], null);
public class MainActivity extends AppCompatActivity {
private FragmentTabHost mFraTabHost;
private Context mContext;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
initTabHost();
initEvent();
}
private void initEvent() {
//監(jiān)聽分頁(yè)切換
mFraTabHost.setOnTabChangedListener(new TabHost.OnTabChangeListener() {
@Override
public void onTabChanged(String s) {
Log.i("TagInfo", s);
}
});
}
private void initTabHost() {
mFraTabHost.setup(mContext, getSupportFragmentManager(), R.id.fra_content);
initTabHostData();
//設(shè)置顯示的當(dāng)前頁(yè)
mFraTabHost.setCurrentTab(1);
//去掉分割線
mFraTabHost.getTabWidget().setShowDividers(LinearLayout.SHOW_DIVIDER_NONE);
}
private void initTabHostData() {
Class[] fraClass = {RedFragment.class, BlueFragment.class};
int[] icon = {R.drawable.red_press, R.drawable.blue_press};
String[] title = {"Red", "Blue"};
for (int i = 0; i < fraClass.length; i++) {
TabHost.TabSpec mTabSpec = mFraTabHost.newTabSpec("Tag" + i);
mTabSpec.setIndicator(getTabHostItemView(icon[i], title[i]));
mFraTabHost.addTab(mTabSpec, fraClass[i], null);
}
}
public View getTabHostItemView(int icon, String itemText) {
LayoutInflater inflater = LayoutInflater.from(this);
View view = inflater.inflate(R.layout.item_tabhost, null);
TextView mItemText = view.findViewById(R.id.tab_text);
ImageView mItemImg = view.findViewById(R.id.tab_img);
mItemImg.setImageResource(icon);
mItemText.setText(itemText);
return view;
}
private void initView() {
mContext = this;
mFraTabHost = findViewById(android.R.id.tabhost);
}
}