说说tabhost和activitygroup
最近在做一个商店的Demo,看其他商店应用的界面,第一感觉用的tabhost,但是是选项卡在下方的tabhost,到最后发现用activitygroup更好些。下面就都说说。
tabhost下方,xml文件:
----------------------------------------------------------------------------------------------------------------------------------------------------------
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost" android:layout_width="fill_parent"
android:background="#808080FF" android:layout_height="fill_parent">
<LinearLayout android:orientation="vertical"
android:layout_width="fill_parent" android:layout_height="fill_parent">
<!-- 实现Tab标签的居底主要是通过设置属性 android:layout_weight="1" -->
<!-- 还要注意FrameLayout标签的位置,要写在TabWidget标签的前面 -->
<FrameLayout android:id="@android:id/tabcontent"
android:layout_weight="1" android:layout_width="fill_parent"
android:layout_height="fill_parent">
<ListView android:id="@+id/menu_listview"
android:layout_width="fill_parent" android:layout_height="wrap_content"
android:cacheColorHint="#00000000" android:choiceMode="singleChoice" />
<ListView android:id="@+id/classify_listview"
android:layout_width="fill_parent" android:layout_height="wrap_content"
android:cacheColorHint="#00000000" android:choiceMode="singleChoice" />
</FrameLayout>
<TabWidget android:id="@android:id/tabs"
android:layout_alignParentBottom="true" android:layout_width="fill_parent"
android:layout_height="wrap_content" />
</LinearLayout>
</TabHost>
------------------------------------------------------------------------------------------------------------------------------------------------------------
去掉tab控件下面的白线: mTabHost.setPadding(mTabHost.getPaddingLeft(),
mTabHost.getPaddingTop(), mTabHost.getPaddingRight(),
mTabHost.getPaddingBottom() - 5);
我做的这个demo,有四个选项卡,tab1,tab2,tab3,tab4.其中点击tab2后,界面显示的是一个listview,用的是activity1,点击listitem,进入界面2,但是要下面的tab选项卡也要显示。当时第一个问题是,跳转后如何让tab也显示。最后是这样解决的,activity1继承了activitygroup,这样显示的时候tab也能显示,但是另一个问题用来了,就是点击tab2选项卡的时候,跳不会activity1那个界面。这个问题我没有解决,就用了另一种方式,抛弃tabhost,用的是activitygroup。
首先主界面activity1继承activitygroup,界面布局文件如下:
我 是 分 割 线
------------------------------------------------------------------------------------------------------------------------------------------------------------
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="bottom"
android:background="@drawable/player_background"
android:id="@+id/parent">
<!--动态显示界面-->
<LinearLayout android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/body"
android:layout_weight="0.95">
</LinearLayout>
<!--底部功能菜单栏 -->
<LinearLayout
android:id="@+id/bottomlist"
android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="50dp"
android:layout_weight="0.05">
<LinearLayout
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:id="@+id/firstpage"
android:layout_weight="5"
android:gravity="center">
<TextView android:layout_width="wrap_content"
android:layout_height="20dp"
android:text="首页"
/>
</LinearLayout>
<LinearLayout
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:id="@+id/classify"
android:layout_weight="5"
android:gravity="center">
<TextView android:layout_width="wrap_content"
android:layout_height="20dp"
android:text="分类"
/>
</LinearLayout>
<LinearLayout
android:orientation="vertical"
android:layout_width="wrap_content"
android:id="@+id/search"
android:layout_height="fill_parent"
android:layout_weight="5"
android:gravity="center">
<TextView android:layout_width="wrap_content"
android:layout_height="20dp"
android:text="搜索"
/>
</LinearLayout>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="wrap_content"
android:id="@+id/menu"
android:layout_height="fill_parent"
android:layout_weight="5"
android:gravity="center">
<TextView android:layout_width="wrap_content"
android:layout_height="20dp"
android:text="菜单"
/>
</LinearLayout>
</LinearLayout>
</LinearLayout>
---------------------------------------------------------------------------------------------------------------------------------------------------------------
id为body的linearlayout用来加载每个选项卡对应的界面。
bodyView.removeAllViews();
bodyView.addView(getLocalActivityManager().startActivity(
"search", new Intent(ChinaUnion_GetWorld_Activity.this, Search.class))
.getDecorView());
同样,点击tab2时进入一个显示listview的activity2,这个activity2同样继承activitygroup(我也不知道是不是这样,但是效果的确是实现了),点击listitem时进入另一个activity3,做界面加载的时候还是用的:
activity1.bodyView.addView(getLocalActivityManager().startActivity(
"Module1",
new Intent(Classify.this, ChinaUnion_GetWorld_MusicList_Activity.class)
.addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP))
.getDecorView());
这样点击的时候都能顺利跳转。
上几张图吧最后。