笔记12--GridView--且解决与ScrollView共用的冲突问题

GridView用法基本逻辑:1)要加载到GridView的数据。2)将数据放入适配器。适配器用来将数据和GridView相匹配3)给GridView加载适配器。GridView的一个注意事项:当适配器使用ArrayAdapter时,要添加到GridView的布局界面只能有一个TextView,否则GridView界面会显示2个TextView。

把GridView和适配器分开来讲吧。适配器见下一章。

四种效果展示:

1、

笔记12--GridView--且解决与ScrollView共用的冲突问题_第1张图片

        淘宝的订单详情界面选择颜色时,类似于此界面。要实现这个效果,需在GridView中填充TextView,看到的青色边框其实是TextView的边框。关于设置TextView的边框颜色,参考笔记6--TextView特效。

笔记12--GridView--且解决与ScrollView共用的冲突问题_第2张图片

        看到此图,就不得不提GridView的一个特点:界面上GridView显示的宽高就是实际运行后的宽高,即使设置wrap_content,GridView控件也不会改变宽高,显示不全时,会以滚动条的方式出现,而且你不去拖动他不会出现滚动条。

        android:scrollbars="none":仅是设置是否显示滚动条,并不能改变GridView的宽高。

        说说怎么动态改变GridView的宽高吧。逻辑:获得要设置的GridView的布局参数,然后更改其宽高,再设置GridView的参数。

1)获取GridView的布局参数:

LayoutParams params=gvColor.getLayoutParams();//注意此处gvColor必须是要设置宽高的GridView。

LayoutParams params=new LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT,ViewGroup.LayoutParams.WRAP_CONTENT);//此种方式绝对不行。

2)改变布局参数的宽高

params.height=100;//height的单位是px,需转换成dp,此处不提供了。gvColor.getHeight()单位也是px。当然,更简单点的做法是此值直接设置为一个特别大的值,然后它会自动调整到合适大小。

3)将布局参数再次赋值给GridView:gvColor.setLayoutParams(params);

问题:以上代码可用的前提是GridView没有嵌套在ScrollView里,否则以上代码无效。

在此说下ListView或者GridView嵌套在ScrollView中:嵌套使用时,会出现ListView/GridView有自己的滚动条,而ScrollView又有自己的滚动条。解决此问题的核心是:重写ListView/GridView的OnMesure方法。

以GridView为例(ListView也是重写OnMesure方法,且与GridView的实现一致):

1)重写OnMesure方法:

注意:GridView的构造方法要写全,不能遗漏。

public class MyGridView extends GridView {

	public MyGridView(Context context) {
		super(context);
	}

	public MyGridView(Context context, AttributeSet attrs) {
		super(context, attrs);
	}

	public MyGridView(Context context, AttributeSet attrs, int defStyle) {
		super(context, attrs, defStyle);
		// TODO 自动生成的构造函数存根
	}

	@Override
	protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
		// TODO 自动生成的方法存根
		int expandSpec = MeasureSpec.makeMeasureSpec( 
				Integer.MAX_VALUE >> 2, MeasureSpec.AT_MOST); 
		super.onMeasure(widthMeasureSpec, expandSpec); 
	}
}
2)xml布局文件加入(假设MyGridView所在的包为com.example.scrollviewandgridview):

 
 
3)获取自定义的GridView控件:

MyGridView myGV=(MyGridView) this.findViewById(R.id.mygridview);

2、

笔记12--GridView--且解决与ScrollView共用的冲突问题_第3张图片

如上图一样显示网格线。GridView默认是没有网格线的。实现逻辑:

1)设置GridView各子项的间隔。2)设置GridView的背景色。3)设置GridView子项(即单元格)的背景色。

只要使得2和3的背景色不一样,则就会显示出网格边框。

代码:

xml中加入:

android:horizontalSpacing="1dp"  
android:verticalSpacing="1dp"  
android:background="#DCDCDC" 
java源文件中,用自定义Adapter,在其getView()方法中加入
TextView result = new TextView(context); 
result.setBackgroundColor(Color.WHITE); //设置背景颜色
return result;

3、

笔记12--GridView--且解决与ScrollView共用的冲突问题_第4张图片

笔记12--GridView--且解决与ScrollView共用的冲突问题_第5张图片

你可能感兴趣的:(笔记12--GridView--且解决与ScrollView共用的冲突问题)