zoukankan      html  css  js  c++  java
  • ListView的基本使用技巧

    ListView的基本使用技巧

    1、headerView和footerView

    2、ViewHolder

    3、OnScrollListener

    4、单行刷新

    5、其它细节


    ListView提供headerView和footerView



    由于ListView事实上是一个ScrollView。而Android的设计是不建议多个ScrollView包括在一起的。所以列表提供headerview和footerview。

    使用这两个须要注意的事项,listView在滑动的时候可能会消耗headerView的事件,表现为。当点击headerview的时候,不能及时的响应,原因是listview可能在滚动。

    滚动有时候没有那么明显。就给造成点击不敏感的效果。

    解决的方法:


    能够重载onInterceptTouchEvent方法,在这种方法里面依据条件分发事件。

    当然也能够让列表重写onTouch方法,在列表的onTouch方法里面调用Headerview.dispatchTouchEvent方法,而让HeaderView不接受事件。

    ListView设置FooterView和headerView ,在调用setAdapter()之前调。

     

    footerView能够单独写点击触发事件,可是注意最好写在listview的 OnItemClickListener()里面,然后依据点击的位置 

     if(position == mListView.getCount - 1){"触发footerview点击事件"} 

    假设是单独给它一个View.onClickListener的话。点击是能够触发事件的。可是没有listview的item按下的变黄色效果。 


    android 自己定义listview无法响应点击事件OnItemClickListener 

    假设你的自己定义ListViewItem中有Button或者Checkable的子类控件的话,那么默认focus是交给了子控件。而ListView的Item能被选中的基础是它能获取Focus,也就是说我们能够通过将ListView中Item中包括的全部控件的focusable属性设置为false,这种话ListView的Item自己主动获得了Focus的权限。也就能够被选中了 

    我们能够通过对Item Layout的根控件设置其android:descendantFocusability=”blocksDescendants”就可以,这样Item Layout就屏蔽了全部子控件获取Focus的权限,不须要针对Item Layout中的每个控件又一次设置focusable属性了,如此就能够顺利的响应onItemClickListener中的onItemClick()方法了。


    ViewHolder注意是性能的问题

    http://www.360doc.com/content/14/0917/15/15077656_410189820.shtml

    这样写的问题是异步载入的时候。会出新错乱。

    由于view可能被循环利用了。

    解决的办法网上说有:View.setTag(), listview.findViewWithTag();可是不一定不好使,得看你的Item的布局。

    比較好用是的getView。当你异步完毕的时候调用getView。


    OnScrollListener

    列表的滚动监听

    获取列表滚动的长度:

    http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2014/0924/1711.html

    滚动时候不载入,滚动停止载入

    http://www.2cto.com/kf/201405/303570.html


    单行刷新

    大部分时候。大家用的列表刷新都是notifyDataSetChanged方法,这种方法通常是所有刷新。所以非常费劲。当列表非常长的时候,你要是刷新一遍就费劲了。getView方法能够单行刷新。所以能够刷新须要变换的。不须要变换的不刷新。


    固定列表高的写法

    重写listview的方法,设置指定的高就可以固定列表的高。

    setMeasuredDimension(widthMeasureSpec, height | MeasureSpec.AT_MOST);

    须要注意的是当固定了列表的高后。列表的载入优化就会失效了,第一次载入的时候,会载入列表高的全部View。这就非常费时,须要注意。当列表非常长的时候,尽量不使用这样的指定了超过屏幕高的列表高的写法。


    android 提供的非常多List控件如 listview、gridview 默认都会显示一个fadingedge的东西。它在View的top和bottom处各显示一个渐变半透的阴影以达到更好的视觉效果,可是这个带来的副作用就是导致在性能不是那么强劲的机器上,一些listview,gridview的拖动会显得非常不流畅。由于我们知道绘制带Alpha的图片是最耗时的。 

    我们的优化思路就是对这个fadingedge做一些改动。当view处于滚动状态时。通过接口setVerticalFadingEdgeEnabled(false)让其不显示fadingedge,当view处于精巧状态时,通过接口setVerticalFadingEdgeEnabled(true)恢复显示fadingedge。

    以上的listview和gridview等控件都是继承与AbsListView,所以我们直接改动framework中的AbsListView.java文件。就能够达到系统级的改动效果了


    1.怎样取消Listview的滚动栏? 

      setVerticalScrollBarEnabled(false)


    2.白色的背景。ListView滚屏进行中的时候。背景会变成黑色,解决的方法? 

      android:cacheColorHint="#00000000" 


    3.ListView滚动栏怎么一直都显示? 

      android:fadeScrollbars="false" 


    4.ListView隔行变色: 

      int[] colors={Color.BLUE,Color.CYAN}; 

      convertView.setBackgroundColor(colors[position%2]); 


    5.ListView中嵌套了checkbox,焦点会到checkbox身上,解决的方法 

      holder.checkBox.setFocusable(false); 


    6.listView滚动轴图片更改? 

       android:scrollbarThumbHorizontal=""   //滚动轴游标 

       android:scrollbarTrackVertical=""  //滚动轴背景、 

       引用的是9patch图片 


    7.ListView设置EmptyView? 

       mListView.serEmptyView(); 

       Sets the view to show if the adapter is empty这个就是对此方法的描写叙述 

        当listview的adapter为null的时候,就会显示所设置的view。 

        须要注意的有两点:在调用setAdapter()之前调这种方法;设置的emptyview必须放 在listview的直接父布局里,比方说listview嵌在一个LinearLayout里面的话。须要在代码里面写  mLinearLayout.addContentView(你的emptyview); 

       否则的话是没效果的。

     

    8、getFirstVisiblePosition()。该方法获取当前状态下list的第一个可见item的position。

    9、getLastVisiblePosition()。该方法获取当前状态下list的最后一个可见item的position。


    10、getItemAtPosition(int position),该方法返回当前状态下position位置上listView的convertView






  • 相关阅读:
    PCB 设计文件中哪些可以不做成元件
    IAR 9+ 编译 TI CC2541 出现 Segment ISTACK (size: 0xc0 align: 0) is too long for segment definition.
    每日一条 git 命令行:git clone https://xxxxx.git -b 12.0 --depth 1
    FastAdmin Bootstrap-table 特定某行背景变红
    如何查看 ThinkPHP5.1 的升级说明
    Windows 2008 关闭远程桌面的单用户多会话模式
    来测试一下你的“金耳朵”
    笔记:关于网站的流量攻击
    排序算法视频 《6 分钟演示 15 种排序算法》
    【转】移动web页面支持弹性滚动的3个方案
  • 原文地址:https://www.cnblogs.com/mthoutai/p/7116610.html
Copyright © 2011-2022 走看看