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

7
我正在尝试创建一个带有碎片的选项卡布局。当我在项目点击时添加另一个碎片,它应该显示在其上面。但我无法实现这个目标。碎片只是出现在现有的碎片上方,但两个碎片的内容都可见。请不要将任何开发者页面的链接扔过来解释。以下是我的代码: 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>

我正在 Sports_Fragment 中添加有关 list_item_click 的另一个片段

@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();
    }

这里是快照: 截图 非常感谢您的任何想法/帮助与解释。
谢谢!!

我正在尝试创建带有片段的标签布局 - 不要这样做。片段作为标签应该在运行时添加。 - user
@Luksprog 那么怎么做呢?有示例吗? - moDev
@droid dev 我已经实现了自定义的swipeTabs+viewpager而不是sherlockActionBar。如果你想要的话,我可以在这里发布解决方案...它很容易实现,但是问题在于你无法动态添加fragment。所以这取决于你。 - TheFlash
@Pratik 没问题。感谢你关注它。 - moDev
@droid dev,我想知道你的应用程序中是否已经实现了SherlockActionBar?我还没有尝试过,因为它很难集成到应用程序中。所以我的问题是,这个库怎么样?我的意思是它是否运行良好? - TheFlash
显示剩余2条评论
1个回答

10
首先,我认为值得一提的是...

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

请参见:

Android:无法用另一个片段替换一个片段

如何在单个选项卡内显示新片段?

这是解决方案。
在home_activity.xml中,您应该将tabcontent保留为空。
    <FrameLayout
        android:id="@+id/tabcontent"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1" />

您的主页活动

    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);
}

在你的onItemClick(Sports_Fragment)中添加以下内容。
MainActivity mainAct = (MainActivity)getActivity();
            mainAct.changeFragment();

我的完整项目基于你的代码,可以在这里找到:这里
我还没有机会仔细检查为什么在测试你的代码时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);

它可以工作,但当我切换回另一个选项卡时,它只是覆盖在当前片段上。 - moDev
如果在一个选项卡上有多个片段,那么如何使用后退按钮返回到先前的片段? - moDev
它能够工作... 但如果我设置 mHost.setCurrentTabByTag("Sports"); 它会重叠。有什么想法吗? - moDev
据我所知,setCurrentTabByTag不支持片段(您可以查看API源代码就会发现)。我们必须找到解决办法... - pt2121
嗨,我需要关于上述问题的帮助。目前,在尝试在同一布局中显示另一个片段时,片段会重叠。 - moDev
显示剩余3条评论

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接