zoukankan      html  css  js  c++  java
  • Android 解决RecyclerView瀑布流效果结合Glide使用时图片变形的问题

    问题描述:使用Glide加载RecyclerView的Item中的图片,RecyclerView使用了瀑布流展示图片,但是滚动时图片会不断的加载,并且大小位置都会改变,造成显示错乱。

    解决方法:使用瀑布流,我们可以根据要展示的列数来将屏幕宽度等分,从而获得Item的宽度。知道了宽度,那么我们就可以使用Glide的override()方法根据图片的比例自适应地放大或缩小得到合适的高度。这样显示时就不会由错乱的问题了。

    步骤1:设置Item的最外层布局的layout_height为wrap_content(当然也可以设置一个固定大小),如果Item里面的图片也设置高度为wrap_content;

    步骤2:先得到屏幕的宽高,然后根据要显示的列数进行均分。比如我现在想要展示列数为2的瀑布流,我们就可以把屏幕宽度除以2,得到图片的宽度。

    //屏幕的宽度(px值)
    int screenWidth = getContext().getResources().getDisplayMetrics().widthPixels;
    //Item的宽度,或图片的宽度
    int width = screenWidth/2;

    步骤3:用Glide加载图片

    //这里的SIZE_ORIGINAL为Gilde里自带的参数,不是我定义的常量
    Glide.with(getContext()).load(item.getUrl()).override(width,SIZE_ORIGINAL)          
    .fitCenter().into(imageview);

    然后再尝试一下上下滚动RecyclerView,你会发现之前图片变形错位的问题都解决了。

  • 相关阅读:
    CVS 快速入门指南
    我的博客皮肤
    OOP三个基本特征
    vi 操作
    智者能堪破这世界的定数,但没人能逃脱劫数
    技术路径的四阶段
    python每日学习2018/1/14(python之禅)
    python每日学习2018/1/11
    Python PyInstaller安装和使用教程(详解版)
    Windows环境下安装MinGW/gcc
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/8127125.html
Copyright © 2011-2022 走看看