我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android:下拉刷新+加载更多+滑动删除实例讲解

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android:下拉刷新+加载更多+滑动删除实例讲解

         小伙伴们在逛淘宝或者是各种app上,都可以看到这样的功能,下拉刷新和加载更多以及滑动删除,刷新,指刷洗之后使之变新,比喻突破旧的而创造出新的,比如在手机上浏览新闻的时候,使用下拉刷新的功能,我们可以第一时间掌握最新消息,加载更多是什么nie,简单来说就是在网页上逛淘宝的时候,我们可以点击下一页来满足我们更多的需求,但是在手机端就不一样了,没有上下页,怎么办nie,方法总比困难多,细心的小伙伴可能会发现,在手机端中,有加载更多来满足我们的要求,其实加载更多也是分页的一种体现。小伙伴在使用手机版QQ的时候,消息界面会有很多的信息,如果你也像小编一样有强迫症,想把看完的消息进行删除,怎么办nie,QQ实现了向右滑动删除的功能,最近在小编的项目中,就遇到这样的功能下拉刷新和加载更多以及滑动删除,经过几天的捣鼓,当冬日的第二缕阳光照到小编身上的时候,小编终于把她捣鼓出来了,今天这篇博客,小编主要和小伙伴们分享下拉刷新和加载更多一级滑动删除,希望可以帮助到有需要的小伙伴,还请小伙伴们多多指教。

       首先我们需要来编写xml里面的内容,我们命名为activity_item,具体代码如下所示:

XML/HTML代码


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:id="@+id/ll_parent" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" 
  android:background="@android:color/darker_gray" 
  android:orientation="vertical" > 
  <TextView 
    android:id="@+id/tv_text" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:gravity="center" 
    android:textSize="25sp" /> 
</LinearLayout>

       接着,我们来编写list_item里面有关xml的代码,具体代码如下所示:

XML/HTML代码


<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  xmlns:tools="http://schemas.android.com/tools" 
  android:id="@+id/ll_parent" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" 
  android:gravity="center" 
  android:background="@android:color/darker_gray" 
  tools:context=".MainActivity" > 
  <TextView 
    android:id="@+id/list_item_textview" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_centerVertical="true" 
    android:textColor="#000" 
    android:textSize="16sp" /> 
  <FrameLayout 
    android:layout_width="wrap_content" 
    android:layout_height="match_parent" 
    android:layout_centerVertical="true" 
    android:layout_alignParentRight="true" 
    android:padding="15dp" > 
    <TextView 
      android:id="@+id/tv_functions" 
      android:layout_width="90dp" 
      android:layout_height="50dp" 
      android:layout_gravity="center" 
      android:background="@drawable/btn_del_bg" 
      android:gravity="center" 
      android:textColor="@android:color/white" 
      android:text="删除" />  
    <TextView 
      android:id="@+id/tv_coating" 
      android:layout_width="90dp" 
      android:layout_height="50dp" 
      android:background="@android:color/darker_gray" 
      android:layout_gravity="center" 
      android:visibility="gone" /> 
  </FrameLayout> 
</RelativeLayout> 

       第三步,我们来编写main里面的xml文件,具体代码如下所示:

XML/HTML代码


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="fill_parent" 
  android:layout_height="fill_parent" 
  android:background="#f0f0f0" 
  android:orientation="vertical" > 
  <TextView 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:text="@string/hello" /> 
  <me.maxwin.view.XListView 
    android:id="@+id/xListView" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:cacheColorHint="#00000000" > 
  </me.maxwin.view.XListView> 
</LinearLayout> 

       第四步,我们来编写xlistview_footer里面的xml文件,具体代码如下所示:

XML/HTML代码


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="fill_parent" 
  android:layout_height="wrap_content" > 
  <RelativeLayout 
    android:id="@+id/xlistview_footer_content" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:padding="10dp" > 
    <ProgressBar 
      android:id="@+id/xlistview_footer_progressbar" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_centerInParent="true" 
      android:visibility="invisible" /> 
    <TextView 
      android:id="@+id/xlistview_footer_hint_textview" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_centerInParent="true" 
      android:text="@string/xlistview_footer_hint_normal" /> 
  </RelativeLayout> 
</LinearLayout>

       第五步,我们来编写xlistview_header里面的xml文件,具体代码如下所示:

XML/HTML代码


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="fill_parent" 
  android:layout_height="wrap_content" 
  android:gravity="bottom" > 
  <RelativeLayout 
    android:id="@+id/xlistview_header_content" 
    android:layout_width="fill_parent" 
    android:layout_height="60dp" > 
    <LinearLayout 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_centerInParent="true" 
      android:gravity="center" 
      android:orientation="vertical" android:id="@+id/xlistview_header_text"> 
      <TextView 
        android:id="@+id/xlistview_header_hint_textview" 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:text="@string/xlistview_header_hint_normal" /> 
      <LinearLayout 
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content" 
        android:layout_marginTop="3dp" > 
        <TextView 
          android:layout_width="wrap_content" 
          android:layout_height="wrap_content" 
          android:text="@string/xlistview_header_last_time" 
          android:textSize="12sp" /> 
        <TextView 
          android:id="@+id/xlistview_header_time" 
          android:layout_width="wrap_content" 
          android:layout_height="wrap_content" 
          android:textSize="12sp" /> 
      </LinearLayout> 
    </LinearLayout> 
    <ImageView 
      android:id="@+id/xlistview_header_arrow" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:layout_alignLeft="@id/xlistview_header_text" 
      android:layout_centerVertical="true" 
      android:layout_marginLeft="-35dp" 
      android:class="lazy" data-src="@drawable/xlistview_arrow" /> 
    <ProgressBar 
      android:id="@+id/xlistview_header_progressbar" 
      android:layout_width="30dp" 
      android:layout_height="30dp" 
      android:layout_alignLeft="@id/xlistview_header_text" 
      android:layout_centerVertical="true" 
      android:layout_marginLeft="-40dp" 
      android:visibility="invisible" /> 
  </RelativeLayout> 
</LinearLayout> 

       至此,关于我们的布局xml文件的代码都已经写完了,接着,我们开始编写java类里面的代码,首先,我们来编写ItemActivity里面的代码,具体代码如下所示:

Java代码


import android.app.Activity; 
import android.os.Bundle; 
import android.view.MotionEvent; 
import android.view.View; 
import android.view.View.OnTouchListener; 
import android.widget.TextView; 
public class ItemActivity extends Activity implements OnTouchListener { 
  private float x, upx; 
  protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_item); 
    init(); 
  } 
  private void init() { 
    findViewById(R.id.ll_parent).setOnTouchListener(this); 
    ((TextView) findViewById(R.id.tv_text)).setText(getIntent().getStringExtra("item")); 
  } 
  public boolean onTouch(View v, MotionEvent event) { 
    if (event.getAction() == MotionEvent.ACTION_DOWN) { 
      x = event.getX(); 
    } 
    if (event.getAction() == MotionEvent.ACTION_UP) { 
      upx = event.getX(); 
      if (Math.abs(x - upx) > 20) { 
        this.finish(); 
        overridePendingTransition(0, R.anim.slide_out_to_right); 
      } 
    } 
    return true; 
  } 
} 

      接着,我们来编写适配器adapter里面的代码,具体代码如下所示:

Java代码


import java.util.ArrayList; 
import android.content.Context; 
import android.view.LayoutInflater; 
import android.view.View; 
import android.view.ViewGroup; 
import android.widget.BaseAdapter; 
import android.widget.TextView; 
public class ItemAdapter extends BaseAdapter { 
  private LayoutInflater inflater; 
  private ArrayList<String> datas; 
  public ItemAdapter(Context context) { 
    inflater = LayoutInflater.from(context); 
  } 
  public void setData(ArrayList<String> datas) { 
    this.datas = datas; 
  } 
  public int getCount() { 
    return datas.size(); 
  } 
  public Object getItem(int position) { 
    return datas.get(position); 
  } 
  public long getItemId(int position) { 
    return position; 
  } 
  public View getView(final int position, View convertView, ViewGroup parent) { 
    ViewHolder holder = null; 
    if (convertView == null) { 
      holder = new ViewHolder(); 
      convertView = inflater.inflate(R.layout.list_item, null); 
      holder.coating = (TextView) convertView.findViewById(R.id.tv_coating); 
      holder.functions = (TextView) convertView.findViewById(R.id.tv_functions); 
      holder.list_item_textview=(TextView) convertView.findViewById(R.id.list_item_textview); 
      convertView.setTag(holder); 
    } else { 
      holder = (ViewHolder) convertView.getTag(); 
    } 
    holder.list_item_textview.setText(datas.get(position)); 
    holder.coating.setVisibility(View.VISIBLE); 
    holder.functions.setClickable(false); 
    return convertView; 
  } 
  public final class ViewHolder { 
    public TextView coating; 
    public TextView functions; 
    public TextView list_item_textview; 
  } 
} 

      最后我们来编写XListViewActivity里面的代码,具体代码如下所示:

Java代码


import java.util.ArrayList; 
import me.maxwin.view.XListView; 
import me.maxwin.view.XListView.IXListViewListener; 
import me.maxwin.view.XListView.RemoveListener; 
import android.app.Activity; 
import android.content.Context; 
import android.content.Intent; 
import android.os.Bundle; 
import android.os.Handler; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
public class XListViewActivity extends Activity implements IXListViewListener ,RemoveListener,OnItemClickListener{ 
  private XListView mListView; 
// private ArrayAdapter<String> mAdapter; 
  private ItemAdapter adapter; 
// private Context context; 
  private ArrayList<String> items = new ArrayList<String>(); 
  private Handler mHandler; 
  private int start = 0; 
  private static int refreshCnt = 0; 
   
  @Override 
  public void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.main); 
    geneItems(); 
    init(); 
    mHandler = new Handler(); 
  } 
  private void init() { 
    // TODO Auto-generated method stub 
    mListView = (XListView) findViewById(R.id.xListView); 
    mListView.setPullLoadEnable(true); 
    mListView.setRemoveListener(this); 
    mListView.setOnItemClickListener(this); 
//   mListView.setPullLoadEnable(false); 
//   mListView.setPullRefreshEnable(false); 
    mListView.setXListViewListener(this); 
    adapter=new ItemAdapter(this); 
    adapter.setData(items); 
    mListView.setAdapter(adapter); 
  } 
  private void geneItems() { 
    for (int i = 0; i != 20; ++i) { 
      items.add("refresh cnt " + (++start)); 
    } 
  } 
  private void onLoad() { 
    mListView.stopRefresh(); 
    mListView.stopLoadMore(); 
    mListView.setRefreshTime("刚刚"); 
  } 
  @Override 
  public void onRefresh() { 
    mHandler.postDelayed(new Runnable() { 
      @Override 
      public void run() { 
        start = ++refreshCnt; 
        items.clear(); 
        geneItems(); 
        // mAdapter.notifyDataSetChanged(); 
        adapter=new ItemAdapter(XListViewActivity.this); 
        adapter.setData(items); 
        mListView.setAdapter(adapter); 
        onLoad(); 
      } 
    }, 2000); 
  } 
  @Override 
  public void onLoadMore() { 
    mHandler.postDelayed(new Runnable() { 
      @Override 
      public void run() { 
        geneItems(); 
        adapter.notifyDataSetChanged(); 
        onLoad(); 
      } 
    }, 2000); 
  } 
  @Override 
  public void removeItem(int position) { 
    // TODO Auto-generated method stub 
    mListView.isSlide = false; 
    mListView.itemView.findViewById(R.id.tv_coating).setVisibility(View.VISIBLE); 
    items.remove(position); 
    adapter.notifyDataSetChanged(); 
  } 
  @Override 
  public void onItemClick(AdapterView<?> parent, View view, int position, 
      long id) { 
    // TODO Auto-generated method stub 
    Intent intent = new Intent(getApplicationContext(), ItemActivity.class); 
    intent.putExtra("item", items.get(position)); 
    startActivity(intent); 
    overridePendingTransition(R.anim.slide_in_from_right, R.anim.remain_original_location); 
  } 
} 

      至此,以上就是Android 实现 下拉刷新和加载以及滑动删除的知识整理,谢谢大家对本站的支持!          

您可能感兴趣的文章:Android Handler 机制实现原理分析Android 个人理财工具六:显示账单明细 下Android 个人理财工具五:显示账单明细 上Android 个人理财工具四:添加账单页面 下Android仿微信通讯录打造带悬停头部的分组列表(上)最常见的猜拳小游戏Android代码实现Android 音乐播放器的开发实例详解Android开发之ListView、GridView 详解及示例代码Android 应用中插入广告的实例Android系统进程间通信Binder机制在应用程序框架层的Java接口源代码分析Android WebP 图片压缩与传输


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android:下拉刷新+加载更多+滑动删除实例讲解

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Android:下拉刷新+加载更多+滑动删除实例讲解

小伙伴们在逛淘宝或者是各种app上,都可以看到这样的功能,下拉刷新和加载更多以及滑动删除,刷新,指刷洗之后使之变新,比喻突破旧的而创造出新的,比如在手机上浏览新闻的时候,使用下拉刷新的功能,我们可以第一时间掌握最新消息,加
2022-06-06

Android下拉刷新上拉加载更多左滑动删除

一、前言老规矩,别的不说,这demo是找了很相关知识集合而成的,可以说对我这种小白来说是绞尽脑汁!程序员讲的是无图无真相! 现在大家一睹为快!二、比较关键的还是scroller这个类的package com.icq.slideview.vi
2022-06-06

Android ListView实现上拉加载下拉刷新和滑动删除功能

最近项目需要用到可以滑动删除并且带有上拉加载下拉刷新的Listview,查阅了一些资料,大多都是在SwipeMenuListView的基础上去添加头部和底部View,来扩展上拉加载和下拉刷新的功能,不过需要手动的去绘制UI及处理一些动画效果
2022-06-06

android RecyclerView侧滑菜单,滑动删除,长按拖拽,下拉刷新上拉加载

本文介绍的库中的侧滑效果借鉴自SwipeMenu,并对SipwMenu的源码做了修改与Bug修复,然后才开发出的SwipeRecyclerView。需要说明的是,本库没有对RecyclerView做大的修改,只是ItemView的封装。看起
2022-06-06

Android ListView下拉刷新上拉自动加载更多DEMO示例

代码下载地址已经更新。因为代码很久没更新,已经很落伍了,建议大家使用RecyclerView实现。 参考项目:https://github.com/bingoogolapple/BGARefreshLayout-Androidhttps:/
2022-06-06

Android程序开发之Listview下拉刷新上拉(滑动分页)加载更多

最近做的类似于微博的项目中,有个Android功能要使用到listview的向下拉刷新来刷新最新消息,向上拉刷新(滑动分页)来加载更多。新浪微博就是使用这种方式的典型。 当用户从网络上读取微博的时候,如果一下子全部加载用户未读的微博这将耗费
2022-06-06

Android之RecyclerView轻松实现下拉刷新和加载更多示例

今天研究了下RecyclerView的滑动事件,特别是下拉刷新和加载更多事件,在现在几乎所有的APP显示数据列表时都用到了。自定义RecyclerView下拉刷新和加载更多听上去很复杂,实际上并不难,只要是对滑动事件的监听和处理。 一、自定
2022-06-06

android瀑布流,完美解决滑动过程中item位置错乱,下拉刷新顶部空白,加载更多顶部错乱等问题

StaggerdRecyclerView android瀑布流,完美解决滑动过程中item位置错乱,下拉刷新顶部空白,加载更多顶部错乱等问题,还可以实现动画效果 效果图集成 allprojects {repositories {...mav
2022-06-06

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录