动态添加Fragment

//-----------------------------------------xml布局--------------------------------------------

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:orientation="vertical"
    android:layout_height="match_parent">

        <android.support.design.widget.TabLayout
            android:id="@+id/tab"
            app:tabMode="scrollable"
            android:layout_width="match_parent"
             android:layout_height="wrap_content">

        </android.support.design.widget.TabLayout>

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

    </android.support.v4.view.ViewPager>
</LinearLayout>

//---------------------------------------------主页面-----------------------------------------------------------
lic class Frag1 extends Fragment {
    private TabLayout tabLayout;
    private ViewPager viewpager;
    private ArrayList<String> list;

    @Nullable
    @Override
    public View onCreateView(@NonNull LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.frag1, null, false);
        //控件
        tabLayout = view.findViewById(R.id.tab);
        viewpager = view.findViewById(R.id.pager);

        //tab的标题

        list = new ArrayList<>();
        list.add("关注");
        list.add("推荐");
        list.add("热点");
        list.add("上海");
        list.add("视频");
        list.add("新时代");
        list.add("国风");
        //Viewpager要展示页面...设置适配器
        //初始化fragment页面适配器 =》new FragmentPagerAdapter
        //获取fragment 管理器=》getSupportFragmentManager
        //getpagetitle 获取当前页面显示的标题是tab对应的标题 position 当前页面的标志
        //getItem 获取当前位置对应的fragment
        viewpager.setAdapter(new FragmentPagerAdapter(getActivity().getSupportFragmentManager()) {
            //得到当前页的标题,,,也就是设置当前页面显示的标题是tab对应的标题
            @Override
            public CharSequence getPageTitle(int position) {
                return list.get(position);
            }

            @Override
            public Fragment getItem(int position) {

                //初始化fragment  对应position有多少,fragment有多少
                NewsFragment newsFragment = new NewsFragment();
                //初始化bundle (数据盒子,装数据元素)
                Bundle bundle = new Bundle();
                bundle.putInt("position", position);
                bundle.putString("list", list.get(position));
                newsFragment.setArguments(bundle);
                return newsFragment;
            }

            @Override
            public int getCount() {
                return list.size();
            }
        });
        //tablayout要与viewpager关联
        tabLayout.setupWithViewPager(viewpager);


        return view;
    }

}
//------------------------------------新建的fragment-------------------------------------------------------

public class NewsFragment extends Fragment {

    int mPosition;
    String mTitle = "";
    private TextView text;

    //private String mstrings;
     @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
        View view = inflater.inflate(R.layout.news_layout, container, false);
         mPosition = getArguments().getInt("position");
         mTitle = getArguments().getString("list");
        //可有可无的两个东西
        // text = view.findViewById(R.id.text);
        // text.setText("第" + mPosition + "个fragment==" + mTitle);

        return view;
    }








}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值