ListView图片错位

ImageLoader版本:

if (!TextUtils.isEmpty(gameListEntity.getIcon())) {

            final String tag = (String) userHolder.team_header.getTag();
            final String uri = gameListEntity.getIcon();
            if (!uri.equals(tag)) {
                // 设置默认图片
                userHolder.team_header.setImageResource(R.mipmap.show_default);
            }

            userHolder.team_header.setTag(uri);
            imageLoader.displayImage(uri, userHolder.team_header, ToolImage.getFadeOptions(R.mipmap.show_default, R.mipmap.show_default));

        } else {
            // 设置默认图片
            userHolder.team_header.setImageResource(R.mipmap.show_default);
        }

解决闪烁的版本(闪烁与不闪烁,各有其利弊,闪烁的始终去服务器加载,这样的话,服务器的图片无论何时更改图片,客户端都能第一时间更新到,缺点是频繁闪烁看起来不太友好。不闪烁的话,获取的图片是第一次加载的,实时性不是很强,但是看起来比较舒服。):

if (!TextUtils.isEmpty(currentTask.getCover())) {
            final String tag = (String) mViewHolder.iv_game_poster.getTag();
            final String uri = currentTask.getCover();
            if (!uri.equals(tag)) {
                // 设置默认图片
                mViewHolder.iv_game_poster.setImageResource(R.mipmap.show_default_big);

                mViewHolder.iv_game_poster.setTag(uri);
                ToolImage.getImageLoader().displayImage(uri, mViewHolder.iv_game_poster, ToolImage.getFadeOptions(R.mipmap.show_default_big, R.mipmap.show_default_big));

            }
        } else {
            // 设置默认图片
            mViewHolder.iv_game_poster.setImageResource(R.mipmap.show_default_big);
        }

Glide版本:
Glide比较坑的就是和CircleImageView混搭使用的时候有bug,通常会在第二次进入才能显示,有个好处是,Glide似乎不用做特殊配置就可以解决图片闪烁的问题:
ListView使用(没有和CircleImageView混搭使用):

if (!TextUtils.isEmpty(gameListEntity.getIcon())) {
                    final String tag = (String) holder.team_header.getTag(R.id.imageloader_uri);
                    final String uri = gameListEntity.getIcon();

                    if (!uri.equals(tag)) {
                        // 设置默认图片
                        holder.team_header.setImageResource(R.mipmap.show_default);
                    }

                    holder.team_header.setTag(R.id.imageloader_uri, gameListEntity.getIcon());
                    Glide.with(mContext).load(uri).dontAnimate().placeholder(R.mipmap.show_default).crossFade().into(holder.team_header);
                } else {
                    // 设置默认图片
                    holder.team_header.setImageResource(R.mipmap.show_default);
                }

这里的R.id.imageloader_uri是values下新建的ids.xml:

<?xml version="1.0" encoding="utf-8"?>
<resources>

    <item name="imageloader_uri" type="id"/>

</resources>

RecyclerView中使用(和CircleImageView混搭使用):

if (!TextUtils.isEmpty(gameListEntity.getIcon())) {
// R.id.team_header就是CircleImageView对应的id
                    final String tag = (String) holder.team_header.getTag(R.id.team_header);
                    final String uri = gameListEntity.getIcon();
                    if (!uri.equals(tag)) {
                        // 设置默认图片
                        holder.team_header.setImageResource(R.mipmap.show_default);
                    }

                    Glide.with(mContext).load(gameListEntity.getIcon()).asBitmap().placeholder(R.mipmap.show_default)
                            .error(R.mipmap.show_default).into(new SimpleTarget<Bitmap>() {
                        @Override
                        public void onResourceReady(Bitmap resource, GlideAnimation<? super Bitmap>
                                glideAnimation) {
                            holder.team_header.setTag(gameListEntity.getIcon());
                            holder.team_header.setImageBitmap(resource);
                        }
                    });
                } else {
                    // 设置默认图片
                    holder.team_header.setImageResource(R.mipmap.show_default);
                }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 Android Studio 的 ListView 中显示图片,可以使用自定义适配器来实现。 以下是一些步骤: 1. 在布局文件中,添加 ListView 控件。 2. 创建一个自定义布局文件,用于显示列表项。 3. 创建一个自定义适配器类,继承自 BaseAdapter。 4. 在自定义适配器类中,实现 getView() 方法,用于设置每个列表项的布局和内容。 5. 在 getView() 方法中,通过调用 findViewById() 方法获取 ImageView 控件,并设置其图片资源。 6. 在主活动中,实例化自定义适配器类,并将其设置为 ListView 的适配器。 以下是一个示例代码,以便更好地理解: 在布局文件中添加 ListView 控件: ```xml <ListView android:id="@+id/listView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 创建一个自定义布局文件,用于显示列表项。例如,我们可以创建一个名为 list_item.xml 的文件,其中包含一个 ImageView 控件: ```xml <ImageView android:id="@+id/imageView" android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/image" /> ``` 创建一个自定义适配器类,继承自 BaseAdapter。例如,我们可以创建一个名为 MyAdapter 的类: ```java public class MyAdapter extends BaseAdapter { private Context mContext; public MyAdapter(Context context) { mContext = context; } @Override public int getCount() { return 10; // 返回列表项的数量 } @Override public Object getItem(int position) { return null; } @Override public long getItemId(int position) { return 0; } @Override public View getView(int position, View convertView, ViewGroup parent) { LayoutInflater inflater = LayoutInflater.from(mContext); View view = inflater.inflate(R.layout.list_item, parent, false); ImageView imageView = view.findViewById(R.id.imageView); imageView.setImageResource(R.drawable.image); // 设置图片资源 return view; } } ``` 在主活动中,实例化自定义适配器类,并将其设置为 ListView 的适配器: ```java ListView listView = findViewById(R.id.listView); MyAdapter adapter = new MyAdapter(this); listView.setAdapter(adapter); ``` 这样,就可以在 ListView 中显示图片了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值