源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

ListView-添加item的事件监听实例

  • 时间:2021-04-01 08:17 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:ListView-添加item的事件监听实例
[b]1. 点击事件(OnItemClickListener)[/b]
onItemClick(AdapterView<?> parent, View view, int position, long id)

[b]parent:[/b]官方解释为:The AdapterView where the click happened,也就是用户所点击的AdapterView,这个参数一般不用。 [b]view:[/b]当前点击的列表项所对应的布局View对象,可通过这个参数获得相应的列表项内部的组件,进而对其进行操作。举个例子,假设有一个ListView,含有4个列表项,你点了第2个,那么通过view你就可以操作第2个列表项里面的TextView、ImageView等等的组件(假设存在)。 [b]position:[/b]当前点击的列表项的位置,从0开始,也就是点击第n个,position就是n-1。 [b]id:[/b]当前点击的列表项的序号,也是从0开始,所以大部分时候position和id是一样的,至于这两个参数之间有什么不同,有兴趣的童鞋可以深究一下。
public class MainActivity extends Activity implements AdapterView.OnItemClickListener{

  private ListView myListView;
  private SimpleAdapter simpleAdapter;
  private List<Map<String, Object>> data;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    data = new ArrayList<Map<String, Object>>();
    simpleAdapter = new SimpleAdapter(this, getData(), R.layout.item, new String[]{"img", "text"}, new int[]{R.id.img, R.id.text});
    myListView = (ListView) findViewById(R.id.myListView);
    //设置监听器
    myListView.setAdapter(simpleAdapter);
    myListView.setOnItemClickListener(this);
  }

  private List<Map<String, Object>> getData() {
    for (int i = 0; i < 20; i++) {
      Map<String, Object>map = new HashMap<String, Object>();
      map.put("img", R.mipmap.ic_launcher);
      map.put("text", "初始simpleAdapter"+(i+1));
      data.add(map);
    }

    return data;
  }

  @Override
  public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
    //通过view获取其内部的组件,进而进行操作
    String text = (String) ((TextView)view.findViewById(R.id.text)).getText();
    //大多数情况下,position和id相同,并且都从0开始
    String showText = "点击第" + position + "项,文本内容为:" + text + ",ID为:" + id;
    Toast.makeText(this, showText, Toast.LENGTH_LONG).show();
  }
}
[b]2. 滚动事件(OnScrollListener)[/b]
void onScrollStateChanged(AbsListView view, int scrollState)
监听滚动状态的变化。 [b]view:[/b]正在被滚动的视图,也就是当前的ListView。 [b]scrollState:[/b]滚动状态,分别有以下几种: [b]SCROLL_STATE_TOUCH_SCROLL:[/b]滑动状态,手指在视图滑动,并且手指一直停留在屏幕上而未离开。 [b]SCROLL_STATE_FLING:[/b]投掷状态,手指在离开视图前,用力划了一下(想象将视图投掷出去的感觉),视图会按照惯性滑动至停止。 [b]SCROLL_STATE_IDLE:[/b]闲置状态,什么都没做的状态。当投掷状态或触摸滚动状态结束时,进入闲置状态。 void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) 监听非滚动状态,只要ListView不滚动,就会被不断调用。 [b]view:[/b]正在被滚动的视图,也就是当前的ListView。 [b]firstVisibleItem:[/b]已加载的第一个列表项的索引值。 [b]visibleItemCount:[/b]已加载的列表项的总数。 [b]totalItemCount:[/b]适配器中数据源对应的列表项总数。
public class MainActivity extends Activity implements AbsListView.OnScrollListener{

  private ListView myListView;
  private SimpleAdapter simpleAdapter;
  private List<Map<String, Object>> data;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);

    data = new ArrayList<Map<String, Object>>();
    simpleAdapter = new SimpleAdapter(this, getData(), R.layout.item, new String[]{"img", "text"}, new int[]{R.id.img, R.id.text});
    myListView = (ListView) findViewById(R.id.myListView);
    myListView.setAdapter(simpleAdapter);

    //设置监听器
    myListView.setOnScrollListener(this);
  }

  private List<Map<String, Object>> getData() {
    for (int i = 0; i < 20; i++) {
      Map<String, Object>map = new HashMap<String, Object>();
      map.put("img", R.mipmap.ic_launcher);
      map.put("text", "初始simpleAdapter"+(i+1));
      data.add(map);
    }

    return data;
  }

  @Override
  public void onScrollStateChanged(AbsListView view, int scrollState) {
    switch (scrollState) {
      //投掷状态
      case SCROLL_STATE_FLING:
        Toast.makeText(this, "SCROLL_STATE_FLING", Toast.LENGTH_SHORT).show();
        break;
      //闲置状态
      case SCROLL_STATE_IDLE:
        Toast.makeText(this, "SCROLL_STATE_IDLE", Toast.LENGTH_SHORT).show();
        break;
      //滑动状态
      case SCROLL_STATE_TOUCH_SCROLL:
        Toast.makeText(this, "SCROLL_STATE_TOUCH_SCROLL", Toast.LENGTH_SHORT).show();
        break;
    }
  }

  @Override
  public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
//    Toast.makeText(this, "滚动已停止,已加载的第一项的索引为:" + firstVisibleItem +
//            ",已加载的列表项总数为:" + visibleItemCount + ",存在的列表项总数为:" +
//            totalItemCount, Toast.LENGTH_LONG).show();
  }
}
以上这篇ListView-添加item的事件监听实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部