android - 查看页面 : lose the state of toggle button when swiping

标签 android android-viewpager togglebutton android-pageradapter recycle

我正在使用 Viewpager 和 PagerAdapter 创建一个带有图像和类似按钮的图库。请引用我的代码:

public class GalleryAdapter extends PagerAdapter {

private Activity _activity;
private ArrayList<MyPhotoItem> _imageCollection;

// Components in fullsceen layout
ImageView imgDisplay;
private ToggleButton btnLike;

// Variable for btnLike
private boolean isChecked;

// constructor
public GalleryAdapter(Activity activity,
        ArrayList<MyPhotoItem> images) {
    this._imageCollection = images;
}

@Override
public int getCount() {
    return this._imageCollection.size();
}

@Override
public boolean isViewFromObject(View view, Object object) {
    return view == ((RelativeLayout) object);
}

@Override
public Object instantiateItem(ViewGroup container, int position) {

    inflater = (LayoutInflater) _activity
            .getSystemService(Context.LAYOUT_INFLATER_SERVICE);

    View viewLayout = inflater.inflate(R.layout.layout_gallery_image,
            container, false);


    imgDisplay = (ImageView) viewLayout
            .findViewById(R.id.layout_gallery_imgDisplay);
    Picasso.with(this._activity.getApplicationContext())
            .load(_imageCollection.get(position).url).into(imgDisplay);

    btnLike = (ToggleButton) viewLayout
            .findViewById(R.id.layout_gallery_likeButton);
    btnLike.setOnCheckedChangeListener(null);
    btnLike.setChecked(isChecked);
    btnLike.setOnCheckedChangeListener(new OnCheckedChangeListener() {

        @Override
        public void onCheckedChanged(CompoundButton buttonView,
                boolean isChecked) {
            if (isChecked) {
                isChecked = true;

            } else {
                isChecked = false;

            }
        }

    });

    ((ViewPager) container).addView(viewLayout);

    return viewLayout;
}


@Override
public void destroyItem(ViewGroup container, int position, Object object) {
    ((ViewPager) container).removeView((RelativeLayout) object);

}

@Override
public int getItemPosition(Object object) {
    return PagerAdapter.POSITION_NONE;
}

我当前的问题:当我滑动到另一个页面并返回到之前的页面时,Viewpager 不会保持切换按钮状态(假设 Viewpager 中加载了 5 张照片)。我浏览了几篇 Stackoverflow 帖子,但没有一篇能正确解决我的问题。

任何建议将不胜感激。提前致谢。

最佳答案

感谢您的回复。虽然他们中的大多数都不是我的案例的直接答案,但他们给了我一些线索来找到我的解决方案。这可能不是最好的解决方案,但它解决了我的问题。

解决方法:

1/添加一个标志来保持对象中 Toggle 的状态:

public class MyPhotoItem {
...
  public boolean like_flag;
...
}

2/自定义一点 OnCheckedChangeListener:

class OnLikeCheckedChangeListener implements OnCheckedChangeListener {
    int mPosition;

    // constructor
    public OnLikeCheckedChangeListener(int position) {
        this.mPosition = position;
    }
    @Override
    public void onCheckedChanged(CompoundButton buttonView,
            boolean isChecked) {
     if (isChecked){ 
            _imageCollection.get(_position).like_flag = true;
            notifyDataSetChanged();
      }
     else{
            _imageCollection.get(_position).like_flag = false;
            notifyDataSetChanged();
     }
  }
}

3/根据 Flag 设置 Toggle 状态:

@Override
public Object instantiateItem(ViewGroup container, int position) {
  ...
  // Init Toggle status
    if (_imageCollection.get(position).like_flag) {
        btnLike.setChecked(true);
    } else {
        btnLike.setChecked(false);
    }
  btnLike.setOnCheckedChangeListener(new OnLikeCheckedChangeListener(
            position));
  ...
 }

就是这样。 Toggle 状态在滑动 Viewpager 期间保持不变。大家有更好的解决方案或者好的做法,欢迎大家评论。

享受编码吧!

关于android - 查看页面 : lose the state of toggle button when swiping,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28304140/

相关文章:

java - 在 Android 上找不到赛门铁克证书

android - Zebra Device-TC75x- Android 8.1-条码扫描问题

android - 在 ViewPager 中使用具有相同布局的不同 fragment

android - ViewPager Fragment 不同步更新?

user-interface - 如何从 Flutter 中的 ToggleButtons 中删除空间并使其滚动

Jquery 加号和减号按钮切换

android - 使用 Tomcat 服务器托管 android 和 web 应用程序打开太多连接

android - 如何停止或取消 Mediaplayer.setOnPreparedListener 表单执行 Android

java - Android 选项卡式 Activity 底部关闭屏幕

c# - 我可以更改弹出窗口的对齐方式,使其出现在按钮的左侧而不是右侧吗?