RecyclerView加ImageView条目单选框

本文介绍如何在Android应用中使用RecyclerView实现条目加载,并结合自定义TextView达到跑马灯滚动文字效果。通过详细代码示例,展示了从环境配置到布局设置、Adapter编写及事件监听的全过程。

创建工程配置相应的环境,这里我们用到了RecyclerView做条目加载器,和引用到自定义Textview跑马灯效果,每个都获取焦点,展示其效果。

有配置:  

compile 'com.android.support:recyclerview-v7:24.2.1'

 

布局,简单的xml,这里我需要的高度为这些,跟据各人需要设置

 

<android.support.v7.widget.RecyclerView
    android:id="@+id/rv_common"
    android:layout_width="match_parent"
    android:layout_height="83dp"
    android:overScrollMode="never"
    android:scrollbars="none" />

然后就是熟知的找控件,省略。。。。

 

 

        adapte = new DialogAdapteList(mActivity, (List<String>) mlist);
//        LinearLayoutManager linearLayoutManager = new LinearLayoutManager(mActivity);
//        linearLayoutManager.setOrientation(LinearLayoutManager.HORIZONTAL);
//        lvList.setLayoutManager(linearLayoutManager);
        lvList.setLayoutManager(new GridLayoutManager(mActivity, 3));
        lvList.setHasFixedSize(true);
        lvList.setAdapter(adapte);
        adapte.setOnItemClickLitener(new DialogAdapteList.OnItemClickLitener() {
            @Override
            public void onItemClick(View itemView, int position, ImageView ivitemView) {
           	adapte.setSelected(position);
                adapte.notifyDataSetChanged();
            }
        });

 

条目样式设置,简单设置下

 

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:gravity="center_vertical"
    android:orientation="horizontal"
    android:clickable="true"
    android:padding="5dp">

    <ImageView
        android:id="@+id/iv_view"
        android:layout_width="30dp"
        android:layout_height="30dp"
        android:src="@drawable/down" />

    <com.pax.th.view.MarqueeTextView
        android:id="@+id/tv_name"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginLeft="2dp"
        android:marqueeRepeatLimit="marquee_forever"
        android:text="123"
        android:textSize="16sp" />
</LinearLayout>

adapter写入方式

 

 

private List<String> data;
private Context context;
public final LayoutInflater layoutInflater;
public int selected = -1;
public boolean down = false;

public DialogAdapteList(Context context, List<String> data) {
    this.context = context;
    this.data = data;
    layoutInflater = LayoutInflater.from(context);
}

public void setSelected(int i) {
    this.selected = i;
}

private OnItemClickLitener mOnItemClickLitener;

public interface OnItemClickLitener {
    void onItemClick(View itemView, int position, ImageView ivitemView);
}

public void setOnItemClickLitener(OnItemClickLitener mOnItemClickLitener) {
    this.mOnItemClickLitener = mOnItemClickLitener;
}

@Override
public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {

    View view = layoutInflater.inflate(R.layout.item_list, parent, false);
    return new ViewHolder(view);
}

@Override
public void onBindViewHolder(final ViewHolder holder, final int position) {
    final String appData = data.get(position);
    holder.itemName.setText(appData);
    if (selected == position) {
        holder.ivitemView.setImageResource(R.drawable.down_up);
    } else {
        holder.ivitemView.setImageResource(R.drawable.down);
    }
    if (mOnItemClickLitener != null) {
        holder.itemView.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                mOnItemClickLitener.onItemClick(holder.itemView, position, holder.ivitemView);
            }
        });

    }

}

@Override
public int getItemCount() {
    return data.size();
}

class ViewHolder extends RecyclerView.ViewHolder {
    ImageView ivitemView;
    MarqueeTextView itemName;

    public ViewHolder(View itemView) {
        super(itemView);
        ivitemView = (ImageView) itemView.findViewById(R.id.iv_view);
        itemName = (MarqueeTextView) itemView.findViewById(R.id.tv_name);
    }
}

 

 

 

 

 

<think>好的,用户想知道如何在Android中使用RecyclerViewImageView。首先,我需要回忆一下RecyclerView的基本用法,以及如何结合ImageView。根据提供的引用,RecyclerView需要配置依赖,设置布局管理器适配器。ImageView通常作为列表项的视图部分,用于显示图片。 用户的问题可能涉及如何将图片载到RecyclerView的每个项中。根据引用[3],适配器负责绑定数据到视图,所以需要在适配器的onBindViewHolder方法里处理ImageView。可能需要使用网络请求获取图片,比如引用[5]中的API,然后使用Glide或Picasso库载图片到ImageView。 另外,横向轮播布局可能涉及设置LinearLayoutManager为横向,如引用[4]提到的。需要确保布局文件中RecyclerView的orientation是horizontal。同时,数据绑定的时候,每个项里的ImageView需要正确设置图片源。 可能还需要考虑图片缓存性能优化,比如使用Glide的缓存机制。用户可能遇到的常见问题包括图片错位、内存溢出,所以要在适配器中正确处理图片回收。</think>在Android中,使用RecyclerView结合ImageView通常用于创建图片列表、相册或横向轮播等场景。以下是具体实现步骤: ### 一、基础配置 1. **添依赖** 在`build.gradle`中配置RecyclerView依赖(支持AndroidX): ```groovy implementation 'androidx.recyclerview:recyclerview:1.3.2' [^2][^4] ``` 2. **布局文件** - Activity布局(如`activity_main.xml`): ```xml <androidx.recyclerview.widget.RecyclerView android:id="@+id/recyclerView" android:layout_width="match_parent" android:layout_height="wrap_content"/> ``` - 列表项布局(如`item_image.xml`): ```xml <ImageView android:id="@+id/imageView" android:layout_width="200dp" android:layout_height="200dp" android:scaleType="centerCrop"/> ``` ### 二、核心实现 1. **初始化RecyclerView** ```java RecyclerView recyclerView = findViewById(R.id.recyclerView); // 设置横向布局 LinearLayoutManager layoutManager = new LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL, false); [^4] recyclerView.setLayoutManager(layoutManager); ``` 2. **创建适配器** ```java public class ImageAdapter extends RecyclerView.Adapter<ImageAdapter.ViewHolder> { private List<String> imageUrls; // 图片URL列表(假设从API获取)[^5] public static class ViewHolder extends RecyclerView.ViewHolder { ImageView imageView; public ViewHolder(View itemView) { super(itemView); imageView = itemView.findViewById(R.id.imageView); } } @Override public void onBindViewHolder(@NonNull ViewHolder holder, int position) { // 使用Glide载网络图片 Glide.with(holder.itemView.getContext()) .load(imageUrls.get(position)) .into(holder.imageView); [^5] } } ``` 3. **设置适配器** ```java List<String> imageUrls = Arrays.asList( "https://example.com/image1.jpg", "https://example.com/image2.jpg" ); recyclerView.setAdapter(new ImageAdapter(imageUrls)); [^3] ``` ### 三、进阶功能 1. **添点击事件** ```java holder.imageView.setOnClickListener(v -> { // 处理图片点击逻辑 }); ``` 2. **性能优化** - 使用`RecyclerView.RecycledViewPool`复用视图 - 在Glide中配置磁盘缓存策略: ```java Glide.with(context) .load(url) .diskCacheStrategy(DiskCacheStrategy.ALL) ``` ### 四、结合API获取数据 参考API调用示例: ```java String apiUrl = "https://api.androidhive.info/feed/feed.json"; [^5] // 使用Retrofit/Volley请求数据后更新适配器 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值