【问题标题】:Dynamically replace fragment when using tablayout and viewpager in android在android中使用tablayout和viewpager时动态替换片段
【发布时间】:2015-10-21 06:35:14
【问题描述】:

在过去的几天里,我一直在努力寻找解决这个问题的方法: 我有一个包含选项卡布局和视图寻呼机的活动。视图寻呼机使用适配器填充片段。标签是用这个 viewpager 创建的并且是固定的。我的问题是如何动态更改选项卡的布局(例如单击按钮后)?

这是xml文件

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:orientation="vertical">

<LinearLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">
    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="?attr/colorPrimary"
        android:theme="@style/ThemeOverlay.AppCompat.Dark" />
    <android.support.design.widget.TabLayout
        android:id="@+id/tablayout"
        android:layout_width="match_parent"
        android:layout_height="65dp"
        android:background="@color/white"
        app:tabMode="fixed"
        app:tabGravity="fill"
        android:theme="@style/ThemeOverlay.AppCompat.Dark" />

    <android.support.v4.view.ViewPager
        android:id="@+id/viewpager"
        android:layout_width="match_parent"
        android:layout_height="0dp"
        android:layout_weight="1"/>
</LinearLayout>

这是活动

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

    setupToolbar();

    viewPager = (ViewPager) findViewById(R.id.viewpager);
    setupViewPager(viewPager);

    TabLayout tabLayout = (TabLayout) findViewById(R.id.tablayout);
    setupTabLayout(tabLayout);
}

private void setupToolbar(){
   ...
}


public void setupViewPager(ViewPager viewPager) {
    pageAdapter = new FragmentPageAdapter(getApplicationContext(), getSupportFragmentManager());
    pageAdapter.addFragment(ContentFragment.newInstance(), "Following", R.drawable.following);
    pageAdapter.addFragment(ContentFragment.newInstance(), "Discover", R.drawable.flower);
    pageAdapter.addFragment(ContentFragment.newInstance(), "", R.drawable.camera);
    pageAdapter.addFragment(ProfileFragment.newInstance(), "Profile", R.drawable.profile);
    pageAdapter.addFragment(ContentFragment.newInstance(), "Task List", R.drawable.list);
    viewPager.setAdapter(pageAdapter);
}

public void setupTabLayout(TabLayout tabLayout) {
    try {
        tabLayout.setupWithViewPager(viewPager);
        for (int i = 0; i < tabLayout.getTabCount(); i++) {
            TabLayout.Tab tab = tabLayout.getTabAt(i);
            tab.setCustomView(pageAdapter.getTabView(i));
        }
        tabLayout.requestFocus();
    }
    catch(Exception ex){
        Log.e("errr2", ex.getMessage());
    }
}

这是适配器

public class FragmentPageAdapter extends FragmentStatePagerAdapter {
    private Context mContext;
private List<Fragment> mFragments = new ArrayList<>();
private List<String> mFragmentTitles = new ArrayList<>();
private List<Integer> mFragmentIcons = new ArrayList<>();

public FragmentPageAdapter(Context context, FragmentManager fm) {
    super(fm);
    this.mContext = context;
}

public void addFragment(Fragment fragment, String title, int drawable) {
    mFragments.add(fragment);
    mFragmentTitles.add(title);
    mFragmentIcons.add(drawable);
}



@Override
public Fragment getItem(int position) {

    return mFragments.get(position);
}


@Override
public int getItemPosition(Object object)
{
    return POSITION_UNCHANGED;
}

@Override
public int getCount() {
    return mFragments.size();
}

@Override
public CharSequence getPageTitle(int position) {
    return mFragmentTitles.get(position);
}

public View getTabView(int position) {
    View tab = LayoutInflater.from(mContext).inflate(R.layout.tabbar_view, null);
    TextView tabText = (TextView) tab.findViewById(R.id.tabText);
    ImageView tabImage = (ImageView) tab.findViewById(R.id.tabImage);
    tabText.setText(mFragmentTitles.get(position));
    tabImage.setBackgroundResource(mFragmentIcons.get(position));
    if (position == 3) {
        tab.setSelected(true);
    }
    return tab;
}

}

替换片段的正常方法是调用

  fragmentManager.beginTransaction().replace(placeholderId, editPrifileFragment).commit();

但是在这种情况下我应该为 placeholderId 使用什么?因为在活动布局中我没有片段的占位符,只有一个viewpager。 那么如何动态替换片段并保留后退按钮功能? 我搜索了很多,发现了一些 hacky 解决方案,但我认为这是一种非常常见的情况,应该有更好的解决方案。 谢谢。

【问题讨论】:

  • 你找到解决这个问题的方法了吗?我花了一个星期尝试一切,但没有结果。提前致谢。

标签: android android-fragments android-viewpager android-tablayout


【解决方案1】:

您的ViewPager Fragment 应该持有placeholderId。 所以在你的Fragment(它是ViewPager的一部分)中,你可以像往常一样调用getChildFragmentManager()来添加Fragment

childFragmentManager.beginTransaction().add(placeholderId, editPrifileFragment).addToBackStack(null).commit();

【讨论】:

  • 感谢您的回复,但是当我尝试时它不起作用。我还尝试删除片段,然后使用以下代码添加新片段:fragmentTransaction.remove(ProfileFragment.this).addToBackStack(null).commit();它可以工作并删除片段,但添加新片段不起作用:fragmentTransaction.add(R.id.layout, editPrifileFragment, "df").addToBackStack(null).commit();这是为什么呢?
猜你喜欢
  • 1970-01-01
  • 2021-05-08
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-24
  • 1970-01-01
  • 2013-01-31
相关资源
最近更新 更多