查看分页器在切换到片段选项卡主机中的选项卡时丢失了其内容

时间:2014-12-31 07:47:22

标签: android android-fragments tabs android-viewpager fragmentstatepageradapter

我正面临着一个非常奇怪的问题,我在网上发现了类似的问题,但没有一个解决方案可以帮助我摆脱这个问题。

问题::

我有一个有3个标签的片段,(使用片段标签主机创建标签)。现在每个标签都有不同的片段。

从第一个标签页面,我设置了一个片段,其中我使用了视图寻呼机和圆形页面指示器来显示带点的图像(圆圈)。

现在,当我将图像从第1个扫描到第2个然后第3个,依此类推,它可以正常工作。 但是在到达第2张图像后,当我点击tab2并再次回到tab1时,我的图像丢失了。

您的指导或任何帮助/链接将不胜感激..
很多人都提前感谢。

为了您的理解,我在下面发布代码::

FragmentwithTabHost ::

public class FragmentwithTabHost extends Fragment{

    private View rootView;
     private FragmentTabHost mTabHost;
     private Context mContext;
    public FragmentwithTabHost() {
    }

    public FragmentwithTabHost(Context ctx) {
        mContext=getActivity();
    }
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        rootView = inflater.inflate(R.layout.mycardswithtabs, container,
                false);

        mTabHost = (FragmentTabHost) rootView.findViewById(android.R.id.tabhost);

        mTabHost.setup(getActivity(), getChildFragmentManager(), android.R.id.tabcontent);
        mTabHost.setBackground(getActivity().getResources().getDrawable(R.drawable.normal));
        mTabHost.addTab(
                mTabHost.newTabSpec("tab1").setIndicator("tab1", null),
                Fragment1.class, null);
        mTabHost.addTab(
                mTabHost.newTabSpec("tab2").setIndicator("tab2", null),
                Fragment2.class, null);
        mTabHost.addTab(
                mTabHost.newTabSpec("tab3").setIndicator("tab3", null),
                Fragment3.class, null);
        return rootView;
    }
}

Fragment1 ::

public class Fragment1 extends Fragment{

    //  private Context mContext;
    private View rootView;

    SlidesFragmentAdapter mAdapter;
    ViewPager mPager;
    PageIndicator mIndicator;
    LinearLayout llSponseredImage,llSponserdByText;
    ImageView imgsponser1,imgsponser2,imgsponser3,imgsponser4;
    public Fragment1() {
    }
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container,
            Bundle savedInstanceState) {
        rootView = inflater.inflate(R.layout.my_card, container,false);

        mAdapter = new SlidesFragmentAdapter(getActivity()
                .getSupportFragmentManager());

        llSponseredImage=(LinearLayout)rootView.findViewById(R.id.mycardbottomViewSponseredImage);
        llSponserdByText=(LinearLayout)rootView.findViewById(R.id.mycardbottomsponsredby);

        imgsponser1=(ImageView)rootView.findViewById(R.id.imgsponser1);
        imgsponser2=(ImageView)rootView.findViewById(R.id.imgsponser2);
        imgsponser3=(ImageView)rootView.findViewById(R.id.imgsponser3);
        imgsponser4=(ImageView)rootView.findViewById(R.id.imgsponser4);

        mPager = (ViewPager) rootView.findViewById(R.id.pager);
        mPager.setOffscreenPageLimit(4);
        mPager.setClipToPadding(false);
        mPager.setPageMargin(12);
        mPager.setAdapter(mAdapter);

        mIndicator = (CirclePageIndicator) rootView.findViewById(R.id.indicator);
        mIndicator.setViewPager(mPager);
        ((CirclePageIndicator) mIndicator).setSnap(true);

        mPager.setOnClickListener(new OnClickListener() {
            @Override
            public void onClick(View v) {
                System.out.println("3242353652523");
                MyCardsWithOffersFragment myCardsWithOffersFragment=new MyCardsWithOffersFragment();
            }
        });
        mIndicator
        .setOnPageChangeListener(new ViewPager.OnPageChangeListener() {
            @Override
            public void onPageSelected(int position) {
                /*Toast.makeText(getActivity(),
                        "Changed to page " + position,
                        Toast.LENGTH_SHORT).show();*/
                if(position==0 || position==2){
                    llSponseredImage.setVisibility(View.GONE);
                    llSponserdByText.setVisibility(View.GONE);
                }else if(position==1){
                    llSponseredImage.setVisibility(View.VISIBLE);
                    llSponserdByText.setVisibility(View.VISIBLE);

                    imgsponser1.setImageResource(R.drawable.sponser1);
                    imgsponser2.setImageResource(R.drawable.sponser2);
                    imgsponser3.setImageResource(R.drawable.sponser3);
                    imgsponser4.setImageResource(R.drawable.sponser4);
                }else if(position==3){
                    llSponseredImage.setVisibility(View.VISIBLE);
                    llSponserdByText.setVisibility(View.VISIBLE);

                    imgsponser1.setImageResource(R.drawable.sponser5);
                    imgsponser2.setImageResource(R.drawable.sponser6);
                    imgsponser3.setImageResource(R.drawable.sponser7);
                    imgsponser4.setImageResource(R.drawable.sponser8);
                }
            }

            @Override
            public void onPageScrolled(int position,
                    float positionOffset, int positionOffsetPixels) {
            }

            @Override
            public void onPageScrollStateChanged(int state) {
            }
        });

        return rootView;
    }

    public class SlidesFragmentAdapter extends FragmentStatePagerAdapter implements IconPagerAdapter {

        private int[] Images = new int[] { R.drawable.first_image, R.drawable.second_image,
                R.drawable.third_image, R.drawable.four_image

        };

        private int[] ICONS = new int[] { R.drawable.first_image, R.drawable.second_image,
                R.drawable.third_image, R.drawable.four_image };

        private int mCount = Images.length;

        public SlidesFragmentAdapter(android.support.v4.app.FragmentManager fragmentManager) {
            super(fragmentManager);
        }

        @Override
        public Fragment getItem(int position) {
            return new DemoFragment(Images[position]);
        }

        @Override
        public int getCount() {
            return mCount;
        }

        @Override
        public int getIconResId(int index) {
            return ICONS[index % ICONS.length];
        }
        public float GetPageWidth (int position) {
            return 0.93f;
        }  
        public void setCount(int count) {
            if (count > 0 && count <= 10) {
                mCount = count;
                notifyDataSetChanged();
            }
        }
    }
}

1 个答案:

答案 0 :(得分:0)

我认为这可以使用show()或add()方法实现。如果它是一个没有Tabhost的Activity那么它很容易。这种情况下切换选项卡我们必须应用相同的逻辑。

Check this solution

我想这会给你一些想法。