android 关于 ScrollView嵌套GridView,ListView 显示和滑动的问题

ScrollView GridView ListView 都有上下滑动的响应函数,所以嵌套在一起的话,里面那一层就监听不到滑动的响应。

如果不处理的话,GridView 和 ListView 在ScrollView中只会显示一部分高度,这样看起来不是很郁闷?


在特殊的情况下,我们需要嵌套起来使用才能符合界面的设计.

SO 在网上找了一些时间后,发现解决办法还是有的,一下是我个人觉得简单,易用,缺点不多的一种方法:

自定义一个类 继承GridView或者ListView,重写其中的 onMeasure 方法、、


onMeasure方法是在这个View构造的时候确定它的长度和宽度的方法。

我们重写的时候,要把滚动条设置为没有滚动条,Gridview就会按照有多少行,就显示多少行

废话少说,上代码

  1. public class MyGridView extends GridView {
  2. private boolean haveScrollbar = true;
  3. public MyGridView(Context context) {
  4. super(context);
  5. }
  6. public MyGridView(Context context, AttributeSet attrs) {
  7. super(context, attrs);
  8. }
  9. public MyGridView(Context context, AttributeSet attrs, int defStyle) {
  10. super(context, attrs, defStyle);
  11. }
  12. /**
  13. * 设置是否有ScrollBar,当要在ScollView中显示时,应当设置为false。 默认为 true
  14. *
  15. * @param haveScrollbars
  16. */
  17. public void setHaveScrollbar(boolean haveScrollbar) {
  18. this.haveScrollbar = haveScrollbar;
  19. }
  20. @Override
  21. protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  22. if (haveScrollbars == false) {
  23. int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
  24. super.onMeasure(widthMeasureSpec, expandSpec);
  25. } else {
  26. super.onMeasure(widthMeasureSpec, heightMeasureSpec);
  27. }
  28. }
  29. }

在xml中这么定义:

  1. <com.erp.android.control.NDGridView
  2. android:id="@+id/myGrideView"
  3. android:layout_width="fill_parent"
  4. android:layout_height="wrap_content"
  5. android:layout_gravity="center"
  6. android:columnWidth="100dp"
  7. android:gravity="center"
  8. android:numColumns="auto_fit" >
  9. </com.erp.android.control.MyGridView>


重写就重写了这一个地方,我认为的缺点就是设置之后不能上下滑动了,不过有ScrollView 可以代替这一功能

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值