详解分别用Kotlin和java写RecyclerView的示例

本文介绍了分别用Kotlin和java写RecyclerView的示例,分享给大家,具体如下:

java:跟一般的写法一样,增加了按钮响应

MainActivity:

public class MainActivity extends AppCompatActivity implements RecyclerAdapter.OnItemClickListener{
    private RecyclerView mRecyclerView;
    private RecyclerView.LayoutManager mLayoutManager;
    private RecyclerAdapter mRecyclerAdapter;
    private ArrayListlist;

    @Override
    protected void onCreate(Bundlesaved InstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        RecyclerItem item;
        list = new ArrayList<>();
        item = new RecyclerItem();
        item.setName("No."+0);
        list.add(item);
        mRecyclerView = findViewById(R.id.recyclerView);
        mRecyclerAdapter = new RecyclerAdapter(this,list);
        mRecyclerAdapter.setOnItemClickListener(this);
        // 竖直方向的网格样式,每行一个Item
        mLayoutManager=new GridLayoutManager(this,3,OrientationHelper.VERTICAL,false);
        // 设置布局管理器
        mRecyclerView.setLayoutManager(mLayoutManager);
        // 设置adapter
        mRecyclerView.setAdapter(mRecyclerAdapter);
        // 设置Item添加和移除的动画
        mRecyclerView.setItemAnimator(newDefaultItemAnimator());
    }
    //adapter的按钮点击事件
    @Override
    public void onItemContentClick(Viewview,intposition) {
        //点击最后一个按钮增加一个item
        if(position == list.size()-1) {
          RecyclerItemitem=newRecyclerItem();
          item.setName("No."+(position+1));
          list.add(0,item);
          //更新RecyclerView
          mRecyclerAdapter.updateData(list);
        }else{
          Toast.makeText(this,"No."+position,Toast.LENGTH_SHORT).show();
        }
    }
}

Adapter:

public class RecyclerAdapter extends RecyclerView.Adapter{
  private ArrayList mData;
  private Context mContext;
  private OnItemClickListener onItemClickListener;
  public void setOnItemClickListener(OnItemClickListener listener) {
    this.onItemClickListener = listener;
  }
  public RecyclerAdapter(Context mContext,ArrayList mData){
    this.mData = mData;
    this.mContext = mContext;
  }

  //刷新整个list
  public void updateData(ArrayList data) {
    this.mData = data;
    notifyDataSetChanged();
  }

  //刷新局部list
  public void updateDataItem(ArrayList data, int itemnm) {
    this.mData = data;
    notifyItemChanged(itemnm);
  }

  @Override
  public View Holder onCreateViewHolder(ViewGroup parent, int viewType) {
    View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.recycler_item, parent, false);
    ViewHolder viewHolder = new ViewHolder(v);
    return viewHolder;
  }

  @Override
  public void onBindViewHolder(final ViewHolder holder, int position) {
    holder.btn.setText(mData.get(position).getName());
    holder.btn.setOnClickListener(newView.OnClickListener() {
      @Override
      public void onClick(View v) {
        if(onItemClickListener != null) {
          int pos = holder.getLayoutPosition();
          onItemClickListener.onItemContentClick(holder.itemView, pos);
        }
      }
    });
  }

  @Override
  public int getItemCount() {
    return mData == null ? 0 : mData.size();
  }

  public static class ViewHolder extends RecyclerView.ViewHolder{
    Button btn;
    public ViewHolder(View itemView) {
      super(itemView);
      btn = itemView.findViewById(R.id.recycle_name);
    }
  }

  public interface OnItemClickListener{
    void onItemContentClick(View view, int position);
  }
}

RecyclerItem:

public class RecyclerItem{
  String name;
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }

activity_main:

<android.support.v7.widget.RecyclerView
  xmlns:app="http://schemas.android.com/apk/res-auto"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context="com.tudou.recycleviewdemo.MainActivity">

  <android.support.v7.widget.RecyclerView
    android:id="@+id/recyclerView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#00000000"
    android:paddingBottom="5dip">
  </android.support.v7.widget.RecyclerView>
</android.support.constraint.ConstraintLayout>

recycler_item:

<RelativeLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="100dp"
  android:layout_height="100dp">
  <Button
    android:id="@+id/recycle_name"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    android:text="No.1"/>
</RelativeLayout>

Kotlin:语法略有不同,recyclerview调用类似

MainActivity:

class MainActivity : AppCompatActivity(), MainAdapter.ItemClick{
  val items : MutableList = ArrayList()
  var mainAdapter : MainAdapter ?= null
  override fun onCreate(savedInstanceState:Bundle?) {
    super.onCreate(savedInstanceState)
    setContentView(R.layout.activity_main)
    //添加一个item
    var item : RecyclerItem
    item = RecyclerItem()
    item.name = "No."+0
    items.add(item)
    val recyclerView = findViewById(R.id.recyclerView) as RecyclerView
    recyclerView.layoutManager = GridLayoutManager(this, 3, OrientationHelper.VERTICAL, false)
    mainAdapter=MainAdapter(items, this)
    mainAdapter!!.setItemClickListener(this)
    recyclerView.adapter = mainAdapter
    recyclerView.itemAnimator = DefaultItemAnimator()
  }

  //adapter的按钮点击事件
  override fun OnItemClick(v : View, position : Int) {
    if(position == items.size - 1) {
      val item = RecyclerItem()
      item.name = "No." + (position + 1)
      items.add(0, item)
      //更新数据
      mainAdapter!!.updateData(items)
    }else{
      Toast.makeText(this,items.get(position).name, Toast.LENGTH_SHORT).show()
    }
  }
}

MainAdapter:

class MainAdapter : RecyclerView.Adapter{
  var items : List? = null
  var context : Context ?= null
  var itemClick : ItemClick ?= null
  constructor(items : List, context : Context){
    this.items = items
    this.context = context
  }
  fun setItemClickListener(itemClick : ItemClick){
    this.itemClick = itemClick
  }
  fun updateData(items : List){
    this.items = items
    notifyDataSetChanged()
  }
  override fun onBindViewHolder(holder : ViewHolder?, position : Int) {
    var name=items!!.get(position).name
    if(holder != null) {
      holder.textName.setText(name)
      holder.textName.setOnClickListener(View.OnClickListener{
        if(itemClick != null) {
          itemClick!!.OnItemClick(holder.itemView, position)
        }
      })
    }
  }
  override fun getItemCount():Int{
    return items!!.size
  }
  override fun onCreateViewHolder(parent : ViewGroup?, viewType : Int) : ViewHolder{
    val v = LayoutInflater.from(parent!!.context).inflate(R.layout.recycler_item, parent, false) as RelativeLayout
    val holder = ViewHolder(v)
    return holder
  }

  class ViewHolder(itemView : View?) : RecyclerView.ViewHolder(itemView) {
    var textName : TextView = itemView!!.findViewById(R.id.recycle_name) as TextView
  }

  interface ItemClick{
    fun OnItemClick(v : View, position : Int);
  }
}

RecyclerItem:

class RecyclerItem{
  var name : String = ""
    get
    set
}

activity_main:

<android.support.constraint.ConstraintLayout
  xmlns:app="http://schemas.android.com/apk/res-auto"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  tools:context="com.tudo.kotlintdemo.MainActivity">
  <android.support.v7.widget.RecyclerView
    android:id="@+id/recyclerView"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#00000000"
    android:paddingBottom="5dip">
  </android.support.v7.widget.RecyclerView>
</android.support.constraint.ConstraintLayout>

recycler_item:

<RelativeLayout>
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="100dp"
  android:layout_height="100dp">
  <Button
    android:id="@+id/recycle_name"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_centerInParent="true"
    android:text="No.1"/>
</RelativeLayout>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Kotlin编写Android适配器Adapter

    说好今天要写一个使用Kotlin写Adapter的列子,我想了半天也没有组织好语言,直接上代码吧,有一定Android基础的小伙伴肯定是能看的懂的 package com.example.administrator.kotlintest import android.content.Context import android.view.LayoutInflater import android.view.View import android.view.ViewGroup import and

  • Kotlin封装RecyclerView Adapter实例教程

    前言 Kotlin越来越流行,在Google的推动下发展的很迅猛,现在的项目大多使用上了Kotlin,其简练的语法糖确实能减少不少代码. Adapter的封装GitHub上有很多了,但大多数封装的太好了,是的,使用太简单了,使用简单.封装力度大就导致灵活性和代码复杂性上升,谁用谁知道,当然也有封装简单的. 这里我借助Kotlin的简单语法再次操刀封装了一下. 先看下使用 单类型的使用 val adapter=recyclerView.setUp(users, R.layout.item_layo

  • 详解分别用Kotlin和java写RecyclerView的示例

    本文介绍了分别用Kotlin和java写RecyclerView的示例,分享给大家,具体如下: java:跟一般的写法一样,增加了按钮响应 MainActivity: public class MainActivity extends AppCompatActivity implements RecyclerAdapter.OnItemClickListener{ private RecyclerView mRecyclerView; private RecyclerView.LayoutMan

  • 详解基于IDEA2020.1的JAVA代码提示插件开发例子

    之前因为项目组有自己的代码规范,为了约束平时的开发规范,于是基于2019.1.3版本开发了一个代码提示的插件.但是在把IDEA切换到2020.1版本的时候,却发现疯狂报错,但是网上关于IDEA插件开发的相关文章还是不够多,只能自己解决.于是根据官方的SDK文档,使用Gradle重新构建了一下项目,把代码拉了过来.下文会根据2020.1版本简单开发一个代码异常的提示插件,把容易踩坑的地方提示一下. 1.首先先根据IDEA插件开发官方文档,用Gradle新建一个project 选中file -> n

  • Spring学习笔记1之IOC详解尽量使用注解以及java代码

    在实战中学习Spring,本系列的最终目的是完成一个实现用户注册登录功能的项目. 预想的基本流程如下: 1.用户网站注册,填写用户名.密码.email.手机号信息,后台存入数据库后返回ok.(学习IOC,mybatis,SpringMVC的基础知识,表单数据验证,文件上传等) 2.服务器异步发送邮件给注册用户.(学习消息队列) 3.用户登录.(学习缓存.Spring Security) 4.其他. 边学习边总结,不定时更新.项目环境为Intellij + Spring4. 一.准备工作. 1.m

  • 详解多云架构下的JAVA微服务技术解析

    微服务生态 微服务生态本质上是一种微服务架构模式的实现,包括微服务开发SDK,以及微服务基础设施. 目前比较成熟的 JAVA 微服务生态包括 servicecomb(华为), spring-cloud (Pivotal), dubbo(阿里), tsf(腾讯)等.gRPC.Thrift 等也用于内部服务之间的通信,但是微服务基础设施比较欠缺. 核心的微服务基础设施包括:注册中心.配置中心.应用网关.此外,分布式事物管理.计划任务.调用链跟踪系统等也是微服务基础设施的组成部分.完整的微服务基础实施

  • 详解Jest 如何支持异步及时间函数实现示例

    目录 异步支持 回调函数 callback promise Mock Timer 基本使用 模拟时钟的机制 典型案例 问题分析 解决方法 总结 异步支持 在前端开发中,我们会遇到很多异步代码,那么就需要测试框架对异步必须支持,那如何支持呢? Jest 支持异步有两种方式:回调函数及 promise(async/await). 回调函数 callback const fetchUser = (cb) => { setTimeout(() => { cb('hello') }, 100) } //

  • 详解Python中@staticmethod和@classmethod区别及使用示例代码

    本文主要介绍Python中,class(类)的装饰器@staticmethod和@classmethod的使用示例代码和它们的区别. 1.@staticmethod和@classmethod区别 @staticmethod:静态方法 @classmethod:类方法 一般来说,要使用某个类的方法,需要先实例化一个对象再调用方法. 而使用@staticmethod或@classmethod,就可以不需要实例化,直接通过类名就可以实现调用 使用:直接类名.方法名()来调用.@staticmethod

  • 详解Node.js使用token进行认证的简单示例

    本文只介绍简单的应用,关于json web token的具体介绍以及原理请参考阮一峰老师的JSON Web Token 入门教程. 使用的Node框架是koa2,前端发送ajax请求使用axios 首先创建工程目录: static中存放静态资源,views存放前端模板,server.js为后端代码. 安装必要的依赖项: "dependencies": { "@koa/router": "^8.0.8", "jsonwebtoken&qu

  • 详解el Cascader懒加载数据回显示例

    正文 数据回显时保证 v-model props options 绑定的数据是正确的. 调用 props.lazyLoad 方法中的 resolve 回掉函数设置数据,示例来自el官网. 好多例子中说需要设置 options, 但是异步获取子节点,设置它是没有用的. <el-cascader :props="props"></el-cascader> <script> let id = 0 export default { data() { retu

  • 详解polyfills如何按需加载及场景示例详解

    目录 前言 青铜时代 火枪时代 webpack添加babel-loader @babel/preset-env @babel/polyfill 配置 useBuiltIns 加入 @babel/plugin-transform-runtime 前言 青铜时代 最使前端头痛的问题,莫过于浏览器兼容性,无论是js,还是css都要考虑浏览器兼容性问题,在webpack出来之前,这无非是一个非常头疼的问题,查到一个兼容性问题,查找很多资料,解决一下,再出来一个问题又要花很长时间解决一下,这无疑要花费很长

  • kotlin和Java的相互调用示例详解

    前言 互操作就是在Kotlin中可以调用其他编程语言的接口,只要它们开放了接口,Kotlin就可以调用其成员属性和成员方法,这是其他编程语言所无法比拟的.同时,在进行Java编程时也可以调用Kotlin中的API接口. 1.在kotlin中调用Java方法 Kotlin和Java是两种不同的语言,所以在互相调用的时候,会有一些特殊的语法.kotlin中对象属性默认就带有setter和getter方法,所以在kotlin中调用Java时直接变量名点属性就可获取到属性的setter和getter的一

随机推荐