使用 viewpager 制作图像视图

Posted

技术标签:

【中文标题】使用 viewpager 制作图像视图【英文标题】:Make imageview with viewpager 【发布时间】:2020-07-24 05:07:55 【问题描述】:

我正在尝试在我的应用程序中创建一个滑动图像视图窗口,因此我使用了 viewpager。但是 android studio 写了关于 java.lang.ClassCastException: androidx.viewpager.widget.ViewPager cannot be cast to android.widget.ImageView at this string:

ImageView imageView = view.findViewById(R.id.view_pager);

我知道这是另一种观点。但我不知道如何连接正确的 imageView。请帮忙。

MyPager 类:

  import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ImageView;

import androidx.viewpager.widget.PagerAdapter;

public class MyPager extends PagerAdapter 
    private Context context;
    public MyPager(Context context) 
        this.context = context;
    

    @Override
    public Object instantiateItem(ViewGroup container, int position) 
        View view = LayoutInflater.from(context).inflate(R.layout.authorization, null);
        ImageView imageView = view.findViewById(R.id.view_pager);
        imageView.setImageDrawable(context.getResources().getDrawable(getImageAt(position)));
        container.addView(view);
        return view;
    

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

    @Override
    public int getCount() 
        return 7;
    

    @Override
    public boolean isViewFromObject(View view, Object object) 
        return object == view;
    
    private int getImageAt(int position) 
        switch (position) 
            case 0:
                return R.drawable.logo0;
            case 1:
                return R.drawable.logo1;
            case 2:
                return R.drawable.logo2;
            case 3:
                return R.drawable.logo3;
            case 4:
                return R.drawable.logo4;
            case 5:
                return R.drawable.logo5;
            case 6:
                return R.drawable.logo6;
            default:
                return R.drawable.logo0;
        
    


【问题讨论】:

【参考方案1】:

您在 MyPager 类中使用了错误的布局

您需要使用R.layout.pager_item 而不是R.layout.authorization

另外,请同时更改findViewById()代码

使用这个

@Override
    public Object instantiateItem(ViewGroup container, int position) 
        View view = LayoutInflater.from(context).inflate(R.layout.pager_item, null);
        ImageView imageView = view.findViewById(R.id.image);
        imageView.setImageDrawable(context.getResources().getDrawable(getImageAt(position)));
        container.addView(view);
        return view;
    

而不是这个

 @Override
    public Object instantiateItem(ViewGroup container, int position) 
        View view = LayoutInflater.from(context).inflate(R.layout.authorization, null);
        ImageView imageView = view.findViewById(R.id.view_pager);
        imageView.setImageDrawable(context.getResources().getDrawable(getImageAt(position)));
        container.addView(view);
        return view;
    

【讨论】:

【参考方案2】:

在“instantiateItem”函数中编辑通胀行

View view = LayoutInflater.from(context).inflate(R.layout.authorization, null);

View view = LayoutInflater.from(context).inflate(R.layout.pager_item, null);

【讨论】:

以上是关于使用 viewpager 制作图像视图的主要内容,如果未能解决你的问题,请参考以下文章

ViewPager详解填充Fragment和懒加载

ViewPager详解填充Fragment和懒加载

Android中ViewPager+Fragment的销毁机制

ViewPager2的使用:基本使用源码分析多种切换动画

ViewPager 在返回时跳过视图留下空白

如何在确定的时间内从 ViewPager 更改图像?