底部Tab+FrameLayout嵌套CoordinatorLayout+Viewpager切换时布局错乱

顶部伸缩效果

现在要实现这么一个效果,有一个标题栏(或者其他控件),下面是tablayout+viewpager,然后在viewpager里面的内容滑动的时候tab悬浮,有点像微博热搜的界面

向下滑动之前

向下滑动之前

向下滑动之后

向下滑动之后

CoordinatorLayout实现头部布局滑动时隐藏

在5.0之后,Google推出了一系列md控件,其中用的最多的就是CoordinatorLayout,它可以实现很酷炫的粘连效果,伸缩控件,直接上代码:

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    android:orientation="vertical">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="@drawable/en_title_bg"
        app:layout_behavior="包名.FlingBehavior"
        android:fitsSystemWindows="true">

        <android.support.design.widget.CollapsingToolbarLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:layout_scrollFlags="scroll|exitUntilCollapsed"
            app:titleEnabled="false">

            <include layout=
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
好的,可以按照以下步骤来实现: 1. 在布局文件添加一个FrameLayout作为容器,用于显示不同的Fragment: ```xml <FrameLayout android:id="@+id/container" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 2. 在布局文件添加一个LinearLayout作为Tab栏,用于切换不同的Fragment: ```xml <LinearLayout android:id="@+id/tab_layout" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="horizontal"> <Button android:id="@+id/tab1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Tab1" /> <Button android:id="@+id/tab2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Tab2" /> <Button android:id="@+id/tab3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Tab3" /> </LinearLayout> ``` 3. 在Activity获取Tab栏的Button并设置点击事件: ```java Button tab1 = findViewById(R.id.tab1); Button tab2 = findViewById(R.id.tab2); Button tab3 = findViewById(R.id.tab3); tab1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 切换Tab1对应的Fragment } }); tab2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 切换Tab2对应的Fragment } }); tab3.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { // 切换Tab3对应的Fragment } }); ``` 4. 创建三个Fragment,分别对应三个Tab: ```java public class Tab1Fragment extends Fragment { // 实现Tab1对应的布局和逻辑 } public class Tab2Fragment extends Fragment { // 实现Tab2对应的布局和逻辑 } public class Tab3Fragment extends Fragment { // 实现Tab3对应的布局和逻辑 } ``` 5. 在Activity实现Tab切换逻辑,将对应的Fragment添加到FrameLayout: ```java private void switchTab(Fragment fragment) { FragmentManager fragmentManager = getSupportFragmentManager(); FragmentTransaction transaction = fragmentManager.beginTransaction(); transaction.replace(R.id.container, fragment); transaction.commit(); } tab1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { switchTab(new Tab1Fragment()); } }); tab2.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { switchTab(new Tab2Fragment()); } }); tab3.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { switchTab(new Tab3Fragment()); } }); ``` 6. 在Tab对应的Fragment实现列表布局,例如使用RecyclerView或ListView: ```java public class Tab1Fragment extends Fragment { private RecyclerView mRecyclerView; private MyAdapter mAdapter; private List<String> mDataList = new ArrayList<>(); @Override public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) { View view = inflater.inflate(R.layout.fragment_tab1, container, false); mRecyclerView = view.findViewById(R.id.recycler_view); mRecyclerView.setLayoutManager(new LinearLayoutManager(getActivity())); mAdapter = new MyAdapter(mDataList); mRecyclerView.setAdapter(mAdapter); return view; } private class MyAdapter extends RecyclerView.Adapter<MyViewHolder> { private List<String> mDataList; public MyAdapter(List<String> dataList) { mDataList = dataList; } @Override public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_layout, parent, false); return new MyViewHolder(view); } @Override public void onBindViewHolder(MyViewHolder holder, int position) { holder.mTextView.setText(mDataList.get(position)); } @Override public int getItemCount() { return mDataList.size(); } } private class MyViewHolder extends RecyclerView.ViewHolder { public TextView mTextView; public MyViewHolder(View itemView) { super(itemView); mTextView = itemView.findViewById(R.id.text_view); } } } ``` 以上就是基于Button和FrameLayout实现Tab和列表的示例,希望对你有所帮助。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值