码迷,mamicode.com
首页 > 移动开发 > 详细

新东西003--android Gridview控制显示高度

时间:2015-02-13 16:32:05      阅读:244      评论:0      收藏:0      [点我收藏+]

标签:android   gridview   标签栏   网易标签   网易导航栏   

一:需求

最近产品决定对公司软件做大修改,他想要实现网易云学习的标签栏效果,如下图(在A区域需要有一系列标签栏(标签栏多少不定,但每行三个,显示时如果超过屏幕2/3就要显示进度条,也就是最大不超过屏幕2/3的显示),B区域是一个listview,中间就是几个button,当B区域往上滑动的时候A区域自动收起,但在最上方显示当前选择的标签,点击标签弹出浮动的标签栏,当B区域滑动到最顶的时候,A区域开始显示.)

技术分享技术分享

技术分享技术分享技术分享


在上面的需求上,主要有两个问题

1.上面那一系列不知道多少个的是用button显示还是其他组件显示.作为一个资深(呵呵)开发者,肯定是不想用动态布局,一个一个button往上加的,所以我用了gridview,每个里面装一个button

2.A区域是作为B区域的headview存在还是一个跟B区域同级的布局存在.

开始的时候想把A区域当作B区域这个Listview的headview来处理,这样就可以实现A跟随B区域一起上下滑动,看起来就像一个完整的个体.但在实现的时候,在listview的滑动传递的时候出了问题,因为listview需要接受滚动事件,上面的gridview因为显示高度不明确,所以可能需要接受滑动事件.总的来说,作为headview在固定高度的时候可以采用,但要实现这种随机高度可能要压缩的,还是不太好实现.所以我就放弃了.我就将A区域的gridview作为B区域的同级view存在,同时,为了实现产品的需求,只是在A展开收起的时候添加动画即可.


Gridview控制显示高度

我原本期望Gridview有maxline或者maxheight之类的属性,那样问题就变的简单了,但是没有.于是琢磨着在height属性上做处理,想在布局文件中写死肯定是不行的,因为高度个数未知,所以就采用了动态布局.在解决动态布局的问题上,就是动态控制高度.我所做的操作分为两步

1.获取屏幕的显示高度

2.计算填充完数据之后的gridview的高度(一定要是填充完数据之后的,否则就是0,没有意义),如果高度大于屏幕的2/3,则将gridview的height设置为屏幕的2/3,如果小于,则不改变heigt的值.(下面为部分代码)

public void setGridviewHeight()
	{
		int needHeight = (((labes.length + 2) / 3 + 1) * dp2Px(this, 40.0f));
		if (needHeight <= ((screenHeight * 4) / 7))
		{
			//表示空间显示足够,不做处理
		}
		else
		{
			LinearLayout.LayoutParams params = (android.widget.LinearLayout.LayoutParams) gridview.getLayoutParams();
			params.height = (screenHeight * 4) / 7 - dp2Px(this, 40.0f);
			params.width = screenWidth;
			gridview.setLayoutParams(params);
			
			//第二个gridview
			RelativeLayout.LayoutParams params2 = (android.widget.RelativeLayout.LayoutParams) gridview2.getLayoutParams();
			params2.height = params.height;
			params2.width = params.width;
			gridview2.setLayoutParams(params2);
		}
	}

3.浮动gridview的解决

实际上就是两个gridview(浮动的那个根据逻辑显示,隐藏即可)


总结:

功能看起来很炫,但是按照写的流程分析,写下来还是没有难度的.后期有时间会整理一个例子再上传

新东西003--android Gridview控制显示高度

标签:android   gridview   标签栏   网易标签   网易导航栏   

原文地址:http://blog.csdn.net/kongzhichen/article/details/43794793

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!