【问题标题】:Change Fragment with ViewPager使用 ViewPager 更改片段
【发布时间】:2014-04-16 16:39:17
【问题描述】:

我正在为ViewPager 使用PagerSlidingTab 库。我想在滚动标签时更改片段。它工作正常。查看我的代码。

我在每个 Fragment 上使用 AsynTask()
当应用程序使用 MainActivity 打开时,第一个 Fragment 附加到 Activity,但它显示两个 AsynTask() 对话框消息,一个来自 First,另一个来自 Second Fragment。当我滚动到第二个选项卡时,它显示第三个Fragment 的对话框消息。

因此,如果我在选项卡中从左向右滚动,则会显示Fragment 右侧到当前片段,如果我从右向左滚动,则会显示Fragment 左侧到当前Fragment

请帮我解决问题。

我的代码:

public class PageSlidingTabStripFragment extends Fragment {

    public static final String TAG = PageSlidingTabStripFragment.class
            .getSimpleName();

    public static PageSlidingTabStripFragment newInstance() {
        return new PageSlidingTabStripFragment();
    }

    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setRetainInstance(true);
    }

    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        return inflater.inflate(R.layout.pager, container, false);
    }

    @Override
    public void onViewCreated(View view, Bundle savedInstanceState) {
        super.onViewCreated(view, savedInstanceState);

        PagerSlidingTabStrip tabs = (PagerSlidingTabStrip) view
                .findViewById(R.id.tabs);
        ViewPager pager = (ViewPager) view.findViewById(R.id.pager);

        MyPagerAdapter adapter = new MyPagerAdapter(getChildFragmentManager());

        pager.setAdapter(adapter);
        tabs.setViewPager(pager);
    }

    public class MyPagerAdapter extends FragmentPagerAdapter {

        public MyPagerAdapter(android.support.v4.app.FragmentManager fm) {
            super(fm);
        }

        private final String[] TITLES = { "Instant Opportunity", "Events",
                "Experts" };

        @Override
        public CharSequence getPageTitle(int position) {
            return TITLES[position];
        }

        @Override
        public int getCount() {
            return TITLES.length;
        }

        @Override
        public Fragment getItem(int position) {
            switch (position) {
            case 0:
                return new InstantOpportunity();
            case 1:
                return new Events();
            case 2:
                return new Experts();
            default:
                break;
            }

            return null;
        }
    }
}

【问题讨论】:

    标签: android android-fragments pagerslidingtabstrip


    【解决方案1】:

    说明:

    事实证明,对于不涉及其他库的可滚动标签有一个更简单的实现。您可以使用直接来自默认 SDK 的普通 Android 代码轻松地在您的应用中实现选项卡。

    代码

    主类:

    public class PageSlidingTabStripFragment extends Fragment {
    
        //Variables
        private ViewPager viewPager;
        private PagerTitleStrip pagerTitleStrip;
    
        public PageSlidingTabStripFragment() {
            // Required empty public constructor
        }
    
        @Override
        public void onViewCreated(View view, Bundle savedInstanceState) {
            super.onViewCreated(view, savedInstanceState);
        }
    
        @Override
        public void onActivityCreated(Bundle savedInstanceState) {
    
            super.onActivityCreated(savedInstanceState);
    
            //Find your pager declared in XML
            viewPager = (ViewPager) getView().findViewById(R.id.pager);
    
            //Set the viewPager to a new adapter (see below)
            viewPager.setAdapter(new MyAdapter(getFragmentManager()));
    
            //If your doing scrollable tabs as opposed to fix tabs,
            //you need to find a pagerTitleStrip that is declared in XML
            //just like the pager
            pagerTitleStrip = (PagerTitleStrip)
                getView().findViewById(R.id.pager_title_strip);
    
        }
    
        @Override
        public View onCreateView(LayoutInflater inflater, ViewGroup container,
                             Bundle savedInstanceState) {
            // Inflate the layout for this fragment
            return inflater.inflate(R.layout.[your layout name here], container, false);
        }
    
    }
    

    适配器:

    //Note: this can go below all of the previous code. Just make sure it's
    //below the last curly bracket in your file!
    class MyAdapter extends FragmentStatePagerAdapter {
    
        public MyAdapter(FragmentManager fm) {
            super(fm);
        }
    
        @Override
        public Fragment getItem(int arg0) {
            Fragment fragment = null;
            if (arg0 == 0) {
                fragment = new InstantOpportunity();
            }
            if (arg0 == 1) {
                fragment = new Events();
            }
            if (arg0 == 2) {
                fragment = new Experts();
            }
            return fragment;
        }
    
        @Override
        public int getCount() {
            return 3;
        }
    
        @Override
        public CharSequence getPageTitle(int position) {
            if (position == 0) {
                return "Instant Opportunity";
            }
            if (position == 1) {
                return "Events";
            }
            if (position == 2) {
                return "Experts";
            }
            return null;
        }
    }
    

    结论:

    我希望这可以帮助您了解制作可滚动标签的另一种方法!我的 Github 页面上有关于如何制作每种类型(固定或可滚动)的示例。

    链接:

    1. 固定标签示例 - Click Here
    2. 可滚动标签示例 - Click Here

    希望这会有所帮助!

    编辑:

    当询问要导入什么时,请确保您选择了 V4 支持片段。

    【讨论】:

    【解决方案2】:

    请使用这个例子。它很简单。我已经实现了。

    reference link

    希望它对你有用。它是 pager-sliding-tabstrip 的最佳示例。

    使用

    framelayout compulsory:
    FrameLayout fl = new FrameLayout(getActivity());
            fl.addView(urFragementView);
    

    然后在这个框架布局中设置你的片段视图。

    【讨论】:

    • 感谢您的回复,但这里我使用的是使用 PagerTabStrip 的导航滑块,所以我不能使用那个东西。我已经试过了。
    • 我的代码几乎是一样的,但是它们显示的是 textview,你有没有我打开片段而不是那个的示例?
    • 没有错误,如果我显示 textview 那就没问题了。像这样:FrameLayout fl = new FrameLayout(getActivity()); fl.setLayoutParams(params); fl.setView(textview); 但在这里,我想打开片段...
    • urFragementView 代表 ?
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2016-11-03
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多