使用glide 时候在listview 或者 grideview 中图片自动拉伸问题

        这篇文章是我转载别人的。 不过原地址我忘记了 只记得解决问题的方法了~ 

    我要加载图片的地方是轮播图, 轮播图中已加入动画效果,用glide 加载图片时候 因为glide 加载图片有一个淡入淡出的动画效果 两个效果貌似有冲突 出现了图片拉伸问题

  解决方法:

  RequestManager manager = Glide.with(mContext);
        DrawableTypeRequest request = null;
        //"http://file2.bbtree.com/group2/M01/1F/61/Cqgv5FZNpUiAXJU7AAEqHsjzFIM015.jpg"
//        mUrl = "http://file2.bbtree.com/group2/M01/1F/61/Cqgv5FZNpUiAXJU7AAEqHsjzFIM015.jpg";
        if (mUrl != null) {
            request = manager.load(mUrl);
        } else if (mFile != null) {
            request = manager.load(mFile);
        } else if (mRes != 0) {
            request = manager.load(mRes);
        } else {
        }

        request.placeholder(getEmpty()).error(getError())<strong>.<span style="color:#ff0000;">dontAnimate()</span></strong><span style="color:#ff0000;">.</span>listener(new RequestListener() {
            @Override
            public boolean onException(Exception e, Object model, Target target, boolean isFirstResource) {
                LOG.d("BaseSliderView", ">>> onError");
                //只有onError 会报 oom 暂时注销
                //作用在加载失败时候 在列表中删除该对象!
                if (mLoadListener != null) {
                    mLoadListener.onEnd(false, me);
                }
                if (v.findViewById(R.id.loading_bar) != null) {
                    v.findViewById(R.id.loading_bar).setVisibility(View.INVISIBLE);
                }
                return false;
            }

            @Override
            public boolean onResourceReady(Object resource, Object model, Target target, boolean isFromMemoryCache, boolean isFirstResource) {
                if (v.findViewById(R.id.loading_bar) != null) {
                    v.findViewById(R.id.loading_bar).setVisibility(View.INVISIBLE);
                }
                return false;
            }
        }).into(targetImageView);

红色字体部分 加入dontAnimate()去掉 glide 的动画效果 
 然后你再试试

在Android Studio使用Glide加载图片ListView,需要遵循以下步骤: 1. 添加Glide依赖项 在项目的build.gradle文件添加以下依赖项: ``` dependencies { implementation 'com.github.bumptech.glide:glide:4.11.0' annotationProcessor 'com.github.bumptech.glide:compiler:4.11.0' } ``` 2. 创建ListView的Adapter 创建一个继承BaseAdapter的Adapter类,并实现getView()方法。在getView()方法使用Glide加载图片。 ```java public class MyAdapter extends BaseAdapter { private Context context; private List<String> imageUrlList; public MyAdapter(Context context, List<String> imageUrlList) { this.context = context; this.imageUrlList = imageUrlList; } @Override public int getCount() { return imageUrlList.size(); } @Override public Object getItem(int position) { return imageUrlList.get(position); } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if (convertView == null) { convertView = LayoutInflater.from(context).inflate(R.layout.item_layout, parent, false); viewHolder = new ViewHolder(); viewHolder.imageView = convertView.findViewById(R.id.imageView); convertView.setTag(viewHolder); } else { viewHolder = (ViewHolder) convertView.getTag(); } Glide.with(context) .load(imageUrlList.get(position)) .into(viewHolder.imageView); return convertView; } static class ViewHolder { ImageView imageView; } } ``` 3. 设置ListView的Adapter 在Activity或Fragment创建ListView并设置Adapter。 ```java public class MyActivity extends AppCompatActivity { private ListView listView; private MyAdapter adapter; private List<String> imageUrlList; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_my); listView = findViewById(R.id.listView); imageUrlList = new ArrayList<>(); imageUrlList.add("https://example.com/image1.jpg"); imageUrlList.add("https://example.com/image2.jpg"); imageUrlList.add("https://example.com/image3.jpg"); adapter = new MyAdapter(this, imageUrlList); listView.setAdapter(adapter); } } ``` 以上就是在Android Studio使用Glide加载图片ListView的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值