如何在现有片段上添加另一个片段?

时间:2013-05-23 14:37:35

标签: android fragment

我正在尝试创建tab layout with fragments。当我在项目上添加另一个片段时,它应该在它上面显示另一个片段。我无法达到目标。片段刚好超过现有片段,但片段内容都可见。请不要将链接抛向任何开发者页面以获得解释。

这是我的代码

home_activity.xml

<TabHost
    android:id="@android:id/tabhost"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_alignParentBottom="true" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >

        <TabWidget
            android:id="@android:id/tabs"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" >
        </TabWidget>

        <FrameLayout
            android:id="@android:id/tabcontent"
            android:layout_width="match_parent"
            android:layout_height="match_parent" >

            <fragment
                android:id="@+id/tab1"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                class="com.example.tabsfragment.School_Fragment" >
            </fragment>

            <fragment
                android:id="@+id/tab2"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                class="com.example.tabsfragment.Sports_Fragment" >
            </fragment>
        </FrameLayout>
    </LinearLayout>
</TabHost>

Home_Activity.java

public class Home_Activity extends FragmentActivity {

TabHost mHost;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.home_activity);

    mHost = (TabHost) findViewById(android.R.id.tabhost);

    mHost.setup();

    TabSpec schoolSpec = mHost.newTabSpec("School").setIndicator("School")
            .setContent(R.id.tab1);
    mHost.addTab(schoolSpec);

    TabSpec sportSpec = mHost.newTabSpec("Sports").setIndicator("Sportss")
            .setContent(R.id.tab2);
    mHost.addTab(sportSpec);

    mHost.setCurrentTab(1);

}

entertainment.xml

<FrameLayout
    android:id="@+id/frameContainer"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />
</FrameLayout>

我在list_item_click

Sports_Fragment添加了另一个片段
@Override
    public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) {
        // TODO Auto-generated method stub

        FragmentTransaction ft = getFragmentManager().beginTransaction();
        Entertainment_Fragment enFragment = new Entertainment_Fragment();
        ft.replace(android.R.id.tabcontent, enFragment);
        ft.commit();
    }

以下是快照:

Screenshot

任何有关解释的想法/帮助都将受到高度赞赏。

谢谢!

1 个答案:

答案 0 :(得分:9)

首先,我认为值得一提......

  

“您无法替换布局文件中静态定义的片段。您只能替换通过FragmentTransaction动态添加的片段”

请参阅

Android: can't replace one fragment with another

How can I show a new Fragment within a single tab?

这是解决方案。

在home_activity.xml中,您应该将tabcontent留空。

    <FrameLayout
        android:id="@+id/tabcontent"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1" />

您的Home_Activity

    private FragmentTabHost mHost;

public void changeFragment() {
    FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
    EntertainmentFragment enFragment = new EntertainmentFragment();
    ft.replace(R.id.tabcontent, enFragment);
    ft.commit();
}

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mHost = (FragmentTabHost) findViewById(android.R.id.tabhost);
    mHost.setup(this, getSupportFragmentManager(), R.id.tabcontent);
    mHost.addTab(mHost.newTabSpec("School")
            .setIndicator("School"), SchoolFragment.class, null);
    mHost.addTab(mHost.newTabSpec("Sport")
            .setIndicator("Sport"), SportsFragment.class, null);
}

在onIemClick(Sports_Fragment)中,添加此

MainActivity mainAct = (MainActivity)getActivity();
            mainAct.changeFragment();

我的完整项目(基于您的代码)为here

我测试你的代码时,我没有机会真正检查为什么TabHost不起作用。 但是FragmentTabHost对我来说很好。

编辑:要解决重叠问题,可以设置OnTabChangeListener:

mHost.setOnTabChangedListener(new TabHost.OnTabChangeListener() {

        @Override
        public void onTabChanged(String tabId) {
            // TODO Auto-generated method stub
            if (tabId.equalsIgnoreCase("School")) {
                Log.v(TAG, "school");
                FragmentTransaction ft = getSupportFragmentManager()
                        .beginTransaction();
                schoolFrag = new SchoolFragment();
                ft.replace(R.id.tabcontent, schoolFrag);
                ft.commit();
            }
            if (tabId.equalsIgnoreCase("Sport")) {
                Log.v(TAG, "Sport");
                FragmentTransaction ft = getSupportFragmentManager()
                        .beginTransaction();
                SportsFragment sportFrag = new SportsFragment();
                ft.replace(R.id.tabcontent, sportFrag);
                ft.commit();
            }
        }

    });

关于背压,你可以尝试

ft.addToBackStack(null);