Android学习之——如何将GridView内嵌在ScrollView中

      最近在做一个项目,有一个需求是在ScrollView中内嵌一个GridView。

      刚开始,我是以为能直接内嵌在里面:

 1 <ScrollView
 2         android:layout_width="match_parent"
 3         android:layout_height="0dp"
 4         android:layout_weight="5.5">
 5         <GridView
 6             android:id="@+id/gridView"
 7             android:layout_width="fill_parent"
 8             android:layout_height="fill_parent"
 9             android:numColumns="auto_fit"
10             android:columnWidth="90dp"
11             android:gravity="center"
12             android:listSelector="@drawable/base_item_selector"
13             android:stretchMode="columnWidth"
14             ></GridView>
15       </ScrollView>
16     <RelativeLayout

 

 

1 mGridView = (GridView)findViewById(R.id.gridView);
2           ArrayAdapter adapter = new ArrayAdapter(this,android.R.layout.simple_list_item_1,
3                   letters);
4           mGridView.setAdapter(adapter);

 

   运行效果:

           只显示一行。

                  

     分析原因:ScrollView和GridView都带滚动条,引起冲突,导致GridView只能显示一行。

    这就需要自定义GirdView:

  

 1 public class MyGridView extends GridView {
 2     public MyGridView(Context context, AttributeSet attrs) {
 3         super(context, attrs);
 4     }
 5     public MyGridView(Context context) {
 6         super(context);
 7     }
 8     public MyGridView(Context context, AttributeSet attrs, int defStyle) {
 9         super(context, attrs, defStyle);
10     }
11     @Override
12     public void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
13         int expandSpec = MeasureSpec.makeMeasureSpec(
14                 Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
15         super.onMeasure(widthMeasureSpec, expandSpec);
16     }
17 }
 1 <ScrollView
 2         android:layout_width="match_parent"
 3         android:layout_height="0dp"
 4         android:layout_weight="5.5">
 5         <com.johntsai.view.MyGridView
 6             android:id="@+id/gridView"
 7             android:layout_width="fill_parent"
 8             android:layout_height="fill_parent"
 9             android:numColumns="auto_fit"
10             android:columnWidth="90dp"
11             android:gravity="center"
12             android:listSelector="@drawable/base_item_selector"
13             android:stretchMode="columnWidth"
14             ></com.johntsai.view.MyGridView>
15       </ScrollView>
16     <RelativeLayout

运行效果:

   完美解决。

  

 

转载于:https://www.cnblogs.com/JohnTsai/p/4231230.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值