android 仿Iphone底部 tab效果
如果你是android初学者,以前做过javaEE开发,或者说你有java基础。那么你学完了android 四大组件。就可以来看看这篇文章了。
四大组件我就不说了 网上一大把的文章 ,四大组件包括activity service Content Providers Intent
如果这篇文章你理解了,加上会xml解析 Json解析(json解析比xml更快,推荐大家以后使用json)就可以去面试android开发了
按钮放在底部是使用TabHost实现的。TabHost可以放在顶部 也可以放在底部。我之前已经发过三篇关于TabHost的文章
如果有不懂的 可以留言给我 ,也可以去看看我之前的三篇文章。 和这里相反的一篇文章是http://blog.****.net/sun6223508/article/details/6617545
转帖请注明出处http://blog.****.net/sun6223508
MainActivity.java
- publicclassMainActivityextendsTabActivity{
- privateRadioGroupgroup;
- privateTabHosttabHost;
- publicstaticfinalStringTAB_HOME="tabHome";
- publicstaticfinalStringTAB_MES="tabMes";
- publicstaticfinalStringTAB_TOUCH="tab_touch";
- @Override
- protectedvoidonCreate(BundlesavedInstanceState){
- //TODOAuto-generatedmethodstub
- super.onCreate(savedInstanceState);
- setContentView(R.layout.maintabs);
- group=(RadioGroup)findViewById(R.id.main_radio);
- tabHost=getTabHost();
- tabHost.addTab(tabHost.newTabSpec(TAB_HOME).setIndicator(TAB_HOME)
- .setContent(newIntent(this,Main.class)));
- tabHost.addTab(tabHost.newTabSpec(TAB_MES).setIndicator(TAB_MES)
- .setContent(newIntent(this,Main2.class)));
- tabHost.addTab(tabHost.newTabSpec(TAB_TOUCH).setIndicator(TAB_TOUCH)
- .setContent(newIntent(this,Main.class)));
- group.setOnCheckedChangeListener(newOnCheckedChangeListener(){
- publicvoidonCheckedChanged(RadioGroupgroup,intcheckedId){
- switch(checkedId){
- caseR.id.radio_button0:
- tabHost.setCurrentTabByTag(TAB_HOME);
- break;
- caseR.id.radio_button1:
- tabHost.setCurrentTabByTag(TAB_MES);
- break;
- caseR.id.radio_button2:
- tabHost.setCurrentTabByTag(TAB_TOUCH);
- break;
- default:
- break;
- }
- }
- });
- }
- }
maintabs.xml
- <?xmlversion="1.0"encoding="UTF-8"?>
- <TabHostandroid:id="@android:id/tabhost"android:layout_width="fill_parent"
- android:layout_height="fill_parent"xmlns:android="http://schemas.android.com/apk/res/android">
- <LinearLayoutandroid:orientation="vertical"
- android:layout_width="fill_parent"android:layout_height="fill_parent">
- <FrameLayoutandroid:id="@android:id/tabcontent"
- android:layout_width="fill_parent"android:layout_height="0.0dip"
- android:layout_weight="1.0"/>
- <TabWidgetandroid:id="@android:id/tabs"android:visibility="gone"
- android:layout_width="fill_parent"android:layout_height="wrap_content"
- android:layout_weight="0.0"/>
- <RadioGroupandroid:gravity="center_vertical"
- android:layout_gravity="bottom"android:orientation="horizontal"
- android:id="@+id/main_radio"android:background="@drawable/home_btn_bg"
- android:layout_width="fill_parent"android:layout_height="wrap_content">
- <RadioButtonandroid:id="@+id/radio_button0"android:tag="radio_button0"
- android:layout_marginTop="2.0dip"android:text="@string/main_home"android:background="@drawable/home_btn_bg"
- android:drawableTop="@drawable/icon_1_n"style="@style/main_tab_bottom"/>
- <RadioButtonandroid:id="@+id/radio_button1"android:tag="radio_button1"
- android:layout_marginTop="2.0dip"android:text="@string/main_message"android:background="@drawable/home_btn_bg"
- android:drawableTop="@drawable/icon_2_n"style="@style/main_tab_bottom"/>
- <RadioButtonandroid:id="@+id/radio_button2"android:tag="radio_button2"
- android:layout_marginTop="2.0dip"android:text="@string/main_comment"android:background="@drawable/home_btn_bg"
- android:drawableTop="@drawable/icon_3_n"style="@style/main_tab_bottom"/>
- </RadioGroup>
- </LinearLayout>
- </TabHost>
最关键就是上面这个XML了。它调用系统的tabhost
main.java
- publicclassMainextendsActivity{
- /**Calledwhentheactivityisfirstcreated.*/
- @Override
- publicvoidonCreate(BundlesavedInstanceState){
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- }
- }
main.xml
- <?xmlversion="1.0"encoding="utf-8"?>
- <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"android:layout_width="fill_parent"
- android:layout_height="fill_parent">
- <ImageViewandroid:text="@+id/Button01"android:id="@+id/Button01"
- android:layout_width="wrap_content"android:layout_height="wrap_content"
- android:background="@drawable/sfsd"></ImageView>
- </LinearLayout>
- publicclassMain2extendsActivity{
- @Override
- protectedvoidonCreate(BundlesavedInstanceState){
- //TODOAuto-generatedmethodstub
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main2);
- }
- }
- <?xmlversion="1.0"encoding="utf-8"?>
- <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- >
- <ImageViewandroid:text="@+id/Button01"android:id="@+id/Button01"
- android:layout_width="wrap_content"android:layout_height="wrap_content"
- android:background="@drawable/dsfdsfds"></ImageView>
- </LinearLayout>
最关键的就是MainActivity.java这个文件 和它的layout