重叠的碎片

19

我有一个带有3个选项卡的操作栏,每个选项卡都打开一个片段。第三个选项卡“目录”中有一个列表: enter image description here

当我点击一个项目时,它会打开另一个片段,该片段不是操作栏的一部分:

public void onClick(View v) {
    switch (v.getId())
    {
    case R.id.category1:    
        Fragment cosmeticsFragment = new ActivityCosmetics();
        FragmentTransaction transaction = getFragmentManager().beginTransaction();

        transaction.replace(android.R.id.content, cosmeticsFragment);
        transaction.addToBackStack(null);

        transaction.setTransition(1);

        transaction.commit();
        break;
        ...
这是操作后的效果图: enter image description here 从这一点开始,如果我切换到其他选项卡然后返回到目录选项卡,我会看到前面的2个片段重叠在一起: enter image description here 我该如何防止它发生?
4个回答

5
您可以通过标签搜索来管理您的碎片。当将碎片添加到返回堆栈时,请添加TAG名称。
transaction.addToBackStack("myCustomFragmentTag");

如果您想在应用程序的任何地方销毁Fragment:
Fragment previousInstance = getFragmentManager().findFragmentByTag("myCustomFragmentTag");
                if (previousInstance != null)
                    transaction.remove(previousInstance);

您可以尝试覆盖一些行为,以便这行代码将销毁已初始化的最后一个片段。
getFragmentManager().popBackStack(); 

我尝试按如下方式使用它:transaction.addToBackStack("CategoryFragment");,然后尝试在onResume和onTabReselected方法中使用其余的代码。但我仍然看到这些片段重叠... - Igal

5
将一个背景设置到片段布局中可以解决这个问题。

这应该是一个注释。 - ρяσѕρєя K
1
android:background="?android:colorBackground" - Dinesh Rajan
同时,你需要添加以下代码以防止点击事件传递给旧的碎片:android:clickable="true" - Dinesh Rajan
4
给碎片添加背景并不是正确的解决方案,这只是一种hack方法。 - Saran Sankaran

1

0

你可以尝试这样做来制作选项卡..

   public class Tabs extends TabActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_tabs);
    Resources res = getResources(); // Resource object to get Drawables
    TabHost tabHost = getTabHost();  // The activity TabHost
    TabHost.TabSpec spec;  // Resusable TabSpec for each tab
   // Intent intent;  // Reusable Intent for each tab
    // Create an Intent to launch an Activity for the tab (to be reused)
    Intent intent1 = new Intent().setClass(this, Social.class);
    // Initialize a TabSpec for each tab and add it to the TabHost
    spec = tabHost.newTabSpec("app_name").setIndicator("Practice",
                      res.getDrawable(R.drawable.tab_social))
                  .setContent(intent1);
    tabHost.addTab(spec);
    tabHost.getTabWidget().getChildAt(0).setBackgroundResource(R.drawable.bbgg);
    // Do the same for the other tabs
    Intent intent2 = new Intent().setClass(this, Web.class);
    spec = tabHost.newTabSpec("application").setIndicator("Application",
                      res.getDrawable(R.drawable.tab_web))
                  .setContent(intent2);
    tabHost.addTab(spec);
    tabHost.getTabWidget().getChildAt(1).setBackgroundResource(R.drawable.bbgg);
    Intent intent3 = new Intent().setClass(this, Catalog.class);
    spec = tabHost.newTabSpec("toplinks").setIndicator("Top Links",
                      res.getDrawable(R.drawable.tab_catalog))
                  .setContent(intent3);
    tabHost.addTab(spec);
    tabHost.getTabWidget().getChildAt(2).setBackgroundResource(R.drawable.bbgg);
    tabHost.setCurrentTab(0);
}
}
在你的布局xml中
    <TabHost 
xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent" 

  <LinearLayout 
android:id="@+id/LinearLayout01" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent"
android:orientation="vertical">
  <TabWidget 
android:id="@android:id/tabs" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content"></TabWidget>
 <FrameLayout 
android:id="@android:id/tabcontent" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent"></FrameLayout>
 </LinearLayout>
 </TabHost>

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