ListView嵌套GridView
2015-01-12 20:28
169 查看
首先,我们通过两个实例来了解下本篇文章所讲的重点,看下图:
微博:
陌陌:
大家应该对这两款软件并不陌生,接下来,我将列举下本文将要实现的几个点:
1.ListView嵌套GridView,互不冲突,界面显示及操作正常;
2.GridView中的图片依据屏幕大小,自动扩大或缩小以适应屏幕,并始终保持正方形;
3.图片数量不同时,布局不同(如上图的4张图片和6张图片);
4.点击ListView的item和点击Gridview的item互不冲突;
5.在GridView区域外的任何一点点击都可以触发ListView的item;
大家也可以针对上面的几点思考下应该如何实现。。。
。。。
好,思考完毕,接下来讲一下我的实现思路:
1.ListView嵌套GridView互不冲突的话就要重写GridView了,这个想必大家都知道,类似ScrollView嵌套ListView,不再多讲;
2.如何让GridView的图片适应屏幕并始终保持正方形呢,这个问题其实我在上几篇博客就已经讲过了,就是根据:屏幕的宽度-GridView以外的部分的宽度-n个图片间距的宽度,最后/GridView每行item的数量;GridView如何适配不同屏幕,当然,所用的都是像素值,因此需要将在xml中的dp转换为px后再进行计算;
3.针对第三点,我们可以根据图片的数量,动态的设置GridView的numColumns;
4.当我们实现的过程中,可能会遇到点击图片可以,但是点击ListView的item时无效,这时我们可以在ListView的item的最外层添加:
5.第五点,我们可以先体验下微博或者陌陌,只要点击图片外任何区域,均能触发LIstView的item,但我们在实现的过程中却会遇到这种问题,即便我们把GridView的宽度设置为wrap_content,却依然充满了布局,导致右半部分全是GridView的布局,也就无法实现这种效果。因此,我们仍需要根据图片数量,动态的设置GridView的宽度。
接下来,我们来看下本篇所实现的效果:
1.
2.
3.
4.
5.
项目结构:
项目源码:http://download.csdn.net/detail/baiyuliang2013/8354615
补充:如果想缩小图片,可以扩大GridView离右边框的间距即可,在item_listview.xml布局中,如下:
微博:
陌陌:
大家应该对这两款软件并不陌生,接下来,我将列举下本文将要实现的几个点:
1.ListView嵌套GridView,互不冲突,界面显示及操作正常;
2.GridView中的图片依据屏幕大小,自动扩大或缩小以适应屏幕,并始终保持正方形;
3.图片数量不同时,布局不同(如上图的4张图片和6张图片);
4.点击ListView的item和点击Gridview的item互不冲突;
5.在GridView区域外的任何一点点击都可以触发ListView的item;
大家也可以针对上面的几点思考下应该如何实现。。。
。。。
好,思考完毕,接下来讲一下我的实现思路:
1.ListView嵌套GridView互不冲突的话就要重写GridView了,这个想必大家都知道,类似ScrollView嵌套ListView,不再多讲;
2.如何让GridView的图片适应屏幕并始终保持正方形呢,这个问题其实我在上几篇博客就已经讲过了,就是根据:屏幕的宽度-GridView以外的部分的宽度-n个图片间距的宽度,最后/GridView每行item的数量;GridView如何适配不同屏幕,当然,所用的都是像素值,因此需要将在xml中的dp转换为px后再进行计算;
3.针对第三点,我们可以根据图片的数量,动态的设置GridView的numColumns;
4.当我们实现的过程中,可能会遇到点击图片可以,但是点击ListView的item时无效,这时我们可以在ListView的item的最外层添加:
android:descendantFocusability="blocksDescendants"属性即可;
5.第五点,我们可以先体验下微博或者陌陌,只要点击图片外任何区域,均能触发LIstView的item,但我们在实现的过程中却会遇到这种问题,即便我们把GridView的宽度设置为wrap_content,却依然充满了布局,导致右半部分全是GridView的布局,也就无法实现这种效果。因此,我们仍需要根据图片数量,动态的设置GridView的宽度。
接下来,我们来看下本篇所实现的效果:
1.
2.
3.
4.
5.
项目结构:
项目源码:http://download.csdn.net/detail/baiyuliang2013/8354615
补充:如果想缩小图片,可以扩大GridView离右边框的间距即可,在item_listview.xml布局中,如下:
<RelativeLayout android:id="@+id/rl4" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_below="@+id/rl3" android:paddingRight="25dp" android:visibility="gone" > <com.byl.listviewwithgrid.view.MyGridView android:id="@+id/gv_images" android:layout_width="wrap_content" android:layout_height="wrap_content" android:horizontalSpacing="2dp" android:listSelector="@null" android:numColumns="3" android:stretchMode="columnWidth" android:verticalSpacing="2dp" > </com.byl.listviewwithgrid.view.MyGridView> </RelativeLayout>扩大
android:paddingRight="25dp"当然,此后再进行计算时,就要用你自己设置的dp转px后计算了...
相关文章推荐
- ScrollView嵌套GridView、ListView的解决办法
- ListView,GridView与ScrollView嵌套使用的故事
- ListView嵌套GridView响应事件两不误的解决方法
- Android在ListView中嵌套一个GridView时只显示一行的原因及解决方法
- ListView嵌套GridView使用详解
- ScrollView嵌套ListView,gridView只显示一行解决方案 (以及计算显示高度错误问题)
- scrollview中嵌套listview,gridview时高度问题
- 关于listview嵌套gridview
- ScrollView嵌套ListView,GridView,ViewPager,以及这些控件自动滚动到底部问题的解决
- Android中Adapter嵌套Adapter、ListView嵌套GridView时的内层Adapter(GridView)内容显示异常
- listview嵌套gridview无法点击
- ScrollView嵌套GridView、ListView
- ListView、GridView等嵌套显示不全问题
- 解决ScrollView中listview、gridview的嵌套问题
- ScrollView中嵌套GridView,Listview的办法
- expandablelistview学习--在listView里面嵌套GridView
- scrollview与gridview及listview嵌套冲突问题
- scrollview嵌套listview 嵌套HorizontalScrollView嵌套gridview 焦点及卡顿问题
- ScrollView下嵌套GridView或ListView默认不在顶部的解决方法
- scrollview嵌套listview,gridview 显示不全万能解决办法