笔记12--GridView--且解决与ScrollView共用的冲突问题
2014-04-07 11:40
351 查看
GridView用法基本逻辑:1)要加载到GridView的数据。2)将数据放入适配器。适配器用来将数据和GridView相匹配3)给GridView加载适配器。GridView的一个注意事项:当适配器使用ArrayAdapter时,要添加到GridView的布局界面只能有一个TextView,否则GridView界面会显示2个TextView。
把GridView和适配器分开来讲吧。适配器见下一章。
四种效果展示:
1、
![](https://img-blog.csdn.net/20140407113631140?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbXdqXzg4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
淘宝的订单详情界面选择颜色时,类似于此界面。要实现这个效果,需在GridView中填充TextView,看到的青色边框其实是TextView的边框。关于设置TextView的边框颜色,参考笔记6--TextView特效。
![](https://img-blog.csdn.net/20140407160145531?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbXdqXzg4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
看到此图,就不得不提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的构造方法要写全,不能遗漏。
MyGridView myGV=(MyGridView) this.findViewById(R.id.mygridview);
2、
![](https://img-blog.csdn.net/20140407113722562?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbXdqXzg4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
如上图一样显示网格线。GridView默认是没有网格线的。实现逻辑:
1)设置GridView各子项的间隔。2)设置GridView的背景色。3)设置GridView子项(即单元格)的背景色。
只要使得2和3的背景色不一样,则就会显示出网格边框。
代码:
xml中加入:
3、
![](https://img-blog.csdn.net/20140407113841078?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbXdqXzg4/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
把GridView和适配器分开来讲吧。适配器见下一章。
四种效果展示:
1、
淘宝的订单详情界面选择颜色时,类似于此界面。要实现这个效果,需在GridView中填充TextView,看到的青色边框其实是TextView的边框。关于设置TextView的边框颜色,参考笔记6--TextView特效。
看到此图,就不得不提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):
<com.example.scrollviewandgridview.MyGridView android:id="@+id/mygridview" android:layout_width="match_parent" android:layout_height="wrap_content" android:numColumns="2" > </com.example.scrollviewandgridview.MyGridView>3)获取自定义的GridView控件:
MyGridView myGV=(MyGridView) this.findViewById(R.id.mygridview);
2、
如上图一样显示网格线。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、
相关文章推荐
- GridView--且解决与ScrollView共用的冲突问题
- GridView--且解决与ScrollView共用的冲突问题
- GridView--且解决与ScrollView共用的冲突问题
- 解决scrollview 嵌套gridview或者listview 冲突的问题
- 解决ScrollView下嵌套ListView、GridView显示不全的问题(冲突)
- 解决ScrollView下嵌套ListView、GridView显示不全的问题(冲突)
- 仿Android GridView以解决ScrollView中嵌套自带GridView滚动条冲突问题
- ScrollView中嵌套ListView或者GridView时的滑动冲突 || ListView中嵌套GridView,GridView只显示一行的问题解决
- Android开发笔记——ScrollView中解决listview,gridview显示不全问题
- Listview或者ExpandableListView以及GridView与ScrollView冲突问题的解决
- Android-GridView与ScrollView共用的冲突问题(类似ListView)
- Android: 解决GridView、ListView在ScrollView中出现冲突的问题
- ScrollView中嵌套ListView和GridView冲突问题的解决
- 解决ScrollView和GridView滑动冲突的问题
- 解决scrollview 与 listview 控件冲突问题
- 解决scrollview+listview的冲突问题
- 解决ScrollView嵌套ViewPager出现的滑动冲突问题
- 解决ScrollView+RecyclerView的滑动冲突问题
- android listview嵌套viewpager,viewpager嵌套gridview,解决内嵌无法显示以及时间冲突的问题
- 解决ScrollView下嵌套自定义ListView、GridView后依然显示不全的问题