Android - 方向更改后GridView图像无法正确显示

时间:2015-09-07 23:06:42

标签: android gridview android-glide

在我的Android应用中,我在GridView中显示照片。在将这些照片加载到GridView之前,我对这些照片进行了一些繁重的处理,因此我决定通过覆盖onConfigurationChanged()方法自行处理配置更改,该方法仅更改GridView的列数,然后将适配器重新分配给它。 当我将设备从横向切换为纵向时,一切都很完美,图像占据了整个列空间,正如预期的那样。 但是当我将设备从纵向切换到横向时,GridView中图像的宽度远远低于它所需要的宽度。 我使用Glide库将照片加载到GridView中。

我该如何解决这个问题?

我的代码如下:

public class PhotosAdapter extends BaseAdapter {
    private ArrayList<String> images;

    public PhotosAdapter(ArrayList<String> images) {
        this.images = images;
    }

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

    @Override
    public Object getItem(int position) {
        return images.get(position);
    }

    @Override
    public long getItemId(int position) {
        return position;
    }

    @Override
    public View getView(final int position, View convertView, ViewGroup parent) {
        View row = convertView;

        if(row == null) {
            //No tenemos vista reciclada, la creamos
            row = getLayoutInflater().inflate(R.layout.grid_row, parent, false);
        }

        TickedImageView thumbV = (TickedImageView) row.findViewById(R.id.thumb);
        int screenWidth = getResources().getDisplayMetrics().widthPixels;
        int numberOfColumns = Utils.landscape(PhotosActivity.this) ? 5 : 3;
        int width = screenWidth / numberOfColumns;

        thumbV.setDrawingWidth(width);

        //Por si la TickedImageView fue reciclada, la desmarcamos
        thumbV.setSelected(selectedPaths.contains(images.get(position)));

        thumbV.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                TickedImageView view = (TickedImageView) v;

                if (view.isSelected())
                    selectedPaths.add(images.get(position));
                else
                    selectedPaths.remove(images.get(position));
            }
        });

        //Cargamos la imagen
        Glide.with(PhotosActivity.this)
                .load(new File(images.get(position)))
                .centerCrop()
                .into(thumbV);

        Log.d("TAG", images.get(position));
        return row;
    }

    public void removeImage(String image) {
        images.remove(image);
    }
    public String getImage(int position) {
        return images.get(position);
    }
}

2 个答案:

答案 0 :(得分:2)

我认为您可能遇到this issue,尝试在XML中将ImageView大小设置为match_parent,并在GridView上设置列数,不需要自定义drawingWidth。其余部分应由安排GridView和Glide的Android布局系统来处理。

Minitip:由于协变式返回类型,您可以说public String getItem,没有重复的getImage可以减少一个方法。

答案 1 :(得分:0)

尝试为横向模式创建单独的布局,然后配置否。网格的列数为 1 +纵向模式下的列数 另外,让您的imageView具有scaleType = centerCrop Android将负责其余的工作。