我正面临着一个非常奇怪的问题,我在网上发现了类似的问题,但没有一个解决方案可以帮助我摆脱这个问题。
问题::
我有一个有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();
}
}
}
}
答案 0 :(得分:0)
我认为这可以使用show()或add()方法实现。如果它是一个没有Tabhost的Activity那么它很容易。这种情况下切换选项卡我们必须应用相同的逻辑。
我想这会给你一些想法。