Fragment遮挡住TabLayout,怎么办?

发布于 2022-09-02 10:06:17 字数 4290 浏览 27 评论 0

我想做一个顶部tab的ViewPager搭配FragmentPagerAdapter,但是写出来的效果很奇怪,Fragment的界面会整个挡住TabLayout。
如图:
clipboard.png

我的代码如下:
其中一个Fragment

 public class FragmentA extends Fragment {
    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.frag_a,container,false);
        TextView textView = (TextView) view.findViewById(R.id.tvA);
        textView.setText("这个就是踌躇满志");
        return view;
    }
}

它所对应的XML

    <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1">
    <TextView
        android:id="@+id/tvA"
        android:textSize="30sp"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
</LinearLayout>

这是MainActivity:
public class MainActivity extends AppCompatActivity {
private TabLayout tabLayout;                            //定义TabLayout
private ViewPager viewPager;                             //定义viewPager
private ViewPagerAdapter pagerAdapter;                               //定义adapter

private List<Fragment> fragments;                                //定义要装fragment的列表
private String[] titles = new String[]{"踌躇满志","混吃等死","吾日三省"};                                     //tab名称数组


@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
    fab.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG)
                    .setAction("Action", null).show();
        }
    });
    initView();
}

private void initView() {
    viewPager = (ViewPager) findViewById(R.id.vp);
    tabLayout = (TabLayout) findViewById(R.id.tl);
    fragments = new ArrayList<>();
    Fragment fragmentA = new FragmentA();
    Fragment fragmentW = new FragmentW();
    Fragment fragmentR = new FragmentR();
    fragments.add(fragmentA);
    fragments.add(fragmentW);
    fragments.add(fragmentR);
    pagerAdapter = new ViewPagerAdapter(getSupportFragmentManager(),fragments,titles);
    tabLayout.setTabMode(TabLayout.MODE_FIXED);
    viewPager.setAdapter(pagerAdapter);
    tabLayout.setupWithViewPager(viewPager);
}
........

这是主布局:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="vertical"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.izp.tablayout.MainActivity"
    tools:showIn="@layout/activity_main">

    <android.support.design.widget.TabLayout
        android:id="@+id/tl"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@color/tabBlue"
        app:tabIndicatorColor="@color/indicatorWhite"
        app:tabSelectedTextColor="@color/indicatorGray"
        app:tabTextColor="@color/indicatorWhite"/>
    <android.support.v4.view.ViewPager
        android:id="@+id/vp"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />
</LinearLayout>

同样的Fragment及其布局使用同样的代码,TabLayout替换成第三方的indicator则不会有此问题。
下面是布局和Fragment都没有改,替换indicator之后的截图:

clipboard.png

求大神给小白解惑,我是更喜欢用TabLayout的毕竟设置样式不用到style里面去改,很方便。有大神遇到过这个问题么?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

玉环 2022-09-09 10:06:17

自问自答,当时我是通过把TabLayout设置在AppBarLayout里面来解决这个问题的。

余罪 2022-09-09 10:06:17

你把app:layout_behavior="@string/appbar_scrolling_view_behavior"去掉试试

零時差 2022-09-09 10:06:17

你的最外层是linearlayout,不需要behavior

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文