利用TabWidget实现底部菜单
生活随笔
收集整理的這篇文章主要介紹了
利用TabWidget实现底部菜单
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
TabWidget類似于通話記錄的界面,通過切換多個標簽從而顯示出多個不同內容,能夠展示內容豐富的頁面信息,而且彼此之間不會干擾,有利于展示。下面,通過一個例子來學習用法
首先用一個類來繼承TabActivity
在開發之前,我們要首先了解,TabHost是整個Tab的容器,包括兩部分,TabWidget和FrameLayout。TabWidget就是每個tab的標簽,FrameLayout則是tab內容。接著我們開始初始化main.xml。
首先聲明TabHost,包含TabWidget,FrameLayout元素。
注意下:
如果我們使用extends TabAcitivty,如同ListActivity,TabHost必須設置為@android:id/tabhost
TabWidget必須設置android:id為@android:id/tabs
FrameLayout需要設置android:id為@android:id/tabcontent
布局文件
<?xml version="1.0" encoding="utf-8"?> <TabHost xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:id="@android:id/tabhost" ><LinearLayout android:layout_width="fill_parent"android:layout_height="fill_parent"android:orientation="vertical" ><FrameLayout android:id="@android:id/tabcontent" android:layout_width="fill_parent"android:layout_height="0.0dip"android:layout_weight="1.0"/><TabWidget android:id="@android:id/tabs" android:layout_width="fill_parent"android:layout_height="wrap_content"android:visibility="gone"/><RadioGroup android:id="@+id/tab_items"android:gravity="center_vertical"android:layout_width="fill_parent"android:layout_height="wrap_content"android:orientation="horizontal"android:layout_gravity="bottom"android:background="@drawable/tab_bg"><RadioButton android:id="@+id/tab_item_home"android:checked="true" style="@style/main_tab_bottom"android:background="@drawable/item_home_bg" /><RadioButton android:id="@+id/tab_item_nearby" style="@style/main_tab_bottom"android:background="@drawable/item_near_bg"/><RadioButton android:id="@+id/tab_item_sort" style="@style/main_tab_bottom"android:background="@drawable/item_sort_bg" /><RadioButton android:id="@+id/tab_item_mine" style="@style/main_tab_bottom"android:background="@drawable/item_mine_bg"/> <RadioButton android:id="@+id/tab_item_more" style="@style/main_tab_bottom" android:background="@drawable/item_more_bg" /></RadioGroup></LinearLayout></TabHost>其中有些控件的圖片點擊與正常情況下是不同的,如item_home_bg.xml文件
<?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/but_index_r_v2" /><item android:drawable="@drawable/but_index_v2"/> </selector>style文件在values文件夾下的styles.xml文件中定義
<?xml version="1.0" encoding="utf-8"?> <resources><style name="main_tab_bottom"><item name="android:gravity">center_horizontal</item><item name="android:layout_width">fill_parent</item><item name="android:layout_height">wrap_content</item><item name="android:button">@null</item><item name="android:layout_weight">1.0</item></style></resources>函數實現
public class MyTab extends TabActivity{private final static String TAG = "TabShow";private TabHost mHost;private RadioGroup tabItems;private RadioButton mineBut;@Overrideprotected void onCreate(Bundle savedInstanceState) {// TODO Auto-generated method stubsuper.onCreate(savedInstanceState);setContentView(R.layout.tablay);initResourceRefs();initSettings();}private void initSettings() {// TODO Auto-generated method stubtabItems.setOnCheckedChangeListener(new OnCheckedChangeListener() {@Overridepublic void onCheckedChanged(RadioGroup group, int checkedId) {// TODO Auto-generated method stubswitch(checkedId){case R.id.tab_item_home :mHost.setCurrentTabByTag("HOME");break;case R.id.tab_item_nearby :mHost.setCurrentTabByTag("NEAR");break;case R.id.tab_item_sort :mHost.setCurrentTabByTag("SORT");break; case R.id.tab_item_more :mHost.setCurrentTabByTag("MORE");break;}}});}private void initResourceRefs() {// TODO Auto-generated method stubmHost = getTabHost();mHost.addTab(mHost.newTabSpec("HOME").setIndicator("HOME").setContent(new Intent(this , HomeActivity.class)));mHost.addTab(mHost.newTabSpec("NEAR").setIndicator("NEAR").setContent(new Intent(this , NearByActivity.class)));mHost.addTab(mHost.newTabSpec("SORT").setIndicator("SORT").setContent(new Intent(this , SortActivity.class)));mHost.addTab(mHost.newTabSpec("My").setIndicator("My").setContent(new Intent(this , MyActivity.class)));mHost.addTab(mHost.newTabSpec("MORE").setIndicator("MORE").setContent(new Intent(this , MoreActivity.class)));tabItems = (RadioGroup)findViewById(R.id.tab_items);mineBut = (RadioButton)findViewById(R.id.tab_item_mine);}}效果如下
總結
以上是生活随笔為你收集整理的利用TabWidget实现底部菜单的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 利用caffe的python接口实现De
- 下一篇: javamail实现邮箱验证功能