您当前的位置: 首页 > 

蓝不蓝编程

暂无认证

  • 0浏览

    0关注

    706博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

安卓使用RecyclerView一行显示多条数据

蓝不蓝编程 发布时间:2020-11-05 19:21:16 ,浏览量:0

背景

平常使用RecyclerView时,都是一行一行显示数据,但是某些场景下,我们需要一行显示多条数据.

效果图

实现方案
  1. 适配器
class RvAdapter : RecyclerView.Adapter() {
    private var mDataList = mutableListOf()
    private lateinit var mContext: Context
    override fun onBindViewHolder(holder: RecyclerView.ViewHolder, position: Int) {
        val data = mDataList[position]
        holder.itemView.imageView.setImageResource(R.mipmap.ic_launcher)
        holder.itemView.setOnClickListener {
            setOnItemClickListener(data)
        }
    }

    fun setData(dataList: List) {
        mDataList.clear()
        mDataList.addAll(dataList)
        notifyDataSetChanged()
    }

    override fun getItemCount(): Int = mDataList.size

    override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
        mContext = parent.context
        val view = LayoutInflater.from(mContext).inflate(R.layout.item_rv, parent, false)
        return ViewHolder(view)
    }

    private fun setOnItemClickListener(data: String) {
        Toast.makeText(mContext, data, Toast.LENGTH_SHORT).show()
    }

    class ViewHolder(itemView: View?) : RecyclerView.ViewHolder(itemView!!)
}
  1. 适配器布局文件:item_rv.xml


    


  1. 主界面
class RecyclerViewActivity : AppCompatActivity() {
    private lateinit var adapter: RvAdapter

    override fun onCreate(savedInstanceState: Bundle?) {
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_recycler_view)
        initRecyclerView()
        loadData()
    }

    private fun initRecyclerView() {
        adapter = RvAdapter()
        recyclerView.adapter = adapter

        //设置布局类型
        recyclerView.layoutManager = GridLayoutManager(this, 4, GridLayoutManager.VERTICAL, false)
    }

    private fun loadData() {
        val data = ArrayList()
        for (i in 0..50) {
            data.add("text-$i")
        }
        adapter.setData(data)
    }
}
  1. 主界面布局文件:activity_recycler_view.xml


    

完整源代码

https://gitee.com/cxyzy1/recyclerViewDemo/tree/master/recyclerViewDemo/app1

关注
打赏
1639405877
查看更多评论
立即登录/注册

微信扫码登录

0.0862s