转载注明出处:http://blog.csdn.net/allen315410/article/details/40152987 最近在做项目中,有个模块需要在ListView中嵌套一个GridView制作“九宫格”的效果,结果GridView上的子元素仅仅显示了一行,没有显示完整的说,如下图:
其实这个ListView上一共需要显示的是6张图片,也就是说还有3张图片需要在下一行显示的,结果GridView没有显示完全,这个问题很奇怪,但是已经找到解决的方案,就是重写一个GridView,做一个自定义的GridView,然后重写GridView的onMeasure(int widthMeasureSpec, int heightMeasureSpec)的方法,将GridView重新测量,并且指定GridView的新的高度。代码如下:
其实这个ListView上一共需要显示的是6张图片,也就是说还有3张图片需要在下一行显示的,结果GridView没有显示完全,这个问题很奇怪,但是已经找到解决的方案,就是重写一个GridView,做一个自定义的GridView,然后重写GridView的onMeasure(int widthMeasureSpec, int heightMeasureSpec)的方法,将GridView重新测量,并且指定GridView的新的高度。代码如下:
- import android.content.Context;
- import android.util.AttributeSet;
- import android.widget.GridView;
- /**
- * 自定义的“九宫格”——用在显示帖子详情的图片集合
- * 解决的问题:GridView显示不全,只显示了一行的图片,比较奇怪,尝试重写GridView来解决
- *
- * @author lichao
- * @since 2014-10-16 16:41
- *
- */
- public class SodukuGridView extends GridView {
- public SodukuGridView(Context context) {
- super(context);
- // TODO Auto-generated constructor stub
- }
- public SodukuGridView(Context context, AttributeSet attrs) {
- super(context, attrs);
- // TODO Auto-generated constructor stub
- }
- public SodukuGridView(Context context, AttributeSet attrs, int defStyle) {
- super(context, attrs, defStyle);
- // TODO Auto-generated constructor stub
- }
- @Override
- protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
- // TODO Auto-generated method stub
- int expandSpec = MeasureSpec.makeMeasureSpec(Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST);
- super.onMeasure(widthMeasureSpec, expandSpec);
- }
- }
复制代码 以下是布局文件:
- <com.fc62.raisebook.view.sodukugridview
- android:id="@+id/gridview"
- android:layout_width="220dp"
- android:layout_height="wrap_content"
- android:layout_below="@id/tv_question_content"
- android:layout_marginBottom="5dp"
- android:layout_marginLeft="10dp"
- android:layout_marginTop="5dp"
- android:columnWidth="70dp"
- android:gravity="center"
- android:horizontalSpacing="2.5dp"
- android:numColumns="3"
- android:stretchMode="columnWidth"
- android:verticalSpacing="2.5dp" >
-
复制代码 然后就拿这个自定义的GridView当做普通的GridView一样使用即可。问题解决了:
|