• 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,你会发现之前图片变形错位的问题都解决了。

  • 相关阅读:
    Delphi XE5 for Android (六)
    Delphi XE5 for Android (四)
    Delphi XE5 for Android (三)
    如何设计并使用FireMonkeyStyle
    Indy发送邮件被kbas退掉
    Indy10收发Hotmail邮件
    一个简单的打印监控示例
    DataSnap侦听端口动态设置问题
    面试题总结一
    spring boot RESTFul API拦截 以及Filter和interceptor 、Aspect区别
  • 原文地址:https://www.cnblogs.com/zhujiabin/p/8127125.html
Copyright © 2020-2023  润新知