当前位置: 移动技术网 > IT编程>移动开发>Android > Android解决ScrollView下嵌套ListView和GridView中内容显示不全的问题

Android解决ScrollView下嵌套ListView和GridView中内容显示不全的问题

2019年07月31日  | 移动技术网IT编程  | 我要评论

最近为公司做的一个demo里面用到了scrollview嵌套了gridview和listview,然而在嵌套的时候我发现gridview和listview都是不能完全显示,显示的基本上都是单行的数据,最后查找资料和翻阅文档看到原因是listview和gridview的绘制过程中在scrollview中无法准确的测量自身的高度,而且listview和gridview抢占了焦点,使得listview和grideview具有自身的显示的效果,这样就测量出显示一行条目即可的距离,其他的条目根据自身的滑动显示。

我的xml的部分代码如下:

<scrollview 
  android:layout_height="match_parent"
  android:layout_width="fill_parent"
  android:scrollbars="none"
  >
  <linearlayout
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="#23000000"
    android:orientation="vertical"
    android:paddingtop="-1dp" >
    <android.support.v4.view.viewpager
      android:id="@+id/home_pager"
      android:layout_width="fill_parent"
      android:layout_height="100dp" >
    </android.support.v4.view.viewpager>
    <gridview
      android:id="@+id/gv_home"
      android:layout_width="fill_parent"
      android:layout_height="wrap_content"
      android:numcolumns="5"
      android:paddingbottom="10dp"
      android:paddingtop="13dp" >
    </gridview>
    <linearlayout
      android:id="@+id/ll_clickin"
      android:layout_width="fill_parent"
      android:layout_height="30dp"
      android:layout_marginbottom="10dp"
      android:layout_marginleft="10dp"
      android:layout_marginright="10dp"
      android:background="@drawable/shape_home"
      android:orientation="horizontal" >
      <imageview
        android:layout_width="85dp"
        android:layout_height="wrap_content"
        android:src="@drawable/click_in" />
      <textview
        android:layout_width="match_parent"
        android:layout_height="fill_parent"
        android:gravity="center"
        android:singleline="true"
        android:text="限时抢购 ,快点进入吧!"
        android:textsize="18sp" />
    </linearlayout>
    <listview
      android:id="@+id/list_home"
      android:layout_width="fill_parent"
      android:layout_height="wrap_content"
      android:background="#ffffff" >
    </listview>
  </linearlayout>
</scrollview>

显示的效果是这样的其中的listview和gridview是可以滑动的就是显示不全

用自己写的方法之后才显示出来了所有的条目 

那就不再废话了 把我个人研究的代码呈上

首先是关于listview的 (注意此方法必须方到setadapter()方法之后执行)

这是控件的查找

list_home = (listview) view.findviewbyid(r.id.list_home);
list_home.setadapter(new mylistviewadapter(grideview_list));
 list_home.setfocusable(false);//词句加不加像也没有什么影响,我是加的
 //setadapter之后调用
 getlistviewselfheight(list_home);

这是getlistviewselfheight(listview youlistview)

public void getlistviewselfheight(listview listview) {  
      // 获取listview对应的adapter  
    listadapter listadapter = listview.getadapter();  
    //健壮性的判断
    if (listadapter == null) {  
      return;  
    } 
    // 统计所有子项的总高度  
    int totalheight = 0;  
    for (int i = 0, len = listadapter.getcount(); i < len; i++) {  
      // listadapter.getcount()返回数据项的数目  
      view listitem = listadapter.getview(i, null, listview);  
      // 调用measure方法 传0是测量默认的大小
      listitem.measure(0, 0);  
      totalheight += listitem.getmeasuredheight();  
    }  
    //通过父控件进行高度的申请
    viewgroup.layoutparams params = listview.getlayoutparams();  
    //listadapter.getcount() - 1 从零开始 listview.getdividerheight()获取子项间分隔符占用的高度 
    params.height = totalheight+ (listview.getdividerheight() * (listadapter.getcount() - 1));  
    listview.setlayoutparams(params);  
  }

下面是gridview的方法和listview的测量的方法基本一样  但是listview是单行条目的不用在担心列的问题问gridview则是需要进行自己分行和自己分列的 所以要注意一下

        gv_home = (gridview) view.findviewbyid(r.id.gv_home);
  gv_home.setselector(new colordrawable(color.transparent));
 home_pager.setfocusable(false);
 gv_home.setadapter(new mygrigeviewadapter(grideview_list));
 getgridviewselfheight(gv_home);

下面是getgridviewselfheight(gridview yougrideview)(这个方法能解决问题但是感觉不是很好灵活性太差 我用的获取的列数始终获取不到,有看神看到了 给我回复)

public void getgridviewselfhetght(gridview gridview) {  
    // 获取gridview对应的adapter  
    listadapter adapter = gridview.getadapter();  
    if (adapter == null) {  
      return;  
    }  
    int totalheight = 0;  
    for (int i = 0, len = adapter.getcount(); i < len; i++) {  
      // gridview.getcount()返回数据项的数目  
      view listitem = adapter.getview(i, null, gridview);  
      // 计算子项view 的宽高  
      listitem.measure(0, 0);  
      //此处方法并不好
      //5其中5是我们在xml中的android:numcolumns="5"
      //fontdisplayutil.dip2px(myglobalapplication.getcontext(),3)设置下边据
      totalheight += listitem.getmeasuredheight()/5+fontdisplayutil.dip2px(myglobalapplication.getcontext(),3);  
    }  
    viewgroup.layoutparams params = gridview.getlayoutparams(); 
    params.height = totalheight;  
    gridview.setlayoutparams(params);  
  }

下面是fontdisplayutil类

import android.content.context;
/**
 * dp、sp 、 px之间的相互转化的工具类
 */
public class fontdisplayutil {
 /**
 * 将px值转换为dip或dp值,保证尺寸大小不变
 */
 public static int px2dip(context context, float pxvalue) {
 final float scale = context.getresources().getdisplaymetrics().density;
 return (int) (pxvalue / scale + 0.5f);
 }
 /**
 * 将dip或dp值转换为px值,保证尺寸大小不变
 */
 public static int dip2px(context context, float dipvalue) {
 final float scale = context.getresources().getdisplaymetrics().density;
 return (int) (dipvalue * scale + 0.5f);
 }
 /**
 * 将px值转换为sp值,保证文字大小不变
 */
 public static int px2sp(context context, float pxvalue) {
 final float fontscale = context.getresources().getdisplaymetrics().scaleddensity;
 return (int) (pxvalue / fontscale + 0.5f);
 }
 /**
 * 将sp值转换为px值,保证文字大小不变
 */
 public static int sp2px(context context, float spvalue) {
 final float fontscale = context.getresources().getdisplaymetrics().scaleddensity;
 return (int) (spvalue * fontscale + 0.5f);
 }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对移动技术网的支持。如果你想了解更多相关内容请查看下面相关链接

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网