如何用最后一张图片的按钮关闭viewAdapter?

问题描述 投票:0回答:1

我想做的是在点击第三个视图中的按钮时关闭图像适配器。

我是按照这个教程来设置视图的,效果很好。https:/www.journaldev.com10096android-viewpager-example-tutorial

现在我想做的是在最后一个视图中用botton关闭适配器。我得到一个错误,说指向按钮。试图在一个空对象引用上调用虚拟方法 "void android.widget.Button.setOnClickListener(android.view.View$OnClickListener)"。

我想这是因为该按钮不在主布局上,而是在视图布局上。

这是主要

protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        textView3 = findViewById(R.id.textView3);

        textView3.setVisibility(View.INVISIBLE);

        btnClose=findViewById(R.id.btnClose);

        viewPager = (ViewPager) findViewById(R.id.viewpager);
        viewPager.setAdapter(new CustomPagerAdapter(this));
        viewPager.setPageTransformer(true, new ZoomOutPageTransformer());
        btnClose.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View arg0) {
                viewPager.setVisibility(View.INVISIBLE);
                textView3.setVisibility(View.VISIBLE);
            }
        });

    }

这是适配器

public class CustomPagerAdapter extends PagerAdapter {

    private Context mContext;

    public CustomPagerAdapter(Context context) {
        mContext = context;
    }

    @Override
    public Object instantiateItem(ViewGroup collection, int position) {
        ModelObject modelObject = ModelObject.values()[position];
        LayoutInflater inflater = LayoutInflater.from(mContext);
        ViewGroup layout = (ViewGroup) inflater.inflate(modelObject.getLayoutResId(), collection, false);
        collection.addView(layout);
        return layout;
    }

    @Override
    public void destroyItem(ViewGroup collection, int position, Object view) {
        collection.removeView((View) view);
    }

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

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

    @Override
    public CharSequence getPageTitle(int position) {
        ModelObject customPagerEnum = ModelObject.values()[position];
        return mContext.getString(customPagerEnum.getTitleResId());
    }

}

这是模型对象类

public enum ModelObject {

    RED(R.string.red, R.layout.view_red),
    BLUE(R.string.blue, R.layout.view_blue),
    GREEN(R.string.green, R.layout.view_green);

    private int mTitleResId;
    private int mLayoutResId;

    ModelObject(int titleResId, int layoutResId) {
        mTitleResId = titleResId;
        mLayoutResId = layoutResId;
    }

    public int getTitleResId() {
        return mTitleResId;
    }

    public int getLayoutResId() {
        return mLayoutResId;
    }

}

我只是想知道它是如何工作的,我想隐藏适配器并显示一个文本视图。我又觉得问题在于按钮在另一个布局上,那么我如何调用它呢?

android android-viewpager adapter
1个回答
1
投票

在main类中实现你的监听器&将其传递给viewpager。按需附加监听器,只有审查视图。

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    textView3 = findViewById(R.id.textView3);

    textView3.setVisibility(View.INVISIBLE);

    viewPager = (ViewPager) findViewById(R.id.viewpager);
    View.OnClickListener listener = new View.OnClickListener() {
        @Override
        public void onClick(View arg0) {
            viewPager.setVisibility(View.INVISIBLE);
            textView3.setVisibility(View.VISIBLE);
        }
    }
    viewPager.setAdapter(new CustomPagerAdapter(this), listener);
    viewPager.setPageTransformer(true, new ZoomOutPageTransformer());
}

public class CustomPagerAdapter extends PagerAdapter {

    private Context mContext;
    private View.OnClickListener mListener;

    public CustomPagerAdapter(Context context, View.OnClickListener listener) {
        mContext = context;
        mListener = listener;
    }

    @Override
    public Object instantiateItem(ViewGroup collection, int position) {
        ModelObject modelObject = ModelObject.values()[position];
        LayoutInflater inflater = LayoutInflater.from(mContext);
        ViewGroup layout = (ViewGroup) inflater.inflate(modelObject.getLayoutResId(), collection, false);
        collection.addView(layout);

        if (position == 2) {
            View btnClose = layout.findViewById(R.id.btnClose);
            btnClose.setOnClickListener(mListener);
        }
        return layout;
    }

    @Override
    public void destroyItem(ViewGroup collection, int position, Object view) {
        collection.removeView((View) view);
    }

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

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

    @Override
    public CharSequence getPageTitle(int position) {
        ModelObject customPagerEnum = ModelObject.values()[position];
        return mContext.getString(customPagerEnum.getTitleResId());
    }
}
© www.soinside.com 2019 - 2024. All rights reserved.