热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

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

本文介绍了分别用Kotlin和java写RecyclerView的示例,分享给大家,具体如下: java:跟一般的写法一样,增加了按钮

本文介绍了分别用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 &#63; 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:



  
  


recycler_item:


  

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

MainActivity:

class MainActivity : AppCompatActivity(), MainAdapter.ItemClick{
  val items : MutableList = ArrayList()
  var mainAdapter : MainAdapter &#63;= null
  override fun onCreate(savedInstanceState:Bundle&#63;) {
    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&#63; = null
  var context : Context &#63;= null
  var itemClick : ItemClick &#63;= 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&#63;, 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&#63;, 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&#63;) : 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:


  
  

recycler_item:


  xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_
  android:layout_>
  

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


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 本文介绍如何在 Android 中通过代码模拟用户的点击和滑动操作,包括参数说明、事件生成及处理逻辑。详细解析了视图(View)对象、坐标偏移量以及不同类型的滑动方式。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本文介绍如何在 Unity 的 XML 配置文件中,将参数传递给自定义生命周期管理器的构造函数。我们将详细探讨 CustomLifetimeManager 类的实现及其配置方法。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
  • 本文详细介绍了如何解决MyBatis中常见的BindingException错误,提供了多种排查和修复方法,确保Mapper接口与XML文件的正确配置。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
author-avatar
川大蛋炒饭-_246
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有