返回顶部
首页 > 资讯 > 移动开发 >Android编程实现ListView滚动提示等待框功能示例
  • 355
分享到

Android编程实现ListView滚动提示等待框功能示例

示例listviewAndroid 2022-06-06 04:06:17 355人浏览 薄情痞子
摘要

本文实例讲述了Android编程实现ListView滚动提示等待框功能。分享给大家供大家参考,具体如下: 其实原理很简单,只需要设置监听listview的滚动事件即可 file

本文实例讲述了Android编程实现ListView滚动提示等待框功能。分享给大家供大家参考,具体如下:

其实原理很简单,只需要设置监听listview的滚动事件即可

file1:


package cn.stay.activity;
import java.util.ArrayList;
import java.util.List;
import com.aoran.R;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.ProgressBar;

public class ListView_sep extends Activity implements OnScrollListener {
  private List<String> list = new ArrayList<String>();
  private ListView listv01;
  private MyAdapter adapter;
  private int current_page = 2;
  ProgressBar progressBar;
  private LinearLayout bottom_linear;
  private int lastItem;
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    listv01 = (ListView) findViewById(R.id.listv01);
    bottom_linear=(LinearLayout) findViewById(R.id.bottom_linear);
    for (int i = 0; i < 100; i++) {
      list.add("i="+i);
    }
    adapter = new MyAdapter(ListView_sep.this, list);
    listv01.setAdapter(adapter);
//   listv01.setSelection(getSingerStrs().size()-1); 设置每次最后一行被选中
    listv01.setOnScrollListener(this);
  }
  @Override
  public void onScrollStateChanged(AbsListView view, int scrollState) {
    if (lastItem==adapter.count && scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
      if ((list.size() - current_page * 10) > 0) {
        bottom_linear.setVisibility(View.VISIBLE);
        if ((list.size() - current_page * 10) >= 10) {
          adapter.count += 10;
        } else {
          adapter.count += (list.size() - current_page * 10);
        }
        current_page++;
        adapter.notifyDataSetChanged();
//       bottom_linear.setVisibility(View.GoNE);
      }
    }
  }
  @Override
  public void onScroll(AbsListView view, int firstVisibleItem,
      int visibleItemCount, int totalItemCount) {
      lastItem=firstVisibleItem+visibleItemCount;
  }
}

file2:


package cn.stay.activity;
import java.util.List;
import com.aoran.R;
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 MyAdapter extends BaseAdapter{
  private Context mContext;
  private List<String> list;
  public int count=20;
  private ViewHolder holder;
  public MyAdapter(Context mContext,List<String> list) {
    this.mContext=mContext;
    this.list=list;
  }
  @Override
  public int getCount() {
    return count;
  }
  @Override
  public Object getItem(int position) {
    // TODO Auto-generated method stub
    return list.get(position);
  }
  @Override
  public long getItemId(int position) {
    return position;
  }
  @Override
  public View getView(int position, View convertView, ViewGroup parent) {
    // TODO Auto-generated method stub
    if(convertView==null || convertView.getTag()==null){
      convertView=LayoutInflater.from(mContext).inflate(R.layout.adapter,null);
      holder = new ViewHolder();
      holder.adapter_tv=(TextView) convertView.findViewById(R.id.adapter_tv);
      convertView.setTag(holder);
      }else{
        holder=(ViewHolder) convertView.getTag();
      }
    holder.adapter_tv.setText(list.get(position));
    return convertView;
  }
  private class ViewHolder{
    private TextView adapter_tv;
  }
}

file3:

main.xml


<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="Http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:background="@drawable/project_main_bg"
  >
  <LinearLayout android:id="@+id/bottom_linear" android:layout_alignParentBottom="true" android:layout_width="fill_parent" android:layout_height="50dip" android:gravity="center" android:visibility="gone">
    <ProgressBar android:layout_width="24dip" android:layout_height="24dip" android:layout_marginLeft="20dip" />
    <TextView android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="正在加载,请稍后。。。" android:textColor="#FFFFFF" android:textSize="20sp" android:gravity="center"/>
  </LinearLayout>
  <ListView android:id="@+id/listv01" android:background="@null" android:layout_above="@id/bottom_linear" android:layout_width="fill_parent" android:layout_height="wrap_content" android:listSelector="#00000000" android:cacheColorHint="#00000000"/>
</RelativeLayout>

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android视图View技巧总结》、《Android布局layout技巧总结》、《Android图形与图像处理技巧总结》、《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

您可能感兴趣的文章:Android ListView滚动到指定的位置Android ListView滚动到底后自动加载数据Android基于ListView实现类似QQ空间的滚动翻页与滚动加载效果Android简单记录和恢复ListView滚动位置的方法Android程序开发之ListView实现横向滚动(带表头与固定列)Android开发ListView中下拉刷新上拉加载及带列的横向滚动实现方法Android程序开发ListView+JSON+异步网络图片加载+滚动翻页的例子(图片能缓存,图片不错乱)android ListView的右边滚动滑块启用方法 分享android listview 水平滚动和垂直滚动的小例子android ListView自动滚动方法android开发之横向滚动/竖向滚动的ListView(固定列头)


--结束END--

本文标题: Android编程实现ListView滚动提示等待框功能示例

本文链接: https://lsjlt.com/news/22302.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作